diff options
Diffstat (limited to 'minishell_test/suites')
| -rw-r--r-- | minishell_test/suites/__init__.py | 17 | ||||
| -rw-r--r-- | minishell_test/suites/builtin.py | 403 | ||||
| -rw-r--r-- | minishell_test/suites/cmd.py | 331 | ||||
| -rw-r--r-- | minishell_test/suites/flow.py | 290 | ||||
| -rw-r--r-- | minishell_test/suites/misc.py | 100 | ||||
| -rw-r--r-- | minishell_test/suites/path.py | 137 | ||||
| -rw-r--r-- | minishell_test/suites/preprocess.py | 463 |
7 files changed, 1741 insertions, 0 deletions
diff --git a/minishell_test/suites/__init__.py b/minishell_test/suites/__init__.py new file mode 100644 index 0000000..b6b3b68 --- /dev/null +++ b/minishell_test/suites/__init__.py @@ -0,0 +1,17 @@ +# ############################################################################ # +# # +# ::: :::::::: # +# __init__.py :+: :+: :+: # +# +:+ +:+ +:+ # +# By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2020/07/15 18:24:48 by charles #+# #+# # +# Updated: 2020/09/11 13:25:26 by charles ### ########.fr # +# # +# ############################################################################ # + +import os +import glob + +modules = glob.glob(os.path.join(os.path.dirname(__file__), "*.py")) +__all__ = [os.path.basename(f)[:-3] for f in modules if os.path.isfile(f) and not f.endswith("__init__.py")] diff --git a/minishell_test/suites/builtin.py b/minishell_test/suites/builtin.py new file mode 100644 index 0000000..9ab2af8 --- /dev/null +++ b/minishell_test/suites/builtin.py @@ -0,0 +1,403 @@ +# **************************************************************************** # +# # +# ::: :::::::: # +# builtin.py :+: :+: :+: # +# +:+ +:+ +:+ # +# By: juligonz <juligonz@student.42.fr> +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2020/07/15 18:24:43 by charles #+# #+# # +# Updated: 2020/11/28 06:17:19 by charles ### ########.fr # +# Updated: 2020/09/11 18:01:27 by juligonz ### ########.fr # +# # +# **************************************************************************** # + +import os + +import config +import hooks +from suite import suite +from hooks import linux_discard + + +@suite() +def suite_echo(test): + """ echo builtin tests """ + test("echo") + test("echo bonjour") + test("echo lalalala lalalalal alalalalal alalalala") + test("echo lalalala lalalalal alalalalal alalalala") + test("echo " + config.LOREM) + test("echo -n") + test("echo -n bonjour") + test("echo -n lalalala lalalalal alalalalal alalalala") + test("echo -n lalalala lalalalal alalalalal alalalala") + test("echo -n " + config.LOREM) + test("echo bonjour -n") + test("echo -n bonjour -n") + test(" echo bonjour je") + test(" echo -n bonjour je") + test("echo a '' b '' c '' d") + test('echo a "" b "" c "" d') + test("echo -n a '' b '' c '' d") + test('echo -n a "" b "" c "" d') + test("echo '' '' ''") + test("Echo bonjour") + test("eCho bonjour") + test("ecHo bonjour") + test("echO bonjour") + test("EchO bonjour") + test("eCHo bonjour") + test("EcHo bonjour") + test("eChO bonjour") + test("Echo bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("eCho bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("ecHo bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("echO bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("EchO bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("eCHo bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("EcHo bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("eChO bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("eChO -e 'bonjo\\nur'", exports={"PATH": "/bin:/usr/bin"}) + test("echo -n -n -n -n bonjour") + test("echo -nnnnnnnnnnnnnnnnnnnnn bonjour") + test("echo -nnnnnnnnnnnnnnnnnnnnn -n -n -n bonjour -n -n") + + +@suite() +def suite_export(test): + """ export builtin tests """ + test("export", hook=hooks.export_singleton) + test("export", exports={"A": ""}, hook=hooks.export_singleton) + test("export", exports={"A": "\""}, hook=hooks.export_singleton) + test("export", exports={"A": "\\"}, hook=hooks.export_singleton) + test("export", exports={"A": "$"}, hook=hooks.export_singleton) + test("export", exports={"A": "\t"}, hook=hooks.export_singleton) + test("export", exports={"A": "'"}, hook=hooks.export_singleton) + test("export", exports={"A": "a"}, hook=hooks.export_singleton) + test("export A=a; echo $A") + test("export A=a B=b C=c; echo $A$B$C") + test("export A=a B=b C=c D=d E=e F=f G=g H=h I=i J=j K=k L=l" + "M=m N=n O=o P=p Q=q R=r S=s T=t U=u V=v W=w X=x Y=y Z=z" + "; echo $A$B$C$D$E$F$G$H$I$J$K$L$M$N$O$P$Q$R$S$T$U$V$W$X$Y$Z") + test("export BONJOURJESUIS=a; echo $BONJOURJESUIS") + test("export bonjourjesuis=a; echo $bonjourjesuis") + test("export bonjour_je_suis=a; echo $bonjour_je_suis") + test("export BONJOURJESUIS1=a; echo $BONJOURJESUIS1") + test("export bO_nJq123o__1ju_je3234sui__a=a; echo $bO_nJq123o__1ju_je3234sui__a") + test("export a0123456789=a; echo $a0123456789") + test("export abcdefghijklmnopqrstuvwxyz=a; echo $abcdefghijklmnopqrstuvwxyz") + test("export ABCDEFGHIJKLMNOPQRSTUVWXYZ=a; echo $ABCDEFGHIJKLMNOPQRSTUVWXYZ") + test("export __________________________=a; echo $__________________________") + test("export _bonjour_=a; echo $_bonjour_") + test("export _=a; echo $_a") + test("export 1=a") + test("export BONJOURJESUIS =a") + test("export BONJOURJESUIS= a") + test(r"export BONJOUR\\JESUIS=a") + test(r"export BONJOUR\'JESUIS=a") + test(r'export BONJOUR\"JESUIS=a') + test(r"export BONJOUR\$JESUIS=a") + test(r"export BONJOUR\&JESUIS=a") + test(r"export BONJOUR\|JESUIS=a") + test(r"export BONJOUR\;JESUIS=a") + test(r"export BONJOUR\_JESUIS=a") + test(r"export BONJOUR\0JESUIS=a") + test(r"export \B\O\N\ \ \ \ \ \ \ JOURJESUIS=a") + test(r"export A=\B\O\N\ \ \ \ \ \ \ JOURJESUIS; echo $A") + test(r"export A='bonjour je suis charles'; echo $A") + test(r'export A="bonjour je suis charles"; echo $A') + test(r"export A==a; echo $A") + test(r"export A===a; echo $A") + test(r"export A====a; echo $A") + test(r"export A=====a; echo $A") + test(r"export A======a; echo $A") + test(r"export A=a=a=a=a=a; echo $A") + test("export A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C; echo $A$B$C") + test("export 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C; echo $A$B$C") + test("export A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf '; echo $A$B$C") + test("export A B C; echo $A$B$C") + test("export A B C; env", hook=hooks.sort_lines) + test("export 'AH@'=nop") + test("export \"AH'\"=nop") + test("export 'AH\"'=nop") + test("export 'AH$'=nop") + test("export 'AH!'=nop") + test("export 'AH|'=nop") + test("export 'AH;'=nop") + test("export 'AH&'=nop") + test("export 'AH\\'=nop") + test("export $TEST", exports={"TEST": "A=a"}) + test(r"export BONJOUR\\JESUIS") + test(r"export BONJOUR\'JESUIS") + test(r'export BONJOUR\"JESUIS') + test(r"export BONJOUR\$JESUIS") + test(r"export BONJOUR\&JESUIS") + test(r"export BONJOUR\|JESUIS") + test(r"export BONJOUR\;JESUIS") + test(r"export BONJOUR\_JESUIS") + test(r"export BONJOUR\0JESUIS") + test("Export B=bonjour") + test("exporT B=bonjour") + test("Export B=bonjour", exports={"PATH": "/bin:/usr/bin"}) + test("exporT B=bonjour", exports={"PATH": "/bin:/usr/bin"}) + + +@suite() +def suite_cd(test): + """ cd builtin tests """ + test("echo $PWD; echo $OLDPWD; cd .; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ../..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ../../..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ../../../..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ../../../../..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ../../../../../..; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd /; pwd; echo $PWD; echo $OLDPWD") + # /etc is a link to /etc/private + # hard and weird to implement with pwd + # test("cd /etc; pwd; echo $PWD") + test("echo $PWD; echo $OLDPWD; cd ''; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd '' ''; pwd; echo $PWD; echo $OLDPWD", hook=linux_discard) + test("echo $PWD; echo $OLDPWD; cd '' '' ''; pwd; echo $PWD; echo $OLDPWD", hook=linux_discard) + test("echo $PWD; echo $OLDPWD; cd ' '; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd d ''; pwd; echo $PWD; echo $OLDPWD", setup="mkdir d", hook=linux_discard) + test("echo $PWD; echo $OLDPWD; cd d d; pwd; echo $PWD; echo $OLDPWD", setup="mkdir d", hook=linux_discard) + test("echo $PWD; echo $OLDPWD; cd d ' '; pwd; echo $PWD; echo $OLDPWD", setup="mkdir d", hook=linux_discard) + test("echo $PWD; echo $OLDPWD; cd $HOME; pwd; echo $PWD; echo $OLDPWD", exports={"HOME": os.getenv("HOME")}) + test("echo $PWD; echo $OLDPWD; cd /; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd /.; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd /./; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd /././././; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd //; pwd; echo $PWD; echo $OLDPWD", hook=hooks.replace_double_slash) + test("echo $PWD; echo $OLDPWD; cd ///; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ////; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd //////////////////////////////////////////////////////; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd; echo $PWD; echo $OLDPWD", exports={"HOME": os.getenv("HOME")}) + test("echo $PWD; echo $OLDPWD; cd ' /'; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ' / '; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ' /'; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ' / '; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ' // '; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd //home; pwd; echo $PWD; echo $OLDPWD", hook=hooks.replace_double_slash) + test("echo $PWD; echo $OLDPWD; cd ' //home'; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd ' //home '; pwd; echo $PWD; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 001 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 002 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 003 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 004 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 005 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 006 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 007 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 010 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 020 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 030 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 040 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 050 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 060 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 070 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 100 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 200 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 300 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 400 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 500 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 600 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 700 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 755 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 644 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 311 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 111 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 222 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 333 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 0777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 1000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 2000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 3000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 4000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 5000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 6000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 7000 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 1777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 2777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 3777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 4777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 5777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 6777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 7777 d") + test("echo $PWD; echo $OLDPWD; cd d; echo $OLDPWD", setup="mkdir -m 0000 d") + test("echo $PWD; echo $OLDPWD; cd /; echo $PWD; echo $OLDPWD; unset PWD; cd /dev; echo $OLDPWD") + test("echo $PWD; echo $OLDPWD; cd /; echo $PWD; echo $OLDPWD; export PWD=bonjour; cd /dev; echo $OLDPWD") + # test("cd '\t'; pwd; echo $PWD"); + # test("cd '\t \t\t\t '; pwd; echo $PWD"); + # test("cd ~; pwd; echo $PWD"); # do we have to handle ~ ? + # test("cd ~/..; pwd; echo $PWD"); + # test("cd ~/../..; pwd; echo $PWD"); + # test("cd $HOME; pwd; echo $PWD") + test("Cd .") + test("cD .") + test("Cd .", exports={"PATH": "/bin:/usr/bin"}) + test("cD .", exports={"PATH": "/bin:/usr/bin"}) + + +@suite() +def suite_unset(test): + """ unset builtin tests """ + test("unset") + test("unset A; echo $A", exports={"A": "a"}) + test("unset 'A '; echo $A", exports={"A": "a"}) + test("unset 'A='; echo $A", exports={"A": "a"}) + test("unset A B C; echo $A$B$C", exports={"A": "a", "B": "b", "C": "c"}) + test("unset A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C; echo $A$B$C", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C; echo $A$B$C", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf '; echo $A$B$C", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset A; echo $A$B$C", exports={"A": "a", "B": "b", "C": "c"}) + test("unset C; echo $A$B$C", exports={"A": "a", "B": "b", "C": "c"}) + test("unset A B C", exports={"A": "a", "B": "b", "C": "c"}) + test("unset A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf ' C", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset A 'asdf ' B ' asdf asdf asd f' ' asdf ' '' 'asdf '", + exports={"A": "a", "B": "b", "C": "c"}) + test("unset A", exports={"A": "a", "B": "b", "C": "c"}) + test("unset 'AH@'=nop") + test("unset \"AH'\"=nop") + test("unset 'AH\"'=nop") + test("unset 'AH$'=nop") + test("unset 'AH!'=nop") + test("unset 'AH|'=nop") + test("unset 'AH;'=nop") + test("unset 'AH&'=nop") + test("unset 'AH\\'=nop") + test("Unset TERM") + test("unseT TERM") + test("Unset TERM", exports={"PATH": "/bin:/usr/bin"}) + test("unseT TERM", exports={"PATH": "/bin:/usr/bin"}) + + +@suite() +def suite_pwd(test): + """ pwd builtin tests """ + test("pwd") + test("pwd", setup="cd ..") + test("pwd", setup="cd ../..") + test("pwd", setup="cd ../../..") + test("pwd", setup="cd /") + test("pwd", setup="cd $HOME") + test("pwd | cat -e") + test("pwd", exports={"PWD": "/etc"}) + test("unset PWD; pwd; echo $PWD") + test("export PWD=foo; pwd; echo $PWD") + # test("cd lnk; rmdir ../d; pwd", setup="mkdir d; ln -s d lnk") + test("Pwd") + test("pwD") + test("Pwd", exports={"PATH": "/bin:/usr/bin"}) + test("pwD", exports={"PATH": "/bin:/usr/bin"}) + + +@suite() +def suite_env(test): + """ env builtin tests """ + test("env", hook=[hooks.sort_lines, hooks.shlvl_0_to_1]) + test("env", setup="export A=a", hook=[hooks.sort_lines, hooks.shlvl_0_to_1]) + test("env", setup="export A=a B=b C=c", hook=[hooks.sort_lines, hooks.shlvl_0_to_1]) + test("env | cat -e", setup="export A=a B=b C=c", hook=[hooks.sort_lines, hooks.shlvl_0_to_1]) + test("Env") + test("enV") + test("Env", exports={"PATH": "/bin:/usr/bin"}) + test("enV", exports={"PATH": "/bin:/usr/bin"}) + + +@suite() +def suite_exit(test): + """ exit builtin tests """ + test("exit") + test("exit 1") + test("exit 2") + test("exit 3") + test("exit ' 3'") + test("exit '\t3'") + test("exit '\t\f\r 3'") + test("exit '3 '") + test("exit '3\t'") + test("exit '3\r'", hook_status=hooks.platform_status(255, 2)) + test("exit '3\t\f\r '", hook_status=hooks.platform_status(255, 2)) + test("exit '3 a'", hook_status=hooks.platform_status(255, 2)) + test("exit '3\t\t\ta'", hook_status=hooks.platform_status(255, 2)) + test("exit 0") + test("exit -0") + test("exit -1") + test("exit 255") + test("exit 256") + test("exit 2000000") + test("exit -2000000") + test("exit 2147483647") + test("exit -2147483648") + test("exit 2147483648") + test("exit -2147483649") + test("exit 3147483648") + test("exit -3147483649") + test("exit 4294967295") + test("exit 4294967296") + test("exit -9223372036854775808") + test("exit 9223372036854775807") + test("exit -9223372036854775809", hook_status=hooks.platform_status(255, 2)) + test("exit 9223372036854775808", hook_status=hooks.platform_status(255, 2)) + test("exit 18446744073709551615", hook_status=hooks.platform_status(255, 2)) + test("exit 18446744073709551616", hook_status=hooks.platform_status(255, 2)) + test("exit +1") + test("exit +2") + test("exit +3") + test("exit +0") + test("exit +255") + test("exit +256") + test("exit +2000000") + test("exit +2147483647") + test("exit ++1", hook_status=hooks.platform_status(255, 2)) + test("exit ++2", hook_status=hooks.platform_status(255, 2)) + test("exit ++3", hook_status=hooks.platform_status(255, 2)) + test("exit ++0", hook_status=hooks.platform_status(255, 2)) + test("exit ++255", hook_status=hooks.platform_status(255, 2)) + test("exit ++256", hook_status=hooks.platform_status(255, 2)) + test("exit ++2000000", hook_status=hooks.platform_status(255, 2)) + test("exit ++2147483647", hook_status=hooks.platform_status(255, 2)) + test("exit --1", hook_status=hooks.platform_status(255, 2)) + test("exit --2", hook_status=hooks.platform_status(255, 2)) + test("exit --3", hook_status=hooks.platform_status(255, 2)) + test("exit --0", hook_status=hooks.platform_status(255, 2)) + test("exit --255", hook_status=hooks.platform_status(255, 2)) + test("exit --256", hook_status=hooks.platform_status(255, 2)) + test("exit --2000000", hook_status=hooks.platform_status(255, 2)) + test("exit --2147483647", hook_status=hooks.platform_status(255, 2)) + test("exit bonjour", hook_status=hooks.platform_status(255, 2)) + test("exit 0_", hook_status=hooks.platform_status(255, 2)) + test("exit _0", hook_status=hooks.platform_status(255, 2)) + test("exit 0123456789") + test("exit -0123456789") + test("exit 00000000000000000000000000000000000000000000001") + test("exit 00000000000000000000000000000000000000000000000" + "00000000000000000000000000000000000000000000001") + test("exit 00000000000000000000000000000000000000000000000" + "00000000000000000000000000000000000000000000000") + test("exit -00000000000000000000000000000000000000000000000" + "00000000000000000000000000000000000000000000001") + test("exit -99999999999999999999999999999999999999999999" + "99999999999999999999999999999999999999999999", hook_status=hooks.platform_status(255, 2)) + test("exit 99999999999999999999999999999999999999999999" + "99999999999999999999999999999999999999999999", hook_status=hooks.platform_status(255, 2)) + test("exit 0 bonjour") + test("exit bonjour 0", hook_status=hooks.platform_status(255, 2)) + test("exit 0 1") + test("exit 0 1 2 3 4 5 6 7 8 9") + test("exit " + config.LOREM, hook_status=hooks.platform_status(255, 2)) + test("exit bonjoru; echo should have exited", hook_status=hooks.platform_status(255, 2)) + test("exit 99999999999999999999999999999999999999999999999999999; echo should have exited", hook_status=hooks.platform_status(255, 2)) + test("exit 9999; echo should have exited") + test("Exit; echo a") + test("exiT; echo a") + test("Exit; echo a", exports={"PATH": "/bin:/usr/bin"}) + test("exiT; echo a", exports={"PATH": "/bin:/usr/bin"}) diff --git a/minishell_test/suites/cmd.py b/minishell_test/suites/cmd.py new file mode 100644 index 0000000..53b1f97 --- /dev/null +++ b/minishell_test/suites/cmd.py @@ -0,0 +1,331 @@ +# ############################################################################ # +# # +# ::: :::::::: # +# cmd.py :+: :+: :+: # +# +:+ +:+ +:+ # +# By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2020/07/15 15:11:46 by charles #+# #+# # +# Updated: 2021/02/04 16:14:54 by charles ### ########.fr # +# # +# ############################################################################ # + +import distutils + +import hooks +import config +from suite import suite + + +@suite() +def suite_redirection(test): + """ append/write/read redirections """ + test("echo bonjour > test", setup="", files=["test"]) + test("echo > test bonjour", setup="", files=["test"]) + test("> test echo bonjour", setup="", files=["test"]) + test("echo bonjour >> test", setup="", files=["test"]) + test("echo >> test bonjour", setup="", files=["test"]) + test(">> test echo bonjour", setup="", files=["test"]) + test("cat < test", setup="echo bonjour > test") + test("echo bonjour > test", setup="", files=["test"]) + test("echo > test'sticked' bonjour", setup="", files=["teststicked"]) + test("> test'sticked' echo bonjour", setup="", files=["teststicked"]) + test("echo bonjour >> test'sticked'", setup="", files=["teststicked"]) + test("echo >> test'sticked' bonjour", setup="", files=["teststicked"]) + test(">> test'sticked' echo bonjour", setup="", files=["teststicked"]) + test("cat < test'sticked'", setup="echo bonjour > test'sticked'") + test("< test'sticked' cat", setup="echo bonjour > test'sticked'") + test("echo > test\"sticked\" bonjour", setup="", files=["teststicked"]) + test("> test\"sticked\" echo bonjour", setup="", files=["teststicked"]) + test("echo bonjour >> test\"sticked\"", setup="", files=["teststicked"]) + test("echo >> test\"sticked\" bonjour", setup="", files=["teststicked"]) + test(">> test\"sticked\" echo bonjour", setup="", files=["teststicked"]) + test("cat < test\"sticked\"", setup="echo bonjour > test\"sticked\"") + test("< test\"sticked\" cat", setup="echo bonjour > test\"sticked\"") + test("echo > test'yo'\"sticked\" bonjour", setup="", files=["testyosticked"]) + test("> test'yo'\"sticked\" echo bonjour", setup="", files=["testyosticked"]) + test("echo bonjour >> test'yo'\"sticked\"", setup="", files=["testyosticked"]) + test("echo >> test'yo'\"sticked\" bonjour", setup="", files=["testyosticked"]) + test(">> test'yo'\"sticked\" echo bonjour", setup="", files=["testyosticked"]) + test("cat < test'yo'\"sticked\"", setup="echo bonjour > test'yo'\"sticked\"") + test("< test'yo'\"sticked\" cat", setup="echo bonjour > test'yo'\"sticked\"") + test("echo bonjour > test > je > suis", setup="", files=["test", "je", "suis"]) + test("echo > test > je bonjour > suis", setup="", files=["test", "je", "suis"]) + test("> test echo bonjour > je > suis", setup="", files=["test", "je", "suis"]) + test("echo bonjour >> test > je >> suis", setup="", files=["test", "je", "suis"]) + test("echo >> test bonjour > je > suis", setup="", files=["test", "je", "suis"]) + test(">> test echo > je bonjour > suis", setup="", files=["test", "je", "suis"]) + test("cat < test < je", setup="echo bonjour > test; echo salut > je") + test("echo bonjour>test>je>suis", setup="", files=["test", "je", "suis"]) + test(">test echo bonjour>je>suis", setup="", files=["test", "je", "suis"]) + test("echo bonjour>>test>je>>suis", setup="", files=["test", "je", "suis"]) + test("cat<test<je", setup="echo bonjour > test; echo salut > je") + test("echo bonjour > a'b'c'd'e'f'g'h'i'j'k'l'm'n'o'p'q'r's't'u'v'w'x'y'z'", + files=["abcdefghijklmnopqrstuvwxyz"]) + test('echo bonjour > a"b"c"d"e"f"g"h"i"j"k"l"m"n"o"p"q"r"s"t"u"v"w"x"y"z"', + files=["abcdefghijklmnopqrstuvwxyz"]) + test('echo bonjour > a\'b\'c"d"e\'f\'g"h"i\'j\'k"l"m\'n\'o"p\'q\'r"s\'t\'u"v"w"x"y\'z\'', + files=["abcdefghijklmnopqrstuvwxyz"]) + test("> file", files=["file"]) + test("< file", setup="echo bonjour > file") + test(">", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test(">>", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("<", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("echo >", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("echo >>", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("echo <", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("> test", files=["test"]) + test(">> test", files=["test"]) + test("< test", setup="touch test") + test("echo foo >>> bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("echo foo >>>> bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("echo foo >>>>> bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("cat << < bar", setup="echo bonjour > bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("cat << << bar", setup="echo bonjour > bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("cat <<<<< bar", setup="echo bonjour > bar", hook=hooks.error_line0, hook_status=hooks.platform_status(1, 2)) + test("cat < doesnotexist") + test("echo bonjour >> a", setup="echo a > a", files=["a"]) + test("echo bonjour >> a >> a", setup="echo a > a", files=["a"]) + test("echo bonjour > a", setup="echo a > a", files=["a"]) + test("echo bonjour > a >> a", setup="echo a > a", files=["a"]) + + +@suite() +def suite_cmd(test): + """ long cmd, cmd not found tests """ + test("notfound") + test("notfound a b c") + test('echo "\\"" >>a"b""c" ', files=["abc"]) + test("echo " + ''.join([chr(i) for i in range(1, 127) if chr(i) not in '\n`"\'()|&><'])) + test("echo foo>bar", files=["bar"]) + test("echo foo >bar", files=["bar"]) + test("echo foo> bar", files=["bar"]) + test("echo foo > bar", files=["bar"]) + test("echo a as df sad f as df qw e qwe as df asd f as df as d fas d f" + "asd f asd f asdf asdf asdf asd f asd f asd f asd f as df as df a" + "asd f asd f asdf asdf asdf asd f asd f asd f asd f as df as df a" + "asd f asd f asdf asdf asdf asd f asd f asd f asd f as df as df a") + test("echo " + config.LOREM * 10) + test("echo " + config.LOREM * 20) + + +@suite() +def suite_status(test): + """ $? tests """ + test("echo $?") + test("echo; echo $?") + test("notfound; echo $?") + test("cat < doesntexist; echo $?") + test("cat < noperm; echo $?", setup="echo bonjour > noperm; chmod 000 noperm") + test("echo") + test("notfound") + test("cat < doesntexist") + test("cat < noperm", setup="echo bonjour > noperm; chmod 000 noperm") + + +@suite() +def suite_cmd_path(test): + """ cmd is a relative path, permissions on executable """ + ls_path = distutils.spawn.find_executable("ls") + if ls_path is None: + print("Couldn't find `ls` in your PATH: Skipping suite") + return + cat_path = distutils.spawn.find_executable("cat") + if cat_path is None: + print("Couldn't find `cat` in your PATH: Skipping suite") + return + test(ls_path, setup="touch a b c") + test(ls_path + " -l", setup="touch a b c") + test("./bonjour", setup="touch a b c; cp {} bonjour".format(ls_path)) + test("./bonjour -l", setup="touch a b c; cp {} bonjour".format(ls_path)) + test("./somedir/bonjour -l", + setup="mkdir somedir; touch a b c; touch somedir/d somedir/e;" + "cp {} somedir/bonjour".format(ls_path)) + test("./ls . a b c", + setup="touch a b c; echo bonjour > a; cp {} ls".format(cat_path)) + test("ls . a b c", + setup="touch a b c; echo bonjour > a; cp {} ls".format(cat_path)) + test("./somefile", setup="echo > somefile; chmod 000 somefile") + test("./somefile", setup="echo > somefile; chmod 001 somefile") + test("./somefile", setup="echo > somefile; chmod 002 somefile") + test("./somefile", setup="echo > somefile; chmod 003 somefile") + test("./somefile", setup="echo > somefile; chmod 004 somefile") + test("./somefile", setup="echo > somefile; chmod 005 somefile") + test("./somefile", setup="echo > somefile; chmod 006 somefile") + test("./somefile", setup="echo > somefile; chmod 007 somefile") + test("./somefile", setup="echo > somefile; chmod 010 somefile") + test("./somefile", setup="echo > somefile; chmod 020 somefile") + test("./somefile", setup="echo > somefile; chmod 030 somefile") + test("./somefile", setup="echo > somefile; chmod 040 somefile") + test("./somefile", setup="echo > somefile; chmod 050 somefile") + test("./somefile", setup="echo > somefile; chmod 060 somefile") + test("./somefile", setup="echo > somefile; chmod 070 somefile") + test("./somefile", setup="echo > somefile; chmod 100 somefile") + test("./somefile", setup="echo > somefile; chmod 200 somefile") + test("./somefile", setup="echo > somefile; chmod 300 somefile") + test("./somefile", setup="echo > somefile; chmod 400 somefile") + test("./somefile", setup="echo > somefile; chmod 500 somefile") + test("./somefile", setup="echo > somefile; chmod 600 somefile") + test("./somefile", setup="echo > somefile; chmod 700 somefile") + test("./somefile", setup="echo > somefile; chmod 755 somefile") + test("./somefile", setup="echo > somefile; chmod 644 somefile") + test("./somefile", setup="echo > somefile; chmod 311 somefile") + test("./somefile", setup="echo > somefile; chmod 111 somefile") + test("./somefile", setup="echo > somefile; chmod 222 somefile") + test("./somefile", setup="echo > somefile; chmod 333 somefile") + test("somedir/", setup="mkdir somedir", hook=hooks.is_directory) + test("./somedir/", setup="mkdir somedir", hook=hooks.is_directory) + test("somedir", setup="mkdir somedir") + test("./somedir", setup="mkdir somedir", hook=hooks.is_directory) + test("somedir", setup="mkdir somedir") + test("somedirsoftlink/", setup="mkdir somedir; ln -s somedir somedirsoftlink", hook=hooks.is_directory) + test("./somedirsoftlink/", setup="mkdir somedir; ln -s somedir somedirsoftlink", hook=hooks.is_directory) + test("somedirsoftlink", setup="mkdir somedir; ln -s somedir somedirsoftlink") + test("./somedirsoftlink", setup="mkdir somedir; ln -s somedir somedirsoftlink", hook=hooks.is_directory) + test("somedirsoftlink", setup="mkdir somedir; ln -s somedir somedirsoftlink") + test("./someremovedlink", setup="touch somefile; ln -s somefile someremovedlink; rm -f somefile") + test("./somelink2", setup="touch somefile; ln -s somefile somelink1; ln -s somelink1 somelink2") + test("./somelink3", setup="touch somefile; ln -s somefile somelink1; ln -s somelink1 somelink2;" + "ln -s somelink2 somelink3") + test("./somelink4", setup="touch somefile; ln -s somefile somelink1; ln -s somelink1 somelink2;" + "ln -s somelink2 somelink3; ln -s somelink3 somelink4") + test("./somelink2ls", setup="cp " + ls_path + " somefile;" + "ln -s somefile somelink1; ln -s somelink1 somelink2") + test("./somelink3ls", setup="cp " + ls_path + " somefile;" + "ln -s somefile somelink1; ln -s somelink1 somelink2;" + "ln -s somelink2 somelink3") + test("./somelink4ls", setup="cp " + ls_path + " somefile;" + "ln -s somefile somelink1; ln -s somelink1 somelink2;" + "ln -s somelink2 somelink3; ln -s somelink3 somelink4") + test("_", setup="touch _") + test("'-'", setup="touch -") + test("./_", setup="touch _") + test("./-", setup="touch a; mv a ./-") + test("./.", setup="touch .", hook=hooks.is_directory) + test("./..", setup="touch ..", hook=hooks.is_directory) + test("./somefile", setup='echo > somefile && chmod 0777 somefile') + test("./somefile", setup='echo > somefile && chmod 1000 somefile') + test("./somefile", setup='echo > somefile && chmod 2000 somefile') + test("./somefile", setup='echo > somefile && chmod 3000 somefile') + test("./somefile", setup='echo > somefile && chmod 4000 somefile') + test("./somefile", setup='echo > somefile && chmod 5000 somefile') + test("./somefile", setup='echo > somefile && chmod 6000 somefile') + test("./somefile", setup='echo > somefile && chmod 7000 somefile') + test("./somefile", setup='echo > somefile && chmod 1777 somefile') + test("./somefile", setup='echo > somefile && chmod 2777 somefile') + test("./somefile", setup='echo > somefile && chmod 3777 somefile') + test("./somefile", setup='echo > somefile && chmod 4777 somefile') + test("./somefile", setup='echo > somefile && chmod 5777 somefile') + test("./somefile", setup='echo > somefile && chmod 6777 somefile') + test("./somefile", setup='echo > somefile && chmod 7777 somefile') + test("./somefile", setup='echo > somefile && chmod 0000 somefile') + test("./somedir", setup='mkdir -m 0777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 1000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 2000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 3000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 4000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 5000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 6000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 7000 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 1777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 2777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 3777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 4777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 5777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 6777 somedir', hook=hooks.is_directory) + test("./somedir", setup='mkdir -m 0000 somedir', hook=hooks.is_directory) + test("./Somefile", setup='echo > somefile && chmod 000 somefile') + test("./someFILE", setup='echo > somefile && chmod 000 somefile') + + +# @suite(bonus=True) +# def suite_cmd_variable(test): +# test("A=a sh -c 'echo $A'") +# test("A=a B=b sh -c 'echo $A$B'") +# test("A=a B=b C=c D=d E=e F=f G=g H=h sh -c 'echo $A$B$C$D$E$F$G$H'") +# test("A=a A=bonjour sh -c 'echo $A'") +# test("A=aA=bonjour sh -c 'echo $A'") +# test("BONJOURJESUIS=a sh -c 'echo $BONJOURJESUIS'") +# test("bonjourjesuis=a sh -c 'echo $bonjourjesuis'") +# test("bonjour_je_suis=a sh -c 'echo $bonjour_je_suis'") +# test("BONJOURJESUIS1=a sh -c 'echo $BONJOURJESUIS1'") +# test("bO_nJq123o__1ju_je3234sui__a=a sh -c 'echo $bO_nJq123o__1ju_je3234sui__a'") +# test("a0123456789=a sh -c 'echo $a0123456789'") +# test("abcdefghijklmnopqrstuvwxyz=a sh -c 'echo $abcdefghijklmnopqrstuvwxyz'") +# test("ABCDEFGHIJKLMNOPQRSTUVWXYZ=a sh -c 'echo $ABCDEFGHIJKLMNOPQRSTUVWXYZ'") +# test("__________________________=a sh -c 'echo $__________________________'") +# test("_bonjour_=a sh -c 'echo $_bonjour_'") +# test("_=a sh -c 'echo $_a'") +# test("1=a") +# test("BONJOURJESUIS =a sh -c 'echo $BONJOURJESUIS '") +# test("BONJOURJESUIS= a sh -c 'echo $BONJOURJESUIS'") +# test(r"BONJOUR\\JESUIS=a sh -c 'echo $BONJOUR\\JESUIS'") +# test(r'BONJOUR\'JESUIS=a sh -c "echo $BONJOUR\'JESUIS"') +# test(r'BONJOUR\"JESUIS=a sh -c "echo $BONJOUR\"JESUIS"') +# test(r"BONJOUR\$JESUIS=a sh -c 'echo $BONJOUR\$JESUIS'") +# test(r"BONJOUR\&JESUIS=a sh -c 'echo $BONJOUR\&JESUIS'") +# test(r"BONJOUR\|JESUIS=a sh -c 'echo $BONJOUR\|JESUIS'") +# test(r"BONJOUR\;JESUIS=a sh -c 'echo $BONJOUR\;JESUIS'") +# test(r"BONJOUR\_JESUIS=a sh -c 'echo $BONJOUR\_JESUIS'") +# test(r"BONJOUR\0JESUIS=a sh -c 'echo $BONJOUR\0JESUIS'") +# test(r"\B\O\N\ \ \ \ \ \ \ JOURJESUIS=a sh -c 'echo $\B\O\N\ \ \ \ \ \ \ JOURJESUIS'") +# test(r"A=\B\O\N\ \ \ \ \ \ \ JOURJESUIS sh -c 'echo $A'") +# test(r"A='bonjour je suis charles' sh -c 'echo $A'") +# test(r'A="bonjour je suis charles" sh -c "echo $A"') +# test(r"A==a sh -c 'echo $A'") +# test(r"A===a sh -c 'echo $A'") +# test(r"A====a sh -c 'echo $A'") +# test(r"A=====a sh -c 'echo $A'") +# test(r"A======a sh -c 'echo $A'") +# test(r"A=a=a=a=a=a sh -c 'echo $A'") +# +# test("A=a; echo $A") +# test("A=a B=b; echo $A$B") +# test("A=a B=b C=c D=d E=e F=f G=g H=h; echo $A$B$C$D$E$F$G$H") +# test("A=a A=bonjour; echo $A") +# test("A=aA=bonjour; echo $A") +# test("BONJOURJESUIS=a; echo $BONJOURJESUIS") |
