test/bin-test/test-dav-sync-hashing-cfgchange.sh

changeset 657
8f3410b9148f
equal deleted inserted replaced
656:3a009658e995 657:8f3410b9148f
1 #!/bin/sh
2 #
3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
4 #
5 # Copyright 2019 Olaf Wintermann. All rights reserved.
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions are met:
9 #
10 # 1. Redistributions of source code must retain the above copyright
11 # notice, this list of conditions and the following disclaimer.
12 #
13 # 2. Redistributions in binary form must reproduce the above copyright
14 # notice, this list of conditions and the following disclaimer in the
15 # documentation and/or other materials provided with the distribution.
16 #
17 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21 # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 # POSSIBILITY OF SUCH DAMAGE.
28 #
29
30 if [ -z "$DAV_BIN" ];
31 then
32 echo "DAV_BIN variable not set"
33 exit 1
34 fi
35 if [ -z "$DAV_SYNC_BIN" ];
36 then
37 echo "DAV_BIN variable not set"
38 exit 1
39 fi
40
41 # checks if tmp-sync/out.txt contains a specific text
42 # arg1: pattern
43 # arg2: errormsg
44 check_tmpout()
45 {
46 TEST=`cat tmp-sync/out.txt | grep "$1"`
47 if [ $? -ne 0 ];
48 then
49 echo "$2"
50 exit 2
51 fi
52 }
53
54 # do dav-sync push and check return value
55 # arg1: dir
56 # arg2: errormsg
57 dav_sync_push()
58 {
59 $DAV_SYNC_BIN push $1 > tmp-sync/out.txt
60 if [ $? -ne 0 ];
61 then
62 echo "$2"
63 exit 2
64 fi
65 }
66 # do dav-sync pull and check return value
67 # arg1: dir
68 # arg2: errormsg
69 dav_sync_pull()
70 {
71 $DAV_SYNC_BIN pull $1 > tmp-sync/out.txt
72 if [ $? -ne 0 ];
73 then
74 echo "$2"
75 exit 2
76 fi
77 }
78
79 rm -f .dav/dav-sync-tests-test3a-db.xml
80 rm -f .dav/dav-sync-tests-test3b-db.xml
81
82 $DAV_BIN rm dav-test-repo/sync/test3 2> /dev/null
83
84 $DAV_BIN mkcol dav-test-repo/sync/test3 2> /dev/null
85
86 # tmp sync dir
87 rm -Rf tmp-sync
88 mkdir tmp-sync
89 mkdir tmp-sync/test3a
90 mkdir tmp-sync/test3b
91
92 # ----------------------------------------------------------------------------
93 # 1. test: add 4 files, push, pull
94 # expected result: 4 files pushed, 4 files pulled
95
96 mkdir tmp-sync/test3a/dir1/
97 mkdir tmp-sync/test3a/dir1/subdir1/
98
99 cp synctest/file1 tmp-sync/test3a/
100 cp synctest/file2 tmp-sync/test3a/dir1/
101 cp synctest/file3 tmp-sync/test3a/dir1/subdir1
102 cp synctest/file4 tmp-sync/test3a/dir1/subdir1
103
104 dav_sync_push test3a "test 1: push failed"
105 check_tmpout "4 files pushed" "test 1: wrong push counter"
106 check_tmpout "0 conflicts" "test 1: wrong conflict counter (push)"
107 check_tmpout "0 errors" "test 1: wrong error counter (push)"
108
109 dav_sync_pull test3b "test 1: pull failed"
110 check_tmpout "4 files pulled" "test 1: wrong pull counter"
111 check_tmpout "0 conflicts" "test 1: wrong conflict counter (pull)"
112 check_tmpout "0 errors" "test 1: wrong error counter (pull)"
113
114 # ----------------------------------------------------------------------------
115 # 2. test: add 4 more files to test3b, push, pull
116 # expected result: 4 files pushed, 4 files pulled
117
118 echo "newfile1" > tmp-sync/test3b/new1
119 echo "newfile2" > tmp-sync/test3b/new2
120 echo "newfile3" > tmp-sync/test3b/dir1/new3
121 echo "newfile4" > tmp-sync/test3b/dir1/new4
122
123 dav_sync_push test3b "test 2: push failed"
124 check_tmpout "4 files pushed" "test 2: wrong push counter"
125 check_tmpout "0 conflicts" "test 2: wrong conflict counter (push)"
126 check_tmpout "0 errors" "test 2: wrong error counter (push)"
127
128 dav_sync_pull test3a "test 2: pull failed"
129 check_tmpout "4 files pulled" "test 2: wrong pull counter"
130 check_tmpout "0 conflicts" "test 2: wrong conflict counter (pull)"
131 check_tmpout "0 errors" "test 2: wrong error counter (pull)"
132
133 # ----------------------------------------------------------------------------
134 # 3. test: enable hashing (by using syncdirs with h suffix), touch file1
135 # and modify file2, push, pull
136 # expected result: 2 files pushed, 1 files pulled
137
138 sleep 2
139
140 touch tmp-sync/test3a/file1
141 echo "test3-mod1" >> tmp-sync/test3a/dir1/file2
142
143 # should push 2 files, because the db doesn't contain any hashes yet
144 dav_sync_push test3ah "test 3: push failed"
145 check_tmpout "2 files pushed" "test 3: wrong push counter"
146 check_tmpout "0 conflicts" "test 3: wrong conflict counter (push)"
147 check_tmpout "0 errors" "test 3: wrong error counter (push)"
148
149 dav_sync_pull test3bh "test 3: pull failed"
150 check_tmpout "1 file pulled" "test 3: wrong pull counter"
151 check_tmpout "0 conflicts" "test 3: wrong conflict counter (pull)"
152 check_tmpout "0 errors" "test 3: wrong error counter (pull)"
153
154 # ----------------------------------------------------------------------------
155 # 4. test: same as test 3, but the db should contain hashes
156 # expected result: 1 file pushed, because the db should contain hashes now
157
158 sleep 2
159
160 touch tmp-sync/test3a/file1
161 echo "test4-mod1" >> tmp-sync/test3a/dir1/file2
162
163 # should push 2 files, because the db doesn't contain any hashes yet
164 dav_sync_push test3ah "test 4: push failed"
165 check_tmpout "1 file pushed" "test 4: wrong push counter"
166 check_tmpout "0 conflicts" "test 4: wrong conflict counter (push)"
167 check_tmpout "0 errors" "test 4: wrong error counter (push)"
168
169 dav_sync_pull test3bh "test 4: pull failed"
170 check_tmpout "1 file pulled" "test 4: wrong pull counter"
171 check_tmpout "0 conflicts" "test 4: wrong conflict counter (pull)"
172 check_tmpout "0 errors" "test 4: wrong error counter (pull)"
173
174 # ----------------------------------------------------------------------------
175 # 5. test: mod file3 on both sides, mod new1 differently on both sides, push
176 # expected result: 1 conflict, 0 files pushed
177
178 echo "test5-mod1" >> tmp-sync/test3a/dir1/subdir1/file3
179 echo "test5-mod1" >> tmp-sync/test3b/dir1/subdir1/file3
180
181 echo "test5-mod-a" >> tmp-sync/test3a/new1
182 echo "test5-mod-b" >> tmp-sync/test3b/new1
183
184 dav_sync_push test3ah "test 5: push test3ah failed"
185 check_tmpout "2 files pushed" "test 5: wrong push counter (test3ah)"
186 check_tmpout "0 conflicts" "test 5: wrong conflict counter (test3ah)"
187 check_tmpout "0 errors" "test 5: wrong error counter (test3ah)"
188
189 dav_sync_push test3bh "test 5: push test3bh failed"
190 check_tmpout "0 files pushed" "test 5: wrong push counter (test3bh)"
191 check_tmpout "1 conflict" "test 5: wrong conflict counter (testbh)"
192 check_tmpout "0 errors" "test 5: wrong error counter (test3bh)"
193
194 # ----------------------------------------------------------------------------
195 # 6. test: cp new1 from test3a to test3b and push test3bh
196 # expected result: 0 files pushed, 0 conflicts
197
198 cp tmp-sync/test3a/new1 tmp-sync/test3b/new1
199
200 dav_sync_push test3bh "test 6: push failed"
201 check_tmpout "0 files pushed" "test 6: wrong push counter"
202 check_tmpout "0 conflicts" "test 6: wrong conflict counter"
203 check_tmpout "0 errors" "test 6: wrong error counter"
204
205 # ----------------------------------------------------------------------------
206 # 7. test: pull test3bh
207 # expected result: 0 files pulled, 0 conflicts
208
209 dav_sync_pull test3bh "test 6: pull failed"
210 check_tmpout "0 files pulled" "test 6: wrong pull counter"
211 check_tmpout "0 conflicts" "test 6: wrong conflict counter"
212 check_tmpout "0 errors" "test 6: wrong error counter"
213
214
215

mercurial