Moved spiff test to a test case. Reset retries in test runner
This commit is contained in:
parent
ddf834c781
commit
78d95431f5
8 changed files with 43 additions and 56 deletions
6
.gitmodules
vendored
6
.gitmodules
vendored
|
@ -13,9 +13,9 @@
|
||||||
[submodule "extras/spiffs/spiffs"]
|
[submodule "extras/spiffs/spiffs"]
|
||||||
path = extras/spiffs/spiffs
|
path = extras/spiffs/spiffs
|
||||||
url = https://github.com/pellepl/spiffs.git
|
url = https://github.com/pellepl/spiffs.git
|
||||||
[submodule "examples/posix_fs/fs-test"]
|
|
||||||
path = examples/posix_fs/fs-test
|
|
||||||
url = https://github.com/sheinz/fs-test
|
|
||||||
[submodule "tests/unity"]
|
[submodule "tests/unity"]
|
||||||
path = tests/unity
|
path = tests/unity
|
||||||
url = https://github.com/ThrowTheSwitch/Unity.git
|
url = https://github.com/ThrowTheSwitch/Unity.git
|
||||||
|
[submodule "tests/fs-test"]
|
||||||
|
path = tests/fs-test
|
||||||
|
url = https://github.com/sheinz/fs-test
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
PROGRAM=posix_fs_example
|
|
||||||
PROGRAM_EXTRA_SRC_FILES=./fs-test/fs_test.c
|
|
||||||
|
|
||||||
EXTRA_COMPONENTS = extras/spiffs
|
|
||||||
FLASH_SIZE = 32
|
|
||||||
|
|
||||||
# spiffs configuration
|
|
||||||
SPIFFS_BASE_ADDR = 0x200000
|
|
||||||
SPIFFS_SIZE = 0x100000
|
|
||||||
|
|
||||||
include ../../common.mk
|
|
|
@ -1,10 +0,0 @@
|
||||||
# POSIX file access example
|
|
||||||
|
|
||||||
This example runs several file system tests on ESP8266.
|
|
||||||
It uses fs-test library to perform file operations test. fs-test library uses
|
|
||||||
only POSIX file functions so can be run on host system as well.
|
|
||||||
|
|
||||||
Currently included tests:
|
|
||||||
* File system load test. Perform multiple file operations in random order.
|
|
||||||
* File system speed test. Measures files read/write speed.
|
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
Subproject commit 2ad547adc5f725594b3c6752f036ff4401b221fc
|
|
|
@ -1,12 +1,18 @@
|
||||||
PROGRAM=tests
|
PROGRAM=tests
|
||||||
|
|
||||||
EXTRA_COMPONENTS=extras/dhcpserver
|
EXTRA_COMPONENTS=extras/dhcpserver extras/spiffs
|
||||||
|
|
||||||
PROGRAM_SRC_DIR = . ./cases
|
PROGRAM_SRC_DIR = . ./cases
|
||||||
|
|
||||||
|
FLASH_SIZE = 32
|
||||||
|
|
||||||
|
# spiffs configuration
|
||||||
|
SPIFFS_BASE_ADDR = 0x200000
|
||||||
|
SPIFFS_SIZE = 0x100000
|
||||||
|
|
||||||
# Add unity test framework headers & core source file
|
# Add unity test framework headers & core source file
|
||||||
PROGRAM_INC_DIR = ./unity/src
|
PROGRAM_INC_DIR = ./unity/src ./fs-test
|
||||||
PROGRAM_EXTRA_SRC_FILES = ./unity/src/unity.c
|
PROGRAM_EXTRA_SRC_FILES = ./unity/src/unity.c ./fs-test/fs_test.c
|
||||||
|
|
||||||
TESTCASE_SRC_FILES = $(wildcard $(PROGRAM_DIR)cases/*.c)
|
TESTCASE_SRC_FILES = $(wildcard $(PROGRAM_DIR)cases/*.c)
|
||||||
|
|
||||||
|
|
|
@ -9,14 +9,18 @@
|
||||||
#include "esp_spiffs.h"
|
#include "esp_spiffs.h"
|
||||||
#include "spiffs.h"
|
#include "spiffs.h"
|
||||||
|
|
||||||
#include "fs-test/fs_test.h"
|
#include "fs_test.h"
|
||||||
|
|
||||||
|
#include "testcase.h"
|
||||||
|
|
||||||
|
DEFINE_SOLO_TESTCASE(05_spiffs)
|
||||||
|
|
||||||
static fs_time_t get_current_time()
|
static fs_time_t get_current_time()
|
||||||
{
|
{
|
||||||
return timer_get_count(FRC2) / 5000; // to get roughly 1ms resolution
|
return timer_get_count(FRC2) / 5000; // to get roughly 1ms resolution
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_task(void *pvParameters)
|
static void test_task(void *pvParameters)
|
||||||
{
|
{
|
||||||
esp_spiffs_init();
|
esp_spiffs_init();
|
||||||
esp_spiffs_mount();
|
esp_spiffs_mount();
|
||||||
|
@ -28,28 +32,19 @@ void test_task(void *pvParameters)
|
||||||
}
|
}
|
||||||
esp_spiffs_mount();
|
esp_spiffs_mount();
|
||||||
|
|
||||||
while (1) {
|
TEST_ASSERT_TRUE_MESSAGE(fs_load_test_run(100), "Load test failed");
|
||||||
vTaskDelay(5000 / portTICK_RATE_MS);
|
|
||||||
if (fs_load_test_run(100)) {
|
|
||||||
printf("PASS\n");
|
|
||||||
} else {
|
|
||||||
printf("FAIL\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
vTaskDelay(5000 / portTICK_RATE_MS);
|
|
||||||
float write_rate, read_rate;
|
float write_rate, read_rate;
|
||||||
if (fs_speed_test_run(get_current_time, &write_rate, &read_rate)) {
|
if (fs_speed_test_run(get_current_time, &write_rate, &read_rate)) {
|
||||||
printf("Read speed: %.0f bytes/s\n", read_rate * 1000);
|
printf("Read speed: %.0f bytes/s\n", read_rate * 1000);
|
||||||
printf("Write speed: %.0f bytes/s\n", write_rate * 1000);
|
printf("Write speed: %.0f bytes/s\n", write_rate * 1000);
|
||||||
} else {
|
} else {
|
||||||
printf("FAIL\n");
|
TEST_FAIL();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
TEST_PASS();
|
||||||
}
|
}
|
||||||
|
|
||||||
void user_init(void)
|
static void a_05_spiffs(void)
|
||||||
{
|
{
|
||||||
uart_set_baud(0, 115200);
|
|
||||||
|
|
||||||
xTaskCreate(test_task, (signed char *)"test_task", 1024, NULL, 2, NULL);
|
xTaskCreate(test_task, (signed char *)"test_task", 1024, NULL, 2, NULL);
|
||||||
}
|
}
|
1
tests/fs-test
Submodule
1
tests/fs-test
Submodule
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit e531bc0d4f75887e5f0e081aae3efbf4a50e2f54
|
|
@ -10,8 +10,9 @@ import time
|
||||||
|
|
||||||
|
|
||||||
SHORT_OUTPUT_TIMEOUT = 0.25 # timeout for resetting and/or waiting for more lines of output
|
SHORT_OUTPUT_TIMEOUT = 0.25 # timeout for resetting and/or waiting for more lines of output
|
||||||
TESTCASE_TIMEOUT = 30
|
TESTCASE_TIMEOUT = 60
|
||||||
TESTRUNNER_BANNER = "esp-open-rtos test runner."
|
TESTRUNNER_BANNER = "esp-open-rtos test runner."
|
||||||
|
RESET_RETRIES = 10 # retries to receive test runner banner after reset
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
@ -213,13 +214,19 @@ class TestEnvironment(object):
|
||||||
|
|
||||||
def reset(self):
|
def reset(self):
|
||||||
""" Resets the test board, and waits for the test runner program to start up """
|
""" Resets the test board, and waits for the test runner program to start up """
|
||||||
|
for i in range(RESET_RETRIES):
|
||||||
self._port.setDTR(False)
|
self._port.setDTR(False)
|
||||||
self._port.setRTS(True)
|
self._port.setRTS(True)
|
||||||
time.sleep(0.05)
|
time.sleep(0.05)
|
||||||
self._port.flushInput()
|
self._port.flushInput()
|
||||||
self._port.setRTS(False)
|
self._port.setRTS(False)
|
||||||
verbose_print("Waiting for test runner startup...")
|
verbose_print("Waiting for test runner startup...")
|
||||||
if not self._port.wait_line(lambda line: line == TESTRUNNER_BANNER):
|
if self._port.wait_line(lambda line: line == TESTRUNNER_BANNER):
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
verbose_print("Retrying to reset the test board, attempt=%d" %
|
||||||
|
(i + 1))
|
||||||
|
continue
|
||||||
raise TestRunnerError("Port %s failed to start test runner" % self._port)
|
raise TestRunnerError("Port %s failed to start test runner" % self._port)
|
||||||
|
|
||||||
def get_testlist(self):
|
def get_testlist(self):
|
||||||
|
|
Loading…
Reference in a new issue