test_move.sh 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. #!/bin/bash
  2. set -eu
  3. echo "=== Move tests ==="
  4. rm -rf blocks
  5. tests/test.py << TEST
  6. lfs_format(&lfs, &cfg) => 0;
  7. lfs_mount(&lfs, &cfg) => 0;
  8. lfs_mkdir(&lfs, "a") => 0;
  9. lfs_mkdir(&lfs, "b") => 0;
  10. lfs_mkdir(&lfs, "c") => 0;
  11. lfs_mkdir(&lfs, "d") => 0;
  12. lfs_mkdir(&lfs, "a/hi") => 0;
  13. lfs_mkdir(&lfs, "a/hi/hola") => 0;
  14. lfs_mkdir(&lfs, "a/hi/bonjour") => 0;
  15. lfs_mkdir(&lfs, "a/hi/ohayo") => 0;
  16. lfs_file_open(&lfs, &file[0], "a/hello", LFS_O_CREAT | LFS_O_WRONLY) => 0;
  17. lfs_file_write(&lfs, &file[0], "hola\n", 5) => 5;
  18. lfs_file_write(&lfs, &file[0], "bonjour\n", 8) => 8;
  19. lfs_file_write(&lfs, &file[0], "ohayo\n", 6) => 6;
  20. lfs_file_close(&lfs, &file[0]) => 0;
  21. lfs_unmount(&lfs) => 0;
  22. TEST
  23. echo "--- Move file ---"
  24. tests/test.py << TEST
  25. lfs_mount(&lfs, &cfg) => 0;
  26. lfs_rename(&lfs, "a/hello", "b/hello") => 0;
  27. lfs_unmount(&lfs) => 0;
  28. TEST
  29. tests/test.py << TEST
  30. lfs_mount(&lfs, &cfg) => 0;
  31. lfs_dir_open(&lfs, &dir[0], "a") => 0;
  32. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  33. strcmp(info.name, ".") => 0;
  34. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  35. strcmp(info.name, "..") => 0;
  36. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  37. strcmp(info.name, "hi") => 0;
  38. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  39. lfs_dir_close(&lfs, &dir[0]) => 0;
  40. lfs_dir_open(&lfs, &dir[0], "b") => 0;
  41. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  42. strcmp(info.name, ".") => 0;
  43. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  44. strcmp(info.name, "..") => 0;
  45. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  46. strcmp(info.name, "hello") => 0;
  47. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  48. lfs_unmount(&lfs) => 0;
  49. TEST
  50. echo "--- Move file corrupt source ---"
  51. tests/test.py << TEST
  52. lfs_mount(&lfs, &cfg) => 0;
  53. lfs_rename(&lfs, "b/hello", "c/hello") => 0;
  54. lfs_unmount(&lfs) => 0;
  55. TEST
  56. tests/corrupt.py -n 1
  57. tests/test.py << TEST
  58. lfs_mount(&lfs, &cfg) => 0;
  59. lfs_dir_open(&lfs, &dir[0], "b") => 0;
  60. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  61. strcmp(info.name, ".") => 0;
  62. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  63. strcmp(info.name, "..") => 0;
  64. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  65. lfs_dir_close(&lfs, &dir[0]) => 0;
  66. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  67. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  68. strcmp(info.name, ".") => 0;
  69. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  70. strcmp(info.name, "..") => 0;
  71. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  72. strcmp(info.name, "hello") => 0;
  73. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  74. lfs_unmount(&lfs) => 0;
  75. TEST
  76. echo "--- Move file corrupt source and dest ---"
  77. tests/test.py << TEST
  78. lfs_mount(&lfs, &cfg) => 0;
  79. lfs_rename(&lfs, "c/hello", "d/hello") => 0;
  80. lfs_unmount(&lfs) => 0;
  81. TEST
  82. tests/corrupt.py -n 2
  83. tests/test.py << TEST
  84. lfs_mount(&lfs, &cfg) => 0;
  85. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  86. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  87. strcmp(info.name, ".") => 0;
  88. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  89. strcmp(info.name, "..") => 0;
  90. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  91. strcmp(info.name, "hello") => 0;
  92. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  93. lfs_dir_close(&lfs, &dir[0]) => 0;
  94. lfs_dir_open(&lfs, &dir[0], "d") => 0;
  95. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  96. strcmp(info.name, ".") => 0;
  97. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  98. strcmp(info.name, "..") => 0;
  99. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  100. lfs_unmount(&lfs) => 0;
  101. TEST
  102. echo "--- Move file after corrupt ---"
  103. tests/test.py << TEST
  104. lfs_mount(&lfs, &cfg) => 0;
  105. lfs_rename(&lfs, "c/hello", "d/hello") => 0;
  106. lfs_unmount(&lfs) => 0;
  107. TEST
  108. tests/test.py << TEST
  109. lfs_mount(&lfs, &cfg) => 0;
  110. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  111. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  112. strcmp(info.name, ".") => 0;
  113. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  114. strcmp(info.name, "..") => 0;
  115. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  116. lfs_dir_close(&lfs, &dir[0]) => 0;
  117. lfs_dir_open(&lfs, &dir[0], "d") => 0;
  118. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  119. strcmp(info.name, ".") => 0;
  120. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  121. strcmp(info.name, "..") => 0;
  122. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  123. strcmp(info.name, "hello") => 0;
  124. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  125. lfs_unmount(&lfs) => 0;
  126. TEST
  127. echo "--- Move dir ---"
  128. tests/test.py << TEST
  129. lfs_mount(&lfs, &cfg) => 0;
  130. lfs_rename(&lfs, "a/hi", "b/hi") => 0;
  131. lfs_unmount(&lfs) => 0;
  132. TEST
  133. tests/test.py << TEST
  134. lfs_mount(&lfs, &cfg) => 0;
  135. lfs_dir_open(&lfs, &dir[0], "a") => 0;
  136. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  137. strcmp(info.name, ".") => 0;
  138. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  139. strcmp(info.name, "..") => 0;
  140. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  141. lfs_dir_close(&lfs, &dir[0]) => 0;
  142. lfs_dir_open(&lfs, &dir[0], "b") => 0;
  143. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  144. strcmp(info.name, ".") => 0;
  145. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  146. strcmp(info.name, "..") => 0;
  147. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  148. strcmp(info.name, "hi") => 0;
  149. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  150. lfs_unmount(&lfs) => 0;
  151. TEST
  152. echo "--- Move dir corrupt source ---"
  153. tests/test.py << TEST
  154. lfs_mount(&lfs, &cfg) => 0;
  155. lfs_rename(&lfs, "b/hi", "c/hi") => 0;
  156. lfs_unmount(&lfs) => 0;
  157. TEST
  158. tests/corrupt.py -n 1
  159. tests/test.py << TEST
  160. lfs_mount(&lfs, &cfg) => 0;
  161. lfs_dir_open(&lfs, &dir[0], "b") => 0;
  162. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  163. strcmp(info.name, ".") => 0;
  164. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  165. strcmp(info.name, "..") => 0;
  166. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  167. lfs_dir_close(&lfs, &dir[0]) => 0;
  168. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  169. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  170. strcmp(info.name, ".") => 0;
  171. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  172. strcmp(info.name, "..") => 0;
  173. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  174. strcmp(info.name, "hi") => 0;
  175. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  176. lfs_unmount(&lfs) => 0;
  177. TEST
  178. echo "--- Move dir corrupt source and dest ---"
  179. tests/test.py << TEST
  180. lfs_mount(&lfs, &cfg) => 0;
  181. lfs_rename(&lfs, "c/hi", "d/hi") => 0;
  182. lfs_unmount(&lfs) => 0;
  183. TEST
  184. tests/corrupt.py -n 2
  185. tests/test.py << TEST
  186. lfs_mount(&lfs, &cfg) => 0;
  187. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  188. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  189. strcmp(info.name, ".") => 0;
  190. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  191. strcmp(info.name, "..") => 0;
  192. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  193. strcmp(info.name, "hi") => 0;
  194. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  195. lfs_dir_close(&lfs, &dir[0]) => 0;
  196. lfs_dir_open(&lfs, &dir[0], "d") => 0;
  197. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  198. strcmp(info.name, ".") => 0;
  199. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  200. strcmp(info.name, "..") => 0;
  201. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  202. strcmp(info.name, "hello") => 0;
  203. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  204. lfs_unmount(&lfs) => 0;
  205. TEST
  206. echo "--- Move dir after corrupt ---"
  207. tests/test.py << TEST
  208. lfs_mount(&lfs, &cfg) => 0;
  209. lfs_rename(&lfs, "c/hi", "d/hi") => 0;
  210. lfs_unmount(&lfs) => 0;
  211. TEST
  212. tests/test.py << TEST
  213. lfs_mount(&lfs, &cfg) => 0;
  214. lfs_dir_open(&lfs, &dir[0], "c") => 0;
  215. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  216. strcmp(info.name, ".") => 0;
  217. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  218. strcmp(info.name, "..") => 0;
  219. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  220. lfs_dir_close(&lfs, &dir[0]) => 0;
  221. lfs_dir_open(&lfs, &dir[0], "d") => 0;
  222. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  223. strcmp(info.name, ".") => 0;
  224. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  225. strcmp(info.name, "..") => 0;
  226. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  227. strcmp(info.name, "hello") => 0;
  228. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  229. strcmp(info.name, "hi") => 0;
  230. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  231. lfs_unmount(&lfs) => 0;
  232. TEST
  233. echo "--- Move check ---"
  234. tests/test.py << TEST
  235. lfs_mount(&lfs, &cfg) => 0;
  236. lfs_dir_open(&lfs, &dir[0], "a/hi") => LFS_ERR_NOENT;
  237. lfs_dir_open(&lfs, &dir[0], "b/hi") => LFS_ERR_NOENT;
  238. lfs_dir_open(&lfs, &dir[0], "c/hi") => LFS_ERR_NOENT;
  239. lfs_dir_open(&lfs, &dir[0], "d/hi") => 0;
  240. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  241. strcmp(info.name, ".") => 0;
  242. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  243. strcmp(info.name, "..") => 0;
  244. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  245. strcmp(info.name, "bonjour") => 0;
  246. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  247. strcmp(info.name, "hola") => 0;
  248. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  249. strcmp(info.name, "ohayo") => 0;
  250. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  251. lfs_dir_close(&lfs, &dir[0]) => 0;
  252. lfs_dir_open(&lfs, &dir[0], "a/hello") => LFS_ERR_NOENT;
  253. lfs_dir_open(&lfs, &dir[0], "b/hello") => LFS_ERR_NOENT;
  254. lfs_dir_open(&lfs, &dir[0], "c/hello") => LFS_ERR_NOENT;
  255. lfs_file_open(&lfs, &file[0], "d/hello", LFS_O_RDONLY) => 0;
  256. lfs_file_read(&lfs, &file[0], buffer, 5) => 5;
  257. memcmp(buffer, "hola\n", 5) => 0;
  258. lfs_file_read(&lfs, &file[0], buffer, 8) => 8;
  259. memcmp(buffer, "bonjour\n", 8) => 0;
  260. lfs_file_read(&lfs, &file[0], buffer, 6) => 6;
  261. memcmp(buffer, "ohayo\n", 6) => 0;
  262. lfs_file_close(&lfs, &file[0]) => 0;
  263. lfs_unmount(&lfs) => 0;
  264. TEST
  265. echo "--- Move state stealing ---"
  266. tests/test.py << TEST
  267. lfs_mount(&lfs, &cfg) => 0;
  268. lfs_remove(&lfs, "b") => 0;
  269. lfs_remove(&lfs, "c") => 0;
  270. lfs_unmount(&lfs) => 0;
  271. TEST
  272. tests/test.py << TEST
  273. lfs_mount(&lfs, &cfg) => 0;
  274. lfs_dir_open(&lfs, &dir[0], "a/hi") => LFS_ERR_NOENT;
  275. lfs_dir_open(&lfs, &dir[0], "b") => LFS_ERR_NOENT;
  276. lfs_dir_open(&lfs, &dir[0], "c") => LFS_ERR_NOENT;
  277. lfs_dir_open(&lfs, &dir[0], "d/hi") => 0;
  278. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  279. strcmp(info.name, ".") => 0;
  280. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  281. strcmp(info.name, "..") => 0;
  282. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  283. strcmp(info.name, "bonjour") => 0;
  284. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  285. strcmp(info.name, "hola") => 0;
  286. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  287. strcmp(info.name, "ohayo") => 0;
  288. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  289. lfs_dir_close(&lfs, &dir[0]) => 0;
  290. lfs_dir_open(&lfs, &dir[0], "a/hello") => LFS_ERR_NOENT;
  291. lfs_dir_open(&lfs, &dir[0], "b") => LFS_ERR_NOENT;
  292. lfs_dir_open(&lfs, &dir[0], "c") => LFS_ERR_NOENT;
  293. lfs_file_open(&lfs, &file[0], "d/hello", LFS_O_RDONLY) => 0;
  294. lfs_file_read(&lfs, &file[0], buffer, 5) => 5;
  295. memcmp(buffer, "hola\n", 5) => 0;
  296. lfs_file_read(&lfs, &file[0], buffer, 8) => 8;
  297. memcmp(buffer, "bonjour\n", 8) => 0;
  298. lfs_file_read(&lfs, &file[0], buffer, 6) => 6;
  299. memcmp(buffer, "ohayo\n", 6) => 0;
  300. lfs_file_close(&lfs, &file[0]) => 0;
  301. lfs_unmount(&lfs) => 0;
  302. TEST
  303. echo "--- Results ---"
  304. tests/stats.py