mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-16 09:54:35 +00:00
test: Update command test to use unit-test functions
Rather than enabled DEBUG and using assert(), use the unit-test functions now provided. Drop a check that causes pytest to fail. Signed-off-by: Simon Glass <sjg@chromium.org> Tested-by: Tom Rini <trini@konsulko.com> # rpi_3, rpi_4, rpi_arm64, am64x_evm_a53, am64-sk
This commit is contained in:
parent
c25b35b6c6
commit
ee3c8698e0
1 changed files with 32 additions and 31 deletions
|
@ -26,16 +26,16 @@ static int command_test(struct unit_test_state *uts)
|
||||||
|
|
||||||
/* commands separated by \n */
|
/* commands separated by \n */
|
||||||
run_command_list("setenv list 1\n setenv list ${list}1", -1, 0);
|
run_command_list("setenv list 1\n setenv list ${list}1", -1, 0);
|
||||||
assert(!strcmp("11", env_get("list")));
|
ut_assert(!strcmp("11", env_get("list")));
|
||||||
|
|
||||||
/* command followed by \n and nothing else */
|
/* command followed by \n and nothing else */
|
||||||
run_command_list("setenv list 1${list}\n", -1, 0);
|
run_command_list("setenv list 1${list}\n", -1, 0);
|
||||||
assert(!strcmp("111", env_get("list")));
|
ut_assert(!strcmp("111", env_get("list")));
|
||||||
|
|
||||||
/* a command string with \0 in it. Stuff after \0 should be ignored */
|
/* a command string with \0 in it. Stuff after \0 should be ignored */
|
||||||
run_command("setenv list", 0);
|
run_command("setenv list", 0);
|
||||||
run_command_list(test_cmd, sizeof(test_cmd), 0);
|
run_command_list(test_cmd, sizeof(test_cmd), 0);
|
||||||
assert(!strcmp("123", env_get("list")));
|
ut_assert(!strcmp("123", env_get("list")));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* a command list where we limit execution to only the first command
|
* a command list where we limit execution to only the first command
|
||||||
|
@ -43,60 +43,61 @@ static int command_test(struct unit_test_state *uts)
|
||||||
*/
|
*/
|
||||||
run_command_list("setenv list 1\n setenv list ${list}2; "
|
run_command_list("setenv list 1\n setenv list ${list}2; "
|
||||||
"setenv list ${list}3", strlen("setenv list 1"), 0);
|
"setenv list ${list}3", strlen("setenv list 1"), 0);
|
||||||
assert(!strcmp("1", env_get("list")));
|
ut_assert(!strcmp("1", env_get("list")));
|
||||||
|
|
||||||
assert(run_command("false", 0) == 1);
|
ut_asserteq(1, run_command("false", 0));
|
||||||
assert(run_command("echo", 0) == 0);
|
ut_assertok(run_command("echo", 0));
|
||||||
assert(run_command_list("false", -1, 0) == 1);
|
ut_asserteq(1, run_command_list("false", -1, 0));
|
||||||
assert(run_command_list("echo", -1, 0) == 0);
|
ut_assertok(run_command_list("echo", -1, 0));
|
||||||
|
|
||||||
#ifdef CONFIG_HUSH_PARSER
|
#ifdef CONFIG_HUSH_PARSER
|
||||||
run_command("setenv foo 'setenv black 1\nsetenv adder 2'", 0);
|
run_command("setenv foo 'setenv black 1\nsetenv adder 2'", 0);
|
||||||
run_command("run foo", 0);
|
run_command("run foo", 0);
|
||||||
assert(env_get("black") != NULL);
|
ut_assertnonnull(env_get("black"));
|
||||||
assert(!strcmp("1", env_get("black")));
|
ut_asserteq(0, strcmp("1", env_get("black")));
|
||||||
assert(env_get("adder") != NULL);
|
ut_assertnonnull(env_get("adder"));
|
||||||
assert(!strcmp("2", env_get("adder")));
|
ut_asserteq(0, strcmp("2", env_get("adder")));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
assert(run_command("", 0) == 0);
|
ut_assertok(run_command("", 0));
|
||||||
assert(run_command(" ", 0) == 0);
|
ut_assertok(run_command(" ", 0));
|
||||||
|
|
||||||
assert(run_command("'", 0) == 1);
|
ut_asserteq(1, run_command("'", 0));
|
||||||
|
|
||||||
/* Variadic function test-cases */
|
/* Variadic function test-cases */
|
||||||
#pragma GCC diagnostic push
|
#pragma GCC diagnostic push
|
||||||
#pragma GCC diagnostic ignored "-Wformat-zero-length"
|
#pragma GCC diagnostic ignored "-Wformat-zero-length"
|
||||||
assert(run_commandf("") == 0);
|
ut_assertok(run_commandf(""));
|
||||||
#pragma GCC diagnostic pop
|
#pragma GCC diagnostic pop
|
||||||
assert(run_commandf(" ") == 0);
|
ut_assertok(run_commandf(" "));
|
||||||
assert(run_commandf("'") == 1);
|
ut_asserteq(1, run_commandf("'"));
|
||||||
|
|
||||||
assert(run_commandf("env %s %s", "delete -f", "list") == 0);
|
ut_assertok(run_commandf("env %s %s", "delete -f", "list"));
|
||||||
/*
|
/*
|
||||||
* Expected: "## Error: "list" not defined"
|
* Expected: "## Error: "list" not defined"
|
||||||
* (disabled to avoid pytest bailing out)
|
* (disabled to avoid pytest bailing out)
|
||||||
*
|
*
|
||||||
* assert(run_commandf("printenv list") == 1);
|
* ut_asserteq(1, run_commandf("printenv list"));
|
||||||
*/
|
*/
|
||||||
|
|
||||||
memset(long_str, 'x', sizeof(long_str));
|
memset(long_str, 'x', sizeof(long_str));
|
||||||
assert(run_commandf("Truncation case: %s", long_str) == -ENOSPC);
|
ut_asserteq(-ENOSPC, run_commandf("Truncation case: %s", long_str));
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_HUSH_PARSER)) {
|
if (IS_ENABLED(CONFIG_HUSH_PARSER)) {
|
||||||
assert(run_commandf("env %s %s %s %s", "delete -f", "adder",
|
ut_assertok(run_commandf("env %s %s %s %s", "delete -f",
|
||||||
"black", "foo") == 0);
|
"adder", "black", "foo"));
|
||||||
assert(run_commandf("setenv foo 'setenv %s 1\nsetenv %s 2'",
|
ut_assertok(run_commandf(
|
||||||
"black", "adder") == 0);
|
"setenv foo 'setenv %s 1\nsetenv %s 2'",
|
||||||
run_command("run foo", 0);
|
"black", "adder"));
|
||||||
assert(env_get("black"));
|
ut_assertok(run_command("run foo", 0));
|
||||||
assert(!strcmp("1", env_get("black")));
|
ut_assertnonnull(env_get("black"));
|
||||||
assert(env_get("adder"));
|
ut_asserteq(0, strcmp("1", env_get("black")));
|
||||||
assert(!strcmp("2", env_get("adder")));
|
ut_assertnonnull(env_get("adder"));
|
||||||
|
ut_asserteq(0, strcmp("2", env_get("adder")));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Clean up before exit */
|
/* Clean up before exit */
|
||||||
run_command("env default -f -a", 0);
|
ut_assertok(run_command("env default -f -a", 0));
|
||||||
|
|
||||||
/* put back the FDT environment */
|
/* put back the FDT environment */
|
||||||
ut_assertok(env_set("from_fdt", "yes"));
|
ut_assertok(env_set("from_fdt", "yes"));
|
||||||
|
|
Loading…
Add table
Reference in a new issue