diff options
author | Simon Glass <sjg@chromium.org> | 2023-03-28 08:34:14 +1300 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2023-03-28 09:25:51 -0400 |
commit | be0169f07e38b81dd96bca2e80610592d89f8550 (patch) | |
tree | 09e08eefd123e358b5012df3dd88f233547b64d8 /test/common/cread.c | |
parent | 17b45e684af98c1cf37648ad05a98d500b367c5a (diff) | |
download | u-boot-be0169f07e38b81dd96bca2e80610592d89f8550.tar.gz u-boot-be0169f07e38b81dd96bca2e80610592d89f8550.tar.bz2 u-boot-be0169f07e38b81dd96bca2e80610592d89f8550.zip |
cli: Correct handling of invalid escape sequences in cread_line()
The second call to cli_ch_process() is in the wrong place, meaning that
the one of the characters of an invalid escape sequence is swallowed
instead of being returned.
Fix the bug and add a test to cover this.
This behaviour matches that of the code before cli_getch() was
introduced. This was verified on the commit before b08e9d4b66 i.e.:
7d850f85aad ("sandbox: Enable mmc command and legacy images")
Signed-off-by: Simon Glass <sjg@chromium.org>
Reported-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Diffstat (limited to 'test/common/cread.c')
-rw-r--r-- | test/common/cread.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/test/common/cread.c b/test/common/cread.c index 3dce4bdb0e..2fdd29a265 100644 --- a/test/common/cread.c +++ b/test/common/cread.c @@ -46,3 +46,48 @@ static int cli_ch_test(struct unit_test_state *uts) return 0; } COMMON_TEST(cli_ch_test, 0); + +static int cread_test(struct unit_test_state *uts) +{ + int duration; + ulong start; + char buf[10]; + + /* + * useful for debugging + * + * gd->flags &= ~GD_FLG_RECORD; + * print_buffer(0, buf, 1, 7, 0); + */ + + console_record_reset_enable(); + + /* simple input */ + *buf = '\0'; + ut_asserteq(4, console_in_puts("abc\n")); + ut_asserteq(3, cli_readline_into_buffer("-> ", buf, 1)); + ut_asserteq_str("abc", buf); + + /* try an escape sequence (cursor left after the 'c') */ + *buf = '\0'; + ut_asserteq(8, console_in_puts("abc\e[Dx\n")); + ut_asserteq(4, cli_readline_into_buffer("-> ", buf, 1)); + ut_asserteq_str("abxc", buf); + + /* invalid escape sequence */ + *buf = '\0'; + ut_asserteq(8, console_in_puts("abc\e[Xx\n")); + ut_asserteq(7, cli_readline_into_buffer("-> ", buf, 1)); + ut_asserteq_str("abc\e[Xx", buf); + + /* check timeout, should be between 1000 and 1050ms */ + start = get_timer(0); + *buf = '\0'; + ut_asserteq(-2, cli_readline_into_buffer("-> ", buf, 1)); + duration = get_timer(start) - 1000; + ut_assert(duration >= 0); + ut_assert(duration < 50); + + return 0; +} +COMMON_TEST(cread_test, 0); |