| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431 |
- #!/bin/bash
- set -eu
- export TEST_FILE=$0
- trap 'export TEST_LINE=$LINENO' DEBUG
- echo "=== Seek tests ==="
- SMALLSIZE=4
- MEDIUMSIZE=128
- LARGESIZE=132
- rm -rf blocks
- scripts/test.py << TEST
- lfs_format(&lfs, &cfg) => 0;
- lfs_mount(&lfs, &cfg) => 0;
- lfs_mkdir(&lfs, "hello") => 0;
- for (int i = 0; i < $LARGESIZE; i++) {
- sprintf(path, "hello/kitty%03d", i);
- lfs_file_open(&lfs, &file, path,
- LFS_O_WRONLY | LFS_O_CREAT | LFS_O_APPEND) => 0;
- lfs_size_t size = strlen("kittycatcat");
- memcpy(buffer, "kittycatcat", size);
- for (int j = 0; j < $LARGESIZE; j++) {
- lfs_file_write(&lfs, &file, buffer, size);
- }
- lfs_file_close(&lfs, &file) => 0;
- }
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Simple dir seek ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_dir_open(&lfs, &dir, "hello") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, ".") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, "..") => 0;
- lfs_soff_t pos;
- int i;
- for (i = 0; i < $SMALLSIZE; i++) {
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- pos = lfs_dir_tell(&lfs, &dir);
- }
- pos >= 0 => 1;
- lfs_dir_seek(&lfs, &dir, pos) => 0;
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_rewind(&lfs, &dir) => 0;
- sprintf(path, "kitty%03d", 0);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, ".") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, "..") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_seek(&lfs, &dir, pos) => 0;
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_close(&lfs, &dir) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Large dir seek ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_dir_open(&lfs, &dir, "hello") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, ".") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, "..") => 0;
- lfs_soff_t pos;
- int i;
- for (i = 0; i < $MEDIUMSIZE; i++) {
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- pos = lfs_dir_tell(&lfs, &dir);
- }
- pos >= 0 => 1;
- lfs_dir_seek(&lfs, &dir, pos) => 0;
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_rewind(&lfs, &dir) => 0;
- sprintf(path, "kitty%03d", 0);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, ".") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, "..") => 0;
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_seek(&lfs, &dir, pos) => 0;
- sprintf(path, "kitty%03d", i);
- lfs_dir_read(&lfs, &dir, &info) => 1;
- strcmp(info.name, path) => 0;
- lfs_dir_close(&lfs, &dir) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Simple file seek ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDONLY) => 0;
- lfs_soff_t pos;
- lfs_size_t size = strlen("kittycatcat");
- for (int i = 0; i < $SMALLSIZE; i++) {
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- pos = lfs_file_tell(&lfs, &file);
- }
- pos >= 0 => 1;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_rewind(&lfs, &file) => 0;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, size, LFS_SEEK_CUR) => 3*size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_CUR) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_END) >= 0 => 1;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- size = lfs_file_size(&lfs, &file);
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Large file seek ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDONLY) => 0;
- lfs_soff_t pos;
- lfs_size_t size = strlen("kittycatcat");
- for (int i = 0; i < $MEDIUMSIZE; i++) {
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- pos = lfs_file_tell(&lfs, &file);
- }
- pos >= 0 => 1;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_rewind(&lfs, &file) => 0;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, size, LFS_SEEK_CUR) => 3*size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_CUR) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_END) >= 0 => 1;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- size = lfs_file_size(&lfs, &file);
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Simple file seek and write ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDWR) => 0;
- lfs_soff_t pos;
- lfs_size_t size = strlen("kittycatcat");
- for (int i = 0; i < $SMALLSIZE; i++) {
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- pos = lfs_file_tell(&lfs, &file);
- }
- pos >= 0 => 1;
- memcpy(buffer, "doggodogdog", size);
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_write(&lfs, &file, buffer, size) => size;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "doggodogdog", size) => 0;
- lfs_file_rewind(&lfs, &file) => 0;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "doggodogdog", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_END) >= 0 => 1;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- size = lfs_file_size(&lfs, &file);
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Large file seek and write ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDWR) => 0;
- lfs_soff_t pos;
- lfs_size_t size = strlen("kittycatcat");
- for (int i = 0; i < $MEDIUMSIZE; i++) {
- lfs_file_read(&lfs, &file, buffer, size) => size;
- if (i != $SMALLSIZE) {
- memcmp(buffer, "kittycatcat", size) => 0;
- }
- pos = lfs_file_tell(&lfs, &file);
- }
- pos >= 0 => 1;
- memcpy(buffer, "doggodogdog", size);
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_write(&lfs, &file, buffer, size) => size;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "doggodogdog", size) => 0;
- lfs_file_rewind(&lfs, &file) => 0;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_seek(&lfs, &file, pos, LFS_SEEK_SET) => pos;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "doggodogdog", size) => 0;
- lfs_file_seek(&lfs, &file, -size, LFS_SEEK_END) >= 0 => 1;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- size = lfs_file_size(&lfs, &file);
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_CUR) => size;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Boundary seek and write ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDWR) => 0;
- lfs_size_t size = strlen("hedgehoghog");
- const lfs_soff_t offsets[] = {512, 1020, 513, 1021, 511, 1019};
- for (unsigned i = 0; i < sizeof(offsets) / sizeof(offsets[0]); i++) {
- lfs_soff_t off = offsets[i];
- memcpy(buffer, "hedgehoghog", size);
- lfs_file_seek(&lfs, &file, off, LFS_SEEK_SET) => off;
- lfs_file_write(&lfs, &file, buffer, size) => size;
- lfs_file_seek(&lfs, &file, off, LFS_SEEK_SET) => off;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "hedgehoghog", size) => 0;
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_SET) => 0;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "kittycatcat", size) => 0;
- lfs_file_sync(&lfs, &file) => 0;
- }
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Out-of-bounds seek ---"
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/kitty042", LFS_O_RDWR) => 0;
- lfs_size_t size = strlen("kittycatcat");
- lfs_file_size(&lfs, &file) => $LARGESIZE*size;
- lfs_file_seek(&lfs, &file, ($LARGESIZE+$SMALLSIZE)*size,
- LFS_SEEK_SET) => ($LARGESIZE+$SMALLSIZE)*size;
- lfs_file_read(&lfs, &file, buffer, size) => 0;
- memcpy(buffer, "porcupineee", size);
- lfs_file_write(&lfs, &file, buffer, size) => size;
- lfs_file_seek(&lfs, &file, ($LARGESIZE+$SMALLSIZE)*size,
- LFS_SEEK_SET) => ($LARGESIZE+$SMALLSIZE)*size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "porcupineee", size) => 0;
- lfs_file_seek(&lfs, &file, $LARGESIZE*size,
- LFS_SEEK_SET) => $LARGESIZE*size;
- lfs_file_read(&lfs, &file, buffer, size) => size;
- memcmp(buffer, "\0\0\0\0\0\0\0\0\0\0\0", size) => 0;
- lfs_file_seek(&lfs, &file, -(($LARGESIZE+$SMALLSIZE)*size),
- LFS_SEEK_CUR) => LFS_ERR_INVAL;
- lfs_file_tell(&lfs, &file) => ($LARGESIZE+1)*size;
- lfs_file_seek(&lfs, &file, -(($LARGESIZE+2*$SMALLSIZE)*size),
- LFS_SEEK_END) => LFS_ERR_INVAL;
- lfs_file_tell(&lfs, &file) => ($LARGESIZE+1)*size;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- echo "--- Inline write and seek ---"
- for SIZE in $SMALLSIZE $MEDIUMSIZE $LARGESIZE
- do
- scripts/test.py << TEST
- lfs_mount(&lfs, &cfg) => 0;
- lfs_file_open(&lfs, &file, "hello/tinykitty$SIZE",
- LFS_O_RDWR | LFS_O_CREAT) => 0;
- int j = 0;
- int k = 0;
- memcpy(buffer, "abcdefghijklmnopqrstuvwxyz", 26);
- for (unsigned i = 0; i < $SIZE; i++) {
- lfs_file_write(&lfs, &file, &buffer[j++ % 26], 1) => 1;
- lfs_file_tell(&lfs, &file) => i+1;
- lfs_file_size(&lfs, &file) => i+1;
- }
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_SET) => 0;
- lfs_file_tell(&lfs, &file) => 0;
- lfs_file_size(&lfs, &file) => $SIZE;
- for (unsigned i = 0; i < $SIZE; i++) {
- uint8_t c;
- lfs_file_read(&lfs, &file, &c, 1) => 1;
- c => buffer[k++ % 26];
- }
- lfs_file_sync(&lfs, &file) => 0;
- lfs_file_tell(&lfs, &file) => $SIZE;
- lfs_file_size(&lfs, &file) => $SIZE;
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_SET) => 0;
- for (unsigned i = 0; i < $SIZE; i++) {
- lfs_file_write(&lfs, &file, &buffer[j++ % 26], 1) => 1;
- lfs_file_tell(&lfs, &file) => i+1;
- lfs_file_size(&lfs, &file) => $SIZE;
- lfs_file_sync(&lfs, &file) => 0;
- lfs_file_tell(&lfs, &file) => i+1;
- lfs_file_size(&lfs, &file) => $SIZE;
- if (i < $SIZE-2) {
- uint8_t c[3];
- lfs_file_seek(&lfs, &file, -1, LFS_SEEK_CUR) => i;
- lfs_file_read(&lfs, &file, &c, 3) => 3;
- lfs_file_tell(&lfs, &file) => i+3;
- lfs_file_size(&lfs, &file) => $SIZE;
- lfs_file_seek(&lfs, &file, i+1, LFS_SEEK_SET) => i+1;
- lfs_file_tell(&lfs, &file) => i+1;
- lfs_file_size(&lfs, &file) => $SIZE;
- }
- }
- lfs_file_seek(&lfs, &file, 0, LFS_SEEK_SET) => 0;
- lfs_file_tell(&lfs, &file) => 0;
- lfs_file_size(&lfs, &file) => $SIZE;
- for (unsigned i = 0; i < $SIZE; i++) {
- uint8_t c;
- lfs_file_read(&lfs, &file, &c, 1) => 1;
- c => buffer[k++ % 26];
- }
- lfs_file_sync(&lfs, &file) => 0;
- lfs_file_tell(&lfs, &file) => $SIZE;
- lfs_file_size(&lfs, &file) => $SIZE;
- lfs_file_close(&lfs, &file) => 0;
- lfs_unmount(&lfs) => 0;
- TEST
- done
- scripts/results.py
|