test_seek.sh 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. #!/bin/bash
  2. set -eu
  3. SMALLSIZE=4
  4. MEDIUMSIZE=128
  5. LARGESIZE=132
  6. echo "=== Seek tests ==="
  7. rm -rf blocks
  8. tests/test.py << TEST
  9. lfs_format(&lfs, &cfg) => 0;
  10. lfs_mount(&lfs, &cfg) => 0;
  11. lfs_mkdir(&lfs, "hello") => 0;
  12. for (int i = 0; i < $LARGESIZE; i++) {
  13. sprintf((char*)buffer, "hello/kitty%d", i);
  14. lfs_file_open(&lfs, &file[0], (char*)buffer,
  15. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_APPEND) => 0;
  16. size = strlen("kittycatcat");
  17. memcpy(buffer, "kittycatcat", size);
  18. for (int j = 0; j < $LARGESIZE; j++) {
  19. lfs_file_write(&lfs, &file[0], buffer, size);
  20. }
  21. lfs_file_close(&lfs, &file[0]) => 0;
  22. }
  23. lfs_unmount(&lfs) => 0;
  24. TEST
  25. echo "--- Simple dir seek ---"
  26. tests/test.py << TEST
  27. lfs_mount(&lfs, &cfg) => 0;
  28. lfs_dir_open(&lfs, &dir[0], "hello") => 0;
  29. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  30. strcmp(info.name, ".") => 0;
  31. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  32. strcmp(info.name, "..") => 0;
  33. lfs_soff_t pos;
  34. int i;
  35. for (i = 0; i < $SMALLSIZE; i++) {
  36. sprintf((char*)buffer, "kitty%d", i);
  37. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  38. strcmp(info.name, (char*)buffer) => 0;
  39. pos = lfs_dir_tell(&lfs, &dir[0]);
  40. }
  41. pos >= 0 => 1;
  42. lfs_dir_seek(&lfs, &dir[0], pos) => 0;
  43. sprintf((char*)buffer, "kitty%d", i);
  44. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  45. strcmp(info.name, (char*)buffer) => 0;
  46. lfs_dir_rewind(&lfs, &dir[0]) => 0;
  47. sprintf((char*)buffer, "kitty%d", 0);
  48. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  49. strcmp(info.name, ".") => 0;
  50. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  51. strcmp(info.name, "..") => 0;
  52. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  53. strcmp(info.name, (char*)buffer) => 0;
  54. lfs_dir_seek(&lfs, &dir[0], pos) => 0;
  55. sprintf((char*)buffer, "kitty%d", i);
  56. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  57. strcmp(info.name, (char*)buffer) => 0;
  58. lfs_dir_close(&lfs, &dir[0]) => 0;
  59. lfs_unmount(&lfs) => 0;
  60. TEST
  61. echo "--- Large dir seek ---"
  62. tests/test.py << TEST
  63. lfs_mount(&lfs, &cfg) => 0;
  64. lfs_dir_open(&lfs, &dir[0], "hello") => 0;
  65. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  66. strcmp(info.name, ".") => 0;
  67. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  68. strcmp(info.name, "..") => 0;
  69. lfs_soff_t pos;
  70. int i;
  71. for (i = 0; i < $MEDIUMSIZE; i++) {
  72. sprintf((char*)buffer, "kitty%d", i);
  73. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  74. strcmp(info.name, (char*)buffer) => 0;
  75. pos = lfs_dir_tell(&lfs, &dir[0]);
  76. }
  77. pos >= 0 => 1;
  78. lfs_dir_seek(&lfs, &dir[0], pos) => 0;
  79. sprintf((char*)buffer, "kitty%d", i);
  80. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  81. strcmp(info.name, (char*)buffer) => 0;
  82. lfs_dir_rewind(&lfs, &dir[0]) => 0;
  83. sprintf((char*)buffer, "kitty%d", 0);
  84. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  85. strcmp(info.name, ".") => 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, (char*)buffer) => 0;
  90. lfs_dir_seek(&lfs, &dir[0], pos) => 0;
  91. sprintf((char*)buffer, "kitty%d", i);
  92. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  93. strcmp(info.name, (char*)buffer) => 0;
  94. lfs_dir_close(&lfs, &dir[0]) => 0;
  95. lfs_unmount(&lfs) => 0;
  96. TEST
  97. echo "--- Simple file seek ---"
  98. tests/test.py << TEST
  99. lfs_mount(&lfs, &cfg) => 0;
  100. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDONLY) => 0;
  101. lfs_soff_t pos;
  102. size = strlen("kittycatcat");
  103. for (int i = 0; i < $SMALLSIZE; i++) {
  104. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  105. memcmp(buffer, "kittycatcat", size) => 0;
  106. pos = lfs_file_tell(&lfs, &file[0]);
  107. }
  108. pos >= 0 => 1;
  109. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  110. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  111. memcmp(buffer, "kittycatcat", size) => 0;
  112. lfs_file_rewind(&lfs, &file[0]) => 0;
  113. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  114. memcmp(buffer, "kittycatcat", size) => 0;
  115. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  116. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  117. memcmp(buffer, "kittycatcat", size) => 0;
  118. lfs_file_seek(&lfs, &file[0], size, LFS_SEEK_CUR) => 3*size;
  119. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  120. memcmp(buffer, "kittycatcat", size) => 0;
  121. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  122. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  123. memcmp(buffer, "kittycatcat", size) => 0;
  124. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_CUR) => pos;
  125. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  126. memcmp(buffer, "kittycatcat", size) => 0;
  127. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_END) >= 0 => 1;
  128. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  129. memcmp(buffer, "kittycatcat", size) => 0;
  130. lfs_size_t size = lfs_file_size(&lfs, &file[0]);
  131. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  132. lfs_file_close(&lfs, &file[0]) => 0;
  133. lfs_unmount(&lfs) => 0;
  134. TEST
  135. echo "--- Large file seek ---"
  136. tests/test.py << TEST
  137. lfs_mount(&lfs, &cfg) => 0;
  138. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDONLY) => 0;
  139. lfs_soff_t pos;
  140. size = strlen("kittycatcat");
  141. for (int i = 0; i < $MEDIUMSIZE; i++) {
  142. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  143. memcmp(buffer, "kittycatcat", size) => 0;
  144. pos = lfs_file_tell(&lfs, &file[0]);
  145. }
  146. pos >= 0 => 1;
  147. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  148. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  149. memcmp(buffer, "kittycatcat", size) => 0;
  150. lfs_file_rewind(&lfs, &file[0]) => 0;
  151. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  152. memcmp(buffer, "kittycatcat", size) => 0;
  153. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  154. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  155. memcmp(buffer, "kittycatcat", size) => 0;
  156. lfs_file_seek(&lfs, &file[0], size, LFS_SEEK_CUR) => 3*size;
  157. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  158. memcmp(buffer, "kittycatcat", size) => 0;
  159. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  160. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  161. memcmp(buffer, "kittycatcat", size) => 0;
  162. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_CUR) => pos;
  163. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  164. memcmp(buffer, "kittycatcat", size) => 0;
  165. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_END) >= 0 => 1;
  166. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  167. memcmp(buffer, "kittycatcat", size) => 0;
  168. lfs_size_t size = lfs_file_size(&lfs, &file[0]);
  169. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  170. lfs_file_close(&lfs, &file[0]) => 0;
  171. lfs_unmount(&lfs) => 0;
  172. TEST
  173. echo "--- Simple file seek and write ---"
  174. tests/test.py << TEST
  175. lfs_mount(&lfs, &cfg) => 0;
  176. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDWR) => 0;
  177. lfs_soff_t pos;
  178. size = strlen("kittycatcat");
  179. for (int i = 0; i < $SMALLSIZE; i++) {
  180. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  181. memcmp(buffer, "kittycatcat", size) => 0;
  182. pos = lfs_file_tell(&lfs, &file[0]);
  183. }
  184. pos >= 0 => 1;
  185. memcpy(buffer, "doggodogdog", size);
  186. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  187. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  188. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  189. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  190. memcmp(buffer, "doggodogdog", size) => 0;
  191. lfs_file_rewind(&lfs, &file[0]) => 0;
  192. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  193. memcmp(buffer, "kittycatcat", size) => 0;
  194. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  195. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  196. memcmp(buffer, "doggodogdog", size) => 0;
  197. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_END) >= 0 => 1;
  198. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  199. memcmp(buffer, "kittycatcat", size) => 0;
  200. lfs_size_t size = lfs_file_size(&lfs, &file[0]);
  201. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  202. lfs_file_close(&lfs, &file[0]) => 0;
  203. lfs_unmount(&lfs) => 0;
  204. TEST
  205. echo "--- Large file seek and write ---"
  206. tests/test.py << TEST
  207. lfs_mount(&lfs, &cfg) => 0;
  208. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDWR) => 0;
  209. lfs_soff_t pos;
  210. size = strlen("kittycatcat");
  211. for (int i = 0; i < $MEDIUMSIZE; i++) {
  212. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  213. if (i != $SMALLSIZE) {
  214. memcmp(buffer, "kittycatcat", size) => 0;
  215. }
  216. pos = lfs_file_tell(&lfs, &file[0]);
  217. }
  218. pos >= 0 => 1;
  219. memcpy(buffer, "doggodogdog", size);
  220. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  221. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  222. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  223. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  224. memcmp(buffer, "doggodogdog", size) => 0;
  225. lfs_file_rewind(&lfs, &file[0]) => 0;
  226. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  227. memcmp(buffer, "kittycatcat", size) => 0;
  228. lfs_file_seek(&lfs, &file[0], pos, LFS_SEEK_SET) => pos;
  229. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  230. memcmp(buffer, "doggodogdog", size) => 0;
  231. lfs_file_seek(&lfs, &file[0], -size, LFS_SEEK_END) >= 0 => 1;
  232. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  233. memcmp(buffer, "kittycatcat", size) => 0;
  234. lfs_size_t size = lfs_file_size(&lfs, &file[0]);
  235. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_CUR) => size;
  236. lfs_file_close(&lfs, &file[0]) => 0;
  237. lfs_unmount(&lfs) => 0;
  238. TEST
  239. echo "--- Boundary seek and write ---"
  240. tests/test.py << TEST
  241. lfs_mount(&lfs, &cfg) => 0;
  242. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDWR) => 0;
  243. size = strlen("hedgehoghog");
  244. const lfs_soff_t offsets[] = {512, 1020, 513, 1021, 511, 1019};
  245. for (int i = 0; i < sizeof(offsets) / sizeof(offsets[0]); i++) {
  246. lfs_soff_t off = offsets[i];
  247. memcpy(buffer, "hedgehoghog", size);
  248. lfs_file_seek(&lfs, &file[0], off, LFS_SEEK_SET) => off;
  249. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  250. lfs_file_seek(&lfs, &file[0], off, LFS_SEEK_SET) => off;
  251. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  252. memcmp(buffer, "hedgehoghog", size) => 0;
  253. lfs_file_seek(&lfs, &file[0], 0, LFS_SEEK_SET) => 0;
  254. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  255. memcmp(buffer, "kittycatcat", size) => 0;
  256. lfs_file_sync(&lfs, &file[0]) => 0;
  257. }
  258. lfs_file_close(&lfs, &file[0]) => 0;
  259. lfs_unmount(&lfs) => 0;
  260. TEST
  261. echo "--- Out-of-bounds seek ---"
  262. tests/test.py << TEST
  263. lfs_mount(&lfs, &cfg) => 0;
  264. lfs_file_open(&lfs, &file[0], "hello/kitty42", LFS_O_RDWR) => 0;
  265. size = strlen("kittycatcat");
  266. lfs_file_size(&lfs, &file[0]) => $LARGESIZE*size;
  267. lfs_file_seek(&lfs, &file[0], ($LARGESIZE+$SMALLSIZE)*size,
  268. LFS_SEEK_SET) => ($LARGESIZE+$SMALLSIZE)*size;
  269. lfs_file_read(&lfs, &file[0], buffer, size) => 0;
  270. memcpy(buffer, "porcupineee", size);
  271. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  272. lfs_file_seek(&lfs, &file[0], ($LARGESIZE+$SMALLSIZE)*size,
  273. LFS_SEEK_SET) => ($LARGESIZE+$SMALLSIZE)*size;
  274. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  275. memcmp(buffer, "porcupineee", size) => 0;
  276. lfs_file_seek(&lfs, &file[0], $LARGESIZE*size,
  277. LFS_SEEK_SET) => $LARGESIZE*size;
  278. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  279. memcmp(buffer, "\0\0\0\0\0\0\0\0\0\0\0", size) => 0;
  280. lfs_file_seek(&lfs, &file[0], -(($LARGESIZE+$SMALLSIZE)*size),
  281. LFS_SEEK_CUR) => LFS_ERR_INVAL;
  282. lfs_file_tell(&lfs, &file[0]) => ($LARGESIZE+1)*size;
  283. lfs_file_seek(&lfs, &file[0], -(($LARGESIZE+2*$SMALLSIZE)*size),
  284. LFS_SEEK_END) => LFS_ERR_INVAL;
  285. lfs_file_tell(&lfs, &file[0]) => ($LARGESIZE+1)*size;
  286. lfs_file_close(&lfs, &file[0]) => 0;
  287. lfs_unmount(&lfs) => 0;
  288. TEST
  289. echo "--- Results ---"
  290. tests/stats.py