env: Allow text-env tests to run with awk

At present the tests assume that gawk is being used. Adjust the tests so
that the names are inserted in alphabetical order, so that awk is happy.

Also use PROCINFO to make gawk output in alphabetical order. This is not
ideal, since it changes the env-car ordering from what the user provided,
but it may be acceptable.

Signed-off-by: Simon Glass <sjg@chromium.org>
Reported-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
Fixes: https://source.denx.de/u-boot/u-boot/-/issues/10
This commit is contained in:
Simon Glass 2022-03-12 22:47:49 -07:00 committed by Tom Rini
parent 754a722d1b
commit 6910dbe341
2 changed files with 18 additions and 15 deletions

View File

@ -81,7 +81,10 @@ END {
if (do_output) {
printf("%s", "#define CONFIG_EXTRA_ENV_TEXT \"")
# Print out all the variables
# Print out all the variables by alphabetic order, if using
# gawk. This allows test_env_test.py to work on both awk (where
# this next line does nothing)
PROCINFO["sorted_in"] = "@ind_str_asc"
for (var in vars) {
env = vars[var]
print var "=" vars[var] "\\0"

View File

@ -554,42 +554,42 @@ def test_env_text(u_boot_console):
# two vars
check_script('''fred=123
ernie=456''', 'fred=123\\0ernie=456\\0')
mary=456''', 'fred=123\\0mary=456\\0')
# blank lines
check_script('''fred=123
ernie=456
mary=456
''', 'fred=123\\0ernie=456\\0')
''', 'fred=123\\0mary=456\\0')
# append
check_script('''fred=123
ernie=456
fred+= 456''', 'fred=123 456\\0ernie=456\\0')
mary=456
fred+= 456''', 'fred=123 456\\0mary=456\\0')
# append from empty
check_script('''fred=
ernie=456
fred+= 456''', 'fred= 456\\0ernie=456\\0')
mary=456
fred+= 456''', 'fred= 456\\0mary=456\\0')
# variable with + in it
check_script('fred+ernie=123', 'fred+ernie=123\\0')
check_script('fred+mary=123', 'fred+mary=123\\0')
# ignores variables that are empty
check_script('''fred=
fred+=
ernie=456''', 'ernie=456\\0')
mary=456''', 'mary=456\\0')
# single-character env name
check_script('''f=123
check_script('''m=123
e=456
f+= 456''', 'e=456\\0f=123 456\\0')
m+= 456''', 'e=456\\0m=123 456\\0')
# contains quotes
check_script('''fred="my var"
ernie=another"''', 'fred=\\"my var\\"\\0ernie=another\\"\\0')
mary=another"''', 'fred=\\"my var\\"\\0mary=another\\"\\0')
# variable name ending in +
check_script('''fred\\+=my var
@ -598,7 +598,7 @@ fred++= again''', 'fred+=my var again\\0')
# variable name containing +
check_script('''fred+jane=both
fred+jane+=again
ernie=456''', 'fred+jane=bothagain\\0ernie=456\\0')
mary=456''', 'fred+jane=bothagain\\0mary=456\\0')
# multi-line vars - new vars always start at column 1
check_script('''fred=first
@ -607,7 +607,7 @@ ernie=456''', 'fred+jane=bothagain\\0ernie=456\\0')
after blank
confusing=oops
ernie=another"''', 'fred=first second third with tab after blank confusing=oops\\0ernie=another\\"\\0')
mary=another"''', 'fred=first second third with tab after blank confusing=oops\\0mary=another\\"\\0')
# real-world example
check_script('''ubifs_boot=