test_format.toml 2.6 KB

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