42tests-tischmid/libft_test/ft_isalpha_test.c

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;
}