aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/ft_read_test.c78
-rw-r--r--test/ft_strdup_test.c11
-rw-r--r--test/ft_write_test.c34
3 files changed, 75 insertions, 48 deletions
diff --git a/test/ft_read_test.c b/test/ft_read_test.c
index c175489..f061c5f 100644
--- a/test/ft_read_test.c
+++ b/test/ft_read_test.c
@@ -6,7 +6,7 @@
/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/08 03:07:44 by cacharle #+# #+# */
-/* Updated: 2020/04/13 14:52:41 by charles ### ########.fr */
+/* Updated: 2020/05/04 16:09:34 by charles ### ########.fr */
/* */
/* ************************************************************************** */
@@ -16,52 +16,63 @@
static int ft_read_pipe[2];
static char buf[FT_READ_BUF_SIZE] = {0};
-static int ret;
+static ssize_t read_ret;
+static ssize_t read_origin_ret;
+static int read_errno;
+static int read_origin_errno;
#define FT_READ_EXPECT(str) do { \
if (pipe(ft_read_pipe) < 0) \
exit(EXIT_FAILURE); \
fcntl(ft_read_pipe[0], F_SETFL, O_NONBLOCK); \
write(ft_read_pipe[1], str, strlen(str)); \
- ret = ft_read(ft_read_pipe[0], buf, strlen(str)); \
- buf[ret] = '\0'; \
- if (strcmp(buf, str) != 0 || ret != strlen(str)) \
- printf("KO: [COMPARE]: %s: expected: %lu \"%s\" got: %d \"%s\" with: %d, \"%s\", %zu \n", \
- test_name, strlen(str), str, ret, buf, ft_read_pipe[0], buf, strlen(str)); \
+ ERRNO_WRAP(read_origin_ret = read(ft_read_pipe[0], buf, strlen(str)), read_origin_errno); \
+ write(ft_read_pipe[1], str, strlen(str)); \
+ ERRNO_WRAP(read_ret = ft_read(ft_read_pipe[0], buf, strlen(str)), read_errno); \
+ buf[read_ret] = '\0'; \
+ if (read_errno != read_origin_errno) \
+ printf("KO: [COMPARE]: %s: expected: errno %d got: errno %d with: "#str"\n", \
+ test_name, read_origin_errno, read_errno); \
+ else if (strcmp(buf, str) != 0 || read_ret != read_origin_ret) \
+ printf("KO: [COMPARE]: %s: expected: %lu \"%s\" got: %lu \"%s\" with: %d, \"%s\", %zu \n", \
+ test_name, strlen(str), str, read_ret, buf, ft_read_pipe[0], buf, read_origin_ret); \
else \
print_ok(); \
close(ft_read_pipe[1]); \
close(ft_read_pipe[0]); \
} while (0);
-#define FT_READ_EXPECT_ERROR(fd, str, size) do { \
- ret = ft_read(fd, str, size); \
- if ((long)ret != -1) \
- printf("KO: [COMPARE]: %s: expected: %ld got: %ld with: %d "#str" %d\n", \
- test_name, -1l, (long)ret, fd, size); \
- else \
- print_ok(); \
+#define FT_READ_EXPECT_ERROR(fd, buf, size) do { \
+ ERRNO_WRAP(read_ret = ft_read(fd, buf, size), read_errno); \
+ ERRNO_WRAP(read_origin_ret = read(fd, buf, size), read_origin_errno); \
+ if ((long)read_ret != -1) \
+ printf("KO: [COMPARE]: %s: expected: %ld got: %ld with: %d "#buf" %d\n", \
+ test_name, -1l, (long)read_ret, fd, size); \
+ else if (read_errno != read_origin_errno) \
+ printf("KO: [COMPARE]: %s: expected: errno %d got: errno %d with: %d "#buf", %d\n", \
+ test_name, read_origin_errno, read_errno, fd, size); \
+ else \
+ print_ok(); \
} while (0);
static
void ft_read_test_segfault(void)
{
int tmp[2];
+ char buf_read[2048];
+
if (pipe(tmp) < 0)
exit(EXIT_FAILURE);
- TEST_ASM_FUNCTION(ft_read(-1, "test", 5));
- TEST_ASM_FUNCTION(ft_read(tmp[1], NULL, 5));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "test", 0));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "test", 5));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "t", 1));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "", 0));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "test", 4));
- TEST_ASM_FUNCTION(ft_read(tmp[1], "test", 2));
- TEST_ASM_FUNCTION(ft_read(tmp[1], NULL, 2));
+ write(tmp[1], "asdfkasdfkl;jasd;ljkfa;lssdlfasdfasdfasdfasdfasdfasdfasdfasdfasdf", 40);
+ TEST_ASM_FUNCTION(ft_read(-1, buf_read, 2));
+ TEST_ASM_FUNCTION(ft_read(tmp[0], NULL, 2));
+ TEST_ASM_FUNCTION(ft_read(tmp[0], buf_read, 0));
+ TEST_ASM_FUNCTION(ft_read(tmp[0], buf_read, 5));
+ TEST_ASM_FUNCTION(ft_read(tmp[0], buf_read, 32));
close(tmp[0]);
close(tmp[1]);
- TEST_ASM_FUNCTION(ft_read(-1, "tt", 2));
- TEST_ASM_FUNCTION(ft_read(OPEN_MAX + 1, "tt", 2));
+ TEST_ASM_FUNCTION(ft_read(-1, buf_read, 2));
+ TEST_ASM_FUNCTION(ft_read(OPEN_MAX + 1, buf_read, 2));
}
static
@@ -70,7 +81,7 @@ void ft_read_test_compare(void)
FT_READ_EXPECT("");
FT_READ_EXPECT("bon");
FT_READ_EXPECT("bonjour");
- FT_READ_EXPECT("%c%s%p%x%X%e%f%g");
+ FT_READ_EXPECT("#c#s#p#x#X#e#f#g");
FT_READ_EXPECT("the\0hidden");
FT_READ_EXPECT("Lorem ipsum dolor sit amet, consectetur adipiscing\
elit. Sed in malesuada purus. Etiam a scelerisque massa. Ut non euismod elit. Aliquam\
@@ -80,11 +91,16 @@ felis sed purus. Mauris magna ex, mollis non suscipit eu, lacinia ac turpis. Pha
ac tortor et lectus fermentum lobortis eu at mauris. Vestibulum sit amet posuere\
tortor, sit amet consequat amet.");
- FT_READ_EXPECT_ERROR(STDOUT_FILENO, NULL, 3);
- FT_READ_EXPECT_ERROR(-1, "bonjour", 7);
- FT_READ_EXPECT_ERROR(42, "bonjour", 7);
- FT_READ_EXPECT_ERROR(9809, "bonjour", 7);
- FT_READ_EXPECT_ERROR(98123, "", 1);
+ int tmp[2];
+ pipe(tmp);
+ char buf[32];
+
+ write(tmp[1], "bonjour", 7);
+ FT_READ_EXPECT_ERROR(tmp[0], NULL, 3);
+ FT_READ_EXPECT_ERROR(-1, buf, 7);
+ FT_READ_EXPECT_ERROR(42, buf, 7);
+ FT_READ_EXPECT_ERROR(9809, buf, 7);
+ FT_READ_EXPECT_ERROR(98123, buf, 1);
FT_READ_EXPECT_ERROR(42, NULL, 7);
}
diff --git a/test/ft_strdup_test.c b/test/ft_strdup_test.c
index a53e58f..19ffe2c 100644
--- a/test/ft_strdup_test.c
+++ b/test/ft_strdup_test.c
@@ -6,7 +6,7 @@
/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/08 03:08:06 by cacharle #+# #+# */
-/* Updated: 2020/04/13 14:45:00 by charles ### ########.fr */
+/* Updated: 2020/05/04 15:21:49 by charles ### ########.fr */
/* */
/* ************************************************************************** */
@@ -27,7 +27,6 @@ static
void ft_strdup_test_segfault(void)
{
char *tmp2 = NULL;
- char a;
TEST_ASM_FUNCTION(ft_strdup(""));
TEST_ASM_FUNCTION(ft_strdup("abc"));
@@ -42,13 +41,13 @@ ac tortor et lectus fermentum lobortis eu at mauris. Vestibulum sit amet posuere
tortor, sit amet consequat amet."));
tmp2 = ft_strdup("");
- TEST_ASM_FUNCTION(a = *tmp2);
+ TEST_ASM_FUNCTION(char a = *tmp2; a++;);
tmp2 = ft_strdup("abc");
- TEST_ASM_FUNCTION(a = *tmp2);
+ TEST_ASM_FUNCTION(char a = *tmp2; a++;);
tmp2 = ft_strdup("asl;fjl;asd");
- TEST_ASM_FUNCTION(a = *tmp2);
+ TEST_ASM_FUNCTION(char a = *tmp2; a++;);
tmp2 = ft_strdup("yope\0la");
- TEST_ASM_FUNCTION(a = *tmp2);
+ TEST_ASM_FUNCTION(char a = *tmp2; a++;);
}
static
diff --git a/test/ft_write_test.c b/test/ft_write_test.c
index 57b1b0b..f961791 100644
--- a/test/ft_write_test.c
+++ b/test/ft_write_test.c
@@ -6,7 +6,7 @@
/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/08 03:07:48 by cacharle #+# #+# */
-/* Updated: 2020/04/13 14:51:39 by charles ### ########.fr */
+/* Updated: 2020/05/04 16:06:28 by charles ### ########.fr */
/* */
/* ************************************************************************** */
@@ -16,17 +16,25 @@
static int ft_write_pipe[2];
static char buf[FT_WRITE_BUF_SIZE] = {0};
-static unsigned long write_ret;
-static int ret;
+static ssize_t write_ret;
+static ssize_t write_origin_ret;
+static int write_errno;
+static int write_origin_errno;
+static ssize_t ret;
#define FT_WRITE_EXPECT(str) do { \
if (pipe(ft_write_pipe) < 0) \
exit(EXIT_FAILURE); \
fcntl(ft_write_pipe[0], F_SETFL, O_NONBLOCK); \
- write_ret = ft_write(ft_write_pipe[1], str, strlen(str)); \
+ ERRNO_WRAP(write_origin_ret = write(ft_write_pipe[1], str, strlen(str)), write_origin_errno); \
+ read(ft_write_pipe[0], buf, FT_WRITE_BUF_SIZE); \
+ ERRNO_WRAP(write_ret = ft_write(ft_write_pipe[1], str, strlen(str)), write_errno); \
ret = read(ft_write_pipe[0], buf, FT_WRITE_BUF_SIZE); \
buf[ret] = '\0'; \
- if (strcmp(buf, str) != 0 || write_ret != strlen(str)) \
+ if (write_errno != write_origin_errno) \
+ printf("KO: [COMPARE]: %s: expected: errno %d got: errno %d with: "#str"\n", \
+ test_name, write_origin_errno, write_errno); \
+ else if (strcmp(buf, str) != 0 || write_ret != write_origin_ret) \
printf("KO: [COMPARE]: %s: expected: %lu \"%s\" got: %lu \"%s\" with: %d, \"%s\", %zu \n", \
test_name, strlen(str), str, write_ret, buf, ft_write_pipe[0], buf, strlen(str)); \
else \
@@ -35,13 +43,17 @@ static int ret;
close(ft_write_pipe[0]); \
} while (0);
-#define FT_WRITE_EXPECT_ERROR(fd, str, size) do { \
- write_ret = ft_write(fd, str, size); \
- if ((long)write_ret != -1) \
+#define FT_WRITE_EXPECT_ERROR(fd, str, size) do { \
+ ERRNO_WRAP(write_ret = ft_write(fd, str, size), write_errno); \
+ ERRNO_WRAP(write_origin_ret = write(fd, str, size), write_origin_errno); \
+ if ((long)write_ret != -1) \
printf("KO: [COMPARE]: %s: expected: %ld got: %ld with: %d "#str", %d\n", \
test_name, -1l, (long)write_ret, fd, size); \
- else \
- print_ok(); \
+ else if (write_errno != write_origin_errno) \
+ printf("KO: [COMPARE]: %s: expected: errno %d got: errno %d with: %d "#str", %d\n", \
+ test_name, write_origin_errno, write_errno, fd, size); \
+ else \
+ print_ok(); \
} while (0);
static
@@ -71,7 +83,7 @@ void ft_write_test_compare(void)
FT_WRITE_EXPECT("");
FT_WRITE_EXPECT("bon");
FT_WRITE_EXPECT("bonjour");
- FT_WRITE_EXPECT("%c%s%p%x%X%e%f%g");
+ FT_WRITE_EXPECT("#c#s#p#x#X#e#f#g");
FT_WRITE_EXPECT("the\0hidden");
FT_WRITE_EXPECT("Lorem ipsum dolor sit amet, consectetur adipiscing\
elit. Sed in malesuada purus. Etiam a scelerisque massa. Ut non euismod elit. Aliquam\