From 06a5b6fe71abac44286adf9c9f439ad5a2e3a519 Mon Sep 17 00:00:00 2001 From: Roland Reichwein Date: Sat, 31 Dec 2022 13:45:31 +0100 Subject: Added tests --- Makefile | 8 ++++++-- TODO | 2 ++ common.mk | 10 ++++++++++ main.cpp | 10 ++++++++++ tests/Makefile | 1 + tests/test-environment.cpp | 48 ++++++++++++++++++++++++++++++++++++++++++++++ tests/test-webserver.cpp | 38 +++++++++--------------------------- webserver.cpp | 2 +- webserver.h | 4 ++++ 9 files changed, 91 insertions(+), 32 deletions(-) create mode 100644 main.cpp create mode 100644 tests/test-environment.cpp create mode 100644 webserver.h diff --git a/Makefile b/Makefile index 87d9240..94bbe46 100644 --- a/Makefile +++ b/Makefile @@ -45,9 +45,10 @@ PROGSRC=\ privileges.cpp \ response.cpp \ statistics.cpp \ - server.cpp + server.cpp \ + webserver.cpp -SRC=$(PROGSRC) webserver.cpp +SRC=$(PROGSRC) main.cpp build: $(PROJECTNAME) $(PLUGINS) @@ -131,6 +132,7 @@ DISTFILES= \ http.h \ https.cpp \ https.h \ + main.cpp \ os.cpp \ os.h \ plugin.cpp \ @@ -145,7 +147,9 @@ DISTFILES= \ statistics.cpp \ statistics.h \ tests/Makefile \ + tests/test-environment.cpp \ tests/test-webserver.cpp \ + webserver.h \ webserver.cpp \ webserver.1 \ README.txt \ diff --git a/TODO b/TODO index ae2b5ef..1131af1 100644 --- a/TODO +++ b/TODO @@ -1,3 +1,5 @@ +Big file bug + stats.png cgi unhandled headers git via smart http / cgi diff --git a/common.mk b/common.mk index 8df3809..fa3d023 100644 --- a/common.mk +++ b/common.mk @@ -1,4 +1,8 @@ +CXX=clang++-14 + +ifeq ($(shell which $(CXX)),) CXX=clang++-13 +endif ifeq ($(shell which $(CXX)),) CXX=clang++-11 @@ -51,6 +55,8 @@ CXXFLAGS+=-DYEAR=\"$(YEAR)\" CXXFLAGS+=-pthread ifeq ($(CXX),clang++-11) CXXFLAGS+=-std=c++20 #-stdlib=libc++ +else ifeq ($(CXX),clang++-14) +CXXFLAGS+=-std=c++2b #-stdlib=libc++ else ifeq ($(CXX),clang++-13) CXXFLAGS+=-std=c++2b #-stdlib=libc++ else ifeq ($(CXX),g++-11) @@ -67,6 +73,10 @@ LIBS+= \ #-lc++abi #-lc++fs #-lstdc++fs +else ifeq ($(CXX),clang++-14) +LIBS+= \ +-fuse-ld=lld-14 \ +-lstdc++ else ifeq ($(CXX),clang++-13) LIBS+= \ -fuse-ld=lld-13 \ diff --git a/main.cpp b/main.cpp new file mode 100644 index 0000000..c0e1884 --- /dev/null +++ b/main.cpp @@ -0,0 +1,10 @@ +// The webserver main() function. The actual webserver resides in +// webserver.cpp as webserver() for testability. + +#include "webserver.h" + +int main(int argc, char* argv[]) +{ + return webserver(argc, argv); +} + diff --git a/tests/Makefile b/tests/Makefile index 1785e09..5903b52 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -20,6 +20,7 @@ LIBS=\ LDFLAGS+=-pie -L../libcommon TESTSRC=\ + test-environment.cpp \ test-webserver.cpp \ $(PROGSRC) diff --git a/tests/test-environment.cpp b/tests/test-environment.cpp new file mode 100644 index 0000000..da8e4e0 --- /dev/null +++ b/tests/test-environment.cpp @@ -0,0 +1,48 @@ +#include +#include +#include +#include + +#include +#include + +#include +#include + +using namespace std::string_literals; +namespace pt = boost::property_tree; + +// test ptree construction and xml serialization +BOOST_AUTO_TEST_CASE(property_tree_put) +{ + pt::ptree p; + pt::ptree list; + + pt::ptree entry; + + entry.put_value("name1.txt"); + entry.put(".type", "file1"); + + list.push_back(pt::ptree::value_type("listentry", entry)); + + entry.put_value("name2.txt"); + entry.put(".type", "file2"); + + list.push_back(pt::ptree::value_type("listentry", entry)); + + p.push_back(pt::ptree::value_type("list", list)); + + std::stringstream ss; + + pt::xml_parser::write_xml(ss, p /*, pt::xml_parser::xml_writer_make_settings(' ', 1)*/); + + BOOST_CHECK_EQUAL(ss.str(), "\nname1.txtname2.txt"); +} + +// test std::stoul for negative numbers +BOOST_AUTO_TEST_CASE(string_stoul) +{ + unsigned long l = std::stoul("-1"); + + BOOST_CHECK_EQUAL(l, std::numeric_limits::max()); +} diff --git a/tests/test-webserver.cpp b/tests/test-webserver.cpp index 7683b93..1668c60 100644 --- a/tests/test-webserver.cpp +++ b/tests/test-webserver.cpp @@ -1,6 +1,8 @@ +// Main unit test compilation unit +// boost mandates that exactly one compilation unit contains the following two lines: #define BOOST_TEST_MODULE webserver_test - #include + #include #include #include @@ -14,35 +16,13 @@ using namespace std::string_literals; namespace pt = boost::property_tree; -BOOST_AUTO_TEST_CASE(property_tree_put) +class Fixture { - pt::ptree p; - pt::ptree list; - - pt::ptree entry; - - entry.put_value("name1.txt"); - entry.put(".type", "file1"); - - list.push_back(pt::ptree::value_type("listentry", entry)); - - entry.put_value("name2.txt"); - entry.put(".type", "file2"); - - list.push_back(pt::ptree::value_type("listentry", entry)); - - p.push_back(pt::ptree::value_type("list", list)); +public: + Fixture(){} + ~Fixture(){} +}; - std::stringstream ss; - - pt::xml_parser::write_xml(ss, p /*, pt::xml_parser::xml_writer_make_settings(' ', 1)*/); - - BOOST_CHECK_EQUAL(ss.str(), "\nname1.txtname2.txt"); -} - -BOOST_AUTO_TEST_CASE(string_stoul) +BOOST_FIXTURE_TEST_CASE(http_download, Fixture) { - unsigned long l = std::stoul("-1"); - - BOOST_CHECK_EQUAL(l, std::numeric_limits::max()); } diff --git a/webserver.cpp b/webserver.cpp index e848fd1..4591fc9 100644 --- a/webserver.cpp +++ b/webserver.cpp @@ -24,7 +24,7 @@ void initlocale() { } } -int main(int argc, char* argv[]) +int webserver(int argc, char* argv[]) { try { //initlocale(); // TODO: breaks plugins diff --git a/webserver.h b/webserver.h new file mode 100644 index 0000000..fa9f1c2 --- /dev/null +++ b/webserver.h @@ -0,0 +1,4 @@ +#pragma once + +int webserver(int argc, char* argv[]); + -- cgit v1.2.3