|
@@ -1,15 +1,17 @@
|
|
|
-#
|
|
|
+#
|
|
|
# Copyright (c) 2019 - 2021 Stefan Strobel <stefan.strobel@shimatta.net>
|
|
|
-#
|
|
|
+#
|
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
# file, You can obtain one at https://mozilla.org/MPL/2.0/.
|
|
|
-#
|
|
|
+#
|
|
|
|
|
|
OBJ_DIR := output/
|
|
|
OBJ_DIR_EXAMPLE := $(OBJ_DIR)example_obj/
|
|
|
INTEGRATIONTEST_CPP_OBJ_DIR := $(OBJ_DIR)test/integrationtest/
|
|
|
+INTEGRATIONTEST_AUTH_CPP_OBJ_DIR := $(OBJ_DIR)test/integrationtest_auth/
|
|
|
INTEGRATIONTEST_C_OBJ_DIR := $(INTEGRATIONTEST_CPP_OBJ_DIR)
|
|
|
+INTEGRATIONTEST_AUTH_C_OBJ_DIR := $(INTEGRATIONTEST_AUTH_CPP_OBJ_DIR)
|
|
|
UNITTEST_OBJ_DIR := $(OBJ_DIR)test/unittest/
|
|
|
|
|
|
CC := gcc
|
|
@@ -53,14 +55,21 @@ INTEGRATIONTEST_SOURCES := test/integrationtest/test_main.cpp
|
|
|
test/integrationtest/test_integration_history.cpp \
|
|
|
test/integrationtest/test_integration_help.cpp
|
|
|
|
|
|
+INTEGRATIONTEST_AUTH_SOURCES := test/integrationtest_auth/test_main.cpp \
|
|
|
+ test/integrationtest_auth/test_integration_auth.cpp
|
|
|
+
|
|
|
UNITTEST_CPPOBJ := $(patsubst %.cpp,$(UNITTEST_OBJ_DIR)%.o,$(UNITTEST_SOURCES))
|
|
|
|
|
|
INTEGRATIONTEST_CPPOBJ := $(patsubst %.cpp,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(INTEGRATIONTEST_SOURCES))
|
|
|
INTEGRATIONTEST_COBJ := $(patsubst %.c,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(SOURCES))
|
|
|
|
|
|
+INTEGRATIONTEST_AUTH_CPPOBJ := $(patsubst %.cpp,$(INTEGRATIONTEST_AUTH_CPP_OBJ_DIR)%.o,$(INTEGRATIONTEST_AUTH_SOURCES))
|
|
|
+INTEGRATIONTEST_AUTH_COBJ := $(patsubst %.c,$(INTEGRATIONTEST_AUTH_CPP_OBJ_DIR)%.o,$(SOURCES) src/shellmatta_auth.c)
|
|
|
+
|
|
|
CFLAGS := $(INCLUDES:%=-I%) -g -Wall -Werror -Wextra -pedantic -DSHELLMATTA_HELP_ALIAS=\(char*\)\"?\"
|
|
|
CFLAGS_EXAMPLE = $(CFLAGS) -DSHELLMATTA_AUTHENTICATION
|
|
|
TESTFLAGS := $(CFLAGS) -fprofile-arcs -ftest-coverage
|
|
|
+TESTFLAGS_AUTH := $(CFLAGS) -DSHELLMATTA_AUTHENTICATION -fprofile-arcs -ftest-coverage
|
|
|
TESTLFLAGS := -fprofile-arcs -Wl,--allow-multiple-definition
|
|
|
|
|
|
DEPEND = -MT $@ -MF "$(@:%.o=%.d)" -MG -MM
|
|
@@ -73,10 +82,13 @@ EXAMPLE_COBJ := $(patsubst %.c,$(OBJ_DIR_EXAMPLE)%.o,$(EXAMPLE_SOURCES))
|
|
|
EXAMPLE_TARGET := $(OBJ_DIR)example/example
|
|
|
|
|
|
UNITTEST_TARGET := $(OBJ_DIR)test/unittest/unittest
|
|
|
-
|
|
|
INTEGRATIONTEST_TARGET := $(OBJ_DIR)test/integrationtest/integrationtest
|
|
|
+INTEGRATIONTEST_TARGET_AUTH := $(OBJ_DIR)test/integrationtest_auth/integrationtest_auth
|
|
|
|
|
|
-OBJ := $(COBJ) $(EXAMPLE_COBJ) $(UNITTEST_CPPOBJ) $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ)
|
|
|
+TEST_RUN_TARGETS := unittest integrationtest integrationtest_auth
|
|
|
+TEST_TARGETS := $(UNITTEST_TARGET) $(INTEGRATIONTEST_TARGET) $(INTEGRATIONTEST_TARGET_AUTH)
|
|
|
+
|
|
|
+OBJ := $(COBJ) $(EXAMPLE_COBJ) $(UNITTEST_CPPOBJ) $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ) $(INTEGRATIONTEST_AUTH_CPPOBJ) $(INTEGRATIONTEST_AUTH_COBJ)
|
|
|
DEPS := $(OBJ:%.o=%.d)
|
|
|
|
|
|
export
|
|
@@ -91,7 +103,7 @@ help:
|
|
|
@echo example - build example
|
|
|
@echo -----------------------------------------------
|
|
|
|
|
|
-test: unittest integrationtest
|
|
|
+test: $(TEST_RUN_TARGETS)
|
|
|
|
|
|
cppcheck:
|
|
|
- @mkdir -p output/cppcheck/html
|
|
@@ -99,27 +111,17 @@ cppcheck:
|
|
|
cppcheck --enable=all --template=gcc --cppcheck-build-dir=output/cppcheck $(SOURCES) --xml 2>output/cppcheck/cppcheck.xml
|
|
|
cppcheck-htmlreport --file=output/cppcheck/cppcheck.xml --title="Shellmatta" --report-dir=output/cppcheck/html
|
|
|
|
|
|
-unittest: $(UNITTEST_TARGET)
|
|
|
- - @mkdir -p output/test/unittest/report
|
|
|
- @echo running test:
|
|
|
+
|
|
|
+$(TEST_RUN_TARGETS): $(TEST_TARGETS)
|
|
|
+ - @mkdir -p output/test/$@/report
|
|
|
+ @echo running test $@:
|
|
|
# remove coverage from former run
|
|
|
@-find . -name "*.gcda" -type f -delete
|
|
|
- -$(UNITTEST_TARGET)
|
|
|
+ -$(OBJ_DIR)test/$@/$@
|
|
|
|
|
|
# remove report from former run
|
|
|
- -rm -rf $(OBJ_DIR)test/unittest/report/*
|
|
|
- gcovr --html-details --output $(OBJ_DIR)test/unittest/report/report.html output/test/unittest -f src -f api -d
|
|
|
-
|
|
|
-integrationtest: $(INTEGRATIONTEST_TARGET)
|
|
|
- - @mkdir -p output/test/integrationtest/report
|
|
|
- @echo running test:
|
|
|
-# remove coverage from former run
|
|
|
-# @-find . -name "*.gcda" -type f -delete
|
|
|
- -$(INTEGRATIONTEST_TARGET)
|
|
|
-
|
|
|
- # remove report from former run
|
|
|
-# -rm -rf $(OBJ_DIR)test/unittest/report/*
|
|
|
- gcovr --html-details --output $(OBJ_DIR)test/integrationtest/report/report.html output/test/integrationtest -f src -f api -d
|
|
|
+ -rm -rf $(OBJ_DIR)test/$@/report/*
|
|
|
+ gcovr --html-details --output $(OBJ_DIR)test/$@/report/report.html output/test/$@ -f src -f api -d
|
|
|
|
|
|
example: $(EXAMPLE_TARGET)
|
|
|
@echo building example
|
|
@@ -128,7 +130,7 @@ doc:
|
|
|
- @mkdir -p output/doc/html
|
|
|
- @mkdir -p output/doc/latex
|
|
|
doxygen cfg/doxygen/doxyfile
|
|
|
-
|
|
|
+
|
|
|
clean:
|
|
|
- rm -rf $(OBJ_DIR)
|
|
|
|
|
@@ -139,15 +141,20 @@ $(EXAMPLE_TARGET): $(EXAMPLE_COBJ)
|
|
|
$(UNITTEST_TARGET): $(UNITTEST_CPPOBJ)
|
|
|
- @mkdir -p $(@D)
|
|
|
$(CPP) $(TESTLFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
-
|
|
|
+
|
|
|
$(INTEGRATIONTEST_TARGET): $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ)
|
|
|
- @mkdir -p $(@D)
|
|
|
$(CPP) $(TESTLFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
|
|
|
+$(INTEGRATIONTEST_TARGET_AUTH): $(INTEGRATIONTEST_AUTH_CPPOBJ) $(INTEGRATIONTEST_AUTH_COBJ)
|
|
|
+ - @mkdir -p $(@D)
|
|
|
+ echo askdjhaskjdhskj
|
|
|
+ $(CPP) $(TESTLFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
+
|
|
|
$(TARGET): $(OBJ)
|
|
|
- @mkdir -p $(@D)
|
|
|
$(CC) $(LFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
-
|
|
|
+
|
|
|
$(COBJ):
|
|
|
- @mkdir -p $(@D)
|
|
|
@$(CC) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
@@ -174,6 +181,16 @@ $(INTEGRATIONTEST_COBJ):
|
|
|
@$(CC) -c $(TESTFLAGS) $(DEPEND) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
$(CC) -c $(TESTFLAGS) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
|
|
+$(INTEGRATIONTEST_AUTH_CPPOBJ):
|
|
|
+ - @mkdir -p $(@D)
|
|
|
+ @$(CPP) -c $(TESTFLAGS_AUTH) $(DEPEND) -o $(@:%.o=%.d) $(subst $(INTEGRATIONTEST_AUTH_CPP_OBJ_DIR), ,$(@:%.o=%.cpp))
|
|
|
+ $(CPP) -c $(TESTFLAGS_AUTH) -o $@ $(subst $(INTEGRATIONTEST_AUTH_CPP_OBJ_DIR), ,$(@:%.o=%.cpp))
|
|
|
+
|
|
|
+$(INTEGRATIONTEST_AUTH_COBJ):
|
|
|
+ - @mkdir -p $(@D)
|
|
|
+ $(CC) -c $(TESTFLAGS_AUTH) $(DEPEND) -o $(@:%.o=%.d) $(subst $(INTEGRATIONTEST_AUTH_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
+ $(CC) -c $(TESTFLAGS_AUTH) -o $@ $(subst $(INTEGRATIONTEST_AUTH_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
+
|
|
|
%.o: %.cpp
|
|
|
- @mkdir -p $(@D)
|
|
|
@$(CPP) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|