Add test case for extensions decoding
[apps/agl-service-can-low-level.git] / tests / Makefile
index 38f10ea..9696b79 100644 (file)
@@ -6,22 +6,30 @@ TESTS=  decode_unittests encode_unittests \
        test_decode1 test_decode2 test_decode3 test_decode3_buf \
        test_encode1 test_encode2 test_encode3 test_encode3_buf \
        test_decode_callbacks test_encode_callbacks \
-       test_missing_fields test_no_messages \
+       test_missing_fields test_no_messages test_funny_name \
        test_multiple_files test_cxxcompile test_options \
-       bc_encode bc_decode
+       bc_encode bc_decode test_encode_extensions test_decode_extensions
 
 # More strict checks for the core part of nanopb
 CC_VERSION=$(shell $(CC) -v 2>&1)
 CFLAGS_CORE=
 ifneq (,$(findstring gcc,$(CC_VERSION)))
        CFLAGS_CORE=-pedantic -Wextra -Wcast-qual -Wlogical-op -Wconversion
-        CFLAGS+=--coverage
-        LDFLAGS+=--coverage
+       CFLAGS+=--coverage -fstack-protector-all
+       LDFLAGS+=--coverage
 endif
 ifneq (,$(findstring clang,$(CC_VERSION)))
        CFLAGS_CORE=-pedantic -Wextra -Wcast-qual -Wconversion
 endif
 
+# Also use mudflap if it is available
+# To enable, run with    make -B USE_MUDFLAP=y
+USE_MUDFLAP ?= n
+ifeq ($(USE_MUDFLAP),y)
+       CFLAGS += -fmudflap
+       LDFLAGS += -lmudflap -fmudflap
+endif
+
 all: breakpoints $(TESTS) run_unittests
 
 clean:
@@ -73,8 +81,11 @@ test_missing_fields: test_missing_fields.o pb_encode.o pb_decode.o missing_field
 decode_unittests: decode_unittests.o pb_decode.o unittestproto.pb.o
 encode_unittests: encode_unittests.o pb_encode.o unittestproto.pb.o
 test_no_messages: no_messages.pb.h no_messages.pb.c no_messages.pb.o
+test_funny_name: funny-proto+name.pb.h funny-proto+name.pb.o
 bc_encode: bc_alltypes.pb.o pb_encode.o bc_encode.o
 bc_decode: bc_alltypes.pb.o pb_decode.o bc_decode.o
+test_encode_extensions: test_encode_extensions.c pb_encode.o alltypes.pb.o extensions.pb.o
+test_decode_extensions: test_decode_extensions.c pb_decode.o alltypes.pb.o extensions.pb.o
 
 %.pb: %.proto
        protoc -I. -I../generator -I/usr/include -o$@ $<
@@ -114,8 +125,10 @@ run_unittests: $(TESTS)
        ./test_encode3 1 | ./test_decode3 1
        ./test_encode3 1 | protoc --decode=AllTypes -I. -I../generator -I/usr/include alltypes.proto >/dev/null
        ./test_encode3_buf 1 | ./test_decode3_buf 1
+       ./test_decode3 < alltypes_with_extra_fields.pb
        ./bc_encode | ./bc_decode
-       
+       ./test_encode_extensions | ./test_decode_extensions
+
        ./test_missing_fields
 
 test_options: options.pb.h options.expected options.pb.o
@@ -126,5 +139,5 @@ test_options: options.pb.h options.expected options.pb.o
            fi \
        done
 
-run_fuzztest: test_decode2
-       bash -c 'I=1; while true; do cat /dev/urandom | ./test_decode2 > /dev/null; I=$$(($$I+1)); echo -en "\r$$I"; done'
+run_fuzztest: test_decode3
+       bash -c 'ulimit -c unlimited; I=1; while true; do cat /dev/urandom | ./test_decode3 > /dev/null; I=$$(($$I+1)); echo -en "\r$$I"; done'