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