|
@@ -9,6 +9,8 @@
|
|
OBJ_DIR := output/
|
|
OBJ_DIR := output/
|
|
INTEGRATIONTEST_CPP_OBJ_DIR := $(OBJ_DIR)test/integrationtest/
|
|
INTEGRATIONTEST_CPP_OBJ_DIR := $(OBJ_DIR)test/integrationtest/
|
|
INTEGRATIONTEST_C_OBJ_DIR := $(INTEGRATIONTEST_CPP_OBJ_DIR)
|
|
INTEGRATIONTEST_C_OBJ_DIR := $(INTEGRATIONTEST_CPP_OBJ_DIR)
|
|
|
|
+INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT := $(OBJ_DIR)test/integrationtest_transport/
|
|
|
|
+INTEGRATIONTEST_C_OBJ_DIR_TRANSPORT := $(INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT)
|
|
UNITTEST_OBJ_DIR := $(OBJ_DIR)test/unittest/
|
|
UNITTEST_OBJ_DIR := $(OBJ_DIR)test/unittest/
|
|
|
|
|
|
CC := gcc
|
|
CC := gcc
|
|
@@ -20,9 +22,12 @@ SOURCES := src/shellmatta.c \
|
|
src/shellmatta_history.c \
|
|
src/shellmatta_history.c \
|
|
src/shellmatta_utils.c \
|
|
src/shellmatta_utils.c \
|
|
src/shellmatta_escape.c \
|
|
src/shellmatta_escape.c \
|
|
- src/shellmatta_opt.c \
|
|
|
|
- src/shellmatta_transport.c \
|
|
|
|
- src/shellmatta_crc.c
|
|
|
|
|
|
+ src/shellmatta_opt.c
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+SOURCES_TRANPORT_LAYER := $(SOURCES) \
|
|
|
|
+ src/shellmatta_transport.c \
|
|
|
|
+ src/shellmatta_crc.c
|
|
|
|
|
|
INCLUDES := api .
|
|
INCLUDES := api .
|
|
|
|
|
|
@@ -54,32 +59,43 @@ INTEGRATIONTEST_SOURCES := test/integrationtest/test_main.cpp
|
|
test/integrationtest/test_integration_continue.cpp \
|
|
test/integrationtest/test_integration_continue.cpp \
|
|
test/integrationtest/test_integration_busy.cpp \
|
|
test/integrationtest/test_integration_busy.cpp \
|
|
test/integrationtest/test_integration_history.cpp \
|
|
test/integrationtest/test_integration_history.cpp \
|
|
- test/integrationtest/test_integration_help.cpp \
|
|
|
|
- test/integrationtest/test_integration_transport.cpp
|
|
|
|
|
|
+ test/integrationtest/test_integration_help.cpp
|
|
|
|
+
|
|
|
|
+INTEGRATIONTEST_TRANSPORT_SOURCES := $(INTEGRATIONTEST_SOURCES) \
|
|
|
|
+ test/integrationtest/test_integration_transport.cpp
|
|
|
|
|
|
UNITTEST_CPPOBJ := $(patsubst %.cpp,$(UNITTEST_OBJ_DIR)%.o,$(UNITTEST_SOURCES))
|
|
UNITTEST_CPPOBJ := $(patsubst %.cpp,$(UNITTEST_OBJ_DIR)%.o,$(UNITTEST_SOURCES))
|
|
|
|
|
|
INTEGRATIONTEST_CPPOBJ := $(patsubst %.cpp,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(INTEGRATIONTEST_SOURCES))
|
|
INTEGRATIONTEST_CPPOBJ := $(patsubst %.cpp,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(INTEGRATIONTEST_SOURCES))
|
|
INTEGRATIONTEST_COBJ := $(patsubst %.c,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(SOURCES))
|
|
INTEGRATIONTEST_COBJ := $(patsubst %.c,$(INTEGRATIONTEST_CPP_OBJ_DIR)%.o,$(SOURCES))
|
|
|
|
|
|
-CFLAGS := $(INCLUDES:%=-I%) -g -Wall -Werror -Wextra -pedantic -DSHELLMATTA_HELP_ALIAS=\(char*\)\"?\"
|
|
|
|
-TESTFLAGS := $(CFLAGS) -fprofile-arcs -ftest-coverage
|
|
|
|
-TESTLFLAGS := -fprofile-arcs -Wl,--allow-multiple-definition
|
|
|
|
|
|
+INTEGRATIONTEST_TRANSPORT_CPPOBJ := $(patsubst %.cpp,$(INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT)%.o,$(INTEGRATIONTEST_TRANSPORT_SOURCES))
|
|
|
|
+INTEGRATIONTEST_TRANSPORT_COBJ := $(patsubst %.c,$(INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT)%.o,$(SOURCES_TRANPORT_LAYER))
|
|
|
|
|
|
-DEPEND = -MT $@ -MF "$(@:%.o=%.d)" -MG -MM
|
|
|
|
|
|
+CFLAGS := $(INCLUDES:%=-I%) -g -Wall -Werror -Wextra -pedantic
|
|
|
|
+CFLAGS += -DSHELLMATTA_HELP_ALIAS=\(char*\)\"?\"
|
|
|
|
+TESTFLAGS := $(CFLAGS) -fprofile-arcs -ftest-coverage
|
|
|
|
+TESTLFLAGS := -fprofile-arcs -Wl,--allow-multiple-definition
|
|
|
|
+TESTFLAGS_TRANSPORT := $(TESTFLAGS) -DSHELLMATTA_TRANSPORT_ENABLE
|
|
|
|
+TESTLFLAGS_TRANSPORT := $(TESTLFLAGS)
|
|
|
|
+EXAMPLE_CFLAGS := $(CFLAGS) -DSHELLMATTA_TRANSPORT_ENABLE
|
|
|
|
+DEPEND = -MT $@ -MF "$(@:%.o=%.d)" -MG -MM
|
|
|
|
|
|
-COBJ := $(patsubst %.c,$(OBJ_DIR)%.o,$(SOURCES))
|
|
|
|
-
|
|
|
|
-EXAMPLE_SOURCES := example/main.c
|
|
|
|
|
|
+EXAMPLE_SOURCES := example/main.c $(SOURCES_TRANPORT_LAYER)
|
|
EXAMPLE_COBJ := $(patsubst %.c,$(OBJ_DIR)%.o,$(EXAMPLE_SOURCES))
|
|
EXAMPLE_COBJ := $(patsubst %.c,$(OBJ_DIR)%.o,$(EXAMPLE_SOURCES))
|
|
|
|
|
|
-EXAMPLE_TARGET := $(OBJ_DIR)example/example
|
|
|
|
-
|
|
|
|
-UNITTEST_TARGET := $(OBJ_DIR)test/unittest/unittest
|
|
|
|
|
|
|
|
-INTEGRATIONTEST_TARGET := $(OBJ_DIR)test/integrationtest/integrationtest
|
|
|
|
|
|
+EXAMPLE_TARGET := $(OBJ_DIR)example/example
|
|
|
|
+UNITTEST_TARGET := $(OBJ_DIR)test/unittest/unittest
|
|
|
|
+INTEGRATIONTEST_TARGET := $(OBJ_DIR)test/integrationtest/integrationtest
|
|
|
|
+INTEGRATIONTEST_TRANSPORT_TARGET := $(OBJ_DIR)test/integrationtest_transport/integrationtest_transport
|
|
|
|
|
|
-OBJ := $(COBJ) $(EXAMPLE_COBJ) $(UNITTEST_CPPOBJ) $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ)
|
|
|
|
|
|
+OBJ := $(EXAMPLE_COBJ) \
|
|
|
|
+ $(UNITTEST_CPPOBJ) \
|
|
|
|
+ $(INTEGRATIONTEST_CPPOBJ) \
|
|
|
|
+ $(INTEGRATIONTEST_COBJ) \
|
|
|
|
+ $(INTEGRATIONTEST_TRANSPORT_CPPOBJ) \
|
|
|
|
+ $(INTEGRATIONTEST_TRANSPORT_COBJ)
|
|
DEPS := $(OBJ:%.o=%.d)
|
|
DEPS := $(OBJ:%.o=%.d)
|
|
|
|
|
|
export
|
|
export
|
|
@@ -94,7 +110,7 @@ help:
|
|
@echo example - build example
|
|
@echo example - build example
|
|
@echo -----------------------------------------------
|
|
@echo -----------------------------------------------
|
|
|
|
|
|
-test: unittest integrationtest
|
|
|
|
|
|
+test: unittest integrationtest integrationtest_transport
|
|
|
|
|
|
cppcheck:
|
|
cppcheck:
|
|
- @mkdir -p output/cppcheck/html
|
|
- @mkdir -p output/cppcheck/html
|
|
@@ -124,6 +140,17 @@ integrationtest: $(INTEGRATIONTEST_TARGET)
|
|
# -rm -rf $(OBJ_DIR)test/unittest/report/*
|
|
# -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
|
|
gcovr --html-details --output $(OBJ_DIR)test/integrationtest/report/report.html output/test/integrationtest -f src -f api -d
|
|
|
|
|
|
|
|
+integrationtest_transport: $(INTEGRATIONTEST_TRANSPORT_TARGET)
|
|
|
|
+ - @mkdir -p output/test/integrationtest_transport/report
|
|
|
|
+ @echo running test:
|
|
|
|
+# remove coverage from former run
|
|
|
|
+# @-find . -name "*.gcda" -type f -delete
|
|
|
|
+ -$(INTEGRATIONTEST_TRANSPORT_TARGET)
|
|
|
|
+
|
|
|
|
+ # remove report from former run
|
|
|
|
+# -rm -rf $(OBJ_DIR)test/unittest/report/*
|
|
|
|
+ gcovr --html-details --output $(OBJ_DIR)test/integrationtest_transport/report/report.html output/test/integrationtest_transport -f src -f api -d
|
|
|
|
+
|
|
example: $(EXAMPLE_TARGET)
|
|
example: $(EXAMPLE_TARGET)
|
|
@echo building example
|
|
@echo building example
|
|
|
|
|
|
@@ -135,7 +162,7 @@ doc:
|
|
clean:
|
|
clean:
|
|
- rm -rf $(OBJ_DIR)
|
|
- rm -rf $(OBJ_DIR)
|
|
|
|
|
|
-$(EXAMPLE_TARGET): $(COBJ) $(EXAMPLE_COBJ)
|
|
|
|
|
|
+$(EXAMPLE_TARGET): $(EXAMPLE_COBJ)
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
$(CC) $(LFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
$(CC) $(LFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
|
|
|
@@ -146,20 +173,15 @@ $(UNITTEST_TARGET): $(UNITTEST_CPPOBJ)
|
|
$(INTEGRATIONTEST_TARGET): $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ)
|
|
$(INTEGRATIONTEST_TARGET): $(INTEGRATIONTEST_CPPOBJ) $(INTEGRATIONTEST_COBJ)
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
$(CPP) $(TESTLFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
$(CPP) $(TESTLFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
-
|
|
|
|
-$(TARGET): $(OBJ)
|
|
|
|
- - @mkdir -p $(@D)
|
|
|
|
- $(CC) $(LFLAGS) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
|
|
|
|
|
-$(COBJ):
|
|
|
|
|
|
+$(INTEGRATIONTEST_TRANSPORT_TARGET): $(INTEGRATIONTEST_TRANSPORT_CPPOBJ) $(INTEGRATIONTEST_TRANSPORT_COBJ)
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
- @$(CC) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
- $(CC) -c $(CFLAGS) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
|
|
+ $(CPP) $(TESTLFLAGS_TRANSPORT) $(LIB_PATH) -o $@ $^ $(LIBS)
|
|
|
|
|
|
$(EXAMPLE_COBJ):
|
|
$(EXAMPLE_COBJ):
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
- @$(CC) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
- $(CC) -c $(CFLAGS) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
|
|
+ @$(CC) -c $(EXAMPLE_CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
+ $(CC) -c $(EXAMPLE_CFLAGS) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
|
|
$(UNITTEST_CPPOBJ):
|
|
$(UNITTEST_CPPOBJ):
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
@@ -176,6 +198,16 @@ $(INTEGRATIONTEST_COBJ):
|
|
@$(CC) -c $(TESTFLAGS) $(DEPEND) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
@$(CC) -c $(TESTFLAGS) $(DEPEND) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
$(CC) -c $(TESTFLAGS) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
$(CC) -c $(TESTFLAGS) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR), ,$(@:%.o=%.c))
|
|
|
|
|
|
|
|
+$(INTEGRATIONTEST_TRANSPORT_CPPOBJ):
|
|
|
|
+ - @mkdir -p $(@D)
|
|
|
|
+ @$(CPP) -c $(TESTFLAGS_TRANSPORT) $(DEPEND) -o $@ $(subst $(INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT), ,$(@:%.o=%.cpp))
|
|
|
|
+ $(CPP) -c $(TESTFLAGS_TRANSPORT) -o $@ $(subst $(INTEGRATIONTEST_CPP_OBJ_DIR_TRANSPORT), ,$(@:%.o=%.cpp))
|
|
|
|
+
|
|
|
|
+$(INTEGRATIONTEST_TRANSPORT_COBJ):
|
|
|
|
+ - @mkdir -p $(@D)
|
|
|
|
+ @$(CC) -c $(TESTFLAGS_TRANSPORT) $(DEPEND) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR_TRANSPORT), ,$(@:%.o=%.c))
|
|
|
|
+ $(CC) -c $(TESTFLAGS_TRANSPORT) -o $@ $(subst $(INTEGRATIONTEST_C_OBJ_DIR_TRANSPORT), ,$(@:%.o=%.c))
|
|
|
|
+
|
|
%.o: %.cpp
|
|
%.o: %.cpp
|
|
- @mkdir -p $(@D)
|
|
- @mkdir -p $(@D)
|
|
@$(CPP) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|
|
@$(CPP) -c $(CFLAGS) $(DEPEND) -o $@ $(subst $(OBJ_DIR), ,$(@:%.o=%.c))
|