diff options
| author | Charles Cabergs <me@cacharle.xyz> | 2021-02-05 12:27:32 +0100 |
|---|---|---|
| committer | Charles Cabergs <me@cacharle.xyz> | 2021-02-05 12:27:32 +0100 |
| commit | 904a033ae738e1c351f8fef71e2ec2418fc4db3d (patch) | |
| tree | 3de4980582c109c4f0d19111a2b88eafec9b9b36 /src/suites/flow.py | |
| parent | a3e983f78dc4cbcf6f75f78fa2b3c57e09cd1b2b (diff) | |
| download | minishell_test-904a033ae738e1c351f8fef71e2ec2418fc4db3d.tar.gz minishell_test-904a033ae738e1c351f8fef71e2ec2418fc4db3d.tar.bz2 minishell_test-904a033ae738e1c351f8fef71e2ec2418fc4db3d.zip | |
Renaming src -> minishell_test for package name, Renaming main.py -> __main__.py for package execution with python -m
Diffstat (limited to 'src/suites/flow.py')
| -rw-r--r-- | src/suites/flow.py | 290 |
1 files changed, 0 insertions, 290 deletions
diff --git a/src/suites/flow.py b/src/suites/flow.py deleted file mode 100644 index 2c00b2f..0000000 --- a/src/suites/flow.py +++ /dev/null @@ -1,290 +0,0 @@ -# ############################################################################ # -# # -# ::: :::::::: # -# flow.py :+: :+: :+: # -# +:+ +:+ +:+ # -# By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ # -# +#+#+#+#+#+ +#+ # -# Created: 2020/07/15 18:24:52 by charles #+# #+# # -# Updated: 2020/11/10 13:16:28 by cacharle ### ########.fr # -# # -# ############################################################################ # - -import config -from suite import suite -from hooks import error_line0, platform_status, discard, replace_double_semi_colon, error_eof_to_expected_token - - -@suite() -def suite_end(test): - """ `;` tests """ - test("echo bonjour; echo je") - test("echo bonjour ;echo je") - test("echo bonjour ; echo je") - test("echo bonjour;") - test("echo; ") - test("echo ; ") - test("echo ;") - test("; echo", hook=error_line0, hook_status=platform_status(2, 1)) - test(" ;echo", hook=error_line0, hook_status=platform_status(2, 1)) - test(" ; echo", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a; echo b; echo c; echo d; echo e; echo f; echo g; echo h; echo i;" - "echo j; echo k; echo l; echo m; echo c; echo c; echo c; echo c; echo c;" - "echo c; echo c; echo c; echo v; echo w; echo x; echo y; echo z") - test("echo a ; echo b; echo c ;echo d ; echo e ;echo f; echo g ;echo h; echo i;" - "echo j ; echo k; echo l; echo m; echo c ; echo c; echo c ; echo c; echo c;" - "echo c; echo c ; echo c; echo v ; echo w; echo x; echo y ; echo z") - test("ls doesnotexists ; echo bonjour") - test("ls doesnotexists; echo bonjour") - test("echo bonjour; ls doesnotexists") - test("echo a ; ;", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a ; ;", hook=error_line0, hook_status=platform_status(2, 1)) - test(";", hook=error_line0, hook_status=platform_status(2, 1)) - test("; ;", hook=error_line0, hook_status=platform_status(2, 1)) - test("; ; ;", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a ; ; echo b", hook=error_line0, hook_status=platform_status(2, 1)) - test(";;", hook=[error_line0, replace_double_semi_colon], hook_status=platform_status(2, 1)) - test(";;;", hook=[error_line0, replace_double_semi_colon], hook_status=platform_status(2, 1)) - test(";;;;;", hook=[error_line0, replace_double_semi_colon], hook_status=platform_status(2, 1)) - test("echo a ;; echo b", hook=[error_line0, replace_double_semi_colon], hook_status=platform_status(2, 1)) - test("echo a ;;;;; echo b", hook=[error_line0, replace_double_semi_colon], hook_status=platform_status(2, 1)) - test("ls " + 40 * " ; ls", setup="touch a b c") - test("ls " + 80 * " ; ls", setup="touch a b c") - test("ls " + 40 * " ; ls" + ";", setup="touch a b c") - test("ls " + 80 * " ; ls" + ";", setup="touch a b c") - - -@suite() -def suite_pipe(test): - """ `|` tests """ - test("cat /etc/shells | head -c 10") - test("cat -e /etc/shells | head -c 10") - test("cat -e /etc/shells | cat -e | head -c 10") - test("cat -e /etc/shells | cat -e | cat -e | head -c 10") - test("cat -e /dev/random | head -c 10", hook=discard) - test("cat -e /dev/random | cat -e | head -c 10", hook=discard) - test("cat -e /dev/random | cat -e | cat -e | head -c 10", hook=discard) - test("echo bonjour | cat") - test("echo bonjour | cat -e") - test("echo bonjour | cat -e | cat -e | cat -e | cat -e | cat -e | cat -e | cat -e") - test("ls | cat -e", setup="touch a b c d; mkdir m1 m2 m3") - test("ls -l | cat -e", setup="touch a b c d; mkdir m1 m2 m3") - test("ls -l | cat -e | cat | cat | cat", setup="touch a b c d; mkdir m1 m2 m3") - test("ls -l | cat -e | cat -e | cat -e | cat -e", setup="touch a b c d; mkdir m1 m2 m3") - test("ls -l | cat -e < a", setup="touch a b c d; mkdir m1 m2 m3; echo bonjour > a") - test("echo|", hook=discard, hook_status=platform_status(2, 1)) - test("echo |", hook=discard, hook_status=platform_status(2, 1)) - test("echo | ", hook=discard, hook_status=platform_status(2, 1)) - test("|cat", hook=error_line0, hook_status=platform_status(2, 1)) - test("| cat", hook=error_line0, hook_status=platform_status(2, 1)) - test(" | cat", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a | export A=a; echo $A") - test("export A=a | cat; echo $A") - test("echo bonjour | | cat -e", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo bonjour | asdf") - test("asdf | echo bonjour") - test("echo a ||| echo b", hook=error_line0, hook_status=platform_status(2, 1)) - test("ls " + 40 * " | ls", setup="touch a b c") - test("ls " + 80 * " | ls", setup="touch a b c") - test("echo bonjour " + 40 * " | cat -e") - test("echo bonjour " + 80 * " | cat -e") - test("ls asdfasdf | echo a") - test("echo a | ls asdfasdf") - test("ls asdfasdf | echo a; echo b") - test("echo a | ls asdfasdf; echo b") - test("echo a > foo | cat -e", files=["foo"]) - test("echo a >> foo | cat -e", files=["foo"]) - test("echo a | cat -e < foo", setup="echo b > foo") - test("echo a > bar | cat -e < foo", setup="echo b > foo", files=["bar"]) - - -@suite(bonus=True) -def suite_and(test): - """ `&&` tests """ - test("echo bonjour&& echo je") - test("echo bonjour &&echo je") - test("echo bonjour && echo je") - test("echo bonjour&&", hook=discard, hook_status=platform_status(2, 1)) - test("echo&& ", hook=discard, hook_status=platform_status(2, 1)) - test("echo && ", hook=discard, hook_status=platform_status(2, 1)) - test("echo &&", hook=discard, hook_status=platform_status(2, 1)) - test("&&echo", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& echo", hook=error_line0, hook_status=platform_status(2, 1)) - test(" && echo", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a&& echo b&& echo c&& echo d&& echo e&& echo f&& echo g&& echo h&& echo i&&" - "echo j&& echo k&& echo l&& echo m&& echo c&& echo c&& echo c&& echo c&& echo c&&" - "echo c&& echo c&& echo c&& echo v&& echo w&& echo x&& echo y&& echo z") - test("echo a && echo b&& echo c &&echo d && echo e &&echo f&& echo g &&echo h&& echo i&&" - "echo j && echo k&& echo l&& echo m&& echo c && echo c&& echo c && echo c&& echo c&&" - "echo c&& echo c && echo c&& echo v && echo w&& echo x&& echo y && echo z") - test("ls doesnotexists && echo bonjour") - test("ls doesnotexists&& echo bonjour") - test("echo bonjour&& ls doesnotexists") - test("ls " + 40 * " && ls", setup="touch a b c") - test("ls " + 80 * " && ls", setup="touch a b c") - - -@suite(bonus=True) -def suite_or(test): - """ `||` tests """ - test("echo bonjour|| echo je") - test("echo bonjour ||echo je") - test("echo bonjour || echo je") - test("echo bonjour||", hook=discard, hook_status=platform_status(2, 1)) - test("echo|| ", hook=discard, hook_status=platform_status(2, 1)) - test("echo || ", hook=discard, hook_status=platform_status(2, 1)) - test("echo ||", hook=discard, hook_status=platform_status(2, 1)) - test("||echo", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| echo", hook=error_line0, hook_status=platform_status(2, 1)) - test(" || echo", hook=error_line0, hook_status=platform_status(2, 1)) - test("echo a|| echo b|| echo c|| echo d|| echo e|| echo f|| echo g|| echo h|| echo i||" - "echo j|| echo k|| echo l|| echo m|| echo c|| echo c|| echo c|| echo c|| echo c||" - "echo c|| echo c|| echo c|| echo v|| echo w|| echo x|| echo y|| echo z") - test("echo a || echo b|| echo c ||echo d || echo e ||echo f|| echo g ||echo h|| echo i||" - "echo j || echo k|| echo l|| echo m|| echo c || echo c|| echo c || echo c|| echo c||" - "echo c|| echo c || echo c|| echo v || echo w|| echo x|| echo y || echo z") - test("ls doesnotexists || echo bonjour") - test("ls doesnotexists|| echo bonjour") - test("echo bonjour|| ls doesnotexists") - test("ls asdf" + 40 * " || ls asdf", setup="touch a b c") - test("ls asdf" + 80 * " || ls asdf", setup="touch a b c") - - -@suite(bonus=True) -def suite_parenthesis(test): - """ `(`, `)` tests """ - test("(echo bonjour)") - test("(echo bonjour )") - test("( echo bonjour )") - test("(echo a && echo b) && echo c") - test("(echo a || echo b) || echo c") - test("(ls doesnotexist || echo b) || echo c") - test("(echo a || ls doesnotexist) || echo c") - test("echo aa && (echo b && echo c)") - test("ls doesnotexist || (echo b && echo c)") - test("(echo bonjour > f1)", files=["f1"]) - test("(echo bonjour > f1 > f2 > f3)", files=["f1", "f2", "f3"]) - test("(echo bonjour > f1 > f2 > f3 > f4 > f5 > f6 > f7 > f8 > f9)", - files=["f1", "f2", "f3", "f4", "f5", "f6", "f7", "f8", "f9"]) - test("(echo bonjour) > f1", files=["f1"]) - test("(echo bonjour) > f1 > f2 > f3", files=["f1", "f2", "f3"]) - test("(echo bonjour) > f1 > f2 > f3 > f4 > f5 > f6 > f7 > f8 > f9", - files=["f1", "f2", "f3", "f4", "f5", "f6", "f7", "f8", "f9"]) - test("(cat -e < f1)", setup="echo bonjour > f1") - test("(cat -e < f1 < f2 < f3)", setup="touch f1 f2 f3 f4; echo bonjour > f3") - test("(cat -e < f1 < f2 < f3 < f4 < f5 < f6 < f7 < f8 < f9)", - setup="touch f1 f2 f3 f4 f5 f6 f7 f8 f9; echo bonjour > f9") - test("(cat -e) < f1", setup="echo bonjour > f1") - test("(cat -e) < f1 < f2 < f3", setup="touch f1 f2 f3 f4; echo bonjour > f3") - test("(cat -e) < f1 < f2 < f3 < f4 < f5 < f6 < f7 < f8 < f9", - setup="touch f1 f2 f3 f4 f5 f6 f7 f8 f9; echo bonjour > f9") - test("(echo bonjour > f1 > f2 > f3 > f4) > f5 > f6 > f7 > f8 > f9", - files=["f1", "f2", "f3", "f4", "f5", "f6", "f7", "f8", "f9"]) - test("(cat -e < f1 < f2 < f3 < f4) < f5 < f6 < f7 < f8 < f9", - setup="touch f1 f2 f3 f4 f5 f6 f7 f8 f9; echo bonjour > f4") - test("(echo bonjour > f1) > f2", files=["f1", "f2"]) - test("(cat -e > f1) < f2", setup="ls -l / > f2", files=["f1"]) - test("(exit); echo bonjour") - test("(echo bonjour; exit; echo aurevoir)") - test("(ls && ls)") - test("(ls doesntexist || ls)") - test("(ls doesntexist && ls)") - test("(ls && ls) && echo $?") - test("(echo a; echo b) | cat -e") - test("echo bonjour | (cat -e; echo a)") - test("echo bonjour | (echo a; cat -e)") - test("(echo a) | (cat -e)") - test("(echo a; echo b) | (cat -e)") - test("(echo a) | (cat -e | cat -e)") - test("(echo a; echo b) | (cat -e | cat -e)") - test("(echo a; echo b) | cat -e | cat -e") - test("(echo a); (echo b) | (cat -e) | (cat -e)") - test("echo a | (cat -e | cat -e | cat -e)") - test("echo a | (cat -e | cat -e | cat -e) | cat -e") - test("(echo a) | (cat -e | cat -e | cat -e) | cat -e") - test("(echo a) | (cat -e | cat -e | cat -e) | (cat -e)") - test("(echo bonjour ; echo aurevoir) | (cat -e | cat -e) | cat -e") - test("( echo salut && echo bonjours ) ; echo comment ca va") - test("(cd /; echo $PWD; pwd); echo $PWD; pwd") - test("(export A=a; echo $A); echo $A") - test("(cat /etc/shells) | (cat -e) | (cat -e) | (cat -e)") - test("(cat /etc/shells) | (cat -e) | (cat -e) | (cat -e) | (cat -e) | (cat -e) | (cat -e) | (cat -e) | (cat -e)") - test("(cat /etc/shells | (cat -e) | (cat -e) | (cat -e)", - hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - test("(cat /etc/shells) | (cat -e) | (cat -e | (cat -e)", - hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - - -@suite() -def suite_syntax_error(test): - """ separator syntax error test """ - test("< | a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> | a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> | a", hook=error_line0, hook_status=platform_status(2, 1)) - test("< ; a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> ; a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> ; a", hook=error_line0, hook_status=platform_status(2, 1)) - test("; | a", hook=error_line0, hook_status=platform_status(2, 1)) - test("; < a", hook=error_line0, hook_status=platform_status(2, 1)) - test("; > a", hook=error_line0, hook_status=platform_status(2, 1)) - test("; >> a", hook=error_line0, hook_status=platform_status(2, 1)) - test("| ; a", hook=error_line0, hook_status=platform_status(2, 1)) - test("| < a", hook=error_line0, hook_status=platform_status(2, 1)) - test("| > a", hook=error_line0, hook_status=platform_status(2, 1)) - test("| >> a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> a ; a", hook=error_line0) - test("< a ; a", hook=error_line0) - test(">> a ; a", hook=error_line0) - test(config.LOREM + " > >" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " < <" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " ; |" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " | ;" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - - -@suite(bonus=True) -def suite_syntax_error_bonus(test): - """ separator syntax error bonus test """ - test("< && a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> && a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> && a", hook=error_line0, hook_status=platform_status(2, 1)) - test("< || a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> || a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> || a", hook=error_line0, hook_status=platform_status(2, 1)) - test("< ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test("< ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test("> ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test(">> ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& < a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& > a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& >> a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& || a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test("&& ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| < a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| > a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| >> a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| && a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test("|| ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test("( < a", hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - test("( > a", hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - test("( >> a", hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - test(") < a", hook=error_line0, hook_status=platform_status(2, 1)) - test(") > a", hook=error_line0, hook_status=platform_status(2, 1)) - test(") >> a", hook=error_line0, hook_status=platform_status(2, 1)) - test("( && a", hook=error_line0, hook_status=platform_status(2, 1)) - test("( || a", hook=error_line0, hook_status=platform_status(2, 1)) - test("( ) a", hook=error_line0, hook_status=platform_status(2, 1)) - test(") && a", hook=error_line0, hook_status=platform_status(2, 1)) - test(") || a", hook=error_line0, hook_status=platform_status(2, 1)) - test(") ( a", hook=error_line0, hook_status=platform_status(2, 1)) - test("() a", hook=error_line0, hook_status=platform_status(2, 1)) - test("( a", hook=[error_line0, error_eof_to_expected_token], hook_status=platform_status(2, 1)) - test(") a", hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " && &&" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " || ||" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " ( (" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test(config.LOREM + " ) )" + config.LOREM, hook=error_line0, hook_status=platform_status(2, 1)) - test("(); () ;() ;() ;() ;() ;() ;() ;() ;() ;a", hook=error_line0, hook_status=platform_status(2, 1)) |
