86 lines
2.9 KiB
C
Executable File
86 lines
2.9 KiB
C
Executable File
#!/usr/bin/env bash
|
|
|
|
tmp_out="$(mktemp)"
|
|
|
|
if [ -f "${0%_test.c}.c" ]; then
|
|
SRC="${0%_test.c}.c"
|
|
else
|
|
SRC="$($(type -P basename) -- "${0%_test.c}.c")"
|
|
fi
|
|
grep -A9999 -- "[S]TART_OF_C_FILE" "${0}" | cc -Wall -Wextra -Werror -o "${tmp_out}" -xc "${SRC}" -
|
|
|
|
if [ ! "${?}" = "0" ] || [ ! -f "${tmp_out}" ]; then
|
|
printf "\e[101;37m%s\e[m\n" "Could not compile"
|
|
exit 1
|
|
fi
|
|
|
|
printf "%s\n" "Testing ${SRC}"
|
|
printf "Expected --> Success\n"
|
|
diff --expand-tabs --left-column --width="60" --side-by-side --label="Expected Output" --label=" Test Output" -- <("${tmp_out}" 2>&1 1>/dev/null) <("${tmp_out}" 2>/dev/null) && { printf "\e[102;30m%s\e[m\n" "All tests passed"; exit_status="0"; } || { printf "\e[101;37m%s\e[m\n" "At least one test failed"; exit_status="1"; }
|
|
rm -f -- "${tmp_out}"
|
|
|
|
exit -- "${exit_status}"
|
|
// START_OF_C_FILE
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
|
|
static int test_counter = 0;
|
|
static int expect_counter = 0;
|
|
|
|
#define test(func, ...) \
|
|
do { \
|
|
int old_stderr_fd = dup(2); \
|
|
dup2(1, 2); \
|
|
fprintf(stdout, "Case %d:", test_counter++); \
|
|
fflush(stdout); \
|
|
func(__VA_ARGS__); \
|
|
fflush(stderr); \
|
|
fflush(stdout); \
|
|
dup2(old_stderr_fd, 2); \
|
|
} while(0)
|
|
|
|
#define expect(inp, func, ...) \
|
|
do { \
|
|
int old_stdout_fd = dup(1); \
|
|
dup2(2, 1); \
|
|
fprintf(stderr, "Case %d:", expect_counter++); \
|
|
fflush(stderr); \
|
|
func(__VA_ARGS__); \
|
|
fflush(stderr); \
|
|
fflush(stdout); \
|
|
dup2(old_stdout_fd, 1); \
|
|
} while(0)
|
|
// END_TEMPLATE
|
|
|
|
#include <ctype.h>
|
|
|
|
int ft_isalpha(int c);
|
|
|
|
int main(){
|
|
test ( "'a'", printf, "%d\n", ft_isalpha('a'));
|
|
expect( "'a'", printf, "%d\n", isalpha('a'));
|
|
test ( "'A'", printf, "%d\n", ft_isalpha('A'));
|
|
expect( "'A'", printf, "%d\n", isalpha('A'));
|
|
test ( "'m'", printf, "%d\n", ft_isalpha('m'));
|
|
expect( "'m'", printf, "%d\n", isalpha('m'));
|
|
test ( "'M'", printf, "%d\n", ft_isalpha('M'));
|
|
expect( "'M'", printf, "%d\n", isalpha('M'));
|
|
test ( "'z'", printf, "%d\n", ft_isalpha('z'));
|
|
expect( "'z'", printf, "%d\n", isalpha('z'));
|
|
test ( "'Z'", printf, "%d\n", ft_isalpha('Z'));
|
|
expect( "'Z'", printf, "%d\n", isalpha('Z'));
|
|
test ( "0", printf, "%d\n", ft_isalpha(0));
|
|
expect( "0", printf, "%d\n", isalpha(0));
|
|
test ( "1", printf, "%d\n", ft_isalpha(1));
|
|
expect( "1", printf, "%d\n", isalpha(1));
|
|
test ("'a' - 1", printf, "%d\n", ft_isalpha('a' - 1));
|
|
expect("'a' - 1", printf, "%d\n", isalpha('a' - 1));
|
|
test ("'A' - 1", printf, "%d\n", ft_isalpha('A' - 1));
|
|
expect("'A' - 1", printf, "%d\n", isalpha('A' - 1));
|
|
test ("'z' + 1", printf, "%d\n", ft_isalpha('z' + 1));
|
|
expect("'z' + 1", printf, "%d\n", isalpha('z' + 1));
|
|
test ("'Z' + 1", printf, "%d\n", ft_isalpha('Z' + 1));
|
|
expect("'Z' + 1", printf, "%d\n", isalpha('Z' + 1));
|
|
return 0;
|
|
}
|