test_alloc.sh 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. #!/bin/bash
  2. set -eu
  3. echo "=== Allocator tests ==="
  4. rm -rf blocks
  5. tests/test.py << TEST
  6. lfs_format(&lfs, &cfg) => 0;
  7. TEST
  8. SIZE=15000
  9. lfs_mkdir() {
  10. tests/test.py << TEST
  11. lfs_mount(&lfs, &cfg) => 0;
  12. lfs_mkdir(&lfs, "$1") => 0;
  13. lfs_unmount(&lfs) => 0;
  14. TEST
  15. }
  16. lfs_remove() {
  17. tests/test.py << TEST
  18. lfs_mount(&lfs, &cfg) => 0;
  19. lfs_remove(&lfs, "$1/eggs") => 0;
  20. lfs_remove(&lfs, "$1/bacon") => 0;
  21. lfs_remove(&lfs, "$1/pancakes") => 0;
  22. lfs_remove(&lfs, "$1") => 0;
  23. lfs_unmount(&lfs) => 0;
  24. TEST
  25. }
  26. lfs_alloc_singleproc() {
  27. tests/test.py << TEST
  28. const char *names[] = {"bacon", "eggs", "pancakes"};
  29. lfs_mount(&lfs, &cfg) => 0;
  30. for (int n = 0; n < sizeof(names)/sizeof(names[0]); n++) {
  31. sprintf((char*)buffer, "$1/%s", names[n]);
  32. lfs_file_open(&lfs, &file[n], (char*)buffer,
  33. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_APPEND) => 0;
  34. }
  35. for (int n = 0; n < sizeof(names)/sizeof(names[0]); n++) {
  36. size = strlen(names[n]);
  37. for (int i = 0; i < $SIZE; i++) {
  38. lfs_file_write(&lfs, &file[n], names[n], size) => size;
  39. }
  40. }
  41. for (int n = 0; n < sizeof(names)/sizeof(names[0]); n++) {
  42. lfs_file_close(&lfs, &file[n]) => 0;
  43. }
  44. lfs_unmount(&lfs) => 0;
  45. TEST
  46. }
  47. lfs_alloc_multiproc() {
  48. for name in bacon eggs pancakes
  49. do
  50. tests/test.py << TEST
  51. lfs_mount(&lfs, &cfg) => 0;
  52. lfs_file_open(&lfs, &file[0], "$1/$name",
  53. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_APPEND) => 0;
  54. size = strlen("$name");
  55. memcpy(buffer, "$name", size);
  56. for (int i = 0; i < $SIZE; i++) {
  57. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  58. }
  59. lfs_file_close(&lfs, &file[0]) => 0;
  60. lfs_unmount(&lfs) => 0;
  61. TEST
  62. done
  63. }
  64. lfs_verify() {
  65. for name in bacon eggs pancakes
  66. do
  67. tests/test.py << TEST
  68. lfs_mount(&lfs, &cfg) => 0;
  69. lfs_file_open(&lfs, &file[0], "$1/$name", LFS_O_RDONLY) => 0;
  70. size = strlen("$name");
  71. for (int i = 0; i < $SIZE; i++) {
  72. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  73. memcmp(buffer, "$name", size) => 0;
  74. }
  75. lfs_file_close(&lfs, &file[0]) => 0;
  76. lfs_unmount(&lfs) => 0;
  77. TEST
  78. done
  79. }
  80. echo "--- Single-process allocation test ---"
  81. lfs_mkdir singleproc
  82. lfs_alloc_singleproc singleproc
  83. lfs_verify singleproc
  84. echo "--- Multi-process allocation test ---"
  85. lfs_mkdir multiproc
  86. lfs_alloc_multiproc multiproc
  87. lfs_verify multiproc
  88. lfs_verify singleproc
  89. echo "--- Single-process reuse test ---"
  90. lfs_remove singleproc
  91. lfs_mkdir singleprocreuse
  92. lfs_alloc_singleproc singleprocreuse
  93. lfs_verify singleprocreuse
  94. lfs_verify multiproc
  95. echo "--- Multi-process reuse test ---"
  96. lfs_remove multiproc
  97. lfs_mkdir multiprocreuse
  98. lfs_alloc_singleproc multiprocreuse
  99. lfs_verify multiprocreuse
  100. lfs_verify singleprocreuse
  101. echo "--- Cleanup ---"
  102. lfs_remove multiprocreuse
  103. lfs_remove singleprocreuse
  104. echo "--- Exhaustion test ---"
  105. tests/test.py << TEST
  106. lfs_mount(&lfs, &cfg) => 0;
  107. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_CREAT);
  108. size = strlen("exhaustion");
  109. memcpy(buffer, "exhaustion", size);
  110. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  111. size = strlen("blahblahblahblah");
  112. memcpy(buffer, "blahblahblahblah", size);
  113. lfs_ssize_t res;
  114. while (true) {
  115. res = lfs_file_write(&lfs, &file[0], buffer, size);
  116. if (res < 0) {
  117. break;
  118. }
  119. res => size;
  120. }
  121. res => LFS_ERR_NOSPC;
  122. lfs_file_close(&lfs, &file[0]) => 0;
  123. lfs_unmount(&lfs) => 0;
  124. TEST
  125. tests/test.py << TEST
  126. lfs_mount(&lfs, &cfg) => 0;
  127. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_RDONLY);
  128. size = strlen("exhaustion");
  129. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  130. memcmp(buffer, "exhaustion", size) => 0;
  131. lfs_file_close(&lfs, &file[0]) => 0;
  132. lfs_unmount(&lfs) => 0;
  133. TEST
  134. echo "--- Exhaustion wraparound test ---"
  135. tests/test.py << TEST
  136. lfs_mount(&lfs, &cfg) => 0;
  137. lfs_remove(&lfs, "exhaustion") => 0;
  138. lfs_file_open(&lfs, &file[0], "padding", LFS_O_WRONLY | LFS_O_CREAT);
  139. size = strlen("buffering");
  140. memcpy(buffer, "buffering", size);
  141. for (int i = 0; i < $SIZE; i++) {
  142. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  143. }
  144. lfs_file_close(&lfs, &file[0]) => 0;
  145. lfs_remove(&lfs, "padding") => 0;
  146. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_CREAT);
  147. size = strlen("exhaustion");
  148. memcpy(buffer, "exhaustion", size);
  149. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  150. size = strlen("blahblahblahblah");
  151. memcpy(buffer, "blahblahblahblah", size);
  152. lfs_ssize_t res;
  153. while (true) {
  154. res = lfs_file_write(&lfs, &file[0], buffer, size);
  155. if (res < 0) {
  156. break;
  157. }
  158. res => size;
  159. }
  160. res => LFS_ERR_NOSPC;
  161. lfs_file_close(&lfs, &file[0]) => 0;
  162. lfs_unmount(&lfs) => 0;
  163. TEST
  164. tests/test.py << TEST
  165. lfs_mount(&lfs, &cfg) => 0;
  166. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_RDONLY);
  167. size = strlen("exhaustion");
  168. lfs_file_read(&lfs, &file[0], buffer, size) => size;
  169. memcmp(buffer, "exhaustion", size) => 0;
  170. lfs_file_close(&lfs, &file[0]) => 0;
  171. lfs_unmount(&lfs) => 0;
  172. TEST
  173. echo "--- Dir exhaustion test ---"
  174. tests/test.py << TEST
  175. lfs_mount(&lfs, &cfg) => 0;
  176. lfs_stat(&lfs, "exhaustion", &info) => 0;
  177. lfs_size_t fullsize = info.size;
  178. lfs_remove(&lfs, "exhaustion") => 0;
  179. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_CREAT);
  180. size = strlen("blahblahblahblah");
  181. memcpy(buffer, "blahblahblahblah", size);
  182. for (lfs_size_t i = 0; i < fullsize - 2*512; i += size) {
  183. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  184. }
  185. lfs_file_close(&lfs, &file[0]) => 0;
  186. lfs_mkdir(&lfs, "exhaustiondir") => 0;
  187. lfs_remove(&lfs, "exhaustiondir") => 0;
  188. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_APPEND);
  189. size = strlen("blahblahblahblah");
  190. memcpy(buffer, "blahblahblahblah", size);
  191. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  192. lfs_file_close(&lfs, &file[0]) => 0;
  193. lfs_mkdir(&lfs, "exhaustiondir") => LFS_ERR_NOSPC;
  194. lfs_unmount(&lfs) => 0;
  195. TEST
  196. echo "--- Chained dir exhaustion test ---"
  197. tests/test.py << TEST
  198. lfs_mount(&lfs, &cfg) => 0;
  199. lfs_stat(&lfs, "exhaustion", &info) => 0;
  200. lfs_size_t fullsize = info.size;
  201. lfs_remove(&lfs, "exhaustion") => 0;
  202. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_CREAT);
  203. size = strlen("blahblahblahblah");
  204. memcpy(buffer, "blahblahblahblah", size);
  205. for (lfs_size_t i = 0; i < fullsize - 19*512; i += size) {
  206. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  207. }
  208. lfs_file_close(&lfs, &file[0]) => 0;
  209. for (int i = 0; i < 9; i++) {
  210. sprintf((char*)buffer, "dirwithanexhaustivelylongnameforpadding%d", i);
  211. lfs_mkdir(&lfs, (char*)buffer) => 0;
  212. }
  213. lfs_mkdir(&lfs, "exhaustiondir") => LFS_ERR_NOSPC;
  214. lfs_remove(&lfs, "exhaustion") => 0;
  215. lfs_file_open(&lfs, &file[0], "exhaustion", LFS_O_WRONLY | LFS_O_CREAT);
  216. size = strlen("blahblahblahblah");
  217. memcpy(buffer, "blahblahblahblah", size);
  218. for (lfs_size_t i = 0; i < fullsize - 20*512; i += size) {
  219. lfs_file_write(&lfs, &file[0], buffer, size) => size;
  220. }
  221. lfs_file_close(&lfs, &file[0]) => 0;
  222. lfs_mkdir(&lfs, "exhaustiondir") => 0;
  223. lfs_mkdir(&lfs, "exhaustiondir2") => LFS_ERR_NOSPC;
  224. TEST
  225. echo "--- Results ---"
  226. tests/stats.py