mirror of
				https://github.com/eledio-devices/thirdparty-littlefs.git
				synced 2025-10-31 08:42:40 +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.
		
	
		
			
				
	
	
		
			163 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| set -eu
 | |
| export TEST_FILE=$0
 | |
| trap 'export TEST_LINE=$LINENO' DEBUG
 | |
| 
 | |
| echo "=== File tests ==="
 | |
| 
 | |
| SMALLSIZE=32
 | |
| MEDIUMSIZE=8192
 | |
| LARGESIZE=262144
 | |
| 
 | |
| rm -rf blocks
 | |
| scripts/test.py << TEST
 | |
|     lfs_format(&lfs, &cfg) => 0;
 | |
| TEST
 | |
| 
 | |
| echo "--- Simple file test ---"
 | |
| scripts/test.py << TEST
 | |
|     lfs_mount(&lfs, &cfg) => 0;
 | |
|     lfs_file_open(&lfs, &file, "hello", LFS_O_WRONLY | LFS_O_CREAT) => 0;
 | |
|     lfs_size_t size = strlen("Hello World!\n");
 | |
|     uint8_t wbuffer[1024];
 | |
|     memcpy(wbuffer, "Hello World!\n", size);
 | |
|     lfs_file_write(&lfs, &file, wbuffer, size) => size;
 | |
|     lfs_file_close(&lfs, &file) => 0;
 | |
| 
 | |
|     lfs_file_open(&lfs, &file, "hello", LFS_O_RDONLY) => 0;
 | |
|     size = strlen("Hello World!\n");
 | |
|     uint8_t rbuffer[1024];
 | |
|     lfs_file_read(&lfs, &file, rbuffer, size) => size;
 | |
|     memcmp(rbuffer, wbuffer, size) => 0;
 | |
|     lfs_file_close(&lfs, &file) => 0;
 | |
|     lfs_unmount(&lfs) => 0;
 | |
| TEST
 | |
| 
 | |
| w_test() {
 | |
| scripts/test.py ${4:-} << TEST
 | |
|     lfs_size_t size = $1;
 | |
|     lfs_size_t chunk = 31;
 | |
|     srand(0);
 | |
|     lfs_mount(&lfs, &cfg) => 0;
 | |
|     lfs_file_open(&lfs, &file, "$2",
 | |
|         ${3:-LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC}) => 0;
 | |
|     for (lfs_size_t i = 0; i < size; i += chunk) {
 | |
|         chunk = (chunk < size - i) ? chunk : size - i;
 | |
|         for (lfs_size_t b = 0; b < chunk; b++) {
 | |
|             buffer[b] = rand() & 0xff;
 | |
|         }
 | |
|         lfs_file_write(&lfs, &file, buffer, chunk) => chunk;
 | |
|     }
 | |
|     lfs_file_close(&lfs, &file) => 0;
 | |
|     lfs_unmount(&lfs) => 0;
 | |
| TEST
 | |
| }
 | |
| 
 | |
| r_test() {
 | |
| scripts/test.py << TEST
 | |
|     lfs_size_t size = $1;
 | |
|     lfs_size_t chunk = 29;
 | |
|     srand(0);
 | |
|     lfs_mount(&lfs, &cfg) => 0;
 | |
|     lfs_stat(&lfs, "$2", &info) => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => size;
 | |
|     lfs_file_open(&lfs, &file, "$2", ${3:-LFS_O_RDONLY}) => 0;
 | |
|     for (lfs_size_t i = 0; i < size; i += chunk) {
 | |
|         chunk = (chunk < size - i) ? chunk : size - i;
 | |
|         lfs_file_read(&lfs, &file, buffer, chunk) => chunk;
 | |
|         for (lfs_size_t b = 0; b < chunk && i+b < size; b++) {
 | |
|             buffer[b] => rand() & 0xff;
 | |
|         }
 | |
|     }
 | |
|     lfs_file_close(&lfs, &file) => 0;
 | |
|     lfs_unmount(&lfs) => 0;
 | |
| TEST
 | |
| }
 | |
| 
 | |
| echo "--- Small file test ---"
 | |
| w_test $SMALLSIZE smallavacado
 | |
| r_test $SMALLSIZE smallavacado
 | |
| 
 | |
| echo "--- Medium file test ---"
 | |
| w_test $MEDIUMSIZE mediumavacado
 | |
| r_test $MEDIUMSIZE mediumavacado
 | |
| 
 | |
| echo "--- Large file test ---"
 | |
| w_test $LARGESIZE largeavacado
 | |
| r_test $LARGESIZE largeavacado
 | |
| 
 | |
| echo "--- Zero file test ---"
 | |
| w_test 0 noavacado
 | |
| r_test 0 noavacado
 | |
| 
 | |
| echo "--- Truncate small test ---"
 | |
| w_test $SMALLSIZE mediumavacado
 | |
| r_test $SMALLSIZE mediumavacado
 | |
| w_test $MEDIUMSIZE mediumavacado
 | |
| r_test $MEDIUMSIZE mediumavacado
 | |
| 
 | |
| echo "--- Truncate zero test ---"
 | |
| w_test $SMALLSIZE noavacado
 | |
| r_test $SMALLSIZE noavacado
 | |
| w_test 0 noavacado
 | |
| r_test 0 noavacado
 | |
| 
 | |
| echo "--- Non-overlap check ---"
 | |
| r_test $SMALLSIZE smallavacado
 | |
| r_test $MEDIUMSIZE mediumavacado
 | |
| r_test $LARGESIZE largeavacado
 | |
| r_test 0 noavacado
 | |
| 
 | |
| echo "--- Dir check ---"
 | |
| scripts/test.py << TEST
 | |
|     lfs_mount(&lfs, &cfg) => 0;
 | |
|     lfs_dir_open(&lfs, &dir, "/") => 0;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     strcmp(info.name, "hello") => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => strlen("Hello World!\n");
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     strcmp(info.name, "largeavacado") => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => $LARGESIZE;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     strcmp(info.name, "mediumavacado") => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => $MEDIUMSIZE;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     strcmp(info.name, "noavacado") => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => 0;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 1;
 | |
|     strcmp(info.name, "smallavacado") => 0;
 | |
|     info.type => LFS_TYPE_REG;
 | |
|     info.size => $SMALLSIZE;
 | |
|     lfs_dir_read(&lfs, &dir, &info) => 0;
 | |
|     lfs_dir_close(&lfs, &dir) => 0;
 | |
|     lfs_unmount(&lfs) => 0;
 | |
| TEST
 | |
| 
 | |
| echo "--- Many file test ---"
 | |
| scripts/test.py << TEST
 | |
|     lfs_format(&lfs, &cfg) => 0;
 | |
| TEST
 | |
| scripts/test.py << TEST
 | |
|     // Create 300 files of 6 bytes
 | |
|     lfs_mount(&lfs, &cfg) => 0;
 | |
|     lfs_mkdir(&lfs, "directory") => 0;
 | |
|     for (unsigned i = 0; i < 300; i++) {
 | |
|         sprintf(path, "file_%03d", i);
 | |
|         lfs_file_open(&lfs, &file, path, LFS_O_WRONLY | LFS_O_CREAT) => 0;
 | |
|         lfs_size_t size = 6;
 | |
|         memcpy(buffer, "Hello", size);
 | |
|         lfs_file_write(&lfs, &file, buffer, size) => size;
 | |
|         lfs_file_close(&lfs, &file) => 0;
 | |
|     }
 | |
|     lfs_unmount(&lfs) => 0;
 | |
| TEST
 | |
| 
 | |
| scripts/results.py
 |