test_format.toml 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. [[case]] # simple formatting test
  2. code = '''
  3. lfs_format(&lfs, &cfg) => 0;
  4. '''
  5. [[case]] # mount/unmount
  6. code = '''
  7. lfs_format(&lfs, &cfg) => 0;
  8. lfs_mount(&lfs, &cfg) => 0;
  9. lfs_unmount(&lfs) => 0;
  10. '''
  11. [[case]] # reentrant format
  12. code = '''
  13. err = lfs_mount(&lfs, &cfg);
  14. if (err) {
  15. lfs_format(&lfs, &cfg) => 0;
  16. lfs_mount(&lfs, &cfg) => 0;
  17. }
  18. lfs_unmount(&lfs) => 0;
  19. '''
  20. reentrant = true
  21. [[case]] # invalid mount
  22. code = '''
  23. lfs_mount(&lfs, &cfg) => LFS_ERR_CORRUPT;
  24. '''
  25. # TODO invalid superblock? (corrupt 1, 0)
  26. [[case]] # expanding superblock
  27. code = '''
  28. lfs_format(&lfs, &cfg) => 0;
  29. lfs_mount(&lfs, &cfg) => 0;
  30. for (int i = 0; i < N; i++) {
  31. lfs_mkdir(&lfs, "dummy") => 0;
  32. lfs_stat(&lfs, "dummy", &info) => 0;
  33. assert(strcmp(info.name, "dummy") == 0);
  34. lfs_remove(&lfs, "dummy") => 0;
  35. }
  36. lfs_unmount(&lfs) => 0;
  37. // one last check after power-cycle
  38. lfs_mount(&lfs, &cfg) => 0;
  39. lfs_mkdir(&lfs, "dummy") => 0;
  40. lfs_stat(&lfs, "dummy", &info) => 0;
  41. assert(strcmp(info.name, "dummy") == 0);
  42. lfs_unmount(&lfs) => 0;
  43. '''
  44. define.BLOCK_CYCLES = [32, 33, 1]
  45. define.N = [10, 100, 1000]
  46. [[case]] # expanding superblock with power cycle
  47. code = '''
  48. lfs_format(&lfs, &cfg) => 0;
  49. for (int i = 0; i < N; i++) {
  50. lfs_mount(&lfs, &cfg) => 0;
  51. // remove lingering dummy?
  52. err = lfs_remove(&lfs, "dummy");
  53. assert(err == 0 || (err == LFS_ERR_NOENT && i == 0));
  54. lfs_mkdir(&lfs, "dummy") => 0;
  55. lfs_stat(&lfs, "dummy", &info) => 0;
  56. assert(strcmp(info.name, "dummy") == 0);
  57. lfs_unmount(&lfs) => 0;
  58. }
  59. // one last check after power-cycle
  60. lfs_mount(&lfs, &cfg) => 0;
  61. lfs_stat(&lfs, "dummy", &info) => 0;
  62. assert(strcmp(info.name, "dummy") == 0);
  63. lfs_unmount(&lfs) => 0;
  64. '''
  65. define.BLOCK_CYCLES = [32, 33, 1]
  66. define.N = [10, 100, 1000]
  67. [[case]] # reentrant expanding superblock
  68. code = '''
  69. err = lfs_mount(&lfs, &cfg);
  70. if (err) {
  71. lfs_format(&lfs, &cfg) => 0;
  72. lfs_mount(&lfs, &cfg) => 0;
  73. }
  74. for (int i = 0; i < N; i++) {
  75. // remove lingering dummy?
  76. err = lfs_remove(&lfs, "dummy");
  77. assert(err == 0 || (err == LFS_ERR_NOENT && i == 0));
  78. lfs_mkdir(&lfs, "dummy") => 0;
  79. lfs_stat(&lfs, "dummy", &info) => 0;
  80. assert(strcmp(info.name, "dummy") == 0);
  81. }
  82. lfs_unmount(&lfs) => 0;
  83. // one last check after power-cycle
  84. lfs_mount(&lfs, &cfg) => 0;
  85. lfs_stat(&lfs, "dummy", &info) => 0;
  86. assert(strcmp(info.name, "dummy") == 0);
  87. lfs_unmount(&lfs) => 0;
  88. '''
  89. define.BLOCK_CYCLES = [2, 1]
  90. define.N = 24
  91. reentrant = true