test_interspersed.sh 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. #!/bin/bash
  2. set -eu
  3. echo "=== Interspersed tests ==="
  4. rm -rf blocks
  5. scripts/test.py << TEST
  6. lfs_format(&lfs, &cfg) => 0;
  7. TEST
  8. echo "--- Interspersed file test ---"
  9. scripts/test.py << TEST
  10. lfs_mount(&lfs, &cfg) => 0;
  11. lfs_file_open(&lfs, &file[0], "a", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  12. lfs_file_open(&lfs, &file[1], "b", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  13. lfs_file_open(&lfs, &file[2], "c", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  14. lfs_file_open(&lfs, &file[3], "d", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  15. for (int i = 0; i < 10; i++) {
  16. lfs_file_write(&lfs, &file[0], (const void*)"a", 1) => 1;
  17. lfs_file_write(&lfs, &file[1], (const void*)"b", 1) => 1;
  18. lfs_file_write(&lfs, &file[2], (const void*)"c", 1) => 1;
  19. lfs_file_write(&lfs, &file[3], (const void*)"d", 1) => 1;
  20. }
  21. lfs_file_close(&lfs, &file[0]);
  22. lfs_file_close(&lfs, &file[1]);
  23. lfs_file_close(&lfs, &file[2]);
  24. lfs_file_close(&lfs, &file[3]);
  25. lfs_dir_open(&lfs, &dir[0], "/") => 0;
  26. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  27. strcmp(info.name, ".") => 0;
  28. info.type => LFS_TYPE_DIR;
  29. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  30. strcmp(info.name, "..") => 0;
  31. info.type => LFS_TYPE_DIR;
  32. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  33. strcmp(info.name, "a") => 0;
  34. info.type => LFS_TYPE_REG;
  35. info.size => 10;
  36. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  37. strcmp(info.name, "b") => 0;
  38. info.type => LFS_TYPE_REG;
  39. info.size => 10;
  40. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  41. strcmp(info.name, "c") => 0;
  42. info.type => LFS_TYPE_REG;
  43. info.size => 10;
  44. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  45. strcmp(info.name, "d") => 0;
  46. info.type => LFS_TYPE_REG;
  47. info.size => 10;
  48. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  49. lfs_dir_close(&lfs, &dir[0]) => 0;
  50. lfs_file_open(&lfs, &file[0], "a", LFS_O_RDONLY) => 0;
  51. lfs_file_open(&lfs, &file[1], "b", LFS_O_RDONLY) => 0;
  52. lfs_file_open(&lfs, &file[2], "c", LFS_O_RDONLY) => 0;
  53. lfs_file_open(&lfs, &file[3], "d", LFS_O_RDONLY) => 0;
  54. for (int i = 0; i < 10; i++) {
  55. lfs_file_read(&lfs, &file[0], buffer, 1) => 1;
  56. buffer[0] => 'a';
  57. lfs_file_read(&lfs, &file[1], buffer, 1) => 1;
  58. buffer[0] => 'b';
  59. lfs_file_read(&lfs, &file[2], buffer, 1) => 1;
  60. buffer[0] => 'c';
  61. lfs_file_read(&lfs, &file[3], buffer, 1) => 1;
  62. buffer[0] => 'd';
  63. }
  64. lfs_file_close(&lfs, &file[0]);
  65. lfs_file_close(&lfs, &file[1]);
  66. lfs_file_close(&lfs, &file[2]);
  67. lfs_file_close(&lfs, &file[3]);
  68. lfs_unmount(&lfs) => 0;
  69. TEST
  70. echo "--- Interspersed remove file test ---"
  71. scripts/test.py << TEST
  72. lfs_mount(&lfs, &cfg) => 0;
  73. lfs_file_open(&lfs, &file[0], "e", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  74. for (int i = 0; i < 5; i++) {
  75. lfs_file_write(&lfs, &file[0], (const void*)"e", 1) => 1;
  76. }
  77. lfs_remove(&lfs, "a") => 0;
  78. lfs_remove(&lfs, "b") => 0;
  79. lfs_remove(&lfs, "c") => 0;
  80. lfs_remove(&lfs, "d") => 0;
  81. for (int i = 0; i < 5; i++) {
  82. lfs_file_write(&lfs, &file[0], (const void*)"e", 1) => 1;
  83. }
  84. lfs_file_close(&lfs, &file[0]);
  85. lfs_dir_open(&lfs, &dir[0], "/") => 0;
  86. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  87. strcmp(info.name, ".") => 0;
  88. info.type => LFS_TYPE_DIR;
  89. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  90. strcmp(info.name, "..") => 0;
  91. info.type => LFS_TYPE_DIR;
  92. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  93. strcmp(info.name, "e") => 0;
  94. info.type => LFS_TYPE_REG;
  95. info.size => 10;
  96. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  97. lfs_dir_close(&lfs, &dir[0]) => 0;
  98. lfs_file_open(&lfs, &file[0], "e", LFS_O_RDONLY) => 0;
  99. for (int i = 0; i < 10; i++) {
  100. lfs_file_read(&lfs, &file[0], buffer, 1) => 1;
  101. buffer[0] => 'e';
  102. }
  103. lfs_file_close(&lfs, &file[0]);
  104. lfs_unmount(&lfs) => 0;
  105. TEST
  106. echo "--- Remove inconveniently test ---"
  107. scripts/test.py << TEST
  108. lfs_mount(&lfs, &cfg) => 0;
  109. lfs_file_open(&lfs, &file[0], "e", LFS_O_WRONLY | LFS_O_TRUNC) => 0;
  110. lfs_file_open(&lfs, &file[1], "f", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  111. lfs_file_open(&lfs, &file[2], "g", LFS_O_WRONLY | LFS_O_CREAT) => 0;
  112. for (int i = 0; i < 5; i++) {
  113. lfs_file_write(&lfs, &file[0], (const void*)"e", 1) => 1;
  114. lfs_file_write(&lfs, &file[1], (const void*)"f", 1) => 1;
  115. lfs_file_write(&lfs, &file[2], (const void*)"g", 1) => 1;
  116. }
  117. lfs_remove(&lfs, "f") => 0;
  118. for (int i = 0; i < 5; i++) {
  119. lfs_file_write(&lfs, &file[0], (const void*)"e", 1) => 1;
  120. lfs_file_write(&lfs, &file[1], (const void*)"f", 1) => 1;
  121. lfs_file_write(&lfs, &file[2], (const void*)"g", 1) => 1;
  122. }
  123. lfs_file_close(&lfs, &file[0]);
  124. lfs_file_close(&lfs, &file[1]);
  125. lfs_file_close(&lfs, &file[2]);
  126. lfs_dir_open(&lfs, &dir[0], "/") => 0;
  127. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  128. strcmp(info.name, ".") => 0;
  129. info.type => LFS_TYPE_DIR;
  130. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  131. strcmp(info.name, "..") => 0;
  132. info.type => LFS_TYPE_DIR;
  133. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  134. strcmp(info.name, "e") => 0;
  135. info.type => LFS_TYPE_REG;
  136. info.size => 10;
  137. lfs_dir_read(&lfs, &dir[0], &info) => 1;
  138. strcmp(info.name, "g") => 0;
  139. info.type => LFS_TYPE_REG;
  140. info.size => 10;
  141. lfs_dir_read(&lfs, &dir[0], &info) => 0;
  142. lfs_dir_close(&lfs, &dir[0]) => 0;
  143. lfs_file_open(&lfs, &file[0], "e", LFS_O_RDONLY) => 0;
  144. lfs_file_open(&lfs, &file[1], "g", LFS_O_RDONLY) => 0;
  145. for (int i = 0; i < 10; i++) {
  146. lfs_file_read(&lfs, &file[0], buffer, 1) => 1;
  147. buffer[0] => 'e';
  148. lfs_file_read(&lfs, &file[1], buffer, 1) => 1;
  149. buffer[0] => 'g';
  150. }
  151. lfs_file_close(&lfs, &file[0]);
  152. lfs_file_close(&lfs, &file[1]);
  153. lfs_unmount(&lfs) => 0;
  154. TEST
  155. echo "--- Results ---"
  156. scripts/stats.py