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) { if (do_output) {
printf("%s", "#define CONFIG_EXTRA_ENV_TEXT \"") 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) { for (var in vars) {
env = vars[var] env = vars[var]
print var "=" vars[var] "\\0" print var "=" vars[var] "\\0"

View File

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