1
0
mirror of https://github.com/falk-werner/webfuse synced 2024-10-27 20:34:10 +00:00

switched tests to google test

This commit is contained in:
Falk Werner 2019-01-30 21:53:57 +01:00
parent f47868ded7
commit 7f8365811f
7 changed files with 31 additions and 78 deletions

1
.gitignore vendored
View File

@ -1 +1,2 @@
.vscode
.build

View File

@ -1,6 +1,8 @@
cmake_minimum_required (VERSION 2.8)
project(fuse-wsfs)
option(WITH_TESTS "enable unit tests" OFF)
set(THREADS_PREFER_PTHREAD_FLAG ON)
find_package(Threads REQUIRED)
@ -64,13 +66,19 @@ target_compile_options(wsfs PUBLIC ${EXTRA_CFLAGS})
# tests
if(WITH_TESTS)
pkg_check_modules(GTEST gtest_main)
add_executable(alltests
test-src/test_main.c
test-src/test_util.c
test-src/test_response_parser.c
test-src/test_response_parser.cc
)
target_link_libraries(alltests PUBLIC fuse-wsfs ${EXTRA_LIBS})
target_include_directories(alltests PUBLIC src ${EXTRA_INCLUDE_DIRS})
target_compile_options(alltests PUBLIC ${EXTRA_CFLAGS})
target_link_libraries(alltests PUBLIC fuse-wsfs ${EXTRA_LIBS} ${GTEST_LIBRARIES})
target_include_directories(alltests PUBLIC src ${EXTRA_INCLUDE_DIRS} ${GTEST_INCLUDE_DIRS})
target_compile_options(alltests PUBLIC ${EXTRA_CFLAGS} ${GTEST_CFLAGS})
enable_testing()
add_test(alltests alltests)
endif(WITH_TESTS)

View File

@ -9,8 +9,9 @@ fuse-wsfs combines libwebsockets and libfuse. It allows ot attach a remote files
cd fuse-wsfs
mkdir ./build
cd ./build
cmake ..
cmake .. -DWITH_TESTS=ON
make
CTEST_OUTPUT_ON_FAILUE=1 make test
mkdir test
./wsfs -s -f --document_root=`realpath ../src/app/www` --port=4711 test
@ -20,5 +21,6 @@ fuse-wsfs combines libwebsockets and libfuse. It allows ot attach a remote files
- [libfuse3](https://github.com/libfuse/libfuse/)
- [libwebsockets](https://libwebsockets.org/)
- [Jansson](https://jansson.readthedocs.io)
- [GoogleTest](https://github.com/google/googletest) *(optional)*

View File

@ -1,13 +0,0 @@
#include <stdio.h>
#include <stdlib.h>
#include "test_util.h"
#include "wsfs/util.h"
extern void test_request_parser();
int main(int WSFS_UNUSED_PARAM(argc), char* WSFS_UNUSED_PARAM(argv[]))
{
test_request_parser();
return EXIT_SUCCESS;
}

View File

@ -1,8 +1,9 @@
#include "test_util.h"
#include <string.h>
#include <cstring>
#include <gtest/gtest.h>
extern "C" {
#include "wsfs/response_parser.h"
}
static void wsfs_response_parse_str(
char const * buffer,
@ -12,7 +13,7 @@ static void wsfs_response_parse_str(
wsfs_response_parse(buffer, length, response);
}
void test_request_parser()
TEST(response_parser, test)
{
struct wsfs_response response;
@ -20,43 +21,43 @@ void test_request_parser()
wsfs_response_parse_str("", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(-1, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// invalid json
wsfs_response_parse_str("invalid_json", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(-1, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// no object
wsfs_response_parse_str("[]", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(-1, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// empty
wsfs_response_parse_str("{}", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(-1, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// no data
wsfs_response_parse_str("{\"id\":42}", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(42, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// custom error code
wsfs_response_parse_str("{\"error\":{\"code\": 42}, \"id\": 42}", &response);
ASSERT_NE(WSFS_GOOD, response.status);
ASSERT_EQ(42, response.status);
ASSERT_EQ(42, response.id);
ASSERT_EQ(NULL, response.result);
ASSERT_EQ(nullptr, response.result);
// valid response
wsfs_response_parse_str("{\"result\": true, \"id\": 42}", &response);
ASSERT_EQ(WSFS_GOOD, response.status);
ASSERT_EQ(42, response.id);
ASSERT_NE(NULL, response.result);
ASSERT_NE(nullptr, response.result);
json_decref(response.result);
}

View File

@ -1,15 +0,0 @@
#include "test_util.h"
#include <stdio.h>
#include <stdlib.h>
void fail(
char const * file_name,
int line,
char const * message
)
{
fprintf(stderr, "error: %s:%d: %s\n", file_name, line, message);
exit(EXIT_FAILURE);
}

View File

@ -1,31 +0,0 @@
#ifndef _WSFS_TEST_UTIL_H
#define _WSFS_TEST_UTIL_H
#define ASSERT_EQ(expected, actual) \
do \
{ \
if ((expected) != (actual)) \
{ \
fail(__FILE__, __LINE__, "expected " #expected ", but was " #actual); \
} \
} \
while (0)
#define ASSERT_NE(expected, actual) \
do \
{ \
if ((expected) == (actual)) \
{ \
fail(__FILE__, __LINE__, "expected " #expected ", but was " #actual); \
} \
} \
while (0)
extern void fail(
char const * file_name,
int line,
char const * message
);
#endif