42tests-tischmid/libft_test/ft_isalpha_test.c

94 lines
2.6 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(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(){
int arg;
arg = 'a';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'A';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'z';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'Z';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'm';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'M';
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'a' - 1;
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'A' - 1
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'z' + 1;
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
arg = 'Z' + 1;
test (printf, "%d\n", ft_isalpha(arg));
expect(printf, "%d\n", isalpha(arg));
return 0;
}