test-delupd.sh 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. #!/bin/bash
  2. # Copyright (C) 2014 Jakob Borg and other contributors. All rights reserved.
  3. # Use of this source code is governed by an MIT-style license that can be
  4. # found in the LICENSE file.
  5. iterations=${1:-5}
  6. id1=I6KAH76-66SLLLB-5PFXSOA-UFJCDZC-YAOMLEK-CP2GB32-BV5RQST-3PSROAU
  7. id2=JMFJCXB-GZDE4BN-OCJE3VF-65GYZNU-AIVJRET-3J6HMRQ-AUQIGJO-FKNHMQU
  8. id3=373HSRP-QLPNLIE-JYKZVQF-P4PKZ63-R2ZE6K3-YD442U2-JHBGBQG-WWXAHAU
  9. go build genfiles.go
  10. go build md5r.go
  11. go build json.go
  12. start() {
  13. echo "Starting..."
  14. for i in 1 2 3 ; do
  15. STTRACE=files,model,puller,versioner,protocol STPROFILER=":909$i" syncthing -home "h$i" > "$i.out" 2>&1 &
  16. done
  17. }
  18. stop() {
  19. for i in 1 2 3 ; do
  20. curl -HX-API-Key:abc123 -X POST "http://127.0.0.1:808$i/rest/shutdown"
  21. done
  22. exit $1
  23. }
  24. testConvergence() {
  25. while true ; do
  26. sleep 5
  27. s1comp=$(curl -HX-API-Key:abc123 -s "http://127.0.0.1:8082/rest/debug/peerCompletion" | ./json "$id1")
  28. s2comp=$(curl -HX-API-Key:abc123 -s "http://127.0.0.1:8083/rest/debug/peerCompletion" | ./json "$id2")
  29. s3comp=$(curl -HX-API-Key:abc123 -s "http://127.0.0.1:8081/rest/debug/peerCompletion" | ./json "$id3")
  30. s1comp=${s1comp:-0}
  31. s2comp=${s2comp:-0}
  32. s3comp=${s3comp:-0}
  33. tot=$(($s1comp + $s2comp + $s3comp))
  34. echo $tot / 300
  35. if [[ $tot == 300 ]] ; then
  36. break
  37. fi
  38. done
  39. echo "Verifying..."
  40. cp md5-1 md5-tot
  41. cp md5-12-2 md5-12-tot
  42. cp md5-23-3 md5-23-tot
  43. for i in 1 2 3 12-1 12-2 23-2 23-3; do
  44. pushd "s$i" >/dev/null
  45. ../md5r -l | sort | grep -v .stversions > ../md5-$i
  46. popd >/dev/null
  47. done
  48. ok=0
  49. for i in 1 2 3 ; do
  50. if ! cmp "md5-$i" md5-tot >/dev/null ; then
  51. echo "Fail: instance $i unconverged for default"
  52. else
  53. ok=$(($ok + 1))
  54. echo "OK: instance $i converged for default"
  55. fi
  56. done
  57. for i in 12-1 12-2 ; do
  58. if ! cmp "md5-$i" md5-12-tot >/dev/null ; then
  59. echo "Fail: instance $i unconverged for s12"
  60. else
  61. ok=$(($ok + 1))
  62. echo "OK: instance $i converged for s12"
  63. fi
  64. done
  65. for i in 23-2 23-3 ; do
  66. if ! cmp "md5-$i" md5-23-tot >/dev/null ; then
  67. echo "Fail: instance $i unconverged for s23"
  68. else
  69. ok=$(($ok + 1))
  70. echo "OK: instance $i converged for s23"
  71. fi
  72. done
  73. if [[ $ok != 7 ]] ; then
  74. stop 1
  75. fi
  76. }
  77. alterFiles() {
  78. pkill -STOP syncthing
  79. for i in 1 12-2 23-3 ; do
  80. # Delete some files
  81. pushd "s$i" >/dev/null
  82. chmod 755 ro-test
  83. nfiles=$(find . -type f | wc -l)
  84. if [[ $nfiles -ge 300 ]] ; then
  85. todelete=$(( $nfiles - 300 ))
  86. echo " $i: deleting $todelete files..."
  87. find . -type f \
  88. | grep -v large \
  89. | sort -k 1.16 \
  90. | head -n "$todelete" \
  91. | xargs rm -f
  92. fi
  93. # Create some new files and alter existing ones
  94. echo " $i: random nonoverlapping"
  95. ../genfiles -maxexp 22 -files 200
  96. echo " $i: append to large file"
  97. dd if=large-$i bs=1024k count=4 >> large-$i 2>/dev/null
  98. echo " $i: new files in ro directory"
  99. uuidgen > ro-test/$(uuidgen)
  100. chmod 500 ro-test
  101. ../md5r -l | sort | grep -v .stversions > ../md5-$i
  102. popd >/dev/null
  103. done
  104. pkill -CONT syncthing
  105. echo "Restarting instance 2"
  106. curl -HX-API-Key:abc123 -X POST "http://127.0.0.1:8082/rest/restart"
  107. }
  108. rm -rf h?/*.idx.gz h?/index
  109. chmod -R u+w s? s??-?
  110. rm -rf s? s??-?
  111. mkdir s1 s2 s3 s12-1 s12-2 s23-2 s23-3
  112. echo "Setting up files..."
  113. for i in 1 12-2 23-3; do
  114. pushd "s$i" >/dev/null
  115. echo " $i: random nonoverlapping"
  116. ../genfiles -maxexp 22 -files 400
  117. echo " $i: ro directory"
  118. mkdir ro-test
  119. uuidgen > ro-test/$(uuidgen)
  120. chmod 500 ro-test
  121. popd >/dev/null
  122. done
  123. echo "MD5-summing..."
  124. for i in 1 12-2 23-3 ; do
  125. pushd "s$i" >/dev/null
  126. ../md5r -l | sort > ../md5-$i
  127. popd >/dev/null
  128. done
  129. start
  130. testConvergence
  131. for ((t = 1; t <= $iterations; t++)) ; do
  132. echo "Add and remove random files ($t / $iterations)..."
  133. alterFiles
  134. echo "Waiting..."
  135. sleep 30
  136. testConvergence
  137. done
  138. stop 0