From c6071aae178ff9c44820d533701c09577c8840c5 Mon Sep 17 00:00:00 2001 From: Johnny Richard Date: Sat, 16 Apr 2022 03:39:09 +0200 Subject: Create string_view struct --- test/Makefile | 7 +++- test/string_view_test.c | 102 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 108 insertions(+), 1 deletion(-) create mode 100644 test/string_view_test.c (limited to 'test') diff --git a/test/Makefile b/test/Makefile index 3d86f0e..7ef1bcc 100644 --- a/test/Makefile +++ b/test/Makefile @@ -1,13 +1,18 @@ CC=gcc .PHONY: all -all: hash_table_test +all: hash_table_test string_view_test .PHONY: hash_table_test hash_table_test: ../hash_table.o hash_table_test.c $(CC) -o hash_table_test ../hash_table.o hash_table_test.c ./hash_table_test +.PHONY: string_view_test +string_view_test: ../string_view.o string_view_test.c + $(CC) -o string_view_test ../string_view.o string_view_test.c + ./string_view_test + .PHONY: clean clean: @$(RM) hash_table_test diff --git a/test/string_view_test.c b/test/string_view_test.c new file mode 100644 index 0000000..d4ecf9e --- /dev/null +++ b/test/string_view_test.c @@ -0,0 +1,102 @@ +/* + * Papo IRC Server + * Copyright (C) 2021 Johnny Richard + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ +#define MUNIT_ENABLE_ASSERT_ALIASES +#include "munit/munit.c" +#include "../string_view.h" + +#include + +static MunitResult +test_create_new(const MunitParameter params[], + void *user_data_or_fixture) +{ + char *data = "hello world"; + string_view_t sv = string_view_new(data, strlen(data)); + + assert_string_equal("hello world", (char *) sv.data); + assert_int(sv.size, ==, strlen(data)); + + return MUNIT_OK; +} + +static MunitResult +test_from_cstr(const MunitParameter params[], + void *user_data_or_fixture) +{ + char *cstr = "hello world"; + + string_view_t sv = string_view_from_cstr(cstr); + + assert_string_equal(cstr, (char *) sv.data); + assert_int(sv.size, ==, strlen(cstr)); + + return MUNIT_OK; +} + +static MunitResult +test_chop_by_delim_when_has_delim(const MunitParameter params[], + void *user_data_or_fixture) +{ + string_view_t sv = string_view_from_cstr("hello world"); + string_view_t result = string_view_chop_by_delim(&sv, ' '); + + char actual[10]; + sprintf(actual, "%.*s", sv.size, sv.data); + assert_string_equal(actual, "world"); + + sprintf(actual, "%.*s", result.size, result.data); + assert_string_equal(actual, "hello"); + + return MUNIT_OK; +} + +static MunitResult +test_chop_by_delim_when_has_no_delim(const MunitParameter params[], + void *user_data_or_fixture) +{ + string_view_t sv = string_view_from_cstr("helloworld"); + string_view_t result = string_view_chop_by_delim(&sv, ' '); + + char actual[10]; + sprintf(actual, "%.*s", sv.size, sv.data); + assert_string_equal(actual, ""); + + sprintf(actual, "%.*s", result.size, result.data); + assert_string_equal(actual, "helloworld"); + + return MUNIT_OK; +} + +static MunitTest tests[] = { + { "/test_create_new", test_create_new, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL }, + { "/test_from_cstr", test_from_cstr, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL }, + { "/test_chop_by_delim_when_has_delim", test_chop_by_delim_when_has_delim, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL }, + { "/test_chop_by_delim_when_has_no_delim", test_chop_by_delim_when_has_no_delim, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL }, + { NULL, NULL, NULL, NULL, MUNIT_TEST_OPTION_NONE, NULL } +}; + +static const MunitSuite suite = { + "/string_view", tests, NULL, 1, MUNIT_SUITE_OPTION_NONE +}; + +int +main(int argc, char *argv[]) +{ + return munit_suite_main(&suite, NULL, argc, argv); + return EXIT_SUCCESS; +} -- cgit v1.2.3