Verifies shell variables are replaced by their values.

Signed-off-by: Francis Laniel <francis.lan...@amarulasolutions.com>
---
 test/hush/Makefile |   1 +
 test/hush/dollar.c | 175 +++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 176 insertions(+)
 create mode 100644 test/hush/dollar.c

diff --git a/test/hush/Makefile b/test/hush/Makefile
index a3c9ae5106..feb4f71956 100644
--- a/test/hush/Makefile
+++ b/test/hush/Makefile
@@ -5,3 +5,4 @@
 
 obj-y += cmd_ut_hush.o
 obj-y += if.o
+obj-y += dollar.o
diff --git a/test/hush/dollar.c b/test/hush/dollar.c
new file mode 100644
index 0000000000..2614517cd2
--- /dev/null
+++ b/test/hush/dollar.c
@@ -0,0 +1,175 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * (C) Copyright 2021
+ * Francis Laniel, Amarula Solutions, francis.lan...@amarulasolutions.com
+ */
+
+#include <common.h>
+#include <command.h>
+#include <env_attr.h>
+#include <test/hush.h>
+#include <test/ut.h>
+
+static int hush_test_simple_dollar(struct unit_test_state *uts)
+{
+       console_record_reset_enable();
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       ut_assert_nextline("%s", "");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("echo ${dollar_foo}", 0));
+       ut_assert_nextline("%s", "");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("dollar_foo=bar", 0));
+
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("echo ${dollar_foo}", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       /*
+        * R is way of giving raw string literals in C++.
+        * It means a "\n" is a R string literal will not be interpreted as line
+        * feed but printed as "\n".
+        * GCC provides it for C as an extension.
+        */
+       ut_assertok(run_command(R"(dollar_foo=\$bar)", 0));
+
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       ut_assert_nextline("$bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("dollar_foo='$bar'", 0));
+
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       ut_assert_nextline("$bar");
+       ut_assert_console_end();
+
+       ut_asserteq(1, run_command("dollar_foo=bar quux", 0));
+       /* Next line contains error message */
+       ut_assert_skipline();
+       ut_assert_console_end();
+
+       ut_asserteq(1, run_command("dollar_foo='bar quux", 0));
+       /* Next line contains error message */
+       ut_assert_skipline();
+       ut_assert_console_end();
+
+       ut_asserteq(1, run_command(R"(dollar_foo=bar quux")", 0));
+       /* Two next lines contain error message */
+       ut_assert_skipline();
+       ut_assert_skipline();
+       ut_assert_console_end();
+
+       ut_assertok(run_command(R"(dollar_foo='bar "quux')", 0));
+
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       /*
+        * This one is buggy.
+        * ut_assert_nextline(R"(bar "quux)");
+        * ut_assert_console_end();
+        *
+        * So, let's reset output:
+        */
+       console_record_reset_enable();
+
+       ut_asserteq(1, run_command(R"(dollar_foo="bar 'quux")", 0));
+       /* Next line contains error message */
+       ut_assert_skipline();
+       ut_assert_console_end();
+
+       ut_assertok(run_command("dollar_foo='bar quux'", 0));
+       ut_assertok(run_command("echo $dollar_foo", 0));
+       ut_assert_nextline("bar quux");
+       ut_assert_console_end();
+
+       puts("Beware: this test set local variable dollar_foo and it cannot be 
unset!");
+
+       return 0;
+}
+HUSH_TEST(hush_test_simple_dollar, 0);
+
+static int hush_test_env_dollar(struct unit_test_state *uts)
+{
+       env_set("env_foo", "bar");
+       console_record_reset_enable();
+
+       ut_assertok(run_command("echo $env_foo", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("echo ${env_foo}", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       /* Environment variables have priority over local variable */
+       ut_assertok(run_command("env_foo=quux", 0));
+       ut_assertok(run_command("echo ${env_foo}", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       /* Clean up setting the variable */
+       env_set("env_foo", NULL);
+
+       puts("Beware: this test set local variable env_foo and it cannot be 
unset!");
+
+       return 0;
+}
+HUSH_TEST(hush_test_env_dollar, 0);
+
+static int hush_test_command_dollar(struct unit_test_state *uts)
+{
+       console_record_reset_enable();
+
+       ut_assertok(run_command(R"(dollar_bar="echo bar")", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("${dollar_bar}", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command(R"(dollar_bar="echo
+       bar")", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command(R"(dollar_bar='echo bar
+       ')", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command(R"(dollar_bar='echo bar\n')", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("barn");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("dollar_bar='echo $bar'", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("$bar");
+       ut_assert_console_end();
+
+       ut_assertok(run_command("dollar_quux=quux", 0));
+       ut_assertok(run_command(R"(dollar_bar="echo $dollar_quux")", 0));
+
+       ut_assertok(run_command("$dollar_bar", 0));
+       ut_assert_nextline("quux");
+       ut_assert_console_end();
+
+       puts("Beware: this test sets local variable dollar_bar and dollar_quux 
and they cannot be unset!");
+
+       return 0;
+}
+HUSH_TEST(hush_test_command_dollar, 0);
-- 
2.25.1

Reply via email to