mirror of
https://github.com/eledio-devices/thirdparty-littlefs.git
synced 2025-11-01 08:48:31 +01:00
- Now test errors have correct line reporting! #line directives
are passed to the compiler that reference the relevant line in
the test case shell script.
--- Multi-block directory ---
./tests/test_dirs.sh:109: assert failed with 0, expected 1
lfs_unmount(&lfs) => 1
- Cleaned up the number of implicit global variables provided to
tests. A lot of these were infrequently used and made it difficult
to remember what was provided. This isn't an MCU, so there's very
little cost to stack allocations when needed.
- Minimized the results.py script (previously stats.py) output to
match minimization of test output.
295 lines
11 KiB
Bash
Executable File
295 lines
11 KiB
Bash
Executable File
#!/bin/bash
|
|
set -eu
|
|
export TEST_FILE=$0
|
|
trap 'export TEST_LINE=$LINENO' DEBUG
|
|
|
|
echo "=== Attr tests ==="
|
|
rm -rf blocks
|
|
scripts/test.py << TEST
|
|
lfs_format(&lfs, &cfg) => 0;
|
|
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
lfs_mkdir(&lfs, "hello") => 0;
|
|
lfs_file_open(&lfs, &file, "hello/hello",
|
|
LFS_O_WRONLY | LFS_O_CREAT) => 0;
|
|
lfs_file_write(&lfs, &file, "hello", strlen("hello"))
|
|
=> strlen("hello");
|
|
lfs_file_close(&lfs, &file);
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
|
|
echo "--- Set/get attribute ---"
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
lfs_setattr(&lfs, "hello", 'A', "aaaa", 4) => 0;
|
|
lfs_setattr(&lfs, "hello", 'B', "bbbbbb", 6) => 0;
|
|
lfs_setattr(&lfs, "hello", 'C', "ccccc", 5) => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => 6;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "bbbbbb", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "hello", 'B', "", 0) => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => 0;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "\0\0\0\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_removeattr(&lfs, "hello", 'B') => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => LFS_ERR_NOATTR;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "\0\0\0\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "hello", 'B', "dddddd", 6) => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => 6;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "dddddd", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "hello", 'B', "eee", 3) => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => 3;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "eee\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "hello", 'A', buffer, LFS_ATTR_MAX+1) => LFS_ERR_NOSPC;
|
|
lfs_setattr(&lfs, "hello", 'B', "fffffffff", 9) => 0;
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 6) => 9;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+10, 5) => 5;
|
|
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
lfs_getattr(&lfs, "hello", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "hello", 'B', buffer+4, 9) => 9;
|
|
lfs_getattr(&lfs, "hello", 'C', buffer+13, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "fffffffff", 9) => 0;
|
|
memcmp(buffer+13, "ccccc", 5) => 0;
|
|
|
|
lfs_file_open(&lfs, &file, "hello/hello", LFS_O_RDONLY) => 0;
|
|
lfs_file_read(&lfs, &file, buffer, sizeof(buffer)) => strlen("hello");
|
|
memcmp(buffer, "hello", strlen("hello")) => 0;
|
|
lfs_file_close(&lfs, &file);
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
|
|
echo "--- Set/get root attribute ---"
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
lfs_setattr(&lfs, "/", 'A', "aaaa", 4) => 0;
|
|
lfs_setattr(&lfs, "/", 'B', "bbbbbb", 6) => 0;
|
|
lfs_setattr(&lfs, "/", 'C', "ccccc", 5) => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => 6;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "bbbbbb", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "/", 'B', "", 0) => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => 0;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "\0\0\0\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_removeattr(&lfs, "/", 'B') => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => LFS_ERR_NOATTR;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "\0\0\0\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "/", 'B', "dddddd", 6) => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => 6;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "dddddd", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "/", 'B', "eee", 3) => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => 3;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "eee\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
lfs_setattr(&lfs, "/", 'A', buffer, LFS_ATTR_MAX+1) => LFS_ERR_NOSPC;
|
|
lfs_setattr(&lfs, "/", 'B', "fffffffff", 9) => 0;
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 6) => 9;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+10, 5) => 5;
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
lfs_getattr(&lfs, "/", 'A', buffer, 4) => 4;
|
|
lfs_getattr(&lfs, "/", 'B', buffer+4, 9) => 9;
|
|
lfs_getattr(&lfs, "/", 'C', buffer+13, 5) => 5;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "fffffffff", 9) => 0;
|
|
memcmp(buffer+13, "ccccc", 5) => 0;
|
|
|
|
lfs_file_open(&lfs, &file, "hello/hello", LFS_O_RDONLY) => 0;
|
|
lfs_file_read(&lfs, &file, buffer, sizeof(buffer)) => strlen("hello");
|
|
memcmp(buffer, "hello", strlen("hello")) => 0;
|
|
lfs_file_close(&lfs, &file);
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
|
|
echo "--- Set/get file attribute ---"
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
struct lfs_attr attrs1[] = {
|
|
{'A', buffer, 4},
|
|
{'B', buffer+4, 6},
|
|
{'C', buffer+10, 5},
|
|
};
|
|
struct lfs_file_config cfg1 = {.attrs=attrs1, .attr_count=3};
|
|
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1) => 0;
|
|
memcpy(buffer, "aaaa", 4);
|
|
memcpy(buffer+4, "bbbbbb", 6);
|
|
memcpy(buffer+10, "ccccc", 5);
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memset(buffer, 0, 15);
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "bbbbbb", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
attrs1[1].size = 0;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memset(buffer, 0, 15);
|
|
attrs1[1].size = 6;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "\0\0\0\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
attrs1[1].size = 6;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1) => 0;
|
|
memcpy(buffer+4, "dddddd", 6);
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memset(buffer, 0, 15);
|
|
attrs1[1].size = 6;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "dddddd", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
attrs1[1].size = 3;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1) => 0;
|
|
memcpy(buffer+4, "eee", 3);
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memset(buffer, 0, 15);
|
|
attrs1[1].size = 6;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "eee\0\0\0", 6) => 0;
|
|
memcmp(buffer+10, "ccccc", 5) => 0;
|
|
|
|
attrs1[0].size = LFS_ATTR_MAX+1;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1)
|
|
=> LFS_ERR_NOSPC;
|
|
|
|
struct lfs_attr attrs2[] = {
|
|
{'A', buffer, 4},
|
|
{'B', buffer+4, 9},
|
|
{'C', buffer+13, 5},
|
|
};
|
|
struct lfs_file_config cfg2 = {.attrs=attrs2, .attr_count=3};
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDWR, &cfg2) => 0;
|
|
memcpy(buffer+4, "fffffffff", 9);
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
attrs1[0].size = 4;
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg1) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
struct lfs_attr attrs2[] = {
|
|
{'A', buffer, 4},
|
|
{'B', buffer+4, 9},
|
|
{'C', buffer+13, 5},
|
|
};
|
|
struct lfs_file_config cfg2 = {.attrs=attrs2, .attr_count=3};
|
|
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_RDONLY, &cfg2) => 0;
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
memcmp(buffer, "aaaa", 4) => 0;
|
|
memcmp(buffer+4, "fffffffff", 9) => 0;
|
|
memcmp(buffer+13, "ccccc", 5) => 0;
|
|
|
|
lfs_file_open(&lfs, &file, "hello/hello", LFS_O_RDONLY) => 0;
|
|
lfs_file_read(&lfs, &file, buffer, sizeof(buffer)) => strlen("hello");
|
|
memcmp(buffer, "hello", strlen("hello")) => 0;
|
|
lfs_file_close(&lfs, &file);
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
|
|
echo "--- Deferred file attributes ---"
|
|
scripts/test.py << TEST
|
|
lfs_mount(&lfs, &cfg) => 0;
|
|
memset(buffer, 0, sizeof(buffer));
|
|
struct lfs_attr attrs1[] = {
|
|
{'B', "gggg", 4},
|
|
{'C', "", 0},
|
|
{'D', "hhhh", 4},
|
|
};
|
|
struct lfs_file_config cfg1 = {.attrs=attrs1, .attr_count=3};
|
|
|
|
lfs_file_opencfg(&lfs, &file, "hello/hello", LFS_O_WRONLY, &cfg1) => 0;
|
|
|
|
lfs_getattr(&lfs, "hello/hello", 'B', buffer, 9) => 9;
|
|
lfs_getattr(&lfs, "hello/hello", 'C', buffer+9, 9) => 5;
|
|
lfs_getattr(&lfs, "hello/hello", 'D', buffer+18, 9) => LFS_ERR_NOATTR;
|
|
memcmp(buffer, "fffffffff", 9) => 0;
|
|
memcmp(buffer+9, "ccccc\0\0\0\0", 9) => 0;
|
|
memcmp(buffer+18, "\0\0\0\0\0\0\0\0\0", 9) => 0;
|
|
|
|
lfs_file_sync(&lfs, &file) => 0;
|
|
lfs_getattr(&lfs, "hello/hello", 'B', buffer, 9) => 4;
|
|
lfs_getattr(&lfs, "hello/hello", 'C', buffer+9, 9) => 0;
|
|
lfs_getattr(&lfs, "hello/hello", 'D', buffer+18, 9) => 4;
|
|
memcmp(buffer, "gggg\0\0\0\0\0", 9) => 0;
|
|
memcmp(buffer+9, "\0\0\0\0\0\0\0\0\0", 9) => 0;
|
|
memcmp(buffer+18, "hhhh\0\0\0\0\0", 9) => 0;
|
|
|
|
lfs_file_close(&lfs, &file) => 0;
|
|
lfs_unmount(&lfs) => 0;
|
|
TEST
|
|
|
|
scripts/results.py
|