test_truncate.sh 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. #!/bin/bash
  2. set -eu
  3. SMALLSIZE=32
  4. MEDIUMSIZE=2048
  5. LARGESIZE=8192
  6. echo "=== Truncate tests ==="
  7. rm -rf blocks
  8. scripts/test.py << TEST
  9. lfs_format(&lfs, &cfg) => 0;
  10. TEST
  11. echo "--- Simple truncate ---"
  12. scripts/test.py << TEST
  13. lfs_mount(&lfs, &cfg) => 0;
  14. lfs_file_open(&lfs, &file[0], "baldynoop",
  15. LFS_O_WRONLY | LFS_O_CREAT) => 0;
  16. strcpy((char*)buffer, "hair");
  17. size = strlen((char*)buffer);
  18. for (lfs_off_t j = 0; j < $LARGESIZE; j += size) {
  19. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  20. }
  21. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  22. lfs_file_close(&lfs, &file[0]) => 0;
  23. lfs_unmount(&lfs) => 0;
  24. TEST
  25. scripts/test.py << TEST
  26. lfs_mount(&lfs, &cfg) => 0;
  27. lfs_file_open(&lfs, &file[0], "baldynoop", LFS_O_RDWR) => 0;
  28. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  29. lfs_file_truncate(&lfs, &file[0], $MEDIUMSIZE) => 0;
  30. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  31. lfs_file_close(&lfs, &file[0]) => 0;
  32. lfs_unmount(&lfs) => 0;
  33. TEST
  34. scripts/test.py << TEST
  35. lfs_mount(&lfs, &cfg) => 0;
  36. lfs_file_open(&lfs, &file[0], "baldynoop", LFS_O_RDONLY) => 0;
  37. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  38. size = strlen("hair");
  39. for (lfs_off_t j = 0; j < $MEDIUMSIZE; j += size) {
  40. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  41. memcmp(buffer, "hair", size) => 0;
  42. }
  43. lfs_file_read(&lfs, &file[0], buffer, size) => 0;
  44. lfs_file_close(&lfs, &file[0]) => 0;
  45. lfs_unmount(&lfs) => 0;
  46. TEST
  47. echo "--- Truncate and read ---"
  48. scripts/test.py << TEST
  49. lfs_mount(&lfs, &cfg) => 0;
  50. lfs_file_open(&lfs, &file[0], "baldyread",
  51. LFS_O_WRONLY | LFS_O_CREAT) => 0;
  52. strcpy((char*)buffer, "hair");
  53. size = strlen((char*)buffer);
  54. for (lfs_off_t j = 0; j < $LARGESIZE; j += size) {
  55. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  56. }
  57. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  58. lfs_file_close(&lfs, &file[0]) => 0;
  59. lfs_unmount(&lfs) => 0;
  60. TEST
  61. scripts/test.py << TEST
  62. lfs_mount(&lfs, &cfg) => 0;
  63. lfs_file_open(&lfs, &file[0], "baldyread", LFS_O_RDWR) => 0;
  64. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  65. lfs_file_truncate(&lfs, &file[0], $MEDIUMSIZE) => 0;
  66. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  67. size = strlen("hair");
  68. for (lfs_off_t j = 0; j < $MEDIUMSIZE; j += size) {
  69. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  70. memcmp(buffer, "hair", size) => 0;
  71. }
  72. lfs_file_read(&lfs, &file[0], buffer, size) => 0;
  73. lfs_file_close(&lfs, &file[0]) => 0;
  74. lfs_unmount(&lfs) => 0;
  75. TEST
  76. scripts/test.py << TEST
  77. lfs_mount(&lfs, &cfg) => 0;
  78. lfs_file_open(&lfs, &file[0], "baldyread", LFS_O_RDONLY) => 0;
  79. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  80. size = strlen("hair");
  81. for (lfs_off_t j = 0; j < $MEDIUMSIZE; j += size) {
  82. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  83. memcmp(buffer, "hair", size) => 0;
  84. }
  85. lfs_file_read(&lfs, &file[0], buffer, size) => 0;
  86. lfs_file_close(&lfs, &file[0]) => 0;
  87. lfs_unmount(&lfs) => 0;
  88. TEST
  89. echo "--- Truncate and write ---"
  90. scripts/test.py << TEST
  91. lfs_mount(&lfs, &cfg) => 0;
  92. lfs_file_open(&lfs, &file[0], "baldywrite",
  93. LFS_O_WRONLY | LFS_O_CREAT) => 0;
  94. strcpy((char*)buffer, "hair");
  95. size = strlen((char*)buffer);
  96. for (lfs_off_t j = 0; j < $LARGESIZE; j += size) {
  97. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  98. }
  99. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  100. lfs_file_close(&lfs, &file[0]) => 0;
  101. lfs_unmount(&lfs) => 0;
  102. TEST
  103. scripts/test.py << TEST
  104. lfs_mount(&lfs, &cfg) => 0;
  105. lfs_file_open(&lfs, &file[0], "baldywrite", LFS_O_RDWR) => 0;
  106. lfs_file_size(&lfs, &file[0]) => $LARGESIZE;
  107. lfs_file_truncate(&lfs, &file[0], $MEDIUMSIZE) => 0;
  108. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  109. strcpy((char*)buffer, "bald");
  110. size = strlen((char*)buffer);
  111. for (lfs_off_t j = 0; j < $MEDIUMSIZE; j += size) {
  112. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  113. }
  114. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  115. lfs_file_close(&lfs, &file[0]) => 0;
  116. lfs_unmount(&lfs) => 0;
  117. TEST
  118. scripts/test.py << TEST
  119. lfs_mount(&lfs, &cfg) => 0;
  120. lfs_file_open(&lfs, &file[0], "baldywrite", LFS_O_RDONLY) => 0;
  121. lfs_file_size(&lfs, &file[0]) => $MEDIUMSIZE;
  122. size = strlen("bald");
  123. for (lfs_off_t j = 0; j < $MEDIUMSIZE; j += size) {
  124. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  125. memcmp(buffer, "bald", size) => 0;
  126. }
  127. lfs_file_read(&lfs, &file[0], buffer, size) => 0;
  128. lfs_file_close(&lfs, &file[0]) => 0;
  129. lfs_unmount(&lfs) => 0;
  130. TEST
  131. # More aggressive general truncation tests
  132. truncate_test() {
  133. STARTSIZES="$1"
  134. STARTSEEKS="$2"
  135. HOTSIZES="$3"
  136. COLDSIZES="$4"
  137. scripts/test.py << TEST
  138. static const lfs_off_t startsizes[] = {$STARTSIZES};
  139. static const lfs_off_t startseeks[] = {$STARTSEEKS};
  140. static const lfs_off_t hotsizes[] = {$HOTSIZES};
  141. lfs_mount(&lfs, &cfg) => 0;
  142. for (unsigned i = 0; i < sizeof(startsizes)/sizeof(startsizes[0]); i++) {
  143. sprintf((char*)buffer, "hairyhead%d", i);
  144. lfs_file_open(&lfs, &file[0], (const char*)buffer,
  145. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0;
  146. strcpy((char*)buffer, "hair");
  147. size = strlen((char*)buffer);
  148. for (lfs_off_t j = 0; j < startsizes[i]; j += size) {
  149. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  150. }
  151. lfs_file_size(&lfs, &file[0]) => startsizes[i];
  152. if (startseeks[i] != startsizes[i]) {
  153. lfs_file_seek(&lfs, &file[0],
  154. startseeks[i], LFS_SEEK_SET) => startseeks[i];
  155. }
  156. lfs_file_truncate(&lfs, &file[0], hotsizes[i]) => 0;
  157. lfs_file_size(&lfs, &file[0]) => hotsizes[i];
  158. lfs_file_close(&lfs, &file[0]) => 0;
  159. }
  160. lfs_unmount(&lfs) => 0;
  161. TEST
  162. scripts/test.py << TEST
  163. static const lfs_off_t startsizes[] = {$STARTSIZES};
  164. static const lfs_off_t hotsizes[] = {$HOTSIZES};
  165. static const lfs_off_t coldsizes[] = {$COLDSIZES};
  166. lfs_mount(&lfs, &cfg) => 0;
  167. for (unsigned i = 0; i < sizeof(startsizes)/sizeof(startsizes[0]); i++) {
  168. sprintf((char*)buffer, "hairyhead%d", i);
  169. lfs_file_open(&lfs, &file[0], (const char*)buffer, LFS_O_RDWR) => 0;
  170. lfs_file_size(&lfs, &file[0]) => hotsizes[i];
  171. size = strlen("hair");
  172. lfs_off_t j = 0;
  173. for (; j < startsizes[i] && j < hotsizes[i]; j += size) {
  174. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  175. memcmp(buffer, "hair", size) => 0;
  176. }
  177. for (; j < hotsizes[i]; j += size) {
  178. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  179. memcmp(buffer, "\0\0\0\0", size) => 0;
  180. }
  181. lfs_file_truncate(&lfs, &file[0], coldsizes[i]) => 0;
  182. lfs_file_size(&lfs, &file[0]) => coldsizes[i];
  183. lfs_file_close(&lfs, &file[0]) => 0;
  184. }
  185. lfs_unmount(&lfs) => 0;
  186. TEST
  187. scripts/test.py << TEST
  188. static const lfs_off_t startsizes[] = {$STARTSIZES};
  189. static const lfs_off_t hotsizes[] = {$HOTSIZES};
  190. static const lfs_off_t coldsizes[] = {$COLDSIZES};
  191. lfs_mount(&lfs, &cfg) => 0;
  192. for (unsigned i = 0; i < sizeof(startsizes)/sizeof(startsizes[0]); i++) {
  193. sprintf((char*)buffer, "hairyhead%d", i);
  194. lfs_file_open(&lfs, &file[0], (const char*)buffer, LFS_O_RDONLY) => 0;
  195. lfs_file_size(&lfs, &file[0]) => coldsizes[i];
  196. size = strlen("hair");
  197. lfs_off_t j = 0;
  198. for (; j < startsizes[i] && j < hotsizes[i] && j < coldsizes[i];
  199. j += size) {
  200. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  201. memcmp(buffer, "hair", size) => 0;
  202. }
  203. for (; j < coldsizes[i]; j += size) {
  204. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  205. memcmp(buffer, "\0\0\0\0", size) => 0;
  206. }
  207. lfs_file_close(&lfs, &file[0]) => 0;
  208. }
  209. lfs_unmount(&lfs) => 0;
  210. TEST
  211. }
  212. echo "--- Cold shrinking truncate ---"
  213. truncate_test \
  214. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  215. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  216. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  217. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE"
  218. echo "--- Cold expanding truncate ---"
  219. truncate_test \
  220. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  221. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  222. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  223. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE"
  224. echo "--- Warm shrinking truncate ---"
  225. truncate_test \
  226. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  227. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  228. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  229. " 0, 0, 0, 0, 0"
  230. echo "--- Warm expanding truncate ---"
  231. truncate_test \
  232. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  233. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  234. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  235. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE"
  236. echo "--- Mid-file shrinking truncate ---"
  237. truncate_test \
  238. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  239. " $LARGESIZE, $LARGESIZE, $LARGESIZE, $LARGESIZE, $LARGESIZE" \
  240. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  241. " 0, 0, 0, 0, 0"
  242. echo "--- Mid-file expanding truncate ---"
  243. truncate_test \
  244. " 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE, 2*$LARGESIZE" \
  245. " 0, 0, $SMALLSIZE, $MEDIUMSIZE, $LARGESIZE" \
  246. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE" \
  247. "2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE, 2*$LARGESIZE"
  248. echo "--- Results ---"
  249. scripts/stats.py