with 42shelltester error

This commit is contained in:
Antoine Riard 2017-03-24 17:43:33 +01:00
parent e213721aec
commit 7bdee8a2e0
403 changed files with 3536 additions and 5166 deletions

235
42sh/21sh_error Normal file
View file

@ -0,0 +1,235 @@
.x....................xxx...xxxx..x.
----------------------------------------------------------------
21sh/misc/002-simple-command-line (FAILED)
Description:
 The purpose of this test is to check that the Shell is able to execute a simple command line that contains separators `;`, pipes `|`, and a right redirection `>`.
Before test:
 01: rm -rf "./size"
02: rm -rf "TOKEN201703241734"
03: echo '^'$(echo TOKEN201703241734_FILE_TOKEN201703241734_STDOUT | wc -c)'$' > "./size"
STDIN:
 01: mkdir TOKEN201703241734 ; cd TOKEN201703241734 ; touch TOKEN201703241734_FILE ; ls -1 ; ls | cat | wc -c > TOKEN201703241734_STDOUT ; cat TOKEN201703241734_STDOUT
STDOUT:
 SUCCESS expected_to match_regex `TOKEN201703241734_FILE$`
 FAILURE expected_to match_each_regex_of_file `./size`
 01: TOKEN201703241734_FILE
02: 98839 redirect_great.c 24 3 1
03: 23
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
21sh/redirections/outputs/truncating/001-creates-file-if-not-exits (FAILED)
Description:
 The right redirection `>` opens the file with the oflag `O_CREAT` so that the file is created if it does not exists.
Before test:
 01: rm -f new_file
STDIN:
 01: ./write_on_stdout TOKEN201703241734 >new_file
STDOUT:
 SUCCESS expected_to_not match_regex `TOKEN201703241734`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file` matching_regex `TOKEN201703241734`
 FAILURE expected_to create_file `new_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/002-truncates-file-if-exists (FAILED)
Description:
 The right redirection `>` opens the file with the oflag `O_TRUNC` so that the file size is truncated to 0 before writing in it.
Before test:
 01: ./write_on_stdout TOKEN201703241734_first >truncated_file
STDIN:
 01: ./write_on_stdout TOKEN201703241734_second >truncated_file
STDOUT:
 SUCCESS expected_to_not match_regex TOKEN201703241734_second
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `truncated_file` matching_regex `TOKEN201703241734_second`
 SUCCESS expected_to create_file `truncated_file` not_matching_regex `TOKEN201703241734_first`
 FAILURE expected_to create_file `truncated_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/003-whitespace-before-filename (FAILED)
Description:
 The file name for a right redirection can be specified closely to the character `>` or in a separated field.
Before test:
 01: rm -f "new_file"
STDIN:
 01: ./write_on_stdout TOKEN201703241734 > new_file
STDOUT:
 SUCCESS expected_to_not match_regex `TOKEN201703241734`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file` matching_regex `TOKEN201703241734`
 FAILURE expected_to create_file `new_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/multiple/004-together (FAILED)
Description:
 A right redirection can be associated to the twice outputs by using `&>...`, that means `redirect stdout and stderr to ...`.
Before test:
 01: rm -f "new_file_stderr_and_stdout"
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241734_1 TOKEN201703241734_2 &>new_file_stderr_and_stdout
STDOUT:
 FAILURE expected_to_not match_regex `TOKEN201703241734_1`
 SUCCESS expected_to_not match_regex `TOKEN201703241734_2`
 01: TOKEN201703241734_1
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241734_1`
 FAILURE expected_to_not match_regex `TOKEN201703241734_2`
 01: TOKEN201703241734_2
MISC:
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241734_1$`
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241734_2$`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/multiple/005-together-with-whitespaces (FAILED)
Description:
 A right redirection can be associated to the twice outputs by using `&>...`, that means `redirect stdout and stderr to ...`.
In this test, we specify the file name in a separate field.
Before test:
 01: rm -f new_file_stderr_and_stdout
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241734_1 TOKEN201703241734_2 &> new_file_stderr_and_stdout
STDOUT:
 FAILURE expected_to_not match_regex `TOKEN201703241734_1`
 SUCCESS expected_to_not match_regex `TOKEN201703241734_2`
 01: TOKEN201703241734_1
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241734_1`
 FAILURE expected_to_not match_regex `TOKEN201703241734_2`
 01: TOKEN201703241734_2
MISC:
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241734_1$`
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241734_2$`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/stderr/001-works (FAILED)
Description:
 The purpose of this test is to check that redirecting the standard error STDERR to a file `2>` works. In this test, the binary writes a token on each standard and error output, so that only the STDOUT is outputted and STDERR is written in a file `new_file_stderr`.
Before test:
 01: rm -f "./new_file_stderr"
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241734_STDOUT TOKEN201703241734_STDERR 2>new_file_stderr
STDOUT:
 SUCCESS expected_to match_regex `TOKEN201703241734_STDOUT`
 01: TOKEN201703241734_STDOUT
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241734_STDERR`
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file_stderr` matching_regex `TOKEN201703241734_STDERR`
 FAILURE expected_to create_file `new_file_stderr` with_nb_of_lines 1
----------------------------------------------------------------
21sh/redirections/outputs/truncating/stdout/001-with-explicit-fd (FAILED)
Description:
 The purpose of this test is to check if '1>' redirect STDIN to a file.
We are using echo with one argument. The output should NOT return anything on the standard output.
Before test:
 01: rm -f new_file
STDIN:
 01: /bin/echo TOKEN1 1>new_file
STDOUT:
 SUCCESS expected_to_not match_regex TOKEN1
 (no output)
STDERR:
 (no output)
MISC:
 SUCCESS expected_to create_file new_file matching_regex TOKEN1
 FAILURE expected_to create_file new_file with_nb_of_lines 1
----------------------------------------------------------------
21sh/separators/semicolon/003-parse-error-empty-inline-command (FAILED)
Description:
 The purpose of this test is to check that using the simicolon separator `;` with empty commands results in error.
STDIN:
 01: ./write_on_stdout TOKEN201703241734 ; ; ./exit_with_status 42
STDOUT:
 SUCCESS expected_to be_empty
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `([Ss]yntax|[Pp]arse) error`
 01: syntax error near unexpected token `;'
MISC:
 SUCCESS expected_to_not exit_with_status `42`
 FAILURE expected_to_not exit_with_status `0`
Total tests: 36
Total failed tests: 9
Total pending tests: 0

View file

@ -8,7 +8,7 @@
It brings you an easy way to **add**, **maintain** and **run** integration tests, helping you to work step by step on your Shell implementation.
<!--START_TOTAL_TESTS-->
42ShellTester is currently packaged with **304 tests**.
42ShellTester is currently packaged with **289 tests**.
<!--END_TOTAL_TESTS-->
## Install
@ -302,25 +302,6 @@ Also display tests that succeed (hidden by default).
* [002-it-works-2](spec/42sh/quoting/simple-quotes/mixed/globbing/bracket-expansion/002-it-works-2)
* **[variable-expansion/](spec/42sh/quoting/simple-quotes/mixed/variable-expansion)**
* [001-expansion-disabled](spec/42sh/quoting/simple-quotes/mixed/variable-expansion/001-expansion-disabled)
* **[shellscript/](spec/42sh/shellscript)**
* **[if/](spec/42sh/shellscript/if)**
* [001-simple-if-1](spec/42sh/shellscript/if/001-simple-if-1)
* [002-simple-if-2](spec/42sh/shellscript/if/002-simple-if-2)
* [003-simple-if-3](spec/42sh/shellscript/if/003-simple-if-3)
* [004-nested-if](spec/42sh/shellscript/if/004-nested-if)
* [005-hard-nested-if](spec/42sh/shellscript/if/005-hard-nested-if)
* **[until/](spec/42sh/shellscript/until)**
* [001-simple-until-1](spec/42sh/shellscript/until/001-simple-until-1)
* [002-simple-until-2](spec/42sh/shellscript/until/002-simple-until-2)
* [003-simple-until-3](spec/42sh/shellscript/until/003-simple-until-3)
* [004-nested-until](spec/42sh/shellscript/until/004-nested-until)
* [005-hard-nested-until](spec/42sh/shellscript/until/005-hard-nested-until)
* **[while/](spec/42sh/shellscript/while)**
* [001-simple-while-1](spec/42sh/shellscript/while/001-simple-while-1)
* [002-simple-while-2](spec/42sh/shellscript/while/002-simple-while-2)
* [003-simple-while-3](spec/42sh/shellscript/while/003-simple-while-3)
* [004-nested-while](spec/42sh/shellscript/while/004-nested-while)
* [005-hard-nested-while](spec/42sh/shellscript/while/005-hard-nested-while)
* **[subshell/](spec/42sh/subshell)**
* [001-tokens-are-recognized](spec/42sh/subshell/001-tokens-are-recognized)
* [002-multiple-levels-of-subshells](spec/42sh/subshell/002-multiple-levels-of-subshells)
@ -562,8 +543,6 @@ Find the available list of support binaries bellow:
<!--START_SUPPORT_BINARIES_LIST-->
* **[./create_file](http://github.com/we-sh/42ShellTester/tree/master/support/create-file)**: A binary that creates file named argv[1] + "_FILE" If argv[1] is not set, the file is named "TOKEN_FILE"
* **[./delete_file](http://github.com/we-sh/42ShellTester/tree/master/support/delete-file)**: A binary that delete all files called in argument.
* **[./display_env](http://github.com/we-sh/42ShellTester/tree/master/support/display-env)**: A binary that iterates on `**envp` and write each element on standard output.
* **[./display_program_name](http://github.com/we-sh/42ShellTester/tree/master/support/display-program-name)**: A binary that writes its name on standard ouput.
* **[./display_pwd](http://github.com/we-sh/42ShellTester/tree/master/support/display-pwd)**: A binary that writes on standard output the absolute path of the current directory returned by `getcwd(3)`, encountered with the strings `PWD:` and `:PWD`.
@ -593,4 +572,3 @@ Find the available list of support binaries bellow:
Edouard Audeguy
Illustrateur / Infographiste
https://edouardaudeguy.wix.com/portfolio
# 42shelltest-tmp

View file

Before

Width:  |  Height:  |  Size: 88 KiB

After

Width:  |  Height:  |  Size: 88 KiB

View file

Before

Width:  |  Height:  |  Size: 12 KiB

After

Width:  |  Height:  |  Size: 12 KiB

View file

Before

Width:  |  Height:  |  Size: 20 KiB

After

Width:  |  Height:  |  Size: 20 KiB

View file

Before

Width:  |  Height:  |  Size: 21 KiB

After

Width:  |  Height:  |  Size: 21 KiB

View file

Before

Width:  |  Height:  |  Size: 5 KiB

After

Width:  |  Height:  |  Size: 5 KiB

View file

Before

Width:  |  Height:  |  Size: 5.2 KiB

After

Width:  |  Height:  |  Size: 5.2 KiB

View file

Before

Width:  |  Height:  |  Size: 570 B

After

Width:  |  Height:  |  Size: 570 B

View file

Before

Width:  |  Height:  |  Size: 725 B

After

Width:  |  Height:  |  Size: 725 B

View file

Before

Width:  |  Height:  |  Size: 654 B

After

Width:  |  Height:  |  Size: 654 B

235
42sh/42ShellTester/log Normal file
View file

@ -0,0 +1,235 @@
.x....................xxx...xxxx..x.
----------------------------------------------------------------
21sh/misc/002-simple-command-line (FAILED)
Description:
 The purpose of this test is to check that the Shell is able to execute a simple command line that contains separators `;`, pipes `|`, and a right redirection `>`.
Before test:
 01: rm -rf "./size"
02: rm -rf "TOKEN201703241733"
03: echo '^'$(echo TOKEN201703241733_FILE_TOKEN201703241733_STDOUT | wc -c)'$' > "./size"
STDIN:
 01: mkdir TOKEN201703241733 ; cd TOKEN201703241733 ; touch TOKEN201703241733_FILE ; ls -1 ; ls | cat | wc -c > TOKEN201703241733_STDOUT ; cat TOKEN201703241733_STDOUT
STDOUT:
 SUCCESS expected_to match_regex `TOKEN201703241733_FILE$`
 FAILURE expected_to match_each_regex_of_file `./size`
 01: TOKEN201703241733_FILE
02: 94296 redirect_great.c 24 3 1
03: 23
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
21sh/redirections/outputs/truncating/001-creates-file-if-not-exits (FAILED)
Description:
 The right redirection `>` opens the file with the oflag `O_CREAT` so that the file is created if it does not exists.
Before test:
 01: rm -f new_file
STDIN:
 01: ./write_on_stdout TOKEN201703241733 >new_file
STDOUT:
 SUCCESS expected_to_not match_regex `TOKEN201703241733`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file` matching_regex `TOKEN201703241733`
 FAILURE expected_to create_file `new_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/002-truncates-file-if-exists (FAILED)
Description:
 The right redirection `>` opens the file with the oflag `O_TRUNC` so that the file size is truncated to 0 before writing in it.
Before test:
 01: ./write_on_stdout TOKEN201703241733_first >truncated_file
STDIN:
 01: ./write_on_stdout TOKEN201703241733_second >truncated_file
STDOUT:
 SUCCESS expected_to_not match_regex TOKEN201703241733_second
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `truncated_file` matching_regex `TOKEN201703241733_second`
 SUCCESS expected_to create_file `truncated_file` not_matching_regex `TOKEN201703241733_first`
 FAILURE expected_to create_file `truncated_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/003-whitespace-before-filename (FAILED)
Description:
 The file name for a right redirection can be specified closely to the character `>` or in a separated field.
Before test:
 01: rm -f "new_file"
STDIN:
 01: ./write_on_stdout TOKEN201703241733 > new_file
STDOUT:
 SUCCESS expected_to_not match_regex `TOKEN201703241733`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file` matching_regex `TOKEN201703241733`
 FAILURE expected_to create_file `new_file` with_nb_of_lines `1`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/multiple/004-together (FAILED)
Description:
 A right redirection can be associated to the twice outputs by using `&>...`, that means `redirect stdout and stderr to ...`.
Before test:
 01: rm -f "new_file_stderr_and_stdout"
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241733_1 TOKEN201703241733_2 &>new_file_stderr_and_stdout
STDOUT:
 FAILURE expected_to_not match_regex `TOKEN201703241733_1`
 SUCCESS expected_to_not match_regex `TOKEN201703241733_2`
 01: TOKEN201703241733_1
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241733_1`
 FAILURE expected_to_not match_regex `TOKEN201703241733_2`
 01: TOKEN201703241733_2
MISC:
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241733_1$`
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241733_2$`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/multiple/005-together-with-whitespaces (FAILED)
Description:
 A right redirection can be associated to the twice outputs by using `&>...`, that means `redirect stdout and stderr to ...`.
In this test, we specify the file name in a separate field.
Before test:
 01: rm -f new_file_stderr_and_stdout
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241733_1 TOKEN201703241733_2 &> new_file_stderr_and_stdout
STDOUT:
 FAILURE expected_to_not match_regex `TOKEN201703241733_1`
 SUCCESS expected_to_not match_regex `TOKEN201703241733_2`
 01: TOKEN201703241733_1
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241733_1`
 FAILURE expected_to_not match_regex `TOKEN201703241733_2`
 01: TOKEN201703241733_2
MISC:
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241733_1$`
 FAILURE expected_to create_file `new_file_stderr_and_stdout` matching_regex `TOKEN201703241733_2$`
----------------------------------------------------------------
21sh/redirections/outputs/truncating/stderr/001-works (FAILED)
Description:
 The purpose of this test is to check that redirecting the standard error STDERR to a file `2>` works. In this test, the binary writes a token on each standard and error output, so that only the STDOUT is outputted and STDERR is written in a file `new_file_stderr`.
Before test:
 01: rm -f "./new_file_stderr"
STDIN:
 01: ./write_on_stdout_and_stderr TOKEN201703241733_STDOUT TOKEN201703241733_STDERR 2>new_file_stderr
STDOUT:
 SUCCESS expected_to match_regex `TOKEN201703241733_STDOUT`
 01: TOKEN201703241733_STDOUT
STDERR:
 SUCCESS expected_to_not match_regex `TOKEN201703241733_STDERR`
 (no output)
MISC:
 SUCCESS expected_to create_file `new_file_stderr` matching_regex `TOKEN201703241733_STDERR`
 FAILURE expected_to create_file `new_file_stderr` with_nb_of_lines 1
----------------------------------------------------------------
21sh/redirections/outputs/truncating/stdout/001-with-explicit-fd (FAILED)
Description:
 The purpose of this test is to check if '1>' redirect STDIN to a file.
We are using echo with one argument. The output should NOT return anything on the standard output.
Before test:
 01: rm -f new_file
STDIN:
 01: /bin/echo TOKEN1 1>new_file
STDOUT:
 SUCCESS expected_to_not match_regex TOKEN1
 (no output)
STDERR:
 (no output)
MISC:
 SUCCESS expected_to create_file new_file matching_regex TOKEN1
 FAILURE expected_to create_file new_file with_nb_of_lines 1
----------------------------------------------------------------
21sh/separators/semicolon/003-parse-error-empty-inline-command (FAILED)
Description:
 The purpose of this test is to check that using the simicolon separator `;` with empty commands results in error.
STDIN:
 01: ./write_on_stdout TOKEN201703241733 ; ; ./exit_with_status 42
STDOUT:
 SUCCESS expected_to be_empty
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `([Ss]yntax|[Pp]arse) error`
 01: syntax error near unexpected token `;'
MISC:
 SUCCESS expected_to_not exit_with_status `42`
 FAILURE expected_to_not exit_with_status `0`
Total tests: 36
Total failed tests: 9
Total pending tests: 0

View file

@ -12,8 +12,6 @@ all:
make TARGET_DIR=$(TARGET_DIR) -C ./write-on-stderr
make TARGET_DIR=$(TARGET_DIR) -C ./write-on-stdout
make TARGET_DIR=$(TARGET_DIR) -C ./write-on-stdout-and-stderr
make TARGET_DIR=$(TARGET_DIR) -C ./create-file
make TARGET_DIR=$(TARGET_DIR) -C ./delete-file
re: fclean all
@ -27,5 +25,5 @@ fclean:
make TARGET_DIR=$(TARGET_DIR) fclean -C ./sleep-and-write-on-stderr
make TARGET_DIR=$(TARGET_DIR) fclean -C ./write-all-arguments-on-stdout
make TARGET_DIR=$(TARGET_DIR) fclean -C ./write-on-stderr
make TARGET_DIR=$(TARGET_DIR) fclean -C ./create-file
make TARGET_DIR=$(TARGET_DIR) fclean -C ./delete-file
make TARGET_DIR=$(TARGET_DIR) fclean -C ./write-on-stdout
make TARGET_DIR=$(TARGET_DIR) fclean -C ./write-on-stdout-and-stderr

2501
42sh/42sh_error Normal file

File diff suppressed because it is too large Load diff

View file

@ -1 +0,0 @@
xxxx.x

View file

@ -1,933 +0,0 @@
...xxxxxxxxxxxxxxxxxxx~xxxxxxxxx..xxxxx..xxx....x....x
----------------------------------------------------------------
minishell/binary/004-binary-test-empty-path (FAILED)
Description:
 The purpose of this test is to check that the Shell finds binaries that are located in the current directory when the environment variable PATH is empty.
Before test:
 01: export PATH=""
STDIN:
 01: write_on_stdout "TOKEN201703202355"
STDOUT:
 FAILURE expected_to match_regex `TOKEN201703202355`
 (no output)
STDERR:
 FAILURE expected_to be_empty
 01: minishell: command not found: write_on_stdout
MISC:
 SUCCESS expected_to exit_with_status `0`
----------------------------------------------------------------
minishell/binary/005-binary-test-wrong-path (FAILED)
Description:
 This test purpose is to check if your shell is not able to use binary with a wrong PATH
We are changing the actual PATH by PATH=NULL
And executing the commande ls
Before test:
 01: export PATH="/"
STDIN:
 01: ls
STDOUT:
 SUCCESS might be_empty
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `[Cc]ommand not found`
 01: minishell: command not found: ls
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/binary/006-binary-undefined-path (FAILED)
Description:
 The purpose of this test is to check that the Shell retrieves the default value of the environment variable PATH if not set. This test depends on the presence of the UNIX binary `ls`, located in a path within the default environment variable PATH.
Before test:
 01: rm -rf "TOKEN201703202355_006-BINARY-UNDEFINED-PATH"
02: touch "TOKEN201703202355_006-BINARY-UNDEFINED-PATH"
03: unset PATH
STDIN:
 01: ls
STDOUT:
 FAILURE expected_to match_regex `TOKEN201703202355_006-BINARY-UNDEFINED-PATH`
 (no output)
STDERR:
 FAILURE expected_to be_empty
 01: minishell: command not found: ls
MISC:
 SUCCESS expected_to exit_with_status `0`
----------------------------------------------------------------
minishell/binary/007-binary-permission-denied (FAILED)
Description:
 The purpose of this test is to check that trying to execute a non-permitted binary results in an error on standard error and a failure exit status.
Before test:
 01: rm -rf ./permission_denied
02: touch ./permission_denied
03: chmod 0 ./permission_denied
STDIN:
 01: ./permission_denied
STDOUT:
 SUCCESS might be_empty
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `[Pp]ermission denied`
 01: minishell: permission denied: ./permission_denied
MISC:
 FAILURE expected_to_not exit_with_status 0
After test:
 01: if [ -d "./permission_denied" ]; then chmod 777 "./permission_denied"; fi
02: rm -rf "./permission_denied"
----------------------------------------------------------------
minishell/binary/008-binary-too-many-symbolic-links-encountered (FAILED)
Description:
 The purpose of this test is to check that trying to execute a path that encounters an infinite loop of symbolic link results in an error on standard error and a failure exit status.
Before test:
 01: rm -rf ./symbolic_link1 ./symbolic_link2 ./symbolic_link3
02: ln -s ./symbolic_link1 ./symbolic_link2
03: ln -s ./symbolic_link2 ./symbolic_link3
04: ln -s ./symbolic_link3 ./symbolic_link1
STDIN:
 01: ./symbolic_link1
STDOUT:
 SUCCESS might be_empty
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 WARNING might match_regex `[Tt]oo many.*symbolic links`
 01: minishell: ./symbolic_link1: no such file or directory
MISC:
 FAILURE expected_to_not exit_with_status 0
----------------------------------------------------------------
minishell/builtins/cd/001-no-arg (FAILED)
Description:
 The purpose of this test is to check that using the builtin `cd` without any argument results in moving to the HOME directory.
STDIN:
 01: cd
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 SUCCESS expected_to_not match_regex `/Users/ariard/Projects/42sh/42shelltest-tmp/tmp$`
 FAILURE expected_to match_regex `PWD:/Users/ariard:PWD`
 01: /Users/ariard
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/002-current-directory (FAILED)
Description:
 The purpose of this test is to check that using `.` as first argument with the builtin `cd` results in not changing current directory.
STDIN:
 01: cd .
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/003-current-directory-2 (FAILED)
Description:
 The purpose of this test is to check that using a relative path to the current directory as argument with the builtin `cd` results in not changing the current directory. The environment variable must not be changed.
STDIN:
 01: cd ../tmp
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/004-parent-directory (FAILED)
Description:
 The purpose of this test is to check that using `..` as first argument with the builtin `cd` results in moving to the parent directory.
STDIN:
 01: cd ..
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp:PWD$`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/005-root-path (FAILED)
Description:
 The purpose of this test is to check that using the root path as first argument with the builtin `cd` results in moving to the correct directory.
STDIN:
 01: cd /
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/:PWD`
 FAILURE expected_to match_regex `^PWD=/$`
 01: PWD:/:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/006-root-path-2 (FAILED)
Description:
 The purpose of this test is to check that using the root path as first argument with the builtin `cd` results in moving to the correct directory.
STDIN:
 01: cd /.
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/:PWD`
 FAILURE expected_to match_regex `^PWD=/$`
 01: PWD:/:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/007-symbolic-link (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link as first argument with the builtin `cd` results in moving the linked directory.
Before test:
 01: rm -f "./symbolic_link"
02: mkdir -p "./sub_directory"
03: ln -s "./sub_directory" "./symbolic_link"
STDIN:
 01: cd symbolic_link
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/sub_directory:PWD$`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/symbolic_link$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/sub_directory:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/008-symbolic-link-2 (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link as first argument with the builtin `cd` results in moving to the linked directory. In this test, the directory is linked with to chained symbolic links.
Before test:
 01: rm -f "./symbolic_link1" "./symbolic_link2"
02: mkdir -p "./sub_directory"
03: ln -s "./sub_directory" "./symbolic_link1"
04: ln -s "./symbolic_link1" "./symbolic_link2"
STDIN:
 01: cd symbolic_link2
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/sub_directory:PWD$`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/symbolic_link2$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/sub_directory:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/010-update-OLDPWD (FAILED)
Description:
 The purpose of this test is to check that using the builtin `cd` results in a modified environment variable `PWD`.
Before test:
 01: rm -rf "TOKEN201703202355"
02: mkdir -p "./TOKEN201703202355/TOKEN201703202355"
STDIN:
 01: cd TOKEN201703202355
02: cd TOKEN201703202355
03: ../../display_env
STDOUT:
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/TOKEN201703202355/TOKEN201703202355$`
 FAILURE expected_to match_regex `^OLDPWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/TOKEN201703202355$`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/011-dotdot (FAILED)
Description:
 The purpose of this test is to check that playing with relative paths with the builtin `cd` results in correctly changing the current directory.
Before test:
 01: rm -rf "playing_with_dotdot"
02: mkdir -p "playing_with_dotdot/1/2/3/4/5/6/7/8/9/10"
STDIN:
 01: cd playing_with_dotdot
02: cd ../playing_with_dotdot
03: cd 1/2/3/4/../4/../4/../../3/4/5/6/7/8/9/10
04: cd ../../../../../../../../../../1/2/3/4/5
05: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
06: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/playing_with_dotdot/1/2/3/4/5:PWD`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/playing_with_dotdot/1/2/3/4/5$`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/012-dot (FAILED)
Description:
 The purpose of this test is to check that playing with relative paths to the current directory with the builtin `cd` results in not changing the current directory.
STDIN:
 01: cd .
02: cd ./
03: cd ./.
04: cd ././
05: cd ./././././././././.
06: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
07: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/013-absolute-path (FAILED)
Description:
 The purpose of this test is to check that using an absolute path as first argument with the builtin `cd` results in moving to the correct directory.
Before test:
 01: rm -rf "./my_sub_directory"
02: mkdir -p "./my_sub_directory/and_another_one/"
STDIN:
 01: cd /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/my_sub_directory/and_another_one
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/my_sub_directory/and_another_one:PWD`
 FAILURE expected_to match_regex `^PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/my_sub_directory/and_another_one$`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/my_sub_directory/and_another_one:PWD
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/errors/001-not-a-directory (FAILED)
Description:
 The purpose of this test is to check that using a file name as first argument with the builtin `cd` results in error and not changing current directory.
Before test:
 01: touch "./not_a_directory"
STDIN:
 01: cd not_a_directory
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 WARNING might match_regex `[Nn]ot a directory`
 01: cd: no such file or directory: not_a_directory
----------------------------------------------------------------
minishell/builtins/cd/errors/002-not-a-directory-2 (FAILED)
Description:
 The purpose of this test is to check that using a file name as first argument with the builtin `cd` results in a Shell termination with a failure exit status.
Before test:
 01: touch "./not_a_directory"
STDIN:
 01: cd not_a_directory
STDOUT:
 (no output)
STDERR:
 01: cd: no such file or directory: not_a_directory
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/cd/errors/003-permission-denied (WARNING)
Description:
 The purpose of this test is to check that using a directory without any permission as first argument with the builtin `cd` results in error and not changing current directory.
Before test:
 01: if [ -d "./permission_denied" ]; then chmod 777 "./permission_denied"; fi
02: rm -rf "./permission_denied"
03: mkdir -m 0 "./permission_denied"
STDIN:
 01: cd permission_denied
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 SUCCESS expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 01: PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD
STDERR:
 SUCCESS expected_to_not be_empty
 WARNING might match_regex `[Pp]ermission denied`
 01: cd: no such file or directory: permission_denied
After test:
 01: if [ -d "./permission_denied" ]; then chmod 777 "./permission_denied"; fi
02: rm -rf "./permission_denied"
----------------------------------------------------------------
minishell/builtins/cd/errors/004-permission-denied-2 (FAILED)
Description:
 The purpose of this test is to check that using a directory without any permission as first argument with the builtin `cd` results in error and not changing current directory.
Before test:
 01: if [ -d "./permission_denied" ]; then chmod 777 "./permission_denied"; fi
02: rm -rf "./permission_denied"
03: mkdir -m 0 "./permission_denied"
STDIN:
 01: cd permission_denied
STDOUT:
 (no output)
STDERR:
 01: cd: no such file or directory: permission_denied
MISC:
 FAILURE expected_to_not exit_with_status `0`
After test:
 01: if [ -d "./permission_denied" ]; then chmod 777 "./permission_denied"; fi
02: rm -rf "./permission_denied"
----------------------------------------------------------------
minishell/builtins/cd/errors/005-too-many-symbolic-links-encountered (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link resulting in ELOOP error as first argument with the builtin `cd` results in error and not changing current directory.
Before test:
 01: rm -f "./symbolic_link1" "./symbolic_link2" "./symbolic_link3"
02: ln -s "./symbolic_link1" "./symbolic_link2"
03: ln -s "./symbolic_link2" "./symbolic_link3"
04: ln -s "./symbolic_link3" "./symbolic_link1"
STDIN:
 01: cd symbolic_link1
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 WARNING might match_regex `[Tt]oo many.*symbolic links`
 01: cd: no such file or directory: symbolic_link1
----------------------------------------------------------------
minishell/builtins/cd/errors/006-too-many-symbolic-links-encountered-2 (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link resulting in ELOOP error as first argument with the builtin `cd` results in a Shell termination with a failure exit status.
Before test:
 01: rm -f "./symbolic_link1" "./symbolic_link2" "./symbolic_link3"
02: ln -s "./symbolic_link1" "./symbolic_link2"
03: ln -s "./symbolic_link2" "./symbolic_link3"
04: ln -s "./symbolic_link3" "./symbolic_link1"
STDIN:
 01: cd symbolic_link1
STDOUT:
 (no output)
STDERR:
 01: cd: no such file or directory: symbolic_link1
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/cd/errors/007-no-such-file-or-directory (FAILED)
Description:
 The purpose of this test is to check that using a non-existing path as first argument with the builtin `cd` results in error and not changing current directory.
Before test:
 01: rm -f "./no_such_file_or_directory"
STDIN:
 01: cd no_such_file_or_directory
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `[Nn]o such file or directory`
 01: cd: no such file or directory: no_such_file_or_directory
----------------------------------------------------------------
minishell/builtins/cd/errors/008-no-such-file-or-directory-2 (FAILED)
Description:
 The purpose of this test is to check that using a non-existing path as first argument with the builtin `cd` results in a Shell termination with an error status code.
Before test:
 01: rm -f "./no_such_file_or_directory"
STDIN:
 01: cd no_such_file_or_directory
STDOUT:
 (no output)
STDERR:
 01: cd: no such file or directory: no_such_file_or_directory
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/cd/errors/009-no-such-file-or-directory-symlink (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link that targets to a non-existing directory with the builtin `cd` results in error and not changing current directory.
Before test:
 01: rm -rf "./enoent_symlink" "./enoent_directory"
02: ln -s "./enoent_directory" "./enoent_symlink"
STDIN:
 01: cd ./enoent_symlink
02: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `[Nn]o such file or directory`
 01: cd: no such file or directory: ./enoent_symlink
----------------------------------------------------------------
minishell/builtins/cd/errors/010-no-such-file-or-directory-symlink-2 (FAILED)
Description:
 The purpose of this test is to check that using a symbolic link that targets to a non-existing directory with the builtin `cd` results in error and not changing current directory.
Before test:
 01: rm -rf "./enoent_symlink" "./enoent_directory"
02: ln -s "./enoent_directory" "./enoent_symlink"
STDIN:
 01: cd ./enoent_symlink
STDOUT:
 (no output)
STDERR:
 01: cd: no such file or directory: ./enoent_symlink
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/cd/options/001-not-following-links (FAILED)
Description:
 The purpose of this test is to check that using symbolic links twice with the builtin `cd` and the option `-P` results in a correct environment variable PWD. The option `-P` makes the Shell to resolve symbolic links.
Before test:
 01: rm -fr "./sub_directory_link" "./sub_directory"
02: mkdir -p "./sub_directory/sub_sub_directory"
03: ln -s "./sub_directory" "./sub_directory_link"
04: ln -s "./sub_sub_directory" "./sub_directory/sub_sub_directory_link"
STDIN:
 01: cd -P sub_directory_link
02: cd -P sub_sub_directory_link
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_env
STDOUT:
 FAILURE expected_to match_regex `PWD=/Users/ariard/Projects/42sh/42shelltest-tmp/tmp/sub_directory/sub_sub_directory`
 (no output)
STDERR:
 SUCCESS might be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/cd/options/002-oldpwd (FAILED)
Description:
 The purpose of this test is to check that using `-` as first argument with the builtin `cd` results in moving the previous current directory.
STDIN:
 01: cd /
02: cd -
03: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp/display_pwd
STDOUT:
 FAILURE expected_to match_regex `PWD:/Users/ariard/Projects/42sh/42shelltest-tmp/tmp:PWD`
 01: /Users/ariard/Projects/42sh/42shelltest-tmp/tmp
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/env/003-ignore-environment (FAILED)
Description:
 The purpose of this test is to check that using the option `-i` with the builtin `env` results in an empty environment sent to the given command.
STDIN:
 01: env -i ./display_env
STDOUT:
 FAILURE expected_to match_regex `TOTAL ENVIRONMENT VARIABLES: 0`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/env/005-set-variables (FAILED)
Description:
 The purpose of this test is to check that the builtin `env` can modify or set multiple environment variables before executing the given command.
Before test:
 01: export VARTEST1="OLD_VALUE"
STDIN:
 01: env VARTEST1=TOKEN201703202355_1 VARTEST2=TOKEN201703202355_2 VARTEST3=TOKEN201703202355_3 ./display_env
STDOUT:
 FAILURE expected_to match_regex `VARTEST1=TOKEN201703202355_1`
 FAILURE expected_to match_regex `VARTEST2=TOKEN201703202355_2`
 FAILURE expected_to match_regex `VARTEST3=TOKEN201703202355_3`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/env/errors/001-command-not-found (FAILED)
Description:
 The purpose of this test is to check that using the builtin `env` with an invalid binary as argument results in an error and failure exit status.
Before test:
 01: rm -f "./invalid_binary"
STDIN:
 01: env ./invalid_binary
STDOUT:
 (no output)
STDERR:
 FAILURE expected_to_not be_empty
 WARNING might match_regex `[Cc]ommand not found`
 (no output)
MISC:
 SUCCESS expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/env/errors/002-illegal-option (FAILED)
Description:
 The purpose of this test is to check that using the builtin `env` with an invalid option results in an error and failure exit status.
Before test:
 01: rm -f -- "-w"
STDIN:
 01: env -w
STDOUT:
 (no output)
STDERR:
 SUCCESS expected_to_not be_empty
 SUCCESS might match_regex `([Ii]nvalid|[Ii]llegal) (option|argument)`
 01: env: illegal option -- w
02: usage: env [-i] [-u name] [name=value]... [utility [argument...]]
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/env/multiple-options/001-ignore-environment-and-set-variable (FAILED)
Description:
 The purpose of this test is to check that `env -i` works if we use a second argument to set an environment variable, we are also checking if this command unset environments variables for a given binary.
STDIN:
 01: env -i TESTVARIABLE=TOKEN201703202355 ./display_env
STDOUT:
 FAILURE expected_to match_regex `TESTVARIABLE=TOKEN201703202355`
 FAILURE expected_to match_regex `TOTAL ENVIRONMENT VARIABLES: 1`
 (no output)
STDERR:
 SUCCESS expected_to be_empty
 (no output)
----------------------------------------------------------------
minishell/builtins/exit/003-status-of-last-command (FAILED)
Description:
 The purpose of this test is to check that using the builtin `exit` without any argument results in a Shell termination and the exit status of the previous command.
STDIN:
 01: ./exit_with_status 42
02: exit
STDOUT:
 SUCCESS might be_empty
 (no output)
STDERR:
 (no output)
MISC:
 FAILURE expected_to exit_with_status `42`
----------------------------------------------------------------
minishell/builtins/exit/errors/001-too-many-args (FAILED)
Description:
 The purpose of this test is to check that using a wrong number of arguments with the builtin `exit` does not result in the Shell termination but an error on standard error.
STDIN:
 01: exit 21 42
02: ./write_on_stdout TOKEN201703202355
STDOUT:
 FAILURE expected_to match_regex `TOKEN201703202355`
 (no output)
STDERR:
 FAILURE expected_to_not be_empty
 WARNING might match_regex `([Tt]oo many arguments|[Aa]rgument list too long)`
 (no output)
MISC:
 FAILURE expected_to exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/exit/errors/002-non-numeric-argument (FAILED)
Description:
 The purpose of this test is to check that using a non-numeric argument with the builtin `exit` results in the Shell termination and an error on standard error.
STDIN:
 01: exit abc
02: ./write_on_stdout TOKEN201703202355
STDOUT:
 SUCCESS expected_to_not match_regex `TOKEN201703202355`
 (no output)
STDERR:
 WARNING might_not be_empty
 WARNING might match_regex `[Nn]umeric argument required`
 (no output)
MISC:
 FAILURE expected_to_not exit_with_status `0`
----------------------------------------------------------------
minishell/builtins/setenv/004-invalid-identifier (FAILED)
Description:
 The purpose of this test is to check that using a wrong variable name with the builtin `setenv` (or `export`) results in error.
STDIN:
 01: setenv 42
02: export 42
STDOUT:
 SUCCESS might be_empty
 (no output)
STDERR:
 FAILURE expected_to_not be_empty
 WARNING might match_regex `(not.*identifier|must begin.*letter)`
 (no output)
----------------------------------------------------------------
minishell/misc/001-copy-of-environment (FAILED)
Description:
 A Shell must send a copy of the environment to its child processes.
Before test:
 01: export COPYENV_VAR1="TOKEN201703202355_VAR1"
02: export COPYENV_VAR2="TOKEN201703202355_VAR2"
03: export COPYENV_VAR3="TOKEN201703202355_VAR3"
STDIN:
 01: ./display_env
STDOUT:
 FAILURE expected_to match_regex `COPYENV_VAR1=TOKEN201703202355_VAR1`
 FAILURE expected_to match_regex `COPYENV_VAR2=TOKEN201703202355_VAR2`
 FAILURE expected_to match_regex `COPYENV_VAR3=TOKEN201703202355_VAR3`
 (no output)
STDERR:
 (no output)
Total tests: 54
Total failed tests: 38
Total pending tests: 0

View file

@ -1,9 +0,0 @@
# bonuses
*[spec](..) > bonuses*
* [builtins](./builtins)
* [inline-environment-variable](./inline-environment-variable)
* [redirections](./redirections)
* [separators](./separators)
* [tilde-expansion](./tilde-expansion)

View file

@ -1,5 +0,0 @@
# builtins
*[spec > bonuses](..) > builtins*
* [env](./env)

View file

@ -1,63 +0,0 @@
# 001-unset-variables
*[spec > bonuses > builtins > env](..) > 001-unset-variables*
The purpose of this test is to check that the builtin `env` implement the option `-u` to unset environment variables.
### What is done before test
```bash
export TESTVARIABLE="${GLOBAL_TOKEN}"
```
### Shell commands that are sent to the standard entry
```bash
env -u HOME -u PATH -u TESTVARIABLE ./display_env
```
### What is expected on standard output
```bash
expected_to_not match_regex "HOME="
expected_to_not match_regex "PATH="
expected_to_not match_regex "TESTVARIABLE="
```
### What is expected on error output
```bash
expected_to be_empty
```
### Variables
The following variables may appear in this test:
* ${**GLOBAL_INSTALLDIR**} -> The installation directory of 42ShellTester
* ${**GLOBAL_TMP_DIRECTORY**} -> The temporary directory in which tests are executed
* ${**GLOBAL_TOKEN**} -> A token that changes value at launch time
* ${**PATH**} -> The standard environment variable PATH
* ${**HOME**} -> The standard environment variable HOME
### Support binaries
The following binaries may appear in this test:
* **[./create_file](http://github.com/we-sh/42ShellTester/tree/master/support/create-file)** -> A binary that creates file named argv[1] + "_FILE" If argv[1] is not set, the file is named "TOKEN_FILE"
* **[./delete_file](http://github.com/we-sh/42ShellTester/tree/master/support/delete-file)** -> A binary that delete all files called in argument.
* **[./display_env](http://github.com/we-sh/42ShellTester/tree/master/support/display-env)** -> A binary that iterates on `**envp` and write each element on standard output.
* **[./display_program_name](http://github.com/we-sh/42ShellTester/tree/master/support/display-program-name)** -> A binary that writes its name on standard ouput.
* **[./display_pwd](http://github.com/we-sh/42ShellTester/tree/master/support/display-pwd)** -> A binary that writes on standard output the absolute path of the current directory returned by `getcwd(3)`, encountered with the strings `PWD:` and `:PWD`.
* **[./exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/exit-with-status)** -> A binary that immediately exits with the status given as first argument.
* **[./read_on_stdin](http://github.com/we-sh/42ShellTester/tree/master/support/read-on-stdin)** -> A binary that reads on standard entry and write each line on standard output suffixed with the character `@` (e.g. same behavior as `cat -e` and the *newline* character). When `read(2)` returns `-1`, then the string `STDIN READ ERROR` is written on standard error.
* **[./sleep_and_exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-exit-with-status)** -> A binary that sleeps for a duration in seconds given as first argument and then exits with status given as second argument.
* **[./sleep_and_write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-write-on-stderr)** -> A binary that sleeps for a duration in seconds given as first argument and then writes on STDERR the string given as second argument without EOL.
* **[./write_all_arguments_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-all-arguments-on-stdout)** -> A binary that writes on standard output each argument separated by the symbol `@`. If no argument is given, it writes the string "nothing to be written on stdout".
* **[./write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stderr)** -> A binary that writes on standard error the first given argument (the same behavior as `echo` but with only one argument) and exits with an error status code given as second argument. If no argument is given, it writes the string "write on stderr" and exit with status `1`.
* **[./write_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout)** -> A binary that writes on standard output the first given argument (the same behavior as `echo` but with only one argument). If no argument is given, it writes the string "write on stdout".
* **[./write_on_stdout_and_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout-and-stderr)** -> A binary that writes on standard output the first given argument, and writes on standard error the second given argument. If an argument is missing, it writes the strings "write on stdout" and "write on stderr".

View file

@ -1 +0,0 @@
export TESTVARIABLE="${GLOBAL_TOKEN}"

View file

@ -1 +0,0 @@
The purpose of this test is to check that the builtin `env` implement the option `-u` to unset environment variables.

View file

@ -1 +0,0 @@
`env -u` is not registered in the POSIX standard.

View file

@ -1 +0,0 @@
expected_to be_empty

View file

@ -1 +0,0 @@
env -u HOME -u PATH -u TESTVARIABLE ./display_env

View file

@ -1,3 +0,0 @@
expected_to_not match_regex "HOME="
expected_to_not match_regex "PATH="
expected_to_not match_regex "TESTVARIABLE="

View file

@ -1,63 +0,0 @@
# 002-unset-and-set-variable
*[spec > bonuses > builtins > env](..) > 002-unset-and-set-variable*
The purpose of this test is to check if env -u works to unset variables for a given binary, we are also checking if an argument not prefix with -u is add to the environment of the given binary.### What is done before test
```bash
# unset all environment variables except PATH
for VARIABLE in $(env | awk 'BEGIN {FS="="} $0 !~ /^PATH/ {print $1}'); do unset "${VARIABLE}"; done;
export HOME="/my/home"
```
### Shell commands that are sent to the standard entry
```bash
env -u HOME TESTVARIABLE=${GLOBAL_TOKEN} ./display_env
```
### What is expected on standard output
```bash
expected_to match_regex "^TESTVARIABLE=${GLOBAL_TOKEN}$"
expected_to_not match_regex "^HOME="
```
### What is expected on error output
```bash
expected_to be_empty
```
### Variables
The following variables may appear in this test:
* ${**GLOBAL_INSTALLDIR**} -> The installation directory of 42ShellTester
* ${**GLOBAL_TMP_DIRECTORY**} -> The temporary directory in which tests are executed
* ${**GLOBAL_TOKEN**} -> A token that changes value at launch time
* ${**PATH**} -> The standard environment variable PATH
* ${**HOME**} -> The standard environment variable HOME
### Support binaries
The following binaries may appear in this test:
* **[./create_file](http://github.com/we-sh/42ShellTester/tree/master/support/create-file)** -> A binary that creates file named argv[1] + "_FILE" If argv[1] is not set, the file is named "TOKEN_FILE"
* **[./delete_file](http://github.com/we-sh/42ShellTester/tree/master/support/delete-file)** -> A binary that delete all files called in argument.
* **[./display_env](http://github.com/we-sh/42ShellTester/tree/master/support/display-env)** -> A binary that iterates on `**envp` and write each element on standard output.
* **[./display_program_name](http://github.com/we-sh/42ShellTester/tree/master/support/display-program-name)** -> A binary that writes its name on standard ouput.
* **[./display_pwd](http://github.com/we-sh/42ShellTester/tree/master/support/display-pwd)** -> A binary that writes on standard output the absolute path of the current directory returned by `getcwd(3)`, encountered with the strings `PWD:` and `:PWD`.
* **[./exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/exit-with-status)** -> A binary that immediately exits with the status given as first argument.
* **[./read_on_stdin](http://github.com/we-sh/42ShellTester/tree/master/support/read-on-stdin)** -> A binary that reads on standard entry and write each line on standard output suffixed with the character `@` (e.g. same behavior as `cat -e` and the *newline* character). When `read(2)` returns `-1`, then the string `STDIN READ ERROR` is written on standard error.
* **[./sleep_and_exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-exit-with-status)** -> A binary that sleeps for a duration in seconds given as first argument and then exits with status given as second argument.
* **[./sleep_and_write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-write-on-stderr)** -> A binary that sleeps for a duration in seconds given as first argument and then writes on STDERR the string given as second argument without EOL.
* **[./write_all_arguments_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-all-arguments-on-stdout)** -> A binary that writes on standard output each argument separated by the symbol `@`. If no argument is given, it writes the string "nothing to be written on stdout".
* **[./write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stderr)** -> A binary that writes on standard error the first given argument (the same behavior as `echo` but with only one argument) and exits with an error status code given as second argument. If no argument is given, it writes the string "write on stderr" and exit with status `1`.
* **[./write_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout)** -> A binary that writes on standard output the first given argument (the same behavior as `echo` but with only one argument). If no argument is given, it writes the string "write on stdout".
* **[./write_on_stdout_and_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout-and-stderr)** -> A binary that writes on standard output the first given argument, and writes on standard error the second given argument. If an argument is missing, it writes the strings "write on stdout" and "write on stderr".

View file

@ -1,4 +0,0 @@
# unset all environment variables except PATH
for VARIABLE in $(env | awk 'BEGIN {FS="="} $0 !~ /^PATH/ {print $1}'); do unset "${VARIABLE}"; done;
export HOME="/my/home"

View file

@ -1 +0,0 @@
The purpose of this test is to check if env -u works to unset variables for a given binary, we are also checking if an argument not prefix with -u is add to the environment of the given binary.

View file

@ -1 +0,0 @@
expected_to be_empty

View file

@ -1 +0,0 @@
env -u HOME TESTVARIABLE=${GLOBAL_TOKEN} ./display_env

View file

@ -1,2 +0,0 @@
expected_to match_regex "^TESTVARIABLE=${GLOBAL_TOKEN}$"
expected_to_not match_regex "^HOME="

View file

@ -1,6 +0,0 @@
# env
*[spec > bonuses > builtins](..) > env*
* [001-unset-variables](./001-unset-variables)
* [002-unset-and-set-variable](./002-unset-and-set-variable)

View file

@ -1,62 +0,0 @@
# 001-modifies-child-environment-1
*[spec > bonuses > inline-environment-variable](..) > 001-modifies-child-environment-1*
The purpose of this test is to check that a binary may have its environment to be modified by appending variables inline.
### What is done before test
```bash
unset "${GLOBAL_TOKEN}_VARIABLE"
```
### Shell commands that are sent to the standard entry
```bash
${GLOBAL_TOKEN}_VARIABLE=${GLOBAL_TOKEN}_VALUE ./display_env
./display_env
```
### What is expected on standard output
```bash
expected_to match_regex "^${GLOBAL_TOKEN}_VARIABLE=${GLOBAL_TOKEN}_VALUE$" once
```
### What is expected on error output
```bash
expected_to be_empty
```
### Variables
The following variables may appear in this test:
* ${**GLOBAL_INSTALLDIR**} -> The installation directory of 42ShellTester
* ${**GLOBAL_TMP_DIRECTORY**} -> The temporary directory in which tests are executed
* ${**GLOBAL_TOKEN**} -> A token that changes value at launch time
* ${**PATH**} -> The standard environment variable PATH
* ${**HOME**} -> The standard environment variable HOME
### Support binaries
The following binaries may appear in this test:
* **[./create_file](http://github.com/we-sh/42ShellTester/tree/master/support/create-file)** -> A binary that creates file named argv[1] + "_FILE" If argv[1] is not set, the file is named "TOKEN_FILE"
* **[./delete_file](http://github.com/we-sh/42ShellTester/tree/master/support/delete-file)** -> A binary that delete all files called in argument.
* **[./display_env](http://github.com/we-sh/42ShellTester/tree/master/support/display-env)** -> A binary that iterates on `**envp` and write each element on standard output.
* **[./display_program_name](http://github.com/we-sh/42ShellTester/tree/master/support/display-program-name)** -> A binary that writes its name on standard ouput.
* **[./display_pwd](http://github.com/we-sh/42ShellTester/tree/master/support/display-pwd)** -> A binary that writes on standard output the absolute path of the current directory returned by `getcwd(3)`, encountered with the strings `PWD:` and `:PWD`.
* **[./exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/exit-with-status)** -> A binary that immediately exits with the status given as first argument.
* **[./read_on_stdin](http://github.com/we-sh/42ShellTester/tree/master/support/read-on-stdin)** -> A binary that reads on standard entry and write each line on standard output suffixed with the character `@` (e.g. same behavior as `cat -e` and the *newline* character). When `read(2)` returns `-1`, then the string `STDIN READ ERROR` is written on standard error.
* **[./sleep_and_exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-exit-with-status)** -> A binary that sleeps for a duration in seconds given as first argument and then exits with status given as second argument.
* **[./sleep_and_write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-write-on-stderr)** -> A binary that sleeps for a duration in seconds given as first argument and then writes on STDERR the string given as second argument without EOL.
* **[./write_all_arguments_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-all-arguments-on-stdout)** -> A binary that writes on standard output each argument separated by the symbol `@`. If no argument is given, it writes the string "nothing to be written on stdout".
* **[./write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stderr)** -> A binary that writes on standard error the first given argument (the same behavior as `echo` but with only one argument) and exits with an error status code given as second argument. If no argument is given, it writes the string "write on stderr" and exit with status `1`.
* **[./write_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout)** -> A binary that writes on standard output the first given argument (the same behavior as `echo` but with only one argument). If no argument is given, it writes the string "write on stdout".
* **[./write_on_stdout_and_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout-and-stderr)** -> A binary that writes on standard output the first given argument, and writes on standard error the second given argument. If an argument is missing, it writes the strings "write on stdout" and "write on stderr".

View file

@ -1 +0,0 @@
The purpose of this test is to check that a binary may have its environment to be modified by appending variables inline.

View file

@ -1,2 +0,0 @@
${GLOBAL_TOKEN}_VARIABLE=${GLOBAL_TOKEN}_VALUE ./display_env
./display_env

View file

@ -1 +0,0 @@
expected_to match_regex "^${GLOBAL_TOKEN}_VARIABLE=${GLOBAL_TOKEN}_VALUE$" once

View file

@ -1,64 +0,0 @@
# 002-modifies-child-environment-2
*[spec > bonuses > inline-environment-variable](..) > 002-modifies-child-environment-2*
The purpose of this test is to check that a binary may have its environment to be modified by appending variables inline.
### What is done before test
```bash
unset "${GLOBAL_TOKEN}_VARIABLE"
```
### Shell commands that are sent to the standard entry
```bash
${GLOBAL_TOKEN}_VARIABLE1=${GLOBAL_TOKEN}_VALUE1 ${GLOBAL_TOKEN}_VARIABLE2=${GLOBAL_TOKEN}_VALUE2 ${GLOBAL_TOKEN}_VARIABLE3=${GLOBAL_TOKEN}_VALUE3 ./display_env
./display_env
```
### What is expected on standard output
```bash
expected_to match_regex "^${GLOBAL_TOKEN}_VARIABLE1=${GLOBAL_TOKEN}_VALUE1$" once
expected_to match_regex "^${GLOBAL_TOKEN}_VARIABLE2=${GLOBAL_TOKEN}_VALUE2$" once
expected_to match_regex "^${GLOBAL_TOKEN}_VARIABLE3=${GLOBAL_TOKEN}_VALUE3$" once
```
### What is expected on error output
```bash
expected_to be_empty
```
### Variables
The following variables may appear in this test:
* ${**GLOBAL_INSTALLDIR**} -> The installation directory of 42ShellTester
* ${**GLOBAL_TMP_DIRECTORY**} -> The temporary directory in which tests are executed
* ${**GLOBAL_TOKEN**} -> A token that changes value at launch time
* ${**PATH**} -> The standard environment variable PATH
* ${**HOME**} -> The standard environment variable HOME
### Support binaries
The following binaries may appear in this test:
* **[./create_file](http://github.com/we-sh/42ShellTester/tree/master/support/create-file)** -> A binary that creates file named argv[1] + "_FILE" If argv[1] is not set, the file is named "TOKEN_FILE"
* **[./delete_file](http://github.com/we-sh/42ShellTester/tree/master/support/delete-file)** -> A binary that delete all files called in argument.
* **[./display_env](http://github.com/we-sh/42ShellTester/tree/master/support/display-env)** -> A binary that iterates on `**envp` and write each element on standard output.
* **[./display_program_name](http://github.com/we-sh/42ShellTester/tree/master/support/display-program-name)** -> A binary that writes its name on standard ouput.
* **[./display_pwd](http://github.com/we-sh/42ShellTester/tree/master/support/display-pwd)** -> A binary that writes on standard output the absolute path of the current directory returned by `getcwd(3)`, encountered with the strings `PWD:` and `:PWD`.
* **[./exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/exit-with-status)** -> A binary that immediately exits with the status given as first argument.
* **[./read_on_stdin](http://github.com/we-sh/42ShellTester/tree/master/support/read-on-stdin)** -> A binary that reads on standard entry and write each line on standard output suffixed with the character `@` (e.g. same behavior as `cat -e` and the *newline* character). When `read(2)` returns `-1`, then the string `STDIN READ ERROR` is written on standard error.
* **[./sleep_and_exit_with_status](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-exit-with-status)** -> A binary that sleeps for a duration in seconds given as first argument and then exits with status given as second argument.
* **[./sleep_and_write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/sleep-and-write-on-stderr)** -> A binary that sleeps for a duration in seconds given as first argument and then writes on STDERR the string given as second argument without EOL.
* **[./write_all_arguments_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-all-arguments-on-stdout)** -> A binary that writes on standard output each argument separated by the symbol `@`. If no argument is given, it writes the string "nothing to be written on stdout".
* **[./write_on_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stderr)** -> A binary that writes on standard error the first given argument (the same behavior as `echo` but with only one argument) and exits with an error status code given as second argument. If no argument is given, it writes the string "write on stderr" and exit with status `1`.
* **[./write_on_stdout](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout)** -> A binary that writes on standard output the first given argument (the same behavior as `echo` but with only one argument). If no argument is given, it writes the string "write on stdout".
* **[./write_on_stdout_and_stderr](http://github.com/we-sh/42ShellTester/tree/master/support/write-on-stdout-and-stderr)** -> A binary that writes on standard output the first given argument, and writes on standard error the second given argument. If an argument is missing, it writes the strings "write on stdout" and "write on stderr".

Some files were not shown because too many files have changed in this diff Show more