test_entries.sh 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. #!/bin/bash
  2. set -eu
  3. # Note: These tests are intended for 512 byte inline size at different
  4. # inline sizes they should still pass, but won't be testing anything
  5. echo "=== Entry tests ==="
  6. rm -rf blocks
  7. function read_file {
  8. cat << TEST
  9. size = $2;
  10. lfs_file_open(&lfs, &file[0], "$1", LFS_O_RDONLY) => 0;
  11. lfs_file_read(&lfs, &file[0], rbuffer, size) => size;
  12. memcmp(rbuffer, wbuffer, size) => 0;
  13. lfs_file_close(&lfs, &file[0]) => 0;
  14. TEST
  15. }
  16. function write_file {
  17. cat << TEST
  18. size = $2;
  19. lfs_file_open(&lfs, &file[0], "$1",
  20. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0;
  21. memset(wbuffer, 'c', size);
  22. lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
  23. lfs_file_close(&lfs, &file[0]) => 0;
  24. TEST
  25. }
  26. echo "--- Entry grow test ---"
  27. tests/test.py << TEST
  28. lfs_format(&lfs, &cfg) => 0;
  29. lfs_mount(&lfs, &cfg) => 0;
  30. $(write_file "hi0" 20)
  31. $(write_file "hi1" 20)
  32. $(write_file "hi2" 20)
  33. $(write_file "hi3" 20)
  34. $(read_file "hi1" 20)
  35. $(write_file "hi1" 200)
  36. $(read_file "hi0" 20)
  37. $(read_file "hi1" 200)
  38. $(read_file "hi2" 20)
  39. $(read_file "hi3" 20)
  40. lfs_unmount(&lfs) => 0;
  41. TEST
  42. echo "--- Entry shrink test ---"
  43. tests/test.py << TEST
  44. lfs_format(&lfs, &cfg) => 0;
  45. lfs_mount(&lfs, &cfg) => 0;
  46. $(write_file "hi0" 20)
  47. $(write_file "hi1" 200)
  48. $(write_file "hi2" 20)
  49. $(write_file "hi3" 20)
  50. $(read_file "hi1" 200)
  51. $(write_file "hi1" 20)
  52. $(read_file "hi0" 20)
  53. $(read_file "hi1" 20)
  54. $(read_file "hi2" 20)
  55. $(read_file "hi3" 20)
  56. lfs_unmount(&lfs) => 0;
  57. TEST
  58. echo "--- Entry spill test ---"
  59. tests/test.py << TEST
  60. lfs_format(&lfs, &cfg) => 0;
  61. lfs_mount(&lfs, &cfg) => 0;
  62. $(write_file "hi0" 200)
  63. $(write_file "hi1" 200)
  64. $(write_file "hi2" 200)
  65. $(write_file "hi3" 200)
  66. $(read_file "hi0" 200)
  67. $(read_file "hi1" 200)
  68. $(read_file "hi2" 200)
  69. $(read_file "hi3" 200)
  70. lfs_unmount(&lfs) => 0;
  71. TEST
  72. echo "--- Entry push spill test ---"
  73. tests/test.py << TEST
  74. lfs_format(&lfs, &cfg) => 0;
  75. lfs_mount(&lfs, &cfg) => 0;
  76. $(write_file "hi0" 200)
  77. $(write_file "hi1" 20)
  78. $(write_file "hi2" 200)
  79. $(write_file "hi3" 200)
  80. $(read_file "hi1" 20)
  81. $(write_file "hi1" 200)
  82. $(read_file "hi0" 200)
  83. $(read_file "hi1" 200)
  84. $(read_file "hi2" 200)
  85. $(read_file "hi3" 200)
  86. lfs_unmount(&lfs) => 0;
  87. TEST
  88. echo "--- Entry push spill two test ---"
  89. tests/test.py << TEST
  90. lfs_format(&lfs, &cfg) => 0;
  91. lfs_mount(&lfs, &cfg) => 0;
  92. $(write_file "hi0" 200)
  93. $(write_file "hi1" 20)
  94. $(write_file "hi2" 200)
  95. $(write_file "hi3" 200)
  96. $(write_file "hi4" 200)
  97. $(read_file "hi1" 20)
  98. $(write_file "hi1" 200)
  99. $(read_file "hi0" 200)
  100. $(read_file "hi1" 200)
  101. $(read_file "hi2" 200)
  102. $(read_file "hi3" 200)
  103. $(read_file "hi4" 200)
  104. lfs_unmount(&lfs) => 0;
  105. TEST
  106. echo "--- Entry drop test ---"
  107. tests/test.py << TEST
  108. lfs_format(&lfs, &cfg) => 0;
  109. lfs_mount(&lfs, &cfg) => 0;
  110. $(write_file "hi0" 200)
  111. $(write_file "hi1" 200)
  112. $(write_file "hi2" 200)
  113. $(write_file "hi3" 200)
  114. lfs_remove(&lfs, "hi1") => 0;
  115. lfs_stat(&lfs, "hi1", &info) => LFS_ERR_NOENT;
  116. $(read_file "hi0" 200)
  117. $(read_file "hi2" 200)
  118. $(read_file "hi3" 200)
  119. lfs_remove(&lfs, "hi2") => 0;
  120. lfs_stat(&lfs, "hi2", &info) => LFS_ERR_NOENT;
  121. $(read_file "hi0" 200)
  122. $(read_file "hi3" 200)
  123. lfs_remove(&lfs, "hi3") => 0;
  124. lfs_stat(&lfs, "hi3", &info) => LFS_ERR_NOENT;
  125. $(read_file "hi0" 200)
  126. lfs_remove(&lfs, "hi0") => 0;
  127. lfs_stat(&lfs, "hi0", &info) => LFS_ERR_NOENT;
  128. lfs_unmount(&lfs) => 0;
  129. TEST
  130. echo "--- Create too big ---"
  131. tests/test.py << TEST
  132. lfs_format(&lfs, &cfg) => 0;
  133. lfs_mount(&lfs, &cfg) => 0;
  134. memset(buffer, 'm', 200);
  135. buffer[200] = '\0';
  136. size = 400;
  137. lfs_file_open(&lfs, &file[0], (char*)buffer,
  138. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0;
  139. memset(wbuffer, 'c', size);
  140. lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
  141. lfs_file_close(&lfs, &file[0]) => 0;
  142. size = 400;
  143. lfs_file_open(&lfs, &file[0], (char*)buffer, LFS_O_RDONLY) => 0;
  144. lfs_file_read(&lfs, &file[0], rbuffer, size) => size;
  145. memcmp(rbuffer, wbuffer, size) => 0;
  146. lfs_file_close(&lfs, &file[0]) => 0;
  147. lfs_unmount(&lfs) => 0;
  148. TEST
  149. echo "--- Resize too big ---"
  150. tests/test.py << TEST
  151. lfs_format(&lfs, &cfg) => 0;
  152. lfs_mount(&lfs, &cfg) => 0;
  153. memset(buffer, 'm', 200);
  154. buffer[200] = '\0';
  155. size = 40;
  156. lfs_file_open(&lfs, &file[0], (char*)buffer,
  157. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0;
  158. memset(wbuffer, 'c', size);
  159. lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
  160. lfs_file_close(&lfs, &file[0]) => 0;
  161. size = 40;
  162. lfs_file_open(&lfs, &file[0], (char*)buffer, LFS_O_RDONLY) => 0;
  163. lfs_file_read(&lfs, &file[0], rbuffer, size) => size;
  164. memcmp(rbuffer, wbuffer, size) => 0;
  165. lfs_file_close(&lfs, &file[0]) => 0;
  166. size = 400;
  167. lfs_file_open(&lfs, &file[0], (char*)buffer,
  168. LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0;
  169. memset(wbuffer, 'c', size);
  170. lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
  171. lfs_file_close(&lfs, &file[0]) => 0;
  172. size = 400;
  173. lfs_file_open(&lfs, &file[0], (char*)buffer, LFS_O_RDONLY) => 0;
  174. lfs_file_read(&lfs, &file[0], rbuffer, size) => size;
  175. memcmp(rbuffer, wbuffer, size) => 0;
  176. lfs_file_close(&lfs, &file[0]) => 0;
  177. lfs_unmount(&lfs) => 0;
  178. TEST
  179. echo "--- Results ---"
  180. tests/stats.py