summaryrefslogtreecommitdiff
path: root/deps/Unity/test
diff options
context:
space:
mode:
authorOmniscient <17525998+omnisci3nce@users.noreply.github.com>2024-02-24 22:47:46 +1100
committerOmniscient <17525998+omnisci3nce@users.noreply.github.com>2024-02-24 22:47:46 +1100
commit7b3afcaf77f96e7d62f6cd1623ead7f17512d79f (patch)
treeb5f82c64e9c06a84e4d095ab4ac48712e860b673 /deps/Unity/test
parentb047be5252aeb981faea077409c1768fda0301d9 (diff)
repo init. partial port of existing code
Diffstat (limited to 'deps/Unity/test')
-rw-r--r--deps/Unity/test/.rubocop.yml78
-rw-r--r--deps/Unity/test/Makefile160
-rw-r--r--deps/Unity/test/expectdata/testsample_cmd.c61
-rw-r--r--deps/Unity/test/expectdata/testsample_def.c57
-rw-r--r--deps/Unity/test/expectdata/testsample_head1.c55
-rw-r--r--deps/Unity/test/expectdata/testsample_head1.h15
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_cmd.c80
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_def.c76
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_head1.c75
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_head1.h13
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_new1.c89
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_new2.c89
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_param.c77
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_run1.c89
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_run2.c89
-rw-r--r--deps/Unity/test/expectdata/testsample_mock_yaml.c90
-rw-r--r--deps/Unity/test/expectdata/testsample_new1.c67
-rw-r--r--deps/Unity/test/expectdata/testsample_new2.c70
-rw-r--r--deps/Unity/test/expectdata/testsample_param.c58
-rw-r--r--deps/Unity/test/expectdata/testsample_run1.c67
-rw-r--r--deps/Unity/test/expectdata/testsample_run2.c70
-rw-r--r--deps/Unity/test/expectdata/testsample_yaml.c71
-rw-r--r--deps/Unity/test/rakefile163
-rw-r--r--deps/Unity/test/rakefile_helper.rb315
-rw-r--r--deps/Unity/test/spec/generate_module_existing_file_spec.rb158
-rw-r--r--deps/Unity/test/targets/ansi.yml44
-rw-r--r--deps/Unity/test/targets/clang_file.yml72
-rw-r--r--deps/Unity/test/targets/clang_strict.yml72
-rw-r--r--deps/Unity/test/targets/gcc_32.yml45
-rw-r--r--deps/Unity/test/targets/gcc_64.yml46
-rw-r--r--deps/Unity/test/targets/gcc_auto_limits.yml43
-rw-r--r--deps/Unity/test/targets/gcc_auto_stdint.yml55
-rw-r--r--deps/Unity/test/targets/gcc_manual_math.yml43
-rw-r--r--deps/Unity/test/targets/hitech_picc18.yml91
-rw-r--r--deps/Unity/test/targets/iar_arm_v4.yml98
-rw-r--r--deps/Unity/test/targets/iar_arm_v5.yml92
-rw-r--r--deps/Unity/test/targets/iar_arm_v5_3.yml92
-rw-r--r--deps/Unity/test/targets/iar_armcortex_LM3S9B92_v5_4.yml90
-rw-r--r--deps/Unity/test/targets/iar_cortexm3_v5.yml94
-rw-r--r--deps/Unity/test/targets/iar_msp430.yml112
-rw-r--r--deps/Unity/test/targets/iar_sh2a_v6.yml99
-rw-r--r--deps/Unity/test/testdata/CException.h11
-rw-r--r--deps/Unity/test/testdata/Defs.h9
-rw-r--r--deps/Unity/test/testdata/cmock.h14
-rw-r--r--deps/Unity/test/testdata/mockMock.h13
-rw-r--r--deps/Unity/test/testdata/testRunnerGenerator.c197
-rw-r--r--deps/Unity/test/testdata/testRunnerGeneratorSmall.c66
-rw-r--r--deps/Unity/test/testdata/testRunnerGeneratorWithMocks.c193
-rw-r--r--deps/Unity/test/tests/self_assessment_utils.h144
-rw-r--r--deps/Unity/test/tests/test_generate_test_runner.rb1298
-rw-r--r--deps/Unity/test/tests/test_unity_arrays.c2940
-rw-r--r--deps/Unity/test/tests/test_unity_core.c371
-rw-r--r--deps/Unity/test/tests/test_unity_doubles.c1284
-rw-r--r--deps/Unity/test/tests/test_unity_floats.c1394
-rw-r--r--deps/Unity/test/tests/test_unity_integers.c2862
-rw-r--r--deps/Unity/test/tests/test_unity_integers_64.c782
-rw-r--r--deps/Unity/test/tests/test_unity_memory.c81
-rw-r--r--deps/Unity/test/tests/test_unity_parameterized.c308
-rw-r--r--deps/Unity/test/tests/test_unity_parameterizedDemo.c21
-rw-r--r--deps/Unity/test/tests/test_unity_strings.c329
-rw-r--r--deps/Unity/test/tests/types_for_test.h14
61 files changed, 15751 insertions, 0 deletions
diff --git a/deps/Unity/test/.rubocop.yml b/deps/Unity/test/.rubocop.yml
new file mode 100644
index 0000000..a3b811b
--- /dev/null
+++ b/deps/Unity/test/.rubocop.yml
@@ -0,0 +1,78 @@
+# This is the configuration used to check the rubocop source code.
+
+#inherit_from: .rubocop_todo.yml
+
+AllCops:
+ TargetRubyVersion: 3.0
+
+# These are areas where ThrowTheSwitch's coding style diverges from the Ruby standard
+Style/SpecialGlobalVars:
+ EnforcedStyle: use_perl_names
+Style/FormatString:
+ Enabled: false
+Style/GlobalVars:
+ Enabled: false
+Style/FrozenStringLiteralComment:
+ Enabled: false
+Style/RegexpLiteral:
+ AllowInnerSlashes: true
+Style/HashSyntax:
+ EnforcedStyle: no_mixed_keys
+Style/NumericPredicate:
+ Enabled: false
+Style/MultilineBlockChain:
+ Enabled: false
+Style/Alias:
+ Enabled: false
+Style/EvalWithLocation:
+ Enabled: false
+Style/MixinUsage:
+ Enabled: false
+Style/OptionalBooleanParameter:
+ Enabled: false
+
+# These are also places we diverge... but we will likely comply down the road
+Style/IfUnlessModifier:
+ Enabled: false
+Style/FormatStringToken:
+ Enabled: false
+
+# This is disabled because it seems to get confused over nested hashes
+Layout/HashAlignment:
+ Enabled: false
+ EnforcedHashRocketStyle: table
+ EnforcedColonStyle: table
+Layout/LineLength:
+ Enabled: false
+
+# We purposefully use these insecure features because they're what makes Ruby awesome
+Security/Eval:
+ Enabled: false
+Security/YAMLLoad:
+ Enabled: false
+
+# At this point, we're not ready to enforce inline documentation requirements
+Style/Documentation:
+ Enabled: false
+Style/DocumentationMethod:
+ Enabled: false
+
+# At this point, we're not ready to enforce any metrics
+Metrics/AbcSize:
+ Enabled: false
+Metrics/BlockLength:
+ Enabled: false
+Metrics/BlockNesting:
+ Enabled: false
+Metrics/ClassLength:
+ Enabled: false
+Metrics/CyclomaticComplexity:
+ Enabled: false
+Metrics/MethodLength:
+ Enabled: false
+Metrics/ModuleLength:
+ Enabled: false
+Metrics/ParameterLists:
+ Enabled: false
+Metrics/PerceivedComplexity:
+ Enabled: false
diff --git a/deps/Unity/test/Makefile b/deps/Unity/test/Makefile
new file mode 100644
index 0000000..5be0488
--- /dev/null
+++ b/deps/Unity/test/Makefile
@@ -0,0 +1,160 @@
+CC = gcc
+ifeq ($(shell uname -s), Darwin)
+CC = clang
+endif
+ifeq ($(findstring clang, $(CC)), clang)
+E = -Weverything
+CFLAGS += $E -Wno-unknown-warning-option -Wno-missing-prototypes
+CFLAGS += -Wno-unused-macros -Wno-padded -Wno-missing-noreturn
+endif
+CFLAGS += -std=c99 -pedantic -Wall -Wextra -Werror
+#CFLAGS += -Wconversion #disabled because if falsely complains about the isinf and isnan macros
+CFLAGS += -Wno-switch-enum -Wno-double-promotion
+CFLAGS += -Wno-poison-system-directories
+CFLAGS += -Wbad-function-cast -Wcast-qual -Wold-style-definition -Wshadow -Wstrict-overflow \
+ -Wstrict-prototypes -Wswitch-default -Wundef
+#DEBUG = -O0 -g
+CFLAGS += $(DEBUG)
+UNITY_SUPPORT_64 = -D UNITY_SUPPORT_64
+UNITY_INCLUDE_DOUBLE = -D UNITY_INCLUDE_DOUBLE
+DEFINES = -D UNITY_OUTPUT_CHAR=putcharSpy
+DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=putcharSpy\(int\)
+DEFINES += -D UNITY_OUTPUT_FLUSH=flushSpy
+DEFINES += -D UNITY_OUTPUT_FLUSH_HEADER_DECLARATION=flushSpy\(void\)
+DEFINES += $(UNITY_SUPPORT_64) $(UNITY_INCLUDE_DOUBLE)
+SRC1 = ../src/unity.c tests/test_unity_arrays.c build/test_unity_arraysRunner.c
+SRC2 = ../src/unity.c tests/test_unity_core.c build/test_unity_coreRunner.c
+SRC3 = ../src/unity.c tests/test_unity_doubles.c build/test_unity_doublesRunner.c
+SRC4 = ../src/unity.c tests/test_unity_floats.c build/test_unity_floatsRunner.c
+SRC5 = ../src/unity.c tests/test_unity_integers.c build/test_unity_integersRunner.c
+SRC6 = ../src/unity.c tests/test_unity_integers_64.c build/test_unity_integers_64Runner.c
+SRC7 = ../src/unity.c tests/test_unity_memory.c build/test_unity_memoryRunner.c
+SRC8 = ../src/unity.c tests/test_unity_strings.c build/test_unity_stringsRunner.c
+INC_DIR = -I ../src
+COV_FLAGS = -fprofile-arcs -ftest-coverage -I ../../src
+BUILD_DIR = build
+TARGET = build/testunity-cov.exe
+
+# To generate coverage, call 'make -s', the default target runs.
+# For verbose output of all the tests, run 'make test'.
+default: coverage
+.PHONY: default coverage test clean
+coverage: $(SRC1) $(SRC2) $(SRC3) $(SRC4) $(SRC5) $(SRC6) $(SRC7) $(SRC8)
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC1), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC2), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC3), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC4), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC5), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC6), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC7), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+ cd $(BUILD_DIR) && \
+ $(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC8), ../$i) $(COV_FLAGS) -o ../$(TARGET)
+ rm -f $(BUILD_DIR)/*.gcda
+ ./$(TARGET) | grep 'Tests\|]]]' -A1
+ cd $(BUILD_DIR) && \
+ gcov unity.c | head -3
+ grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
+
+test: $(SRC1) $(SRC2) $(SRC3) $(SRC4) $(SRC5) $(SRC6) $(SRC7) $(SRC8)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC1) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC2) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC3) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC4) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC5) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC6) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC7) -o $(TARGET)
+ ./$(TARGET)
+ $(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC8) -o $(TARGET)
+ ./$(TARGET)
+
+# Compile only, for testing that preprocessor detection works
+UNITY_C_ONLY =-c ../src/unity.c -o $(BUILD_DIR)/unity.o
+intDetection:
+ $(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_STDINT_H
+ $(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_LIMITS_H
+
+$(BUILD_DIR)/test_unity_arraysRunner.c: tests/test_unity_arrays.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_arrays.c > $@
+
+$(BUILD_DIR)/test_unity_coreRunner.c: tests/test_unity_core.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_core.c > $@
+
+$(BUILD_DIR)/test_unity_doublesRunner.c: tests/test_unity_doubles.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_doubles.c > $@
+
+$(BUILD_DIR)/test_unity_floatsRunner.c: tests/test_unity_floats.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_floats.c > $@
+
+$(BUILD_DIR)/test_unity_integersRunner.c: tests/test_unity_integers.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_integers.c > $@
+
+$(BUILD_DIR)/test_unity_integers_64Runner.c: tests/test_unity_integers_64.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_integers_64.c > $@
+
+$(BUILD_DIR)/test_unity_memoryRunner.c: tests/test_unity_memory.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_memory.c > $@
+
+$(BUILD_DIR)/test_unity_stringsRunner.c: tests/test_unity_strings.c | $(BUILD_DIR)
+ awk $(AWK_SCRIPT) tests/test_unity_strings.c > $@
+
+AWK_SCRIPT=\
+ '/^void test/{ declarations[d++]=$$0; gsub(/\(?void\)? ?/,""); tests[t++]=$$0; line[u++]=NR } \
+ END{ print "\#include \"unity.h\" /* Autogenerated by awk in Makefile */" ; \
+ for (i=0; i<d; i++) { print declarations[i] ";" } \
+ print "int main(void)\n{\n UnityBegin(\"" FILENAME "\");" ; \
+ for (i=0; i<t; i++) { print " RUN_TEST(" tests[i] ", " line[i] ");" } \
+ print " return UNITY_END();\n}" }'
+
+$(BUILD_DIR):
+ mkdir -p $(BUILD_DIR)
+
+clean:
+ rm -f $(TARGET) $(BUILD_DIR)/*.gc* $(BUILD_DIR)/test_unity_*Runner.c
diff --git a/deps/Unity/test/expectdata/testsample_cmd.c b/deps/Unity/test/expectdata/testsample_cmd.c
new file mode 100644
index 0000000..7bcf8e1
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_cmd.c
@@ -0,0 +1,61 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_def.c b/deps/Unity/test/expectdata/testsample_def.c
new file mode 100644
index 0000000..b8ad559
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_def.c
@@ -0,0 +1,57 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_head1.c b/deps/Unity/test/expectdata/testsample_head1.c
new file mode 100644
index 0000000..1d01551
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_head1.c
@@ -0,0 +1,55 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "testsample_head1.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_head1.h b/deps/Unity/test/expectdata/testsample_head1.h
new file mode 100644
index 0000000..da6b7ab
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_head1.h
@@ -0,0 +1,15 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+#ifndef _TESTSAMPLE_HEAD1_H
+#define _TESTSAMPLE_HEAD1_H
+
+#include "unity.h"
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+void test_TheFirstThingToTest(void);
+void test_TheSecondThingToTest(void);
+void test_TheThirdThingToTest(void);
+void test_TheFourthThingToTest(void);
+#endif
+
diff --git a/deps/Unity/test/expectdata/testsample_mock_cmd.c b/deps/Unity/test/expectdata/testsample_mock_cmd.c
new file mode 100644
index 0000000..45a09af
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_cmd.c
@@ -0,0 +1,80 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_def.c b/deps/Unity/test/expectdata/testsample_mock_def.c
new file mode 100644
index 0000000..a7a2607
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_def.c
@@ -0,0 +1,76 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_head1.c b/deps/Unity/test/expectdata/testsample_mock_head1.c
new file mode 100644
index 0000000..45829fe
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_head1.c
@@ -0,0 +1,75 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "testsample_mock_head1.h"
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_head1.h b/deps/Unity/test/expectdata/testsample_mock_head1.h
new file mode 100644
index 0000000..30c509a
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_head1.h
@@ -0,0 +1,13 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+#ifndef _TESTSAMPLE_MOCK_HEAD1_H
+#define _TESTSAMPLE_MOCK_HEAD1_H
+
+#include "unity.h"
+#include "cmock.h"
+#include "funky.h"
+#include <setjmp.h>
+
+void test_TheFirstThingToTest(void);
+void test_TheSecondThingToTest(void);
+#endif
+
diff --git a/deps/Unity/test/expectdata/testsample_mock_new1.c b/deps/Unity/test/expectdata/testsample_mock_new1.c
new file mode 100644
index 0000000..0061822
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_new1.c
@@ -0,0 +1,89 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "one.h"
+#include "two.h"
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+int GlobalExpectCount;
+int GlobalVerifyOrder;
+char* GlobalOrderError;
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ GlobalExpectCount = 0;
+ GlobalVerifyOrder = 0;
+ GlobalOrderError = NULL;
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_new2.c b/deps/Unity/test/expectdata/testsample_mock_new2.c
new file mode 100644
index 0000000..ee63cdc
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_new2.c
@@ -0,0 +1,89 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_custom_setup();
+}
+
+/*=======Suite Teardown=====*/
+static int suite_teardown(int num_failures)
+{
+a_custom_teardown();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return suite_teardown(UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_param.c b/deps/Unity/test/expectdata/testsample_mock_param.c
new file mode 100644
index 0000000..a42b7de
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_param.c
@@ -0,0 +1,77 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST_NO_ARGS
+#define RUN_TEST(TestFunc, TestLineNum, ...) \
+{ \
+ Unity.CurrentTestName = #TestFunc "(" #__VA_ARGS__ ")"; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(__VA_ARGS__); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21, RUN_TEST_NO_ARGS);
+ RUN_TEST(test_TheSecondThingToTest, 43, RUN_TEST_NO_ARGS);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_run1.c b/deps/Unity/test/expectdata/testsample_mock_run1.c
new file mode 100644
index 0000000..0061822
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_run1.c
@@ -0,0 +1,89 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "one.h"
+#include "two.h"
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+int GlobalExpectCount;
+int GlobalVerifyOrder;
+char* GlobalOrderError;
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ GlobalExpectCount = 0;
+ GlobalVerifyOrder = 0;
+ GlobalOrderError = NULL;
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_run2.c b/deps/Unity/test/expectdata/testsample_mock_run2.c
new file mode 100644
index 0000000..ee63cdc
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_run2.c
@@ -0,0 +1,89 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_custom_setup();
+}
+
+/*=======Suite Teardown=====*/
+static int suite_teardown(int num_failures)
+{
+a_custom_teardown();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return suite_teardown(UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_mock_yaml.c b/deps/Unity/test/expectdata/testsample_mock_yaml.c
new file mode 100644
index 0000000..a24bb5a
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_mock_yaml.c
@@ -0,0 +1,90 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ CMock_Init(); \
+ UNITY_CLR_DETAILS(); \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ CMock_Verify(); \
+ } \
+ CMock_Destroy(); \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include "cmock.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "two.h"
+#include "three.h"
+#include <four.h>
+#include "funky.h"
+#include <setjmp.h>
+#include "Mockstanky.h"
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+
+
+/*=======Mock Management=====*/
+static void CMock_Init(void)
+{
+ Mockstanky_Init();
+}
+static void CMock_Verify(void)
+{
+ Mockstanky_Verify();
+}
+static void CMock_Destroy(void)
+{
+ Mockstanky_Destroy();
+}
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_yaml_setup();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ CMock_Verify();
+ CMock_Destroy();
+ tearDown();
+ CMock_Init();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/mocksample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+
+ CMock_Guts_MemFreeFinal();
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_new1.c b/deps/Unity/test/expectdata/testsample_new1.c
new file mode 100644
index 0000000..7dcd3fd
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_new1.c
@@ -0,0 +1,67 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "one.h"
+#include "two.h"
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+int GlobalExpectCount;
+int GlobalVerifyOrder;
+char* GlobalOrderError;
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_new2.c b/deps/Unity/test/expectdata/testsample_new2.c
new file mode 100644
index 0000000..c98c697
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_new2.c
@@ -0,0 +1,70 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_custom_setup();
+}
+
+/*=======Suite Teardown=====*/
+static int suite_teardown(int num_failures)
+{
+a_custom_teardown();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return suite_teardown(UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_param.c b/deps/Unity/test/expectdata/testsample_param.c
new file mode 100644
index 0000000..adf6c26
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_param.c
@@ -0,0 +1,58 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST_NO_ARGS
+#define RUN_TEST(TestFunc, TestLineNum, ...) \
+{ \
+ Unity.CurrentTestName = #TestFunc "(" #__VA_ARGS__ ")"; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(__VA_ARGS__); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21, RUN_TEST_NO_ARGS);
+ RUN_TEST(test_TheSecondThingToTest, 43, RUN_TEST_NO_ARGS);
+ RUN_TEST(test_TheThirdThingToTest, 53, RUN_TEST_NO_ARGS);
+ RUN_TEST(test_TheFourthThingToTest, 58, RUN_TEST_NO_ARGS);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_run1.c b/deps/Unity/test/expectdata/testsample_run1.c
new file mode 100644
index 0000000..7dcd3fd
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_run1.c
@@ -0,0 +1,67 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "one.h"
+#include "two.h"
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+int GlobalExpectCount;
+int GlobalVerifyOrder;
+char* GlobalOrderError;
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_run2.c b/deps/Unity/test/expectdata/testsample_run2.c
new file mode 100644
index 0000000..c98c697
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_run2.c
@@ -0,0 +1,70 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ setUp(); \
+ TestFunc(); \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_custom_setup();
+}
+
+/*=======Suite Teardown=====*/
+static int suite_teardown(int num_failures)
+{
+a_custom_teardown();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return suite_teardown(UnityEnd());
+}
diff --git a/deps/Unity/test/expectdata/testsample_yaml.c b/deps/Unity/test/expectdata/testsample_yaml.c
new file mode 100644
index 0000000..3316024
--- /dev/null
+++ b/deps/Unity/test/expectdata/testsample_yaml.c
@@ -0,0 +1,71 @@
+/* AUTOGENERATED FILE. DO NOT EDIT. */
+
+/*=======Test Runner Used To Run Each Test Below=====*/
+#define RUN_TEST(TestFunc, TestLineNum) \
+{ \
+ Unity.CurrentTestName = #TestFunc; \
+ Unity.CurrentTestLineNumber = TestLineNum; \
+ Unity.NumberOfTests++; \
+ if (TEST_PROTECT()) \
+ { \
+ CEXCEPTION_T e; \
+ Try { \
+ setUp(); \
+ TestFunc(); \
+ } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \
+ } \
+ if (TEST_PROTECT() && !TEST_IS_IGNORED) \
+ { \
+ tearDown(); \
+ } \
+ UnityConcludeTest(); \
+}
+
+/*=======Automagically Detected Files To Include=====*/
+#include "unity.h"
+#include <setjmp.h>
+#include <stdio.h>
+#include "CException.h"
+#include "two.h"
+#include "three.h"
+#include <four.h>
+#include "funky.h"
+#include "stanky.h"
+#include <setjmp.h>
+
+/*=======External Functions This Runner Calls=====*/
+extern void setUp(void);
+extern void tearDown(void);
+extern void test_TheFirstThingToTest(void);
+extern void test_TheSecondThingToTest(void);
+extern void test_TheThirdThingToTest(void);
+extern void test_TheFourthThingToTest(void);
+
+
+/*=======Suite Setup=====*/
+static int suite_setup(void)
+{
+a_yaml_setup();
+}
+
+/*=======Test Reset Option=====*/
+void resetTest(void);
+void resetTest(void)
+{
+ tearDown();
+ setUp();
+}
+
+
+/*=======MAIN=====*/
+int main(void)
+{
+ suite_setup();
+ UnityBegin("testdata/testsample.c");
+ RUN_TEST(test_TheFirstThingToTest, 21);
+ RUN_TEST(test_TheSecondThingToTest, 43);
+ RUN_TEST(test_TheThirdThingToTest, 53);
+ RUN_TEST(test_TheFourthThingToTest, 58);
+
+ return (UnityEnd());
+}
diff --git a/deps/Unity/test/rakefile b/deps/Unity/test/rakefile
new file mode 100644
index 0000000..e5f3b74
--- /dev/null
+++ b/deps/Unity/test/rakefile
@@ -0,0 +1,163 @@
+# ==========================================
+# Unity Project - A Test Framework for C
+# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+# [Released under MIT License. Please refer to license.txt for details]
+# ==========================================
+
+$verbose = false
+$extra_paths = []
+
+require 'rake'
+require 'rake/clean'
+require_relative 'rakefile_helper'
+require 'rspec/core/rake_task'
+
+TEMP_DIRS = [
+ File.join(__dir__, 'build'),
+ File.join(__dir__, 'sandbox')
+]
+
+TEMP_DIRS.each do |dir|
+ directory(dir)
+ CLOBBER.include(dir)
+end
+
+task :prepare_for_tests => TEMP_DIRS
+
+include RakefileHelpers
+
+# Load proper GCC as defult configuration
+DEFAULT_CONFIG_FILE = 'gcc_auto_stdint.yml'
+configure_toolchain(DEFAULT_CONFIG_FILE)
+
+############# ALL THE SELF-TESTS WE CAN PERFORM
+namespace :test do
+ desc "Build and test Unity"
+ task :all => [:clean, :prepare_for_tests, 'test:scripts', 'test:unit', :style, 'test:fixture', 'test:memory', 'test:summary']
+ task :ci => [:clean, :prepare_for_tests, 'test:scripts', 'test:unit', :style, 'test:make', 'test:fixture', 'test:memory', 'test:summary']
+
+ desc "Test unity with its own unit tests"
+ task :unit => [:prepare_for_tests] do
+ run_tests unit_test_files
+ end
+
+ namespace :unit do
+ unit_test_files.each do |f|
+ desc "test this unit only"
+ task File.basename(f,'.c').sub('test_unity_','') => [:prepare_for_tests] do
+ run_tests [f]
+ end
+ end
+ end
+
+ desc "Test unity's helper scripts"
+ task :scripts => [:prepare_for_tests] do
+ Dir['tests/test_*.rb'].each do |scriptfile|
+ require "./"+scriptfile
+ end
+ end
+
+ desc "Test unity triggered from make"
+ task :make => [:prepare_for_tests] do
+ run_make_tests()
+ end
+
+ desc "Test unity fixture addon"
+ task :fixture => [:prepare_for_tests] do
+ test_fixtures()
+ end
+
+ desc "Test unity memory addon"
+ task :memory => [:prepare_for_tests] do
+ test_memory()
+ end
+
+ desc "Test unity examples"
+ task :examples => [:prepare_for_tests] do
+ execute("cd ../examples/example_1 && make -s ci", false)
+ execute("cd ../examples/example_2 && make -s ci", false)
+ execute("cd ../examples/example_3 && rake", false)
+ end
+
+ desc "Run all rspecs"
+ RSpec::Core::RakeTask.new(:spec) do |t|
+ t.pattern = 'spec/**/*_spec.rb'
+ end
+
+ desc "Generate test summary"
+ task :summary do
+ report_summary
+ end
+end
+
+###################### Shorthand for many common tasks
+task :ci => ['test:ci']
+task :all => ['test:all']
+task :default => [:clobber, :all]
+
+desc "Load configuration"
+task :config, :config_file do |t, args|
+ configure_toolchain(args[:config_file])
+end
+
+task :no_color do
+ $colour_output = false
+end
+
+task :verbose do
+ $verbose = true
+end
+
+################### CODING STYLE VALIDATION
+namespace :style do
+ desc "Check style"
+ task :check do
+ report "\nVERIFYING RUBY STYLE"
+ report execute("rubocop ../auto ../examples ../extras --config .rubocop.yml", true)
+ report "Styling Ruby:PASS"
+ end
+
+ namespace :check do
+ Dir['../**/*.rb'].each do |f|
+ filename = File.basename(f, '.rb')
+ #desc "Check Style of #{filename}"
+ task filename.to_sym => ['style:clean'] do
+ report execute("rubocop #{f} --color --config .rubocop.yml", true)
+ report "Style Checked for #{f}"
+ end
+ end
+ end
+
+ desc "Fix Style of all C Code"
+ task :c do
+ run_astyle("../src/*.* ../extras/fixture/src/*.*")
+ end
+
+ namespace :c do
+ Dir['../{src,extras/**}/*.{c,h}'].each do |f|
+ filename = File.basename(f)[0..-3]
+ #desc "Check Style of #{filename}"
+ task filename.to_sym do
+ run_astyle f
+ end
+ end
+ end
+
+ desc "Attempt to Autocorrect style"
+ task :auto => ['style:clean'] do
+ execute("rubocop ../auto ../examples ../extras --auto-correct --config .rubocop.yml")
+ report "Autocorrected What We Could."
+ end
+
+ desc "Update style todo list"
+ task :todo => ['style:clean'] do
+ execute("rubocop ../auto ../examples ../extras --auto-gen-config --config .rubocop.yml")
+ report "Updated Style TODO List."
+ end
+
+ task :clean do
+ File.delete(".rubocop_todo.yml") if File.exists?(".rubocop_todo.yml")
+ end
+end
+
+task :style => ['style:check']
diff --git a/deps/Unity/test/rakefile_helper.rb b/deps/Unity/test/rakefile_helper.rb
new file mode 100644
index 0000000..1a9fc33
--- /dev/null
+++ b/deps/Unity/test/rakefile_helper.rb
@@ -0,0 +1,315 @@
+# ==========================================
+# Unity Project - A Test Framework for C
+# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+# [Released under MIT License. Please refer to license.txt for details]
+# ==========================================
+
+require 'fileutils'
+require_relative '../auto/unity_test_summary'
+require_relative '../auto/generate_test_runner'
+require_relative '../auto/colour_reporter'
+require_relative '../auto/yaml_helper'
+
+module RakefileHelpers
+ C_EXTENSION = '.c'.freeze
+ def load_configuration(config_file)
+ return if $configured
+
+ $cfg_file = "targets/#{config_file}" unless config_file =~ /[\\|\/]/
+ $cfg = YamlHelper.load_file($cfg_file)
+ $colour_output = false unless $cfg['colour']
+ $configured = true if config_file != DEFAULT_CONFIG_FILE
+ end
+
+ def configure_clean
+ CLEAN.include('build/*.*')
+ end
+
+ def configure_toolchain(config_file = DEFAULT_CONFIG_FILE)
+ config_file += '.yml' unless config_file =~ /\.yml$/
+ config_file = config_file unless config_file =~ /[\\|\/]/
+ load_configuration(config_file)
+ configure_clean
+ end
+
+ def unit_test_files
+ path = 'tests/test*' + C_EXTENSION
+ path.tr!('\\', '/')
+ FileList.new(path)
+ end
+
+ def local_include_dirs
+ include_dirs = $cfg[:paths][:includes] || []
+ include_dirs += $cfg[:paths][:source] || []
+ include_dirs += $cfg[:paths][:test] || []
+ include_dirs += $cfg[:paths][:support] || []
+ include_dirs.delete_if { |dir| dir.is_a?(Array) }
+ include_dirs
+ end
+
+ def extract_headers(filename)
+ includes = []
+ lines = File.readlines(filename)
+ lines.each do |line|
+ m = line.match(/^\s*#include\s+\"\s*(.+\.[hH])\s*\"/)
+ includes << m[1] unless m.nil?
+ end
+ includes
+ end
+
+ def find_source_file(header, paths)
+ paths.each do |dir|
+ src_file = dir + header.ext(C_EXTENSION)
+ return src_file if File.exist?(src_file)
+ end
+ nil
+ end
+
+ def tackit(strings)
+ result = if strings.is_a?(Array)
+ "\"#{strings.join}\""
+ else
+ strings
+ end
+ result
+ end
+
+ def squash(prefix, items)
+ result = ''
+ items.each { |item| result += " #{prefix}#{tackit(item)}" }
+ result
+ end
+
+ def should(behave, &block)
+ if block
+ puts 'Should ' + behave
+ yield block
+ else
+ puts "UNIMPLEMENTED CASE: Should #{behave}"
+ end
+ end
+
+ def build_command_string(hash, values, defines = nil)
+
+ # Replace named and numbered slots
+ args = []
+ hash[:arguments].each do |arg|
+ if arg.include? '$'
+ if arg.include? ': COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ pattern = arg.gsub(': COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE','')
+ [ File.join('..','src') ].each do |f|
+ args << pattern.gsub(/\$/,f)
+ end
+
+ elsif arg.include? ': COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ pattern = arg.gsub(': COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR','')
+ [ $extra_paths, 'src', File.join('tests'), File.join('testdata'), $cfg[:paths][:support] ].flatten.uniq.compact.each do |f|
+ args << pattern.gsub(/\$/,f)
+ end
+
+ elsif arg.include? ': COLLECTION_DEFINES_TEST_AND_VENDOR'
+ pattern = arg.gsub(': COLLECTION_DEFINES_TEST_AND_VENDOR','')
+ [ $cfg[:defines][:test], defines ].flatten.uniq.compact.each do |f|
+ args << pattern.gsub(/\$/,f)
+ end
+
+ elsif arg =~ /\$\{(\d+)\}/
+ i = $1.to_i - 1
+ if (values[i].is_a?(Array))
+ values[i].each {|v| args << arg.gsub(/\$\{\d+\}/, v)}
+ else
+ args << arg.gsub(/\$\{(\d)+\}/, values[i] || '')
+ end
+
+ else
+ args << arg
+
+ end
+ else
+ args << arg
+ end
+ end
+
+ # Build Command
+ return tackit(hash[:executable]) + squash('', args)
+ end
+
+ def compile(file, defines = [])
+ out_file = File.join('build', File.basename(file, C_EXTENSION)) + $cfg[:extension][:object]
+ cmd_str = build_command_string( $cfg[:tools][:test_compiler], [ file, out_file ], defines )
+ execute(cmd_str)
+ out_file
+ end
+
+ def link_it(exe_name, obj_list)
+ exe_name = File.join('build', File.basename(exe_name))
+ cmd_str = build_command_string( $cfg[:tools][:test_linker], [ obj_list, exe_name ] )
+ execute(cmd_str)
+ end
+
+ def runtest(bin_name, ok_to_fail = false, extra_args = nil)
+ bin_name = File.join('build', File.basename(bin_name))
+ extra_args = extra_args.nil? ? "" : " " + extra_args
+ if $cfg[:tools][:test_fixture]
+ cmd_str = build_command_string( $cfg[:tools][:test_fixture], [ bin_name, extra_args ] )
+ else
+ cmd_str = bin_name + extra_args
+ end
+ execute(cmd_str, ok_to_fail)
+ end
+
+ def run_astyle(style_what)
+ report "Styling C Code..."
+ command = "AStyle " \
+ "--style=allman --indent=spaces=4 --indent-switches --indent-preproc-define --indent-preproc-block " \
+ "--pad-oper --pad-comma --unpad-paren --pad-header " \
+ "--align-pointer=type --align-reference=name " \
+ "--add-brackets --mode=c --suffix=none " \
+ "#{style_what}"
+ execute(command, false)
+ report "Styling C:PASS"
+ end
+
+ def execute(command_string, ok_to_fail = false)
+ report command_string if $verbose
+ output = `#{command_string}`.chomp
+ report(output) if ($verbose && !output.nil? && !output.empty?) || (!$?.nil? && !$?.exitstatus.zero? && !ok_to_fail)
+ raise "Command failed. (Returned #{$?.exitstatus})" if !$?.nil? && !$?.exitstatus.zero? && !ok_to_fail
+ output
+ end
+
+ def report_summary
+ summary = UnityTestSummary.new
+ summary.root = __dir__
+ results_glob = File.join('build','*.test*')
+ results_glob.tr!('\\', '/')
+ results = Dir[results_glob]
+ summary.targets = results
+ report summary.run
+ end
+
+ def save_test_results(test_base, output)
+ test_results = File.join('build',test_base)
+ if output.match(/OK$/m).nil?
+ test_results += '.testfail'
+ else
+ report output unless $verbose # Verbose already prints this line, as does a failure
+ test_results += '.testpass'
+ end
+ File.open(test_results, 'w') { |f| f.print output }
+ end
+
+ def test_fixtures()
+ report "\nRunning Fixture Addon"
+
+ # Get a list of all source files needed
+ src_files = Dir[File.join('..','extras','fixture','src','*.c')]
+ src_files += Dir[File.join('..','extras','fixture','test','*.c')]
+ src_files += Dir[File.join('..','extras','fixture','test','main','*.c')]
+ src_files += Dir[File.join('..','extras','memory','src','*.c')]
+ src_files << File.join('..','src','unity.c')
+
+ # Build object files
+ $extra_paths = [File.join('..','extras','fixture','src'), File.join('..','extras','memory','src')]
+ obj_list = src_files.map { |f| compile(f, ['UNITY_SKIP_DEFAULT_RUNNER', 'UNITY_FIXTURE_NO_EXTRAS']) }
+
+ # Link the test executable
+ test_base = File.basename('framework_test', C_EXTENSION)
+ link_it(test_base, obj_list)
+
+ # Run and collect output
+ output = runtest(test_base + " -v -r")
+ save_test_results(test_base, output)
+ end
+
+ def test_memory()
+ { 'w_malloc' => [],
+ 'wo_malloc' => ['UNITY_EXCLUDE_STDLIB_MALLOC']
+ }.each_pair do |name, defs|
+ report "\nRunning Memory Addon #{name}"
+
+ # Get a list of all source files needed
+ src_files = Dir[File.join('..','extras','memory','src','*.c')]
+ src_files += Dir[File.join('..','extras','memory','test','*.c')]
+ src_files += Dir[File.join('..','extras','memory','test','main','*.c')]
+ src_files << File.join('..','src','unity.c')
+
+ # Build object files
+ $extra_paths = [File.join('..','extras','memory','src')]
+ obj_list = src_files.map { |f| compile(f, defs) }
+
+ # Link the test executable
+ test_base = File.basename("memory_test_#{name}", C_EXTENSION)
+ link_it(test_base, obj_list)
+
+ # Run and collect output
+ output = runtest(test_base)
+ save_test_results(test_base, output)
+ end
+ end
+
+ def run_tests(test_files)
+ report "\nRunning Unity system tests"
+
+ include_dirs = local_include_dirs
+
+ # Build and execute each unit test
+ test_files.each do |test|
+
+ # Drop Out if we're skipping this type of test
+ if $cfg[:skip_tests]
+ if $cfg[:skip_tests].include?(:parameterized) && test.match(/parameterized/)
+ report("Skipping Parameterized Tests for this Target:IGNORE")
+ next
+ end
+ end
+
+ report "\nRunning Tests in #{test}"
+ obj_list = []
+ test_defines = []
+
+ # Detect dependencies and build required modules
+ extract_headers(test).each do |header|
+ # Compile corresponding source file if it exists
+ src_file = find_source_file(header, include_dirs)
+
+ obj_list << compile(src_file, test_defines) unless src_file.nil?
+ end
+
+ # Build the test runner (generate if configured to do so)
+ test_base = File.basename(test, C_EXTENSION)
+ runner_name = test_base + '_Runner.c'
+ runner_path = File.join('build',runner_name)
+
+ options = $cfg[:unity]
+ options[:use_param_tests] = test =~ /parameterized/ ? true : false
+ UnityTestRunnerGenerator.new(options).run(test, runner_path)
+ obj_list << compile(runner_path, test_defines)
+
+ # Build the test module
+ obj_list << compile(test, test_defines)
+
+ # Link the test executable
+ link_it(test_base, obj_list)
+
+ # Execute unit test and generate results file
+ output = runtest(test_base)
+ save_test_results(test_base, output)
+ end
+ end
+
+ def run_make_tests()
+ [ "make -s", # test with all defaults
+ #"make -s DEBUG=-m32", # test 32-bit architecture with 64-bit support
+ #"make -s DEBUG=-m32 UNITY_SUPPORT_64=", # test 32-bit build without 64-bit types
+ "make -s UNITY_INCLUDE_DOUBLE= ", # test without double
+ "cd #{File.join("..","extras","fixture",'test')} && make -s default noStdlibMalloc",
+ "cd #{File.join("..","extras","fixture",'test')} && make -s C89",
+ "cd #{File.join("..","extras","memory",'test')} && make -s default noStdlibMalloc",
+ "cd #{File.join("..","extras","memory",'test')} && make -s C89",
+ ].each do |cmd|
+ report "Testing '#{cmd}'"
+ execute(cmd, false)
+ end
+ end
+end
diff --git a/deps/Unity/test/spec/generate_module_existing_file_spec.rb b/deps/Unity/test/spec/generate_module_existing_file_spec.rb
new file mode 100644
index 0000000..74e7fc8
--- /dev/null
+++ b/deps/Unity/test/spec/generate_module_existing_file_spec.rb
@@ -0,0 +1,158 @@
+
+require '../auto/generate_module.rb'
+require 'fileutils'
+
+def touch_src(file)
+ FileUtils.touch "sandbox/src/#{file}"
+end
+
+def touch_test(file)
+ FileUtils.touch "sandbox/test/#{file}"
+end
+
+def create_src_with_known_content(file)
+ File.open("sandbox/src/#{file}", "w") {|f| f.write("the original #{file}")}
+end
+
+def create_test_with_known_content(file)
+ File.open("sandbox/test/#{file}", "w") {|f| f.write("the original #{file}")}
+end
+
+def expect_src_content_didnt_change(file)
+ expect(File.read("sandbox/src/#{file}")).to eq("the original #{file}")
+end
+
+def expect_test_content_didnt_change(file)
+ expect(File.read("sandbox/test/#{file}")).to eq("the original #{file}")
+end
+
+def expect_src_file_to_exist(file)
+ expect(File.exist?("sandbox/src/#{file}")).to be true
+end
+
+def expect_test_file_to_exist(file)
+ expect(File.exist?("sandbox/test/#{file}")).to be true
+end
+
+describe "UnityModuleGenerator" do
+
+ before do
+ # clean sandbox and setup our "project" folders
+ FileUtils.rm_rf "sandbox"
+ FileUtils.mkdir_p "sandbox"
+ FileUtils.mkdir_p "sandbox/src"
+ FileUtils.mkdir_p "sandbox/test"
+
+ @options = {
+ :path_src => "sandbox/src",
+ :path_tst => "sandbox/test",
+ }
+ end
+
+ context "with src pattern" do
+ before do
+ @options[:pattern] = "src"
+ end
+
+ it "fails when all files already exist" do
+ # create an existing triad of files
+ touch_src "meh.c"
+ touch_src "meh.h"
+ touch_test "Testmeh.c"
+ expect {
+ UnityModuleGenerator.new(@options).generate("meh")
+ }.to raise_error("ERROR: File meh already exists. Exiting.")
+ end
+
+ it "creates the test file if the source and header files exist" do
+ # Create the existing files.
+ touch_src "meh.c"
+ touch_src "meh.h"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_test_file_to_exist "Testmeh.c"
+ end
+
+ it "does not alter existing files" do
+ # Create some files with known content.
+ create_src_with_known_content "meh.c"
+ create_src_with_known_content "meh.h"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_src_content_didnt_change "meh.c"
+ expect_src_content_didnt_change "meh.c"
+ end
+
+ it "does not alter existing test files" do
+ # Create some files with known content.
+ create_test_with_known_content "Testmeh.c"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_test_content_didnt_change "Testmeh.c"
+ end
+
+ end
+
+ context "with mch pattern" do
+ before do
+ @options[:pattern] = "mch"
+ end
+
+ it "fails when all files exist" do
+ touch_src "meh_model.c"
+ touch_src "meh_conductor.c"
+ touch_src "meh_hardware.c"
+ touch_src "meh_model.h"
+ touch_src "meh_conductor.h"
+ touch_src "meh_hardware.h"
+ touch_test "Testmeh_model.c"
+ touch_test "Testmeh_conductor.c"
+ touch_test "Testmeh_hardware.c"
+ expect {
+ UnityModuleGenerator.new(@options).generate("meh")
+ }.to raise_error("ERROR: File meh_model already exists. Exiting.")
+ end
+
+ it "creates files that don't exist" do
+ touch_src "meh_model.c"
+ touch_src "meh_conductor.c"
+ touch_src "meh_hardware.c"
+ touch_src "meh_model.h"
+ touch_src "meh_conductor.h"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_src_file_to_exist "meh_hardware.h"
+ expect_test_file_to_exist "Testmeh_model.c"
+ expect_test_file_to_exist "Testmeh_conductor.c"
+ expect_test_file_to_exist "Testmeh_hardware.c"
+ end
+
+ it "does not alter existing source files" do
+ create_src_with_known_content "meh_model.c"
+ create_src_with_known_content "meh_model.c"
+ create_src_with_known_content "meh_model.c"
+ create_src_with_known_content "meh_model.h"
+ create_src_with_known_content "meh_model.c"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_src_content_didnt_change "meh_model.c"
+ expect_src_content_didnt_change "meh_model.c"
+ expect_src_content_didnt_change "meh_model.c"
+ expect_src_content_didnt_change "meh_model.c"
+ end
+
+ it "does not alter existing test files" do
+ create_test_with_known_content "Testmeh_model.c"
+
+ UnityModuleGenerator.new(@options).generate("meh")
+
+ expect_test_content_didnt_change "Testmeh_model.c"
+ end
+
+ end
+end
diff --git a/deps/Unity/test/targets/ansi.yml b/deps/Unity/test/targets/ansi.yml
new file mode 100644
index 0000000..81af4c7
--- /dev/null
+++ b/deps/Unity/test/targets/ansi.yml
@@ -0,0 +1,44 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:skip_tests:
+- :parameterized
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m64"
+ - "-Wall"
+ - "-Wno-address"
+ - "-ansi"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_EXCLUDE_TESTING_NEW_COMMENTS
+ - UNITY_SUPPORT_64
diff --git a/deps/Unity/test/targets/clang_file.yml b/deps/Unity/test/targets/clang_file.yml
new file mode 100644
index 0000000..964e814
--- /dev/null
+++ b/deps/Unity/test/targets/clang_file.yml
@@ -0,0 +1,72 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: clang
+ :arguments:
+ - "-c"
+ - "-Wall"
+ - "-Wextra"
+ - "-Werror"
+ - "-Wcast-qual"
+ - "-Wconversion"
+ - "-Wdisabled-optimization"
+ - "-Wformat=2"
+ - "-Winit-self"
+ - "-Winline"
+ - "-Winvalid-pch"
+ - "-Wmissing-include-dirs"
+ - "-Wnonnull"
+ - "-Wpacked"
+ - "-Wpointer-arith"
+ - "-Wswitch-default"
+ - "-Wstrict-aliasing"
+ - "-Wstrict-overflow=5"
+ - "-Wuninitialized"
+ - "-Wunused"
+ - "-Wreturn-type"
+ - "-Wshadow"
+ - "-Wundef"
+ - "-Wwrite-strings"
+ - "-Wno-nested-externs"
+ - "-Wno-unused-parameter"
+ - "-Wno-variadic-macros"
+ - "-Wbad-function-cast"
+ - "-fms-extensions"
+ - "-fno-omit-frame-pointer"
+ - "-ffloat-store"
+ - "-fno-common"
+ - "-fstrict-aliasing"
+ - "-std=gnu99"
+ - "-pedantic"
+ - "-O0"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: clang
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_64
+ - UNITY_OUTPUT_RESULTS_FILE
diff --git a/deps/Unity/test/targets/clang_strict.yml b/deps/Unity/test/targets/clang_strict.yml
new file mode 100644
index 0000000..f124e8f
--- /dev/null
+++ b/deps/Unity/test/targets/clang_strict.yml
@@ -0,0 +1,72 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: clang
+ :arguments:
+ - "-c"
+ - "-Wall"
+ - "-Wextra"
+ - "-Werror"
+ - "-Wcast-qual"
+ - "-Wconversion"
+ - "-Wdisabled-optimization"
+ - "-Wformat=2"
+ - "-Winit-self"
+ - "-Winline"
+ - "-Winvalid-pch"
+ - "-Wmissing-include-dirs"
+ - "-Wnonnull"
+ - "-Wpacked"
+ - "-Wpointer-arith"
+ - "-Wswitch-default"
+ - "-Wstrict-aliasing"
+ - "-Wstrict-overflow=5"
+ - "-Wuninitialized"
+ - "-Wunused"
+ - "-Wreturn-type"
+ - "-Wshadow"
+ - "-Wundef"
+ - "-Wwrite-strings"
+ - "-Wno-nested-externs"
+ - "-Wno-unused-parameter"
+ - "-Wno-variadic-macros"
+ - "-Wbad-function-cast"
+ - "-fms-extensions"
+ - "-fno-omit-frame-pointer"
+ - "-fno-common"
+ - "-fstrict-aliasing"
+ - "-std=gnu99"
+ - "-pedantic"
+ - "-O0"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: clang
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_SUPPORT_64
+ - UNITY_COMPARE_PTRS_ON_ZERO_ARRAY
diff --git a/deps/Unity/test/targets/gcc_32.yml b/deps/Unity/test/targets/gcc_32.yml
new file mode 100644
index 0000000..ba388cf
--- /dev/null
+++ b/deps/Unity/test/targets/gcc_32.yml
@@ -0,0 +1,45 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m32"
+ - "-Wall"
+ - "-Wno-address"
+ - "-std=c99"
+ - "-pedantic"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m32"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_EXCLUDE_STDINT_H
+ - UNITY_EXCLUDE_LIMITS_H
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_INT_WIDTH=32
+ - UNITY_LONG_WIDTH=32
diff --git a/deps/Unity/test/targets/gcc_64.yml b/deps/Unity/test/targets/gcc_64.yml
new file mode 100644
index 0000000..ed9eb4a
--- /dev/null
+++ b/deps/Unity/test/targets/gcc_64.yml
@@ -0,0 +1,46 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m64"
+ - "-Wall"
+ - "-Wno-address"
+ - "-std=c99"
+ - "-pedantic"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_EXCLUDE_STDINT_H
+ - UNITY_EXCLUDE_LIMITS_H
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_SUPPORT_64
+ - UNITY_INT_WIDTH=32
+ - UNITY_LONG_WIDTH=64
diff --git a/deps/Unity/test/targets/gcc_auto_limits.yml b/deps/Unity/test/targets/gcc_auto_limits.yml
new file mode 100644
index 0000000..9cfda8d
--- /dev/null
+++ b/deps/Unity/test/targets/gcc_auto_limits.yml
@@ -0,0 +1,43 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m64"
+ - "-Wall"
+ - "-Wno-address"
+ - "-std=c99"
+ - "-pedantic"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_EXCLUDE_STDINT_H
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_SUPPORT_64
diff --git a/deps/Unity/test/targets/gcc_auto_stdint.yml b/deps/Unity/test/targets/gcc_auto_stdint.yml
new file mode 100644
index 0000000..66602ef
--- /dev/null
+++ b/deps/Unity/test/targets/gcc_auto_stdint.yml
@@ -0,0 +1,55 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m64"
+ - "-Wall"
+ - "-Wno-address"
+ - "-std=c99"
+ - "-pedantic"
+ - "-Wextra"
+ - "-Werror"
+ - "-Wpointer-arith"
+ - "-Wcast-align"
+ - "-Wwrite-strings"
+ - "-Wswitch-default"
+ - "-Wunreachable-code"
+ - "-Winit-self"
+ - "-Wmissing-field-initializers"
+ - "-Wno-unknown-pragmas"
+ - "-Wstrict-prototypes"
+ - "-Wundef"
+ - "-Wold-style-definition"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_SUPPORT_64
diff --git a/deps/Unity/test/targets/gcc_manual_math.yml b/deps/Unity/test/targets/gcc_manual_math.yml
new file mode 100644
index 0000000..b1b5b82
--- /dev/null
+++ b/deps/Unity/test/targets/gcc_manual_math.yml
@@ -0,0 +1,43 @@
+---
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: gcc
+ :arguments:
+ - "-c"
+ - "-m64"
+ - "-Wall"
+ - "-Wno-address"
+ - "-std=c99"
+ - "-pedantic"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable: gcc
+ :arguments:
+ - "${1}"
+ - "-lm"
+ - "-m64"
+ - "-o ${2}"
+:extension:
+ :object: ".o"
+ :executable: ".exe"
+:paths:
+ :test:
+ - src/
+ - "../src/"
+ - testdata/
+ - tests/
+:defines:
+ :test:
+ - UNITY_EXCLUDE_MATH_H
+ - UNITY_INCLUDE_DOUBLE
+ - UNITY_SUPPORT_TEST_CASES
+ - UNITY_SUPPORT_64
diff --git a/deps/Unity/test/targets/hitech_picc18.yml b/deps/Unity/test/targets/hitech_picc18.yml
new file mode 100644
index 0000000..b984edb
--- /dev/null
+++ b/deps/Unity/test/targets/hitech_picc18.yml
@@ -0,0 +1,91 @@
+---
+:cmock:
+ :plugins: []
+ :includes:
+ - Types.h
+ :suite_teardown: |
+ if (num_failures)
+ _FAILED_TEST();
+ else
+ _PASSED_TESTS();
+ return 0;
+colour: true
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable: cd build && picc18
+ :arguments:
+ - "--chip=18F87J10"
+ - "--ide=hitide"
+ - "--q"
+ - "--asmlist"
+ - "--codeoffset=0"
+ - "--emi=wordwrite"
+ - "--warn=0"
+ - "--errors=10"
+ - "--char=unsigned"
+ - "-Bl"
+ - "-G"
+ - "--cp=16"
+ - "--double=24"
+ - "-N255"
+ - "--opt=none"
+ - "-c"
+ - "-M"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - " ${2}"
+ :test_linker:
+ :name: linker
+ :executable: cd build && picc18
+ :arguments:
+ - "${1}"
+ - "--chip=18F87J10"
+ - "--ide=hitide"
+ - "--cp=24"
+ - "--double=24"
+ - "-Lw"
+ - "--summary=mem,file"
+ - "--summary=+psect"
+ - "--summary=+hex"
+ - "--output=+intel"
+ - "--output=+mcof"
+ - "--runtime=+init"
+ - "--runtime=+clear"
+ - "--runtime=+clib"
+ - "--runtime=+keep"
+ - "-G"
+ - "-MIWasTheLastToBuild.map"
+ - "--warn=0"
+ - "-Bl"
+ - "-O ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable: 'java -client -jar '
+ :arguments:
+ - - C:\Program Files\HI-TECH Software\HI-TIDE\3.15\lib\
+ - simpic18.jar
+ - 18F87J10
+ - "${1}"
+:extension:
+ :object: ".obj"
+ :executable: ".hex"
+:paths:
+ :test:
+ - c:/Projects/NexGen/Prototypes/CMockTest/src/
+ - c:/Projects/NexGen/Prototypes/CMockTest/mocks/
+ - c:/CMock/src/
+ - c:/CMock/examples/src/
+ - c:/CMock/vendor/unity/src/
+ - c:/CMock/vendor/unity/examples/helper/
+ - tests\
+:defines:
+ :test:
+ - UNITY_INT_WIDTH=16
+ - UNITY_POINTER_WIDTH=16
+ - CMOCK_MEM_STATIC
+ - CMOCK_MEM_SIZE=3000
+ - UNITY_SUPPORT_TEST_CASES
+ - _PICC18
diff --git a/deps/Unity/test/targets/iar_arm_v4.yml b/deps/Unity/test/targets/iar_arm_v4.yml
new file mode 100644
index 0000000..9a1a276
--- /dev/null
+++ b/deps/Unity/test/targets/iar_arm_v4.yml
@@ -0,0 +1,98 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\bin\iccarm.exe
+ :arguments:
+ - "--dlib_config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\lib\dl4tptinl8n.h
+ - "-z3"
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--no_clustering"
+ - "--no_scheduling"
+ - "--debug"
+ - "--cpu_mode thumb"
+ - "--endian little"
+ - "--cpu ARM7TDMI"
+ - "--stack_align 4"
+ - "--interwork"
+ - "-e"
+ - "--silent"
+ - "--warnings_are_errors"
+ - "--fpu None"
+ - "--diag_suppress Pa050"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - common\bin\xlink.exe
+ :arguments:
+ - "${1}"
+ - "-rt"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\lib\dl4tptinl8n.r79
+ - "-D_L_EXTMEM_START=0"
+ - "-D_L_EXTMEM_SIZE=0"
+ - "-D_L_HEAP_SIZE=120"
+ - "-D_L_STACK_SIZE=32"
+ - "-e_small_write=_formatted_write"
+ - "-s"
+ - __program_start
+ - "-f"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - "\\arm\\config\\lnkarm.xcl"
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\bin\armproc.dll
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\bin\armsim.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\bin\armbat.dll
+ - "--backend"
+ - "-B"
+ - "-p"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\config\ioat91sam7X256.ddf
+ - "-d"
+ - sim
+:extension:
+ :object: ".r79"
+ :executable: ".d79"
+:paths:
+ :test:
+ - - C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
+ - arm\inc\
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+:defines:
+ :test:
+ - UNITY_SUPPORT_64
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/targets/iar_arm_v5.yml b/deps/Unity/test/targets/iar_arm_v5.yml
new file mode 100644
index 0000000..d4b115f
--- /dev/null
+++ b/deps/Unity/test/targets/iar_arm_v5.yml
@@ -0,0 +1,92 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\iccarm.exe
+ :arguments:
+ - "--dlib_config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\inc\DLib_Config_Normal.h
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--no_clustering"
+ - "--no_scheduling"
+ - "--debug"
+ - "--cpu_mode thumb"
+ - "--endian=little"
+ - "--cpu=ARM7TDMI"
+ - "--interwork"
+ - "--warnings_are_errors"
+ - "--fpu=None"
+ - "--diag_suppress=Pa050"
+ - "--diag_suppress=Pe111"
+ - "-e"
+ - "-On"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\ilinkarm.exe
+ :arguments:
+ - "${1}"
+ - "--redirect _Printf=_PrintfLarge"
+ - "--redirect _Scanf=_ScanfSmall"
+ - "--semihosting"
+ - "--entry __iar_program_start"
+ - "--config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\config\generic.icf
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armproc.dll
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armsim.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armbat.dll
+ - "--backend"
+ - "-B"
+ - "-p"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\config\debugger\atmel\ioat91sam7X256.ddf
+ - "-d"
+ - sim
+:extension:
+ :object: ".r79"
+ :executable: ".out"
+:paths:
+ :test:
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\inc\
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+ - iar\iar_v5\incIAR\
+:defines:
+ :test:
+ - UNITY_SUPPORT_64
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/targets/iar_arm_v5_3.yml b/deps/Unity/test/targets/iar_arm_v5_3.yml
new file mode 100644
index 0000000..d4b115f
--- /dev/null
+++ b/deps/Unity/test/targets/iar_arm_v5_3.yml
@@ -0,0 +1,92 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\iccarm.exe
+ :arguments:
+ - "--dlib_config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\inc\DLib_Config_Normal.h
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--no_clustering"
+ - "--no_scheduling"
+ - "--debug"
+ - "--cpu_mode thumb"
+ - "--endian=little"
+ - "--cpu=ARM7TDMI"
+ - "--interwork"
+ - "--warnings_are_errors"
+ - "--fpu=None"
+ - "--diag_suppress=Pa050"
+ - "--diag_suppress=Pe111"
+ - "-e"
+ - "-On"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\ilinkarm.exe
+ :arguments:
+ - "${1}"
+ - "--redirect _Printf=_PrintfLarge"
+ - "--redirect _Scanf=_ScanfSmall"
+ - "--semihosting"
+ - "--entry __iar_program_start"
+ - "--config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\config\generic.icf
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armproc.dll
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armsim.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\bin\armbat.dll
+ - "--backend"
+ - "-B"
+ - "-p"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\config\debugger\atmel\ioat91sam7X256.ddf
+ - "-d"
+ - sim
+:extension:
+ :object: ".r79"
+ :executable: ".out"
+:paths:
+ :test:
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.3\
+ - arm\inc\
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+ - iar\iar_v5\incIAR\
+:defines:
+ :test:
+ - UNITY_SUPPORT_64
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/targets/iar_armcortex_LM3S9B92_v5_4.yml b/deps/Unity/test/targets/iar_armcortex_LM3S9B92_v5_4.yml
new file mode 100644
index 0000000..1703fe2
--- /dev/null
+++ b/deps/Unity/test/targets/iar_armcortex_LM3S9B92_v5_4.yml
@@ -0,0 +1,90 @@
+---
+tools_root: C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\bin\iccarm.exe
+ :arguments:
+ - "--diag_suppress=Pa050"
+ - "--debug"
+ - "--endian=little"
+ - "--cpu=Cortex-M3"
+ - "--no_path_in_file_macros"
+ - "-e"
+ - "--fpu=None"
+ - "--dlib_config"
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\inc\DLib_Config_Normal.h
+ - "--interwork"
+ - "--warnings_are_errors"
+ - "-Oh"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\bin\ilinkarm.exe
+ :arguments:
+ - "${1}"
+ - "--redirect _Printf=_PrintfLarge"
+ - "--redirect _Scanf=_ScanfSmall"
+ - "--semihosting"
+ - "--entry __iar_program_start"
+ - "--config"
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\config\generic.icf
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\bin\armproc.dll
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\bin\armsim2.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\bin\armbat.dll
+ - "--backend"
+ - "-B"
+ - "--endian=little"
+ - "--cpu=Cortex-M3"
+ - "--fpu=None"
+ - "-p"
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\config\debugger\TexasInstruments\iolm3sxxxx.ddf
+ - "--semihosting"
+ - "--device=LM3SxBxx"
+:extension:
+ :object: ".r79"
+ :executable: ".out"
+:paths:
+ :test:
+ - - C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
+ - arm\inc\
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+ - iar\iar_v5\incIAR\
+:defines:
+ :test:
+ - ewarm
+ - PART_LM3S9B92
+ - TARGET_IS_TEMPEST_RB1
+ - USE_ROM_DRIVERS
+ - UART_BUFFERED
+ - UNITY_SUPPORT_64
diff --git a/deps/Unity/test/targets/iar_cortexm3_v5.yml b/deps/Unity/test/targets/iar_cortexm3_v5.yml
new file mode 100644
index 0000000..8b0978f
--- /dev/null
+++ b/deps/Unity/test/targets/iar_cortexm3_v5.yml
@@ -0,0 +1,94 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\bin\iccarm.exe
+ :arguments:
+ - "--dlib_config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\inc\DLib_Config_Normal.h
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--no_clustering"
+ - "--no_scheduling"
+ - "--debug"
+ - "--cpu_mode thumb"
+ - "--endian=little"
+ - "--cpu=Cortex-M3"
+ - "--interwork"
+ - "--warnings_are_errors"
+ - "--fpu=None"
+ - "--diag_suppress=Pa050"
+ - "--diag_suppress=Pe111"
+ - "-e"
+ - "-On"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\bin\ilinkarm.exe
+ :arguments:
+ - "${1}"
+ - "--redirect _Printf=_PrintfLarge"
+ - "--redirect _Scanf=_ScanfSmall"
+ - "--semihosting"
+ - "--entry __iar_program_start"
+ - "--config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\config\generic_cortex.icf
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\bin\armproc.dll
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\bin\armsim.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\bin\armbat.dll
+ - "--backend"
+ - "-B"
+ - "-p"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\config\debugger\ST\iostm32f107xx.ddf
+ - "--cpu=Cortex-M3"
+ - "-d"
+ - sim
+:extension:
+ :object: ".r79"
+ :executable: ".out"
+:paths:
+ :test:
+ - - C:\Program Files\IAR Systems\Embedded Workbench 5.4\
+ - arm\inc\
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+ - iar\iar_v5\incIAR\
+:defines:
+ :test:
+ - IAR
+ - UNITY_SUPPORT_64
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/targets/iar_msp430.yml b/deps/Unity/test/targets/iar_msp430.yml
new file mode 100644
index 0000000..6587253
--- /dev/null
+++ b/deps/Unity/test/targets/iar_msp430.yml
@@ -0,0 +1,112 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\
+core_root: &1
+- C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\
+- 430\
+core_bin: &2
+- *1
+- bin\
+core_config: &4
+- *1
+- config\
+core_lib: &3
+- *1
+- lib\
+core_inc: &5
+- *1
+- inc\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - *2
+ - icc430.exe
+ :arguments:
+ - "--dlib_config"
+ - - *3
+ - dlib\dl430fn.h
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--debug"
+ - "-e"
+ - "-Ol"
+ - "--multiplier=16"
+ - "--double=32"
+ - "--diag_suppress Pa050"
+ - "--diag_suppress Pe111"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - *2
+ - xlink.exe
+ :arguments:
+ - "${1}"
+ - "-rt"
+ - - *3
+ - dlib\dl430fn.r43
+ - "-e_PrintfTiny=_Printf"
+ - "-e_ScanfSmall=_Scanf"
+ - "-s __program_start"
+ - "-D_STACK_SIZE=50"
+ - "-D_DATA16_HEAP_SIZE=50"
+ - "-D_DATA20_HEAP_SIZE=50"
+ - "-f"
+ - - *4
+ - lnk430f5438.xcl
+ - "-f"
+ - - *4
+ - multiplier.xcl
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - *2
+ - 430proc.dll
+ - - *2
+ - 430sim.dll
+ - "${1}"
+ - "--plugin"
+ - - *2
+ - 430bat.dll
+ - "--backend -B"
+ - "--cpu MSP430F5438"
+ - "-p"
+ - - *4
+ - MSP430F5438.ddf
+ - "-d sim"
+:extension:
+ :object: ".r43"
+ :executable: ".d79"
+:paths:
+ :test:
+ - *5
+ - - *5
+ - dlib
+ - - *3
+ - dlib
+ - src\
+ - "../src/"
+ - testdata/
+ - tests\
+ - vendor\unity\src
+:defines:
+ :test:
+ - __MSP430F149__
+ - INT_WIDTH=16
+ - UNITY_EXCLUDE_FLOAT
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/targets/iar_sh2a_v6.yml b/deps/Unity/test/targets/iar_sh2a_v6.yml
new file mode 100644
index 0000000..b4371cd
--- /dev/null
+++ b/deps/Unity/test/targets/iar_sh2a_v6.yml
@@ -0,0 +1,99 @@
+---
+tools_root: C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+colour: true
+:unity:
+ :plugins: []
+:tools:
+ :test_compiler:
+ :name: compiler
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\bin\iccsh.exe
+ :arguments:
+ - "-e"
+ - "--char_is_signed"
+ - "-Ol"
+ - "--no_cse"
+ - "--no_unroll"
+ - "--no_inline"
+ - "--no_code_motion"
+ - "--no_tbaa"
+ - "--no_scheduling"
+ - "--no_clustering"
+ - "--debug"
+ - "--dlib_config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\inc\DLib_Product.h
+ - "--double=32"
+ - "--code_model=huge"
+ - "--data_model=huge"
+ - "--core=sh2afpu"
+ - "--warnings_affect_exit_code"
+ - "--warnings_are_errors"
+ - "--mfc"
+ - "--use_unix_directory_separators"
+ - "--diag_suppress=Pe161"
+ - '-I"$": COLLECTION_PATHS_TEST_TOOLCHAIN_INCLUDE'
+ - '-I"$": COLLECTION_PATHS_TEST_SUPPORT_SOURCE_INCLUDE_VENDOR'
+ - "-D$: COLLECTION_DEFINES_TEST_AND_VENDOR"
+ - "${1}"
+ - "-o ${2}"
+ :test_linker:
+ :name: linker
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\bin\ilinksh.exe
+ :arguments:
+ - "${1}"
+ - "--redirect __Printf=__PrintfSmall"
+ - "--redirect __Scanf=__ScanfSmall"
+ - "--config"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\config\generic.icf
+ - "--config_def _CSTACK_SIZE=0x800"
+ - "--config_def _HEAP_SIZE=0x800"
+ - "--config_def _INT_TABLE=0x10"
+ - "--entry __iar_program_start"
+ - "--debug_lib"
+ - "-o ${2}"
+ :test_fixture:
+ :name: simulator
+ :executable:
+ - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - common\bin\CSpyBat.exe
+ :arguments:
+ - "--silent"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\bin\shproc.dll
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\bin\shsim.dll
+ - "${1}"
+ - "--plugin"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\bin\shbat.dll
+ - "--backend"
+ - "-B"
+ - "--core sh2afpu"
+ - "-p"
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\config\debugger\io7264.ddf
+ - "-d"
+ - sim
+:extension:
+ :object: ".o"
+ :executable: ".out"
+:paths:
+ :test:
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\inc\
+ - - C:\Program Files\IAR Systems\Embedded Workbench 6.0\
+ - sh\inc\c
+ - src\
+ - "..\\src\\"
+ - testdata/
+ - tests\
+ - vendor\unity\src\
+:defines:
+ :test:
+ - UNITY_SUPPORT_64
+ - UNITY_SUPPORT_TEST_CASES
diff --git a/deps/Unity/test/testdata/CException.h b/deps/Unity/test/testdata/CException.h
new file mode 100644
index 0000000..3872fa7
--- /dev/null
+++ b/deps/Unity/test/testdata/CException.h
@@ -0,0 +1,11 @@
+#ifndef CEXCEPTION_H
+#define CEXCEPTION_H
+
+#define CEXCEPTION_BEING_USED 1
+
+#define CEXCEPTION_NONE 0
+#define CEXCEPTION_T int e = 1; (void)
+#define Try if (e)
+#define Catch(a) if (!a)
+
+#endif
diff --git a/deps/Unity/test/testdata/Defs.h b/deps/Unity/test/testdata/Defs.h
new file mode 100644
index 0000000..58678c1
--- /dev/null
+++ b/deps/Unity/test/testdata/Defs.h
@@ -0,0 +1,9 @@
+#ifndef DEF_H
+#define DEF_H
+
+#define EXTERN_DECL
+
+extern int CounterSuiteSetup;
+extern int isArgumentOne(int i);
+
+#endif
diff --git a/deps/Unity/test/testdata/cmock.h b/deps/Unity/test/testdata/cmock.h
new file mode 100644
index 0000000..33ddbfc
--- /dev/null
+++ b/deps/Unity/test/testdata/cmock.h
@@ -0,0 +1,14 @@
+#ifndef CMOCK_H
+#define CMOCK_H
+
+int CMockMemFreeFinalCounter = 0;
+int mockMock_Init_Counter = 0;
+int mockMock_Verify_Counter = 0;
+int mockMock_Destroy_Counter = 0;
+
+void CMock_Guts_MemFreeFinal(void) { CMockMemFreeFinalCounter++; }
+void mockMock_Init(void) { mockMock_Init_Counter++; }
+void mockMock_Verify(void) { mockMock_Verify_Counter++; }
+void mockMock_Destroy(void) { mockMock_Destroy_Counter++; }
+
+#endif
diff --git a/deps/Unity/test/testdata/mockMock.h b/deps/Unity/test/testdata/mockMock.h
new file mode 100644
index 0000000..5c6829d
--- /dev/null
+++ b/deps/Unity/test/testdata/mockMock.h
@@ -0,0 +1,13 @@
+#ifndef MOCK_MOCK_H
+#define MOCK_MOCK_H
+
+extern int mockMock_Init_Counter;
+extern int mockMock_Verify_Counter;
+extern int mockMock_Destroy_Counter;
+extern int CMockMemFreeFinalCounter;
+
+void mockMock_Init(void);
+void mockMock_Verify(void);
+void mockMock_Destroy(void);
+
+#endif
diff --git a/deps/Unity/test/testdata/testRunnerGenerator.c b/deps/Unity/test/testdata/testRunnerGenerator.c
new file mode 100644
index 0000000..475e243
--- /dev/null
+++ b/deps/Unity/test/testdata/testRunnerGenerator.c
@@ -0,0 +1,197 @@
+/* This Test File Is Used To Verify Many Combinations Of Using the Generate Test Runner Script */
+
+#include <stdio.h>
+#include "unity.h"
+#include "Defs.h"
+
+#ifdef USE_CEXCEPTION
+#include "CException.h"
+#endif
+
+/* Notes about prefixes:
+ test - normal default prefix. these are "always run" tests for this procedure
+ spec - normal default prefix. required to run default setup/teardown calls.
+ should - normal default prefix.
+ qwiktest - custom prefix for when tests skip all setup/teardown calls.
+ custtest - custom prefix for when tests use custom setup/teardown calls.
+ paratest - custom prefix for when we want to verify parameterized tests.
+ extest - custom prefix only used during cexception
+ suitetest- custom prefix for when we want to use custom suite setup/teardown
+*/
+
+/* Include Passthroughs for Linking Tests */
+void putcharSpy(int c) { (void)putchar(c);}
+void flushSpy(void) {}
+
+/* Global Variables Used During These Tests */
+int CounterSetup = 0;
+int CounterTeardown = 0;
+int CounterSuiteSetup = 0;
+
+void setUp(void)
+{
+ CounterSetup = 1;
+}
+
+void tearDown(void)
+{
+ CounterTeardown = 1;
+}
+
+void custom_setup(void)
+{
+ CounterSetup = 2;
+}
+
+void custom_teardown(void)
+{
+ CounterTeardown = 2;
+}
+
+/*
+void test_OldSchoolCommentsShouldBeIgnored(void)
+{
+ TEST_ASSERT_FAIL("Old-School Comments Should Be Ignored");
+}
+*/
+
+void test_ThisTestAlwaysPasses(void)
+{
+ TEST_PASS();
+}
+
+void test_ThisTestAlwaysFails(void)
+{
+ TEST_FAIL_MESSAGE("This Test Should Fail");
+}
+
+void test_ThisTestAlwaysIgnored(void)
+{
+ TEST_IGNORE_MESSAGE("This Test Should Be Ignored");
+}
+
+void qwiktest_ThisTestPassesWhenNoSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterSetup, "Setup Was Unexpectedly Run");
+}
+
+void qwiktest_ThisTestPassesWhenNoTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterTeardown, "Teardown Was Unexpectedly Run");
+}
+
+void spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterSuiteSetup, "Suite Setup Was Unexpectedly Run");
+}
+
+void spec_ThisTestPassesWhenNormalSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterSetup, "Normal Setup Wasn't Run");
+}
+
+void spec_ThisTestPassesWhenNormalTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterTeardown, "Normal Teardown Wasn't Run");
+}
+
+void custtest_ThisTestPassesWhenCustomSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(2, CounterSetup, "Custom Setup Wasn't Run");
+}
+
+void custtest_ThisTestPassesWhenCustomTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(2, CounterTeardown, "Custom Teardown Wasn't Run");
+}
+
+#ifndef UNITY_EXCLUDE_TESTING_NEW_COMMENTS
+//void test_NewStyleCommentsShouldBeIgnored(void)
+//{
+// TEST_ASSERT_FAIL("New Style Comments Should Be Ignored");
+//}
+#endif
+
+void test_NotBeConfusedByLongComplicatedStrings(void)
+{
+ const char* crazyString = "GET / HTTP/1.1\r\nHost: 127.0.0.1:8081\r\nConnection: keep-alive\r\nCache-Control: no-cache\r\nUser-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.80 Safari/537.36\r\nPostman-Token: 768c7149-c3fb-f704-71a2-63918d9195b2\r\nAccept: */*\r\nAccept-Encoding: gzip, deflate, sdch\r\nAccept-Language: en-GB,en-US;q=0.8,en;q=0.6\r\n\r\n";
+
+ TEST_ASSERT_EQUAL_STRING_MESSAGE(crazyString, crazyString, "These Strings Are The Same");
+}
+
+/* The next test should still appear even though we have this confusing nested comment thing going on http://looks_like_comments.com */
+void test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings(void)
+{
+ TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
+ /* still should not break anything */
+}
+/* nor should this */
+
+void test_StillNotBeConfusedByLongComplicatedStrings(void)
+{
+ const char* crazyString = "GET / HTTP/1.1\r\nHost: 127.0.0.1:8081\r\nConnection: keep-alive\r\nCache-Control: no-cache\r\nUser-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.80 Safari/537.36\r\nPostman-Token: 768c7149-c3fb-f704-71a2-63918d9195b2\r\nAccept: */*\r\nAccept-Encoding: gzip, deflate, sdch\r\nAccept-Language: en-GB,en-US;q=0.8,en;q=0.6\r\n\r\n";
+
+ TEST_ASSERT_EQUAL_STRING_MESSAGE(crazyString, crazyString, "These Strings Are Still The Same");
+}
+
+void should_RunTestsStartingWithShouldByDefault(void)
+{
+ TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
+}
+
+TEST_CASE(25)
+TEST_CASE(125)
+TEST_CASE(5)
+void paratest_ShouldHandleParameterizedTests(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, (Num % 5), "All The Values Are Divisible By 5");
+}
+
+TEST_CASE(7)
+void paratest_ShouldHandleParameterizedTests2(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(7, Num, "The Only Call To This Passes");
+}
+
+void paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid(void)
+{
+ TEST_PASS();
+}
+
+TEST_CASE(17)
+void paratest_ShouldHandleParameterizedTestsThatFail(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(3, Num, "This call should fail");
+}
+
+int isArgumentOne(int i)
+{
+ return i == 1;
+}
+
+TEST_CASE(isArgumentOne)
+void paratest_WorksWithFunctionPointers(int function(int))
+{
+ TEST_ASSERT_TRUE_MESSAGE(function(1), "Function should return True");
+}
+
+#ifdef USE_CEXCEPTION
+void extest_ShouldHandleCExceptionInTest(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CEXCEPTION_BEING_USED, "Should be pulling in CException");
+}
+#endif
+
+#ifdef USE_ANOTHER_MAIN
+int custom_main(void);
+
+int main(void)
+{
+ return custom_main();
+}
+#endif
+
+void suitetest_ThisTestPassesWhenCustomSuiteSetupAndTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterSuiteSetup, "Suite Setup Should Have Run");
+}
diff --git a/deps/Unity/test/testdata/testRunnerGeneratorSmall.c b/deps/Unity/test/testdata/testRunnerGeneratorSmall.c
new file mode 100644
index 0000000..58bc65c
--- /dev/null
+++ b/deps/Unity/test/testdata/testRunnerGeneratorSmall.c
@@ -0,0 +1,66 @@
+/* This Test File Is Used To Verify Many Combinations Of Using the Generate Test Runner Script */
+
+#include <stdio.h>
+#include "unity.h"
+#include "Defs.h"
+
+TEST_SOURCE_FILE("some_file.c")
+
+/* Notes about prefixes:
+ test - normal default prefix. these are "always run" tests for this procedure
+ spec - normal default prefix. required to run default setup/teardown calls.
+*/
+
+/* Include Passthroughs for Linking Tests */
+void putcharSpy(int c) { (void)putchar(c);}
+void flushSpy(void) {}
+
+/* Global Variables Used During These Tests */
+int CounterSetup = 0;
+int CounterTeardown = 0;
+int CounterSuiteSetup = 0;
+
+void setUp(void)
+{
+ CounterSetup = 1;
+}
+
+void tearDown(void)
+{
+ CounterTeardown = 1;
+}
+
+void custom_setup(void)
+{
+ CounterSetup = 2;
+}
+
+void custom_teardown(void)
+{
+ CounterTeardown = 2;
+}
+
+void test_ThisTestAlwaysPasses(void)
+{
+ TEST_PASS();
+}
+
+void test_ThisTestAlwaysFails(void)
+{
+ TEST_FAIL_MESSAGE("This Test Should Fail");
+}
+
+void test_ThisTestAlwaysIgnored(void)
+{
+ TEST_IGNORE_MESSAGE("This Test Should Be Ignored");
+}
+
+void spec_ThisTestPassesWhenNormalSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterSetup, "Normal Setup Wasn't Run");
+}
+
+void spec_ThisTestPassesWhenNormalTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterTeardown, "Normal Teardown Wasn't Run");
+}
diff --git a/deps/Unity/test/testdata/testRunnerGeneratorWithMocks.c b/deps/Unity/test/testdata/testRunnerGeneratorWithMocks.c
new file mode 100644
index 0000000..d48692e
--- /dev/null
+++ b/deps/Unity/test/testdata/testRunnerGeneratorWithMocks.c
@@ -0,0 +1,193 @@
+/* This Test File Is Used To Verify Many Combinations Of Using the Generate Test Runner Script */
+
+#include <stdio.h>
+#include "unity.h"
+#include "Defs.h"
+#include "mockMock.h"
+
+#ifdef USE_CEXCEPTION
+#include "CException.h"
+#endif
+
+/* Notes about prefixes:
+ test - normal default prefix. these are "always run" tests for this procedure
+ spec - normal default prefix. required to run default setup/teardown calls.
+ should - normal default prefix.
+ qwiktest - custom prefix for when tests skip all setup/teardown calls.
+ custtest - custom prefix for when tests use custom setup/teardown calls.
+ paratest - custom prefix for when we want to verify parameterized tests.
+ extest - custom prefix only used during cexception
+ suitetest- custom prefix for when we want to use custom suite setup/teardown
+*/
+
+/* Include Passthroughs for Linking Tests */
+void putcharSpy(int c) { (void)putchar(c);}
+void flushSpy(void) {}
+
+/* Global Variables Used During These Tests */
+int CounterSetup = 0;
+int CounterTeardown = 0;
+int CounterSuiteSetup = 0;
+
+void setUp(void)
+{
+ CounterSetup = 1;
+}
+
+void tearDown(void)
+{
+ CounterTeardown = 1;
+}
+
+void custom_setup(void)
+{
+ CounterSetup = 2;
+}
+
+void custom_teardown(void)
+{
+ CounterTeardown = 2;
+}
+
+/*
+void test_OldSchoolCommentsShouldBeIgnored(void)
+{
+ TEST_ASSERT_FAIL("Old-School Comments Should Be Ignored");
+}
+*/
+
+void test_ThisTestAlwaysPasses(void)
+{
+ TEST_PASS();
+}
+
+void test_ThisTestAlwaysFails(void)
+{
+ TEST_FAIL_MESSAGE("This Test Should Fail");
+}
+
+void test_ThisTestAlwaysIgnored(void)
+{
+ TEST_IGNORE_MESSAGE("This Test Should Be Ignored");
+}
+
+void qwiktest_ThisTestPassesWhenNoSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterSetup, "Setup Was Unexpectedly Run");
+}
+
+void qwiktest_ThisTestPassesWhenNoTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterTeardown, "Teardown Was Unexpectedly Run");
+}
+
+void spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, CounterSuiteSetup, "Suite Setup Was Unexpectedly Run");
+}
+
+void spec_ThisTestPassesWhenNormalSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterSetup, "Normal Setup Wasn't Run");
+}
+
+void spec_ThisTestPassesWhenNormalTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterTeardown, "Normal Teardown Wasn't Run");
+}
+
+void custtest_ThisTestPassesWhenCustomSetupRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(2, CounterSetup, "Custom Setup Wasn't Run");
+}
+
+void custtest_ThisTestPassesWhenCustomTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(2, CounterTeardown, "Custom Teardown Wasn't Run");
+}
+
+#ifndef UNITY_EXCLUDE_TESTING_NEW_COMMENTS
+//void test_NewStyleCommentsShouldBeIgnored(void)
+//{
+// TEST_ASSERT_FAIL("New Style Comments Should Be Ignored");
+//}
+#endif
+
+void test_NotBeConfusedByLongComplicatedStrings(void)
+{
+ const char* crazyString = "GET / HTTP/1.1\r\nHost: 127.0.0.1:8081\r\nConnection: keep-alive\r\nCache-Control: no-cache\r\nUser-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.80 Safari/537.36\r\nPostman-Token: 768c7149-c3fb-f704-71a2-63918d9195b2\r\nAccept: */*\r\nAccept-Encoding: gzip, deflate, sdch\r\nAccept-Language: en-GB,en-US;q=0.8,en;q=0.6\r\n\r\n";
+
+ TEST_ASSERT_EQUAL_STRING_MESSAGE(crazyString, crazyString, "These Strings Are The Same");
+}
+
+void test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings(void)
+{
+ TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
+}
+
+void test_StillNotBeConfusedByLongComplicatedStrings(void)
+{
+ const char* crazyString = "GET / HTTP/1.1\r\nHost: 127.0.0.1:8081\r\nConnection: keep-alive\r\nCache-Control: no-cache\r\nUser-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.80 Safari/537.36\r\nPostman-Token: 768c7149-c3fb-f704-71a2-63918d9195b2\r\nAccept: */*\r\nAccept-Encoding: gzip, deflate, sdch\r\nAccept-Language: en-GB,en-US;q=0.8,en;q=0.6\r\n\r\n";
+
+ TEST_ASSERT_EQUAL_STRING_MESSAGE(crazyString, crazyString, "These Strings Are Still The Same");
+}
+
+void should_RunTestsStartingWithShouldByDefault(void)
+{
+ TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
+}
+
+TEST_CASE(25)
+TEST_CASE(125)
+TEST_CASE(5)
+void paratest_ShouldHandleParameterizedTests(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(0, (Num % 5), "All The Values Are Divisible By 5");
+}
+
+TEST_CASE(7)
+void paratest_ShouldHandleParameterizedTests2(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(7, Num, "The Only Call To This Passes");
+}
+
+void paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid(void)
+{
+ TEST_PASS();
+}
+
+TEST_CASE(17)
+void paratest_ShouldHandleParameterizedTestsThatFail(int Num)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(3, Num, "This call should fail");
+}
+
+#ifdef USE_CEXCEPTION
+void extest_ShouldHandleCExceptionInTest(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CEXCEPTION_BEING_USED, "Should be pulling in CException");
+}
+#endif
+
+#ifdef USE_ANOTHER_MAIN
+int custom_main(void);
+
+int main(void)
+{
+ return custom_main();
+}
+#endif
+
+void suitetest_ThisTestPassesWhenCustomSuiteSetupAndTeardownRan(void)
+{
+ TEST_ASSERT_EQUAL_MESSAGE(1, CounterSuiteSetup, "Suite Setup Should Have Run");
+}
+
+void test_ShouldCallMockInitAndVerifyFunctionsForEachTest(void)
+{
+ int passesOrIgnores = (int)(Unity.NumberOfTests - Unity.TestFailures);
+ TEST_ASSERT_EQUAL_MESSAGE(Unity.NumberOfTests, mockMock_Init_Counter, "Mock Init Should Be Called Once Per Test Started");
+ TEST_ASSERT_EQUAL_MESSAGE(passesOrIgnores, mockMock_Verify_Counter, "Mock Verify Should Be Called Once Per Test Passed");
+ TEST_ASSERT_EQUAL_MESSAGE(Unity.NumberOfTests - 1, mockMock_Destroy_Counter, "Mock Destroy Should Be Called Once Per Test Completed");
+ TEST_ASSERT_EQUAL_MESSAGE(0, CMockMemFreeFinalCounter, "Mock MemFreeFinal Should Not Be Called Until End");
+}
diff --git a/deps/Unity/test/tests/self_assessment_utils.h b/deps/Unity/test/tests/self_assessment_utils.h
new file mode 100644
index 0000000..c8cb595
--- /dev/null
+++ b/deps/Unity/test/tests/self_assessment_utils.h
@@ -0,0 +1,144 @@
+#ifdef TEST_INSTANCES
+
+#include <string.h>
+#include <stdint.h>
+
+/* Dividing by these constants produces +/- infinity.
+ * The rationale is given in UnityAssertFloatIsInf's body.
+ */
+#ifndef UNITY_EXCLUDE_FLOAT
+static const UNITY_FLOAT f_zero = 0.0f;
+#endif
+
+#ifndef UNITY_EXCLUDE_DOUBLE
+static const UNITY_DOUBLE d_zero = 0.0;
+#endif
+
+/* Macros for Catching An Expected Failure or Ignore */
+#define EXPECT_ABORT_BEGIN \
+ startPutcharSpy(); \
+ if (TEST_PROTECT()) \
+ {
+
+#define VERIFY_FAILS_END \
+ } \
+ endPutcharSpy(); /* start/end Spy to suppress output of failure message */ \
+ Unity.CurrentTestFailed = (Unity.CurrentTestFailed == 1) ? 0 : 1; \
+ if (Unity.CurrentTestFailed == 1) { \
+ SetToOneMeanWeAlreadyCheckedThisGuy = 1; \
+ UnityPrintNumberUnsigned(Unity.CurrentTestLineNumber); \
+ UNITY_OUTPUT_CHAR(':'); \
+ UnityPrint(Unity.CurrentTestName); \
+ UnityPrint(":FAIL: [[[[ Test Should Have Failed But Did Not ]]]]"); \
+ UNITY_OUTPUT_CHAR('\n'); \
+ }
+
+#define VERIFY_IGNORES_END \
+ } \
+ endPutcharSpy(); /* start/end Spy to suppress output of ignore message */ \
+ Unity.CurrentTestFailed = (Unity.CurrentTestIgnored == 1) ? 0 : 1; \
+ Unity.CurrentTestIgnored = 0; \
+ if (Unity.CurrentTestFailed == 1) { \
+ SetToOneMeanWeAlreadyCheckedThisGuy = 1; \
+ UnityPrintNumberUnsigned(Unity.CurrentTestLineNumber); \
+ UNITY_OUTPUT_CHAR(':'); \
+ UnityPrint(Unity.CurrentTestName); \
+ UnityPrint(":FAIL: [[[[ Test Should Have Ignored But Did Not ]]]]"); \
+ UNITY_OUTPUT_CHAR('\n'); \
+ }
+
+/* Tricky series of macros to set USING_OUTPUT_SPY */
+#define USING_SPY_AS(a) EXPAND_AND_USE_2ND(ASSIGN_VALUE(a), 0)
+#define ASSIGN_VALUE(a) VAL_##a
+#define VAL_putcharSpy 0, 1
+#define EXPAND_AND_USE_2ND(a, b) SECOND_PARAM(a, b, throwaway)
+#define SECOND_PARAM(a, b, ...) b
+#if USING_SPY_AS(UNITY_OUTPUT_CHAR)
+ #define USING_OUTPUT_SPY /* true only if UNITY_OUTPUT_CHAR = putcharSpy */
+#endif
+
+#ifdef USING_OUTPUT_SPY
+#include <stdio.h>
+#define SPY_BUFFER_MAX 40
+static char putcharSpyBuffer[SPY_BUFFER_MAX];
+#endif
+static int indexSpyBuffer;
+static int putcharSpyEnabled;
+
+void startPutcharSpy(void)
+{
+ indexSpyBuffer = 0;
+ putcharSpyEnabled = 1;
+}
+
+void endPutcharSpy(void)
+{
+ putcharSpyEnabled = 0;
+}
+
+char* getBufferPutcharSpy(void)
+{
+#ifdef USING_OUTPUT_SPY
+ putcharSpyBuffer[indexSpyBuffer] = '\0';
+ return putcharSpyBuffer;
+#else
+ return NULL;
+#endif
+}
+
+void putcharSpy(int c)
+{
+#ifdef USING_OUTPUT_SPY
+ if (putcharSpyEnabled)
+ {
+ if (indexSpyBuffer < SPY_BUFFER_MAX - 1)
+ putcharSpyBuffer[indexSpyBuffer++] = (char)c;
+ } else
+ putchar((char)c);
+#else
+ (void)c;
+#endif
+}
+
+/* This is for counting the calls to the flushSpy */
+static int flushSpyEnabled;
+static int flushSpyCalls = 0;
+
+void startFlushSpy(void)
+{
+ flushSpyCalls = 0;
+ flushSpyEnabled = 1;
+}
+
+void endFlushSpy(void)
+{
+ flushSpyCalls = 0;
+ flushSpyEnabled = 0;
+}
+
+int getFlushSpyCalls(void)
+{
+ return flushSpyCalls;
+}
+
+void flushSpy(void)
+{
+ if (flushSpyEnabled){ flushSpyCalls++; }
+}
+
+#define TEST_ASSERT_EQUAL_PRINT_NUMBERS(expected, actual) { \
+ startPutcharSpy(); UnityPrintNumber((actual)); endPutcharSpy(); \
+ TEST_ASSERT_EQUAL_STRING((expected), getBufferPutcharSpy()); \
+ }
+
+#define TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS(expected, actual) { \
+ startPutcharSpy(); UnityPrintNumberUnsigned((actual)); endPutcharSpy(); \
+ TEST_ASSERT_EQUAL_STRING((expected), getBufferPutcharSpy()); \
+ }
+
+#define TEST_ASSERT_EQUAL_PRINT_FLOATING(expected, actual) { \
+ startPutcharSpy(); UnityPrintFloat((actual)); endPutcharSpy(); \
+ TEST_ASSERT_EQUAL_STRING((expected), getBufferPutcharSpy()); \
+ }
+
+#endif
diff --git a/deps/Unity/test/tests/test_generate_test_runner.rb b/deps/Unity/test/tests/test_generate_test_runner.rb
new file mode 100644
index 0000000..229b6ab
--- /dev/null
+++ b/deps/Unity/test/tests/test_generate_test_runner.rb
@@ -0,0 +1,1298 @@
+# ==========================================
+# CMock Project - Automatic Mock Generation for C
+# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+# [Released under MIT License. Please refer to license.txt for details]
+# ==========================================
+
+require '../auto/generate_test_runner.rb'
+
+$generate_test_runner_tests = 0
+$generate_test_runner_failures = 0
+
+OUT_FILE = 'build/testsample_'
+
+RUNNER_TESTS = [
+ { :name => 'DefaultsThroughOptions',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => nil, #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'DefaultsThroughCommandLine',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => "", #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'DefaultsThroughYAMLFile',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => "", #defaults
+ :yaml => {}, #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustTest',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "test",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustShould',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "should",
+ },
+ :expected => {
+ :to_pass => [ 'should_RunTestsStartingWithShouldByDefault' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustSpec',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "spec",
+ },
+ :expected => {
+ :to_pass => [ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'InjectIncludes',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :includes => ['Defs.h'],
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughOptions',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "paratest",
+ :use_param_tests => true,
+ },
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ 'paratest_WorksWithFunctionPointers\(isArgumentOne\)',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughCommandLine',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"paratest\" --use_param_tests=1",
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ 'paratest_WorksWithFunctionPointers\(isArgumentOne\)',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughCommandLineAndYaml',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => "--use_param_tests=1",
+ :yaml => {
+ :test_prefix => "paratest"
+ },
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ 'paratest_WorksWithFunctionPointers\(isArgumentOne\)',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'CException',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'USE_CEXCEPTION'],
+ :options => {
+ :test_prefix => "extest",
+ :plugins => [ :cexception ],
+ },
+ :expected => {
+ :to_pass => [ 'extest_ShouldHandleCExceptionInTest' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughOptions',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "custtest|test",
+ :setup_name => "custom_setup",
+ :teardown_name => "custom_teardown",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughCommandLine',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"custtest|test\" --setup_name=\"custom_setup\" --teardown_name=\"custom_teardown\"",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughYaml',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"custtest|test\"",
+ :yaml => {
+ :setup_name => "custom_setup",
+ :teardown_name => "custom_teardown",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomMain',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', "USE_ANOTHER_MAIN"],
+ :options => {
+ :main_name => "custom_main",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSuiteSetupAndTeardown',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :includes => ['Defs.h'],
+ :options => {
+ :test_prefix => "suitetest|test",
+ :suite_setup => " CounterSuiteSetup = 1;",
+ :suite_teardown => " return num_failures;",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'suitetest_ThisTestPassesWhenCustomSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'MainExternDeclaration',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST'],
+ :includes => ['Defs.h'],
+ :options => {
+ :main_export_decl => "EXTERN_DECL",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+
+ #### WITH MOCKS ##########################################
+
+ { :name => 'DefaultsThroughOptions',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => nil, #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'DefaultsThroughCommandLine',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => "", #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'DefaultsThroughYAMLFile',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => "", #defaults
+ :yaml => {}, #defaults
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustTest',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "test",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustShould',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "should",
+ },
+ :expected => {
+ :to_pass => [ 'should_RunTestsStartingWithShouldByDefault' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ShorterFilterOfJustSpec',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "spec",
+ },
+ :expected => {
+ :to_pass => [ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'InjectIncludes',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :includes => ['Defs.h'],
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughOptions',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "paratest",
+ :use_param_tests => true,
+ },
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughCommandLine',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"paratest\" --use_param_tests=1",
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ParameterizedThroughCommandLineAndYaml',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => "--use_param_tests=1",
+ :yaml => {
+ :test_prefix => "paratest"
+ },
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'CException',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST', 'USE_CEXCEPTION'],
+ :options => {
+ :test_prefix => "extest",
+ :plugins => [ :cexception ],
+ },
+ :expected => {
+ :to_pass => [ 'extest_ShouldHandleCExceptionInTest' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughOptions',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :options => {
+ :test_prefix => "custtest|test",
+ :setup_name => "custom_setup",
+ :teardown_name => "custom_teardown",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughCommandLine',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"custtest|test\" --setup_name=\"custom_setup\" --teardown_name=\"custom_teardown\"",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSetupAndTeardownThroughYaml',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :cmdline => " --test_prefix=\"custtest|test\"",
+ :yaml => {
+ :setup_name => "custom_setup",
+ :teardown_name => "custom_teardown",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'custtest_ThisTestPassesWhenCustomSetupRan',
+ 'custtest_ThisTestPassesWhenCustomTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomMain',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST', "USE_ANOTHER_MAIN"],
+ :options => {
+ :main_name => "custom_main",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'CustomSuiteSetupAndTeardown',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :includes => ['Defs.h'],
+ :options => {
+ :test_prefix => "suitetest|test",
+ :suite_setup => " CounterSuiteSetup = 1;",
+ :suite_teardown => " return num_failures;",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'suitetest_ThisTestPassesWhenCustomSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'MainExternDeclaration',
+ :testfile => 'testdata/testRunnerGeneratorWithMocks.c',
+ :testdefines => ['TEST'],
+ :includes => ['Defs.h'],
+ :options => {
+ :main_export_decl => "EXTERN_DECL",
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'test_ShouldCallMockInitAndVerifyFunctionsForEachTest',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+
+
+ #### WITH ARGS ##########################################
+
+ { :name => 'ArgsThroughOptions',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsThroughCommandLine',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :cmdline => "--cmdline_args=1",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsThroughYAMLFile',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :cmdline => "",
+ :yaml => {
+ :cmdline_args => true,
+ },
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterJustTest',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n test_",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterJustShould',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n should_",
+ :expected => {
+ :to_pass => [ 'should_RunTestsStartingWithShouldByDefault' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterTestAndShould',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n should_,test_",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterWithWildcardOnFile',
+ :testfile => 'testdata/testRunnerGeneratorSmall.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n=testRunnerGeneratorSma*",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterWithWildcardAsName',
+ :testfile => 'testdata/testRunnerGeneratorSmall.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGeneratorSmall:*",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterWithWildcardOnName',
+ :testfile => 'testdata/testRunnerGeneratorSmall.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGeneratorSmall:test_*",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterWithWildcardAndShortName',
+ :testfile => 'testdata/testRunnerGeneratorSmall.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGeneratorSmall:te*",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsNameFilterWithWildcardOnBoth',
+ :testfile => 'testdata/testRunnerGeneratorSmall.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGeneratorSm*:*",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsExcludeFilterJustTest',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-x test_",
+ :expected => {
+ :to_pass => [ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ 'should_RunTestsStartingWithShouldByDefault',
+ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeAndExcludeFilter',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ :includes => ['Defs.h'],
+ },
+ :cmdline_args => "-n test_ -x Ignored",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeSingleTest',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n ThisTestAlwaysPasses",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeSingleTestInSpecificFile',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGenerator:ThisTestAlwaysPasses",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeTestFileWithExtension',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGenerator.c:ThisTestAlwaysPasses",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeDoubleQuotes',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n \"testRunnerGenerator:ThisTestAlwaysPasses,test_ThisTestAlwaysFails\"",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeSingleQuotes',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n 'testRunnerGenerator:ThisTestAlwaysPasses,test_ThisTestAlwaysFails'",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeAValidTestForADifferentFile',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n AnotherFile:ThisTestDoesNotExist",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeNoTests',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n ThisTestDoesNotExist",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsExcludeAllTests',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-x _",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeFullFile',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n testRunnerGenerator",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses',
+ 'spec_ThisTestPassesWhenNormalSetupRan',
+ 'spec_ThisTestPassesWhenNormalTeardownRan',
+ 'test_NotBeConfusedByLongComplicatedStrings',
+ 'test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings',
+ 'test_StillNotBeConfusedByLongComplicatedStrings',
+ 'should_RunTestsStartingWithShouldByDefault',
+ 'spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan',
+ ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ 'test_ThisTestAlwaysIgnored' ],
+ }
+ },
+
+ { :name => 'ArgsIncludeWithAlternateFlag',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-f=\"testRunnerGenerator:ThisTestAlwaysPasses,test_ThisTestAlwaysFails\"",
+ :expected => {
+ :to_pass => [ 'test_ThisTestAlwaysPasses' ],
+ :to_fail => [ 'test_ThisTestAlwaysFails' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsIncludeWithParameterized',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :cmdline => "--use_param_tests=1",
+ :yaml => {
+ :cmdline_args => true,
+ :test_prefix => "paratest"
+ },
+ :cmdline_args => "-n ShouldHandleParameterizedTests",
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ ],
+ :to_fail => [ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)' ],
+ :to_ignore => [ ],
+ }
+ },
+
+ { :name => 'ArgsList',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-l",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [ "testRunnerGenerator",
+ "test_ThisTestAlwaysPasses",
+ "test_ThisTestAlwaysFails",
+ "test_ThisTestAlwaysIgnored",
+ "spec_ThisTestPassesWhenNormalSuiteSetupAndTeardownRan",
+ "spec_ThisTestPassesWhenNormalSetupRan",
+ "spec_ThisTestPassesWhenNormalTeardownRan",
+ "test_NotBeConfusedByLongComplicatedStrings",
+ "test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings",
+ "test_StillNotBeConfusedByLongComplicatedStrings",
+ "should_RunTestsStartingWithShouldByDefault"
+ ]
+ }
+ },
+
+ { :name => 'ArgsListParameterized',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :test_prefix => "paratest",
+ :use_param_tests => true,
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-l",
+ :features => [ :parameterized ],
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [ "testRunnerGenerator",
+ 'paratest_ShouldHandleParameterizedTests\(25\)',
+ 'paratest_ShouldHandleParameterizedTests\(125\)',
+ 'paratest_ShouldHandleParameterizedTests\(5\)',
+ 'paratest_ShouldHandleParameterizedTests2\(7\)',
+ 'paratest_ShouldHandleNonParameterizedTestsWhenParameterizationValid',
+ 'paratest_ShouldHandleParameterizedTestsThatFail\(17\)',
+ 'paratest_WorksWithFunctionPointers\(isArgumentOne\)',
+ ],
+ }
+ },
+
+ { :name => 'ArgsIncompleteIncludeFlags',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-n",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [ "ERROR: No Test String to Include Matches For" ],
+ }
+ },
+
+ { :name => 'ArgsIncompleteExcludeFlags',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-x",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [ "ERROR: No Test String to Exclude Matches For" ],
+ }
+ },
+
+ { :name => 'ArgsIllegalFlags',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-z",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [
+ "ERROR: Unknown Option z",
+ "Options:",
+ "-l List all tests and exit",
+ "-f NAME Filter to run only tests whose name includes NAME",
+ "-n NAME \\(deprecated\\) alias of -f",
+ "-h show this Help menu",
+ "-q Quiet/decrease verbosity",
+ "-v increase Verbosity",
+ "-x NAME eXclude tests whose name includes NAME",
+ ],
+ }
+ },
+
+ { :name => 'ArgsHelp',
+ :testfile => 'testdata/testRunnerGenerator.c',
+ :testdefines => ['TEST', 'UNITY_USE_COMMAND_LINE_ARGS'],
+ :options => {
+ :cmdline_args => true,
+ },
+ :cmdline_args => "-h",
+ :expected => {
+ :to_pass => [ ],
+ :to_fail => [ ],
+ :to_ignore => [ ],
+ :text => [
+ "Options:",
+ "-l List all tests and exit",
+ "-f NAME Filter to run only tests whose name includes NAME",
+ "-n NAME \\(deprecated\\) alias of -f",
+ "-h show this Help menu",
+ "-q Quiet/decrease verbosity",
+ "-v increase Verbosity",
+ "-x NAME eXclude tests whose name includes NAME",
+ ],
+ }
+ },
+]
+
+def runner_test(test, runner, expected, test_defines, cmdline_args, features)
+ # Tack on TEST define for compiling unit tests
+ load_configuration($cfg_file)
+
+ # Drop Out if we're skipping this type of test
+ if $cfg[:skip_tests] && features
+ if $cfg[:skip_tests].include?(:parameterized) && features.include?(:parameterized)
+ report("Skipping Parameterized Tests for this Target:IGNORE")
+ return true
+ end
+ end
+
+ #compile objects
+ obj_list = [
+ compile(runner, test_defines),
+ compile(test, test_defines),
+ compile('../src/unity.c', test_defines),
+ ]
+
+ # Link the test executable
+ test_base = File.basename(test, C_EXTENSION)
+ link_it(test_base, obj_list)
+
+ # Execute unit test and generate results file
+ output = runtest(test_base, true, cmdline_args)
+
+ #compare to the expected pass/fail
+ allgood = expected[:to_pass].inject(true) {|s,v| s && verify_match(/#{v}:PASS/, output) }
+ allgood = expected[:to_fail].inject(allgood) {|s,v| s && verify_match(/#{v}:FAIL/, output) }
+ allgood = expected[:to_ignore].inject(allgood) {|s,v| s && verify_match(/#{v}:IGNORE/, output) }
+
+ #verify there weren't more pass/fail/etc than expected
+ allgood &&= verify_number( expected[:to_pass], /(:PASS)/, output)
+ allgood &&= verify_number( expected[:to_fail], /(:FAIL)/, output)
+ allgood &&= verify_number( expected[:to_ignore], /(:IGNORE)/, output)
+
+ #if we care about any other text, check that too
+ if (expected[:text])
+ allgood = expected[:text].inject(allgood) {|s,v| s && verify_match(/#{v}/, output) }
+ allgood &&= verify_number( expected[:text], /.+/, output )
+ end
+
+ report output if (!allgood && !$verbose) #report failures if not already reporting everything
+ return allgood
+end
+
+def verify_match(expression, output)
+ if (expression =~ output)
+ return true
+ else
+ report " FAIL: No Match For /#{expression.to_s}/"
+ return false
+ end
+end
+
+def verify_number(expected, expression, output)
+ exp = expected.length
+ act = output.scan(expression).length
+ if (exp == act)
+ return true
+ else
+ report " FAIL: Expected #{exp} Matches For /#{expression.to_s}/. Was #{act}"
+ return false
+ end
+end
+
+RUNNER_TESTS.each do |testset|
+ basename = File.basename(testset[:testfile], C_EXTENSION)
+ testset_name = "Runner_#{basename}_#{testset[:name]}"
+ should testset_name do
+ runner_name = OUT_FILE + testset[:name] + '_runner.c'
+
+ #create a yaml file first if required
+ yaml_option = ""
+ if (testset[:yaml])
+ File.open("build/runner_options.yml",'w') {|f| f << { :unity => testset[:yaml] }.to_yaml }
+ yaml_option = "build/runner_options.yml"
+ end
+
+ #run script via command line or through hash function call, as requested
+ if (testset[:cmdline])
+ cmdstr = "ruby ../auto/generate_test_runner.rb #{yaml_option} #{testset[:cmdline]} \"#{testset[:testfile]}\" \"#{runner_name}\""
+ `#{cmdstr}`
+ else
+ UnityTestRunnerGenerator.new(testset[:options]).run(testset[:testfile], runner_name)
+ end
+
+ #test the script against the specified test file and check results
+ if (runner_test(testset[:testfile], runner_name, testset[:expected], testset[:testdefines], testset[:cmdline_args], testset[:features]))
+ report "#{testset_name}:PASS"
+ else
+ report "#{testset_name}:FAIL"
+ $generate_test_runner_failures += 1
+ end
+ $generate_test_runner_tests += 1
+ end
+end
+
+raise "There were #{$generate_test_runner_failures.to_s} failures while testing generate_test_runner.rb" if ($generate_test_runner_failures > 0)
diff --git a/deps/Unity/test/tests/test_unity_arrays.c b/deps/Unity/test/tests/test_unity_arrays.c
new file mode 100644
index 0000000..5984883
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_arrays.c
@@ -0,0 +1,2940 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testInt64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualSmallDelta[] = {12345001, -12344996, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+#endif
+}
+
+void testInt64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualSmallDelta[] = {12345001, -12344996, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void tesUInt64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, expected, 3);
+#endif
+}
+
+void testInt64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testIntArrayWithinDelta(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualSmallDelta[] = {5001, -4996, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ TEST_ASSERT_INT_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_INT_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testIntArrayWithinDeltaAndMessage(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualSmallDelta[] = {5001, -4996, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testIntArrayNotWithinDelta(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testIntArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaPointless(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_INT actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaActualNull(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testIntArrayWithinDeltaSamePointer(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+
+ TEST_ASSERT_INT_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testIntArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_INT expected[] = {5000, -4995, 5005};
+
+ TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+void testInt16ArrayWithinDelta(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualSmallDelta[] = {5001, -4996, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ TEST_ASSERT_INT16_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_INT16_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testInt16ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualSmallDelta[] = {5001, -4996, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testInt16ArrayNotWithinDelta(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaPointless(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_INT16 actualBigDelta[] = {5101, -4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaActualNull(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt16ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+
+ TEST_ASSERT_INT16_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testInt16ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_INT16 expected[] = {5000, -4995, 5005};
+
+ TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+void testInt8ArrayWithinDelta(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualSmallDelta[] = {21, -94, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ TEST_ASSERT_INT8_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_INT8_ARRAY_WITHIN(11, expected, actualBigDelta, 3);
+}
+
+void testInt8ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualSmallDelta[] = {21, -94, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testInt8ArrayNotWithinDelta(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaPointless(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN(11, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN(11, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_INT8 actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(11, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaActualNull(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN(11, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(11, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testInt8ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+
+ TEST_ASSERT_INT8_ARRAY_WITHIN(11, expected, expected, 3);
+}
+
+void testInt8ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_INT8 expected[] = {20, -95, 55};
+
+ TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(11, expected, expected, 3, "Custom Message.");
+}
+
+void testCHARArrayWithinDelta(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualSmallDelta[] = {21, -94, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(11, expected, actualBigDelta, 3);
+}
+
+void testCHARArrayWithinDeltaAndMessage(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualSmallDelta[] = {21, -94, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testCHARArrayNotWithinDelta(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayNotWithinDeltaAndMessage(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaPointless(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(11, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaPointlessAndMessage(void)
+{
+ char expected[] = {20, -95, 55};
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaExpectedNull(void)
+{
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(11, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ char actualBigDelta[] = {11, -86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(11, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaActualNull(void)
+{
+ char expected[] = {20, -95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(11, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaActualNullAndMessage(void)
+{
+ char expected[] = {20, -95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(11, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testCHARArrayWithinDeltaSamePointer(void)
+{
+ char expected[] = {20, -95, 55};
+
+ TEST_ASSERT_CHAR_ARRAY_WITHIN(11, expected, expected, 3);
+}
+
+void testCHARArrayWithinDeltaSamePointerAndMessage(void)
+{
+ char expected[] = {20, -95, 55};
+
+ TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(11, expected, expected, 3, "Custom Message.");
+}
+
+void testUInt64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualSmallDelta[] = {12345001, 12344996, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+#endif
+}
+
+void testUInt64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualSmallDelta[] = {12345001, 12344996, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void testUInt64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, expected, 3);
+#endif
+}
+
+void testUInt64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testUIntArrayWithinDelta(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualSmallDelta[] = {125001, 124996, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ TEST_ASSERT_UINT_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_UINT_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testUIntArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualSmallDelta[] = {125001, 124996, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testUIntArrayNotWithinDelta(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT actualBigDelta[] = {125101, 124896, 125055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+
+ TEST_ASSERT_UINT_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testUIntArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT expected[] = {125000, 124995, 125005};
+
+ TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+void testUInt16ArrayWithinDelta(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualSmallDelta[] = {5001, 4996, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testUInt16ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualSmallDelta[] = {5001, 4996, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testUInt16ArrayNotWithinDelta(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT16 actualBigDelta[] = {5101, 4896, 5055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt16ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+
+ TEST_ASSERT_UINT16_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testUInt16ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {5000, 4995, 5005};
+
+ TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+void testUInt8ArrayWithinDelta(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualSmallDelta[] = {21, 94, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(11, expected, actualBigDelta, 3);
+}
+
+void testUInt8ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualSmallDelta[] = {21, 94, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testUInt8ArrayNotWithinDelta(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(11, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(11, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(11, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT8 actualBigDelta[] = {11, 86, 45};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(11, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(11, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(11, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUInt8ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+
+ TEST_ASSERT_UINT8_ARRAY_WITHIN(11, expected, expected, 3);
+}
+
+void testUInt8ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {20, 95, 55};
+
+ TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(11, expected, expected, 3, "Custom Message.");
+}
+
+void testHEX64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualSmallDelta[] = {0xABCD123500000000, 0xABCD112100000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x100000000, expected, actualSmallDelta, 3);
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, actualBigDelta, 3);
+#endif
+}
+
+void testHEX64ArrayWithinDeltaShouldNotHaveSignIssues(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0x7FFFFFFFFFFFFFFF, 0x8000000000000000};
+ UNITY_UINT64 actualBigDelta[] = {0x8000000000000000, 0x7FFFFFFFFFFFFFFF};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(1, expected, actualBigDelta, 2);
+#endif
+}
+
+void testHEX64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualSmallDelta[] = {0xABCD123500000000, 0xABCD112100000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x100000000, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void testHEX64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x100000000, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x100000000, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, expected, 3);
+#endif
+}
+
+void testHEX64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testHEX32ArrayWithinDelta(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualSmallDelta[] = {0xABCD1235, 0xABCD1121, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testHEX32ArrayWithinDeltaShouldNotHaveSignIssues(void)
+{
+ UNITY_UINT32 expected[] = {0x7FFFFFFF, 0x80000000};
+ UNITY_UINT32 actualBigDelta[] = {0x80000000, 0x7FFFFFFF};
+
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(1, expected, actualBigDelta, 2);
+}
+
+void testHEX32ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualSmallDelta[] = {0xABCD1235, 0xABCD1121, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testHEX32ArrayNotWithinDelta(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT actualBigDelta[] = {0xABCD1267, 0xABCD1188, 0xABCD12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+
+ TEST_ASSERT_HEX32_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testHEX32ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT expected[] = {0xABCD1234, 0xABCD1122, 0xABCD1277};
+
+ TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+
+void testHEX16ArrayWithinDelta(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualSmallDelta[] = {0x1235, 0x1121, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+}
+
+void testHEX16ArrayWithinDeltaShouldNotHaveSignIssues(void)
+{
+ UNITY_UINT16 expected[] = {0x7FFF, 0x8000};
+ UNITY_UINT16 actualBigDelta[] = {0x8000, 0x7FFF};
+
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(1, expected, actualBigDelta, 2);
+}
+
+void testHEX16ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualSmallDelta[] = {0x1235, 0x1121, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testHEX16ArrayNotWithinDelta(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT16 actualBigDelta[] = {0x1267, 0x1188, 0x12AC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX16ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+
+ TEST_ASSERT_HEX16_ARRAY_WITHIN(110, expected, expected, 3);
+}
+
+void testHEX16ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT16 expected[] = {0x1234, 0x1122, 0x1277};
+
+ TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+}
+
+void testHEX8ArrayWithinDelta(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualSmallDelta[] = {0x35, 0x21, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x47, 0x48, 0x4C};
+
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(60, expected, actualBigDelta, 3);
+}
+
+void testHEX8ArrayWithinDeltaAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualSmallDelta[] = {0x35, 0x21, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x47, 0x48, 0x4C};
+
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(60, expected, actualBigDelta, 3, "Custom Message.");
+}
+
+void testHEX8ArrayNotWithinDelta(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaShouldNotHaveSignIssues(void)
+{
+ UNITY_UINT8 expected[] = {0x7F, 0x80};
+ UNITY_UINT8 actualBigDelta[] = {0x80, 0x7F};
+
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(1, expected, actualBigDelta, 2);
+}
+
+void testHEX8ArrayNotWithinDeltaAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaPointless(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(60, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaPointlessAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(60, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaExpectedNull(void)
+{
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(60, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+ UNITY_UINT8 actualBigDelta[] = {0x67, 0x88, 0xAC};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(60, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaActualNull(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(60, expected, NULL, 3);
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaActualNullAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(60, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX8ArrayWithinDeltaSamePointer(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+
+ TEST_ASSERT_HEX8_ARRAY_WITHIN(60, expected, expected, 3);
+}
+
+void testHEX8ArrayWithinDeltaSamePointerAndMessage(void)
+{
+ UNITY_UINT8 expected[] = {0x34, 0x22, 0x77};
+
+ TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(60, expected, expected, 3, "Custom Message.");
+}
+
+void testEqualIntArrays(void)
+{
+ int p0[] = {1, 8, 987, -2};
+ int p1[] = {1, 8, 987, -2};
+ int p2[] = {1, 8, 987, 2};
+ int p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p3, 1);
+ TEST_ASSERT_EQUAL_INT_ARRAY(NULL, NULL, 1);
+}
+
+void testNotEqualIntArraysNullExpected(void)
+{
+ int* p0 = NULL;
+ int p1[] = {1, 8, 987, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntArraysNullActual(void)
+{
+ int* p1 = NULL;
+ int p0[] = {1, 8, 987, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntArrays1(void)
+{
+ int p0[] = {1, 8, 987, -2};
+ int p1[] = {1, 8, 987, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntArrays2(void)
+{
+ int p0[] = {1, 8, 987, -2};
+ int p1[] = {2, 8, 987, -2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntArrays3(void)
+{
+ int p0[] = {1, 8, 987, -2};
+ int p1[] = {1, 8, 986, -2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntArraysLengthZero(void)
+{
+ UNITY_UINT32 p0[1] = {1};
+ UNITY_UINT32 p1[1] = {1};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(p0, p1, 0);
+ VERIFY_FAILS_END
+}
+
+void testEqualIntEachEqual(void)
+{
+ int p0[] = {1, 1, 1, 1};
+ int p1[] = {987, 987, 987, 987};
+ int p2[] = {-2, -2, -2, -3};
+ int p3[] = {1, 5, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_INT(1, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_INT(1, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_INT(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_INT(-2, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_INT(1, p3, 1);
+}
+
+void testNotEqualIntEachEqualNullActual(void)
+{
+ int* p1 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT(1, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntEachEqual1(void)
+{
+ int p0[] = {1, 1, 1, -2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT(1, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntEachEqual2(void)
+{
+ int p0[] = {-5, -5, -1, -5};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT(-5, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualIntEachEqual3(void)
+{
+ int p0[] = {1, 88, 88, 88};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT(88, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualEachEqualLengthZero(void)
+{
+ UNITY_UINT32 p0[1] = {1};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT(0, p0, 0);
+ VERIFY_FAILS_END
+}
+
+void testEqualPtrArrays(void)
+{
+ char A = 1;
+ char B = 2;
+ char C = 3;
+ char* p0[] = {&A, &B, &C};
+ char* p1[] = {&A, &B, &C, &A};
+ char* p2[] = {&A, &B};
+ char* p3[] = {&A};
+
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p0, 3);
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p1, 3);
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p1, p2, 2);
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p3, p0, 1);
+}
+
+void testNotEqualPtrArraysNullExpected(void)
+{
+ char A = 1;
+ char B = 2;
+ char** p0 = NULL;
+ char* p1[] = {&A, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p1, 2);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrArraysNullActual(void)
+{
+ char A = 1;
+ char B = 2;
+ char** p0 = NULL;
+ char* p1[] = {&A, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p1, p0, 2);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrArrays1(void)
+{
+ char A = 1;
+ char B = 2;
+ char C = 3;
+ char* p0[] = {&A, &B, &C, &B};
+ char* p1[] = {&A, &B, &C, &A};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrArrays2(void)
+{
+ char A = 1;
+ char B = 2;
+ char C = 3;
+ char* p0[] = {&B, &B, &C, &A};
+ char* p1[] = {&A, &B, &C, &A};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrArrays3(void)
+{
+ char A = 1;
+ char B = 2;
+ char C = 3;
+ char* p0[] = {&A, &B, &B, &A};
+ char* p1[] = {&A, &B, &C, &A};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualPtrEachEqual(void)
+{
+ char A = 1;
+ char B = 2;
+ char C = 3;
+ char* p0[] = {&A, &A, &A};
+ char* p1[] = {&A, &B, &C, &A};
+ char* p2[] = {&B, &B};
+ char* p3[] = {&C};
+
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p0, 3);
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p1, 1);
+ TEST_ASSERT_EACH_EQUAL_PTR(&B, p2, 2);
+ TEST_ASSERT_EACH_EQUAL_PTR(&C, p3, 1);
+}
+
+void testNotEqualPtrEachEqualNullExpected(void)
+{
+ char A = 1;
+ char B = 1;
+ char* p0[] = {&A, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p0, 2);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrEachEqualNullActual(void)
+{
+ char A = 1;
+ char** p0 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p0, 2);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrEachEqual1(void)
+{
+ char A = 1;
+ char B = 1;
+ char* p0[] = {&A, &A, &A, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_PTR(&A, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrEachEqual2(void)
+{
+ char A = 1;
+ char B = 1;
+ char* p0[] = {&B, &B, &A, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_PTR(&B, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualPtrEachEqual3(void)
+{
+ char A = 1;
+ char B = 1;
+ char* p0[] = {&A, &B, &B, &B};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_PTR(&B, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt8Arrays(void)
+{
+ UNITY_INT8 p0[] = {1, 8, 117, -2};
+ UNITY_INT8 p1[] = {1, 8, 117, -2};
+ UNITY_INT8 p2[] = {1, 8, 117, 2};
+ UNITY_INT8 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualInt8Arrays(void)
+{
+ UNITY_INT8 p0[] = {1, 8, 36, -2};
+ UNITY_INT8 p1[] = {1, 8, 36, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt8EachEqual(void)
+{
+ UNITY_INT8 p0[] = {1, 1, 1, 1};
+ UNITY_INT8 p1[] = {117, 117, 117, -2};
+ UNITY_INT8 p2[] = {-1, -1, 117, 2};
+ UNITY_INT8 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EACH_EQUAL_INT8(1, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_INT8(1, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_INT8(117, p1, 3);
+ TEST_ASSERT_EACH_EQUAL_INT8(-1, p2, 2);
+ TEST_ASSERT_EACH_EQUAL_INT8(1, p3, 1);
+}
+
+void testNotEqualInt8EachEqual(void)
+{
+ UNITY_INT8 p0[] = {1, 8, 36, -2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT8(1, p0, 2);
+ VERIFY_FAILS_END
+}
+
+void testEqualCHARArrays(void)
+{
+ char p0[] = {1, 8, 117, -2};
+ char p1[] = {1, 8, 117, -2};
+ char p2[] = {1, 8, 117, 2};
+ char p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualCHARArrays(void)
+{
+ char p0[] = {1, 8, 36, -2};
+ char p1[] = {1, 8, 36, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_CHAR_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualCHAREachEqual(void)
+{
+ char p0[] = {1, 1, 1, 1};
+ char p1[] = {117, 117, 117, -2};
+ char p2[] = {-1, -1, 117, 2};
+ char p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EACH_EQUAL_CHAR(1, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_CHAR(1, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_CHAR(117, p1, 3);
+ TEST_ASSERT_EACH_EQUAL_CHAR(-1, p2, 2);
+ TEST_ASSERT_EACH_EQUAL_CHAR(1, p3, 1);
+}
+
+void testNotEqualCHAREachEqual(void)
+{
+ char p0[] = {1, 8, 36, -2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_CHAR(1, p0, 2);
+ VERIFY_FAILS_END
+}
+
+void testEqualUIntArrays(void)
+{
+ unsigned int p0[] = {1, 8, 987, 65132u};
+ unsigned int p1[] = {1, 8, 987, 65132u};
+ unsigned int p2[] = {1, 8, 987, 2};
+ unsigned int p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualUIntArrays1(void)
+{
+ unsigned int p0[] = {1, 8, 987, 65132u};
+ unsigned int p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUIntArrays2(void)
+{
+ unsigned int p0[] = {1, 8, 987, 65132u};
+ unsigned int p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUIntArrays3(void)
+{
+ unsigned int p0[] = {1, 8, 987, 65132u};
+ unsigned int p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUIntEachEqual(void)
+{
+ unsigned int p0[] = {1, 1, 1, 1};
+ unsigned int p1[] = {65132u, 65132u, 65132u, 65132u};
+ unsigned int p2[] = {8, 8, 987, 2};
+ unsigned int p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_UINT(1, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_UINT(1, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT(65132u, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT(8, p2, 2);
+ TEST_ASSERT_EACH_EQUAL_UINT(1, p3, 1);
+}
+
+void testNotEqualUIntEachEqual1(void)
+{
+ unsigned int p0[] = {1, 65132u, 65132u, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUIntEachEqual2(void)
+{
+ unsigned int p0[] = {987, 8, 987, 987};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT(987, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUIntEachEqual3(void)
+{
+ unsigned int p0[] = {1, 1, 1, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT(1, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt16Arrays(void)
+{
+ UNITY_INT16 p0[] = {1, 8, 117, 3};
+ UNITY_INT16 p1[] = {1, 8, 117, 3};
+ UNITY_INT16 p2[] = {1, 8, 117, 2};
+ UNITY_INT16 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualInt16Arrays(void)
+{
+ UNITY_INT16 p0[] = {1, 8, 127, 3};
+ UNITY_INT16 p1[] = {1, 8, 127, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt16EachEqual(void)
+{
+ UNITY_INT16 p0[] = {1, 1, 1, 1};
+ UNITY_INT16 p1[] = {32111, 32111, 32111, 3};
+ UNITY_INT16 p2[] = {-1, -1, -1, 2};
+ UNITY_INT16 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EACH_EQUAL_INT16(1, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_INT16(1, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_INT16(32111, p1, 3);
+ TEST_ASSERT_EACH_EQUAL_INT16(-1, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_INT16(1, p3, 1);
+}
+
+void testNotEqualInt16EachEqual(void)
+{
+ UNITY_INT16 p0[] = {127, 127, 127, 3};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT16(127, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt32Arrays(void)
+{
+ UNITY_INT32 p0[] = {1, 8, 117, 3};
+ UNITY_INT32 p1[] = {1, 8, 117, 3};
+ UNITY_INT32 p2[] = {1, 8, 117, 2};
+ UNITY_INT32 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualInt32Arrays(void)
+{
+ UNITY_INT32 p0[] = {1, 8, 127, 3};
+ UNITY_INT32 p1[] = {1, 8, 127, 2};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualInt32EachEqual(void)
+{
+ UNITY_INT32 p0[] = {8, 8, 8, 8};
+ UNITY_INT32 p1[] = {65537, 65537, 65537, 65537};
+ UNITY_INT32 p2[] = {-3, -3, -3, 2};
+ UNITY_INT32 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EACH_EQUAL_INT32(8, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_INT32(8, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_INT32(65537, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_INT32(-3, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_INT32(1, p3, 1);
+}
+
+void testNotEqualInt32EachEqual(void)
+{
+ UNITY_INT32 p0[] = {127, 8, 127, 127};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_INT32(127, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUINT8Arrays(void)
+{
+ UNITY_UINT8 p0[] = {1, 8, 100, 127};
+ UNITY_UINT8 p1[] = {1, 8, 100, 127};
+ UNITY_UINT8 p2[] = {1, 8, 100, 2};
+ UNITY_UINT8 p3[] = {1, 50, 60, 70};
+
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualUINT8Arrays1(void)
+{
+ unsigned char p0[] = {1, 8, 100, 127u};
+ unsigned char p1[] = {1, 8, 100, 255u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT8Arrays2(void)
+{
+ unsigned char p0[] = {1, 8, 100, 127u};
+ unsigned char p1[] = {1, 8, 100, 255u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT8Arrays3(void)
+{
+ unsigned char p0[] = {1, 8, 100, 127u};
+ unsigned char p1[] = {1, 8, 100, 255u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+
+void testEqualUINT16Arrays(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 987, 65132u};
+ unsigned short p2[] = {1, 8, 987, 2};
+ unsigned short p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualUINT16Arrays1(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT16Arrays2(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT16Arrays3(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUINT32Arrays(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p2[] = {1, 8, 987, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualUINT32Arrays1(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT32Arrays2(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT32Arrays3(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEXArrays(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p2[] = {1, 8, 987, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_HEX_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_HEX_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_HEX_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualHEXArrays1(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEXArrays2(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEXArrays3(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX32Arrays(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p2[] = {1, 8, 987, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualHEX32Arrays1(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX32Arrays2(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX32Arrays3(void)
+{
+ UNITY_UINT32 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT32 p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX16Arrays(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 987, 65132u};
+ unsigned short p2[] = {1, 8, 987, 2};
+ unsigned short p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualHEX16Arrays1(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX16Arrays2(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX16Arrays3(void)
+{
+ unsigned short p0[] = {1, 8, 987, 65132u};
+ unsigned short p1[] = {1, 8, 986, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX16_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX8Arrays(void)
+{
+ unsigned char p0[] = {1, 8, 254u, 123};
+ unsigned char p1[] = {1, 8, 254u, 123};
+ unsigned char p2[] = {1, 8, 254u, 2};
+ unsigned char p3[] = {1, 23, 25, 26};
+
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p3, 1);
+}
+
+void testNotEqualHEX8Arrays1(void)
+{
+ unsigned char p0[] = {1, 8, 254u, 253u};
+ unsigned char p1[] = {1, 8, 254u, 252u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX8Arrays2(void)
+{
+ unsigned char p0[] = {1, 8, 254u, 253u};
+ unsigned char p1[] = {2, 8, 254u, 253u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX8Arrays3(void)
+{
+ unsigned char p0[] = {1, 8, 254u, 253u};
+ unsigned char p1[] = {1, 8, 255u, 253u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUINT8EachEqual(void)
+{
+ UNITY_UINT8 p0[] = {127u, 127u, 127u, 127u};
+ UNITY_UINT8 p1[] = {1u, 1u, 1u, 1u};
+ UNITY_UINT8 p2[] = {128u, 128u, 128u, 2u};
+ UNITY_UINT8 p3[] = {1u, 50u, 60u, 70u};
+
+ TEST_ASSERT_EACH_EQUAL_UINT8(127u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_UINT8(127u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT8(1u, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT8(128u, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_UINT8(1u, p3, 1);
+}
+
+void testNotEqualUINT8EachEqual1(void)
+{
+ unsigned char p0[] = {127u, 127u, 128u, 127u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT8(127u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT8EachEqual2(void)
+{
+ unsigned char p0[] = {1, 1, 1, 127u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT8(1, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT8EachEqual3(void)
+{
+ unsigned char p0[] = {54u, 55u, 55u, 55u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT8(55u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUINT16EachEqual(void)
+{
+ unsigned short p0[] = {65132u, 65132u, 65132u, 65132u};
+ unsigned short p1[] = {987, 987, 987, 987};
+ unsigned short p2[] = {1, 1, 1, 2};
+ unsigned short p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_UINT16(65132u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_UINT16(65132u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT16(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT16(1, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_UINT16(1, p3, 1);
+}
+
+void testNotEqualUINT16EachEqual1(void)
+{
+ unsigned short p0[] = {1, 65132u, 65132u, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT16(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT16EachEqual2(void)
+{
+ unsigned short p0[] = {65132u, 65132u, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT16(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT16EachEqual3(void)
+{
+ unsigned short p0[] = {65132u, 65132u, 65132u, 65133u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT16(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualUINT32EachEqual(void)
+{
+ UNITY_UINT32 p0[] = {65132u, 65132u, 65132u, 65132u};
+ UNITY_UINT32 p1[] = {987, 987, 987, 987};
+ UNITY_UINT32 p2[] = {8, 8, 8, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_UINT32(65132u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_UINT32(65132u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT32(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_UINT32(8, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_UINT32(1, p3, 1);
+}
+
+void testNotEqualUINT32EachEqual1(void)
+{
+ UNITY_UINT32 p0[] = {65132u, 65132u, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT32(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT32EachEqual2(void)
+{
+ UNITY_UINT32 p0[] = {1, 987, 987, 987};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT32(987, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT32EachEqual3(void)
+{
+ UNITY_UINT32 p0[] = {1, 1, 1, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_UINT32(1, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEXEachEqual(void)
+{
+ UNITY_UINT32 p0[] = {65132u, 65132u, 65132u, 65132u};
+ UNITY_UINT32 p1[] = {987, 987, 987, 987};
+ UNITY_UINT32 p2[] = {8, 8, 8, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_HEX(65132u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_HEX(65132u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX(8, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_HEX(1, p3, 1);
+}
+
+void testNotEqualHEXEachEqual1(void)
+{
+ UNITY_UINT32 p0[] = {1, 65132u, 65132u, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX32(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEXEachEqual2(void)
+{
+ UNITY_UINT32 p0[] = {987, 987, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX32(987, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEXEachEqual3(void)
+{
+ UNITY_UINT32 p0[] = {8, 8, 987, 8};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX(8, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX32EachEqual(void)
+{
+ UNITY_UINT32 p0[] = {65132u, 65132u, 65132u, 65132u};
+ UNITY_UINT32 p1[] = {987, 987, 987, 987};
+ UNITY_UINT32 p2[] = {8, 8, 8, 2};
+ UNITY_UINT32 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_HEX32(65132u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_HEX32(65132u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX32(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX32(8, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_HEX32(1, p3, 1);
+}
+
+void testNotEqualHEX32EachEqual1(void)
+{
+ UNITY_UINT32 p0[] = {65132u, 8, 65132u, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX32(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX32EachEqual2(void)
+{
+ UNITY_UINT32 p0[] = {1, 987, 987, 987};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX32(987, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX32EachEqual3(void)
+{
+ UNITY_UINT32 p0[] = {8, 8, 8, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX32(8, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX16EachEqual(void)
+{
+ UNITY_UINT16 p0[] = {65132u, 65132u, 65132u, 65132u};
+ UNITY_UINT16 p1[] = {987, 987, 987, 987};
+ UNITY_UINT16 p2[] = {8, 8, 8, 2};
+ UNITY_UINT16 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EACH_EQUAL_HEX16(65132u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_HEX16(65132u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX16(987, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX16(8, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_HEX16(1, p3, 1);
+}
+
+void testNotEqualHEX16EachEqual1(void)
+{
+ unsigned short p0[] = {65132u, 65132u, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX16(65132u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX16EachEqual2(void)
+{
+ unsigned short p0[] = {1, 987, 987, 987};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX16(987, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX16EachEqual3(void)
+{
+ unsigned short p0[] = {8, 8, 8, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX16(8, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX8EachEqual(void)
+{
+ unsigned char p0[] = {254u, 254u, 254u, 254u};
+ unsigned char p1[] = {123, 123, 123, 123};
+ unsigned char p2[] = {8, 8, 8, 2};
+ unsigned char p3[] = {1, 23, 25, 26};
+
+ TEST_ASSERT_EACH_EQUAL_HEX8(254u, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_HEX8(254u, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX8(123, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_HEX8(8, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_HEX8(1, p3, 1);
+}
+
+void testNotEqualHEX8EachEqual1(void)
+{
+ unsigned char p0[] = {253u, 253u, 254u, 253u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX8(253u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX8EachEqual2(void)
+{
+ unsigned char p0[] = {254u, 254u, 254u, 253u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX8(254u, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX8EachEqual3(void)
+{
+ unsigned char p0[] = {1, 8, 8, 8};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_HEX8(8, p0, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualHEX64Arrays(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p1[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p2[] = {1, 8, 987, 2};
+ UNITY_UINT64 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p3, 1);
+#endif
+}
+
+void testEqualUint64Arrays(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p1[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p2[] = {1, 8, 987, 2};
+ UNITY_UINT64 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p3, 1);
+#endif
+}
+
+void testEqualInt64Arrays(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 p0[] = {1, 8, 987, -65132};
+ UNITY_INT64 p1[] = {1, 8, 987, -65132};
+ UNITY_INT64 p2[] = {1, 8, 987, -2};
+ UNITY_INT64 p3[] = {1, 500, 600, 700};
+
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p3, 1);
+#endif
+}
+
+
+void testNotEqualHEX64Arrays1(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualHEX64Arrays2(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p1[] = {2, 8, 987, 65132u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX64_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualUint64Arrays(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 p0[] = {1, 8, 987, 65132u};
+ UNITY_UINT64 p1[] = {1, 8, 987, 65131u};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT64_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualInt64Arrays(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 p0[] = {1, 8, 987, -65132};
+ UNITY_INT64 p1[] = {1, 8, 987, -65131};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT64_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testVerifyIntPassingPointerComparisonOnZeroLengthArray(void)
+{
+ int a[] = { 1 };
+
+#ifndef UNITY_COMPARE_PTRS_ON_ZERO_ARRAY
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(a, a, 0);
+ VERIFY_FAILS_END
+#else
+
+ TEST_ASSERT_EQUAL_INT_ARRAY(a, a, 0);
+#endif
+}
+
+void testVerifyIntFailingPointerComparisonOnZeroLengthArray(void)
+{
+ int a[] = { 1 };
+ int b[] = { 1 };
+
+#ifndef UNITY_COMPARE_PTRS_ON_ZERO_ARRAY
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(a, b, 0);
+ VERIFY_FAILS_END
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_ARRAY(a, b, 0);
+ VERIFY_FAILS_END
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_core.c b/deps/Unity/test/tests/test_unity_core.c
new file mode 100644
index 0000000..d324e86
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_core.c
@@ -0,0 +1,371 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testUnitySizeInitializationReminder(void)
+{
+ /* This test ensures that sizeof(struct UNITY_STORAGE_T) doesn't change. If this
+ * test breaks, go look at the initialization of the Unity global variable
+ * in unity.c and make sure we're filling in the proper fields. */
+ const char* message = "Unexpected size for UNITY_STORAGE_T struct. Please check that "
+ "the initialization of the Unity symbol in unity.c is "
+ "still correct.";
+
+ /* Define a structure with all the same fields as `struct UNITY_STORAGE_T`. */
+#ifdef UNITY_EXCLUDE_DETAILS
+ struct {
+ const char* TestFile;
+ const char* CurrentTestName;
+ UNITY_LINE_TYPE CurrentTestLineNumber;
+ UNITY_COUNTER_TYPE NumberOfTests;
+ UNITY_COUNTER_TYPE TestFailures;
+ UNITY_COUNTER_TYPE TestIgnores;
+ UNITY_COUNTER_TYPE CurrentTestFailed;
+ UNITY_COUNTER_TYPE CurrentTestIgnored;
+#ifdef UNITY_INCLUDE_EXEC_TIME
+ UNITY_TIME_TYPE CurrentTestStartTime;
+ UNITY_TIME_TYPE CurrentTestStopTime;
+#endif
+#ifndef UNITY_EXCLUDE_SETJMP_H
+ jmp_buf AbortFrame;
+#endif
+ } _Expected_Unity;
+#else
+ struct {
+ const char* TestFile;
+ const char* CurrentTestName;
+ const char* CurrentDetails1;
+ const char* CurrentDetails2;
+ UNITY_LINE_TYPE CurrentTestLineNumber;
+ UNITY_COUNTER_TYPE NumberOfTests;
+ UNITY_COUNTER_TYPE TestFailures;
+ UNITY_COUNTER_TYPE TestIgnores;
+ UNITY_COUNTER_TYPE CurrentTestFailed;
+ UNITY_COUNTER_TYPE CurrentTestIgnored;
+#ifdef UNITY_INCLUDE_EXEC_TIME
+ UNITY_COUNTER_TYPE CurrentTestStartTime;
+ UNITY_COUNTER_TYPE CurrentTestStopTime;
+#endif
+#ifndef UNITY_EXCLUDE_SETJMP_H
+ jmp_buf AbortFrame;
+#endif
+ } _Expected_Unity;
+#endif
+
+ /* Compare our fake structure's size to the actual structure's size. They
+ * should be the same.
+ *
+ * This accounts for alignment, padding, and packing issues that might come
+ * up between different architectures. */
+ TEST_ASSERT_EQUAL_MESSAGE(sizeof(_Expected_Unity), sizeof(Unity), message);
+}
+
+void testPassShouldEndImmediatelyWithPass(void)
+{
+ TEST_PASS();
+ TEST_FAIL_MESSAGE("We should have passed already and finished this test");
+}
+
+void testPassShouldEndImmediatelyWithPassAndMessage(void)
+{
+ TEST_PASS_MESSAGE("Woohoo! This Automatically Passes!");
+ TEST_FAIL_MESSAGE("We should have passed already and finished this test");
+}
+
+void testMessageShouldDisplayMessageWithoutEndingAndGoOnToPass(void)
+{
+ TEST_MESSAGE("This is just a message");
+ TEST_MESSAGE("This is another message");
+ TEST_PASS();
+}
+
+void testMessageShouldDisplayMessageWithoutEndingAndGoOnToFail(void)
+{
+ TEST_MESSAGE("This is yet another message");
+
+ EXPECT_ABORT_BEGIN
+ TEST_FAIL();
+ VERIFY_FAILS_END
+}
+
+void testTrue(void)
+{
+ TEST_ASSERT(1);
+
+ TEST_ASSERT_TRUE(1);
+}
+
+void testFalse(void)
+{
+ TEST_ASSERT_FALSE(0);
+
+ TEST_ASSERT_UNLESS(0);
+}
+
+void testSingleStatement(void)
+{
+ for(int i = 0; i < 2; i++)
+ {
+ /* TEST_ASSERT_TRUE should expand to a single C statement, minus
+ * the semicolon. This if-else will fail to compile otherwise. */
+ if(i > 0)
+ TEST_ASSERT_TRUE(i);
+ else
+ TEST_ASSERT_FALSE(i);
+ }
+}
+
+void testPreviousPass(void)
+{
+ TEST_ASSERT_EQUAL_INT(0U, Unity.TestFailures);
+}
+
+void testNotVanilla(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT(0);
+ VERIFY_FAILS_END
+}
+
+void testNotTrue(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_TRUE(0);
+ VERIFY_FAILS_END
+}
+
+void testNotFalse(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FALSE(1);
+ VERIFY_FAILS_END
+}
+
+void testNotUnless(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UNLESS(1);
+ VERIFY_FAILS_END
+}
+
+void testNotNotEqual(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL(10, 10);
+ VERIFY_FAILS_END
+}
+
+void testFail(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_FAIL_MESSAGE("Expected for testing");
+ VERIFY_FAILS_END
+}
+
+void testIsNull(void)
+{
+ char* ptr1 = NULL;
+ const char* ptr2 = "hello";
+
+ TEST_ASSERT_NULL(ptr1);
+ TEST_ASSERT_NOT_NULL(ptr2);
+}
+
+void testIsNullShouldFailIfNot(void)
+{
+ const char* ptr1 = "hello";
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NULL(ptr1);
+ VERIFY_FAILS_END
+}
+
+void testNotNullShouldFailIfNULL(void)
+{
+ char* ptr1 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_NULL(ptr1);
+ VERIFY_FAILS_END
+}
+
+void testIsEmpty(void)
+{
+ const char* ptr1 = "\0";
+ const char* ptr2 = "hello";
+
+ TEST_ASSERT_EMPTY(ptr1);
+ TEST_ASSERT_NOT_EMPTY(ptr2);
+}
+
+void testIsEmptyShouldFailIfNot(void)
+{
+ const char* ptr1 = "hello";
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EMPTY(ptr1);
+ VERIFY_FAILS_END
+}
+
+void testNotEmptyShouldFailIfEmpty(void)
+{
+ const char* ptr1 = "\0";
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EMPTY(ptr1);
+ VERIFY_FAILS_END
+}
+
+void testIgnore(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_IGNORE();
+ TEST_FAIL_MESSAGE("This should not be reached");
+ VERIFY_IGNORES_END
+}
+
+void testIgnoreMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_IGNORE_MESSAGE("This is an expected TEST_IGNORE_MESSAGE string!");
+ TEST_FAIL_MESSAGE("This should not be reached");
+ VERIFY_IGNORES_END
+}
+
+void testProtection(void)
+{
+ volatile int mask = 0;
+
+ if (TEST_PROTECT())
+ {
+ mask |= 1;
+ TEST_ABORT();
+ }
+ else
+ {
+ Unity.CurrentTestFailed = 0;
+ mask |= 2;
+ }
+
+ TEST_ASSERT_EQUAL(3, mask);
+}
+
+void testIgnoredAndThenFailInTearDown(void)
+{
+ SetToOneToFailInTearDown = 1;
+ TEST_IGNORE();
+}
+
+void testFailureCountIncrementsAndIsReturnedAtEnd(void)
+{
+#ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+#else
+ UNITY_UINT savedFailures = Unity.TestFailures;
+ Unity.CurrentTestFailed = 1;
+ startPutcharSpy(); /* Suppress output */
+ startFlushSpy();
+ TEST_ASSERT_EQUAL(0, getFlushSpyCalls());
+ UnityConcludeTest();
+ endPutcharSpy();
+ TEST_ASSERT_EQUAL(savedFailures + 1, Unity.TestFailures);
+#if defined(UNITY_OUTPUT_FLUSH) && defined(UNITY_OUTPUT_FLUSH_HEADER_DECLARATION)
+ TEST_ASSERT_EQUAL(1, getFlushSpyCalls());
+#else
+ TEST_ASSERT_EQUAL(0, getFlushSpyCalls());
+#endif
+ endFlushSpy();
+
+ startPutcharSpy(); /* Suppress output */
+ int failures = UnityEnd();
+ Unity.TestFailures--;
+ endPutcharSpy();
+ TEST_ASSERT_EQUAL(savedFailures + 1, failures);
+#endif
+}
+
+/* ===================== THESE TEST WILL RUN IF YOUR CONFIG INCLUDES DETAIL SUPPORT ================== */
+
+void testThatDetailsCanBeHandleOneDetail(void)
+{
+#ifdef UNITY_EXCLUDE_DETAILS
+ TEST_IGNORE();
+#else
+ UNITY_SET_DETAIL("Detail1");
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT_MESSAGE(5, 6, "Should Fail And Say Detail1");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testThatDetailsCanHandleTestFail(void)
+{
+#ifdef UNITY_EXCLUDE_DETAILS
+ TEST_IGNORE();
+#else
+ UNITY_SET_DETAILS("Detail1","Detail2");
+
+ EXPECT_ABORT_BEGIN
+ TEST_FAIL_MESSAGE("Should Fail And Say Detail1 and Detail2");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testThatDetailsCanBeHandleTwoDetails(void)
+{
+#ifdef UNITY_EXCLUDE_DETAILS
+ TEST_IGNORE();
+#else
+ UNITY_SET_DETAILS("Detail1","Detail2");
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8_MESSAGE(7, 8, "Should Fail And Say Detail1 and Detail2");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testThatDetailsCanBeHandleSingleDetailClearingTwoDetails(void)
+{
+#ifdef UNITY_EXCLUDE_DETAILS
+ TEST_IGNORE();
+#else
+ UNITY_SET_DETAILS("Detail1","Detail2");
+ UNITY_SET_DETAIL("DetailNew");
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_MESSAGE("MEH", "GUH", "Should Fail And Say DetailNew");
+ VERIFY_FAILS_END
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_doubles.c b/deps/Unity/test/tests/test_unity_doubles.c
new file mode 100644
index 0000000..0ad9494
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_doubles.c
@@ -0,0 +1,1284 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testDoublesWithinDelta(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_WITHIN(0.00003, 187245.03485, 187245.03488);
+ TEST_ASSERT_DOUBLE_WITHIN(1.0, 187245.0, 187246.0);
+ TEST_ASSERT_DOUBLE_WITHIN(0.05, 9273.2549, 9273.2049);
+ TEST_ASSERT_DOUBLE_WITHIN(0.007, -726.93725, -726.94424);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_NOT_WITHIN(0.05, 9273.2549, 9273.2049);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotWithinDelta(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_NOT_WITHIN(0.05, 9273.2649, 9273.2049);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_WITHIN(0.05, 9273.2649, 9273.2049);
+ VERIFY_FAILS_END
+#endif
+}
+
+
+void testDoublesEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_DOUBLE(187245123456.0, 187245123456.0);
+ TEST_ASSERT_EQUAL_DOUBLE(187241234567.5, 187241234567.6);
+ TEST_ASSERT_EQUAL_DOUBLE(9273.2512345649, 9273.25123455699);
+ TEST_ASSERT_EQUAL_DOUBLE(-726.12345693724, -726.1234569374);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(-726.12345693724, -726.1234569374);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(9273.9649, 9273.0049);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(9273.9649, 9273.0049);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(-9273.9649, -9273.0049);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(-9273.9649, -9273.0049);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(-9273.0049, -9273.9649);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(-9273.0049, -9273.9649);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualActualNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(85.963, 0.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(85.963, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualExpectedNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(0.0 / d_zero, 85.963);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(0.0 / d_zero, 85.963);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesEqualBothNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualInfNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(1.0 / d_zero, 0.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(1.0 / d_zero, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualNaNInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(0.0 / d_zero, 1.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(0.0 / d_zero, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualActualInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(321.642, 1.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(321.642, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualExpectedInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(1.0 / d_zero, 321.642);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(1.0 / d_zero, 321.642);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotEqualPlusMinusInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_DOUBLE(1.0 / d_zero, -1.0 / d_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE(1.0 / d_zero, -1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesGreaterThan(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0, 2.0);
+ TEST_ASSERT_GREATER_THAN_DOUBLE(-1.0, 1.0);
+ TEST_ASSERT_GREATER_THAN_DOUBLE(-2.0, -1.0);
+#endif
+}
+
+void testDoublesGreaterThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0, 1.0 / d_zero);
+ TEST_ASSERT_GREATER_THAN_DOUBLE(-1.0 / d_zero, 1.0 / d_zero);
+ TEST_ASSERT_GREATER_THAN_DOUBLE(-1.0 / d_zero, 1.0);
+#endif
+}
+
+void testDoublesNotGreaterThan(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(2.0, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(0.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanInfActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0, -1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterThanBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_DOUBLE(-1.0 / d_zero, -1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesGreaterOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0, 2.0);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(2.0, 2.0);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-1.0, 1.0);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-2.0, -1.0);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-2.0, -2.0);
+#endif
+}
+
+void testDoublesGreaterOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0, 1.0 / d_zero);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-1.0 / d_zero, 1.0 / d_zero);
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-1.0 / d_zero, 1.0);
+#endif
+}
+
+void testDoublesNotGreaterOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(2.0, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterOrEqualNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterOrEqualNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(0.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesGreaterOrEqualNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+#endif
+}
+
+void testDoublesNotGreaterOrEqualInfActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotGreaterOrEqualNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0, -1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesGreaterOrEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+#endif
+}
+
+void testDoublesGreaterOrEqualBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_DOUBLE(-1.0 / d_zero, -1.0 / d_zero);
+#endif
+}
+
+void testDoublesLessThan(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_THAN_DOUBLE(2.0, 1.0);
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0, -1.0);
+ TEST_ASSERT_LESS_THAN_DOUBLE(-1.0, -2.0);
+#endif
+}
+
+void testDoublesLessThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0 / d_zero, 1.0);
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0 / d_zero, -1.0 / d_zero);
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0, -1.0 / d_zero);
+#endif
+}
+
+void testDoublesNotLessThan(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0, 2.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(0.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(-1.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessThanBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_DOUBLE(-1.0 / d_zero, -1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesLessOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(2.0, 1.0);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(2.0, 2.0);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0, -1.0);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(-1.0, -2.0);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(-2.0, -2.0);
+#endif
+}
+
+void testDoublesLessOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0 / d_zero, 1.0);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0 / d_zero, -1.0 / d_zero);
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0, -1.0 / d_zero);
+#endif
+}
+
+void testDoublesNotLessOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0, 2.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessOrEqualNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0, 0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessOrEqualNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(0.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesLessOrEqualNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(0.0 / d_zero, 0.0 / d_zero);
+#endif
+}
+
+void testDoublesNotLessOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0, 1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesNotLessOrEqualNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(-1.0 / d_zero, 1.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublesLessOrEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(1.0 / d_zero, 1.0 / d_zero);
+#endif
+}
+
+void testDoublesLessOrEqualBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_DOUBLE(-1.0 / d_zero, -1.0 / d_zero);
+#endif
+}
+
+void testDoubleIsPosInf1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_INF(2.0 / d_zero);
+#endif
+}
+
+void testDoubleIsPosInf2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NOT_INF(2.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNegInf1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_NEG_INF(-3.0 / d_zero);
+#endif
+}
+
+void testDoubleIsNegInf2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NOT_NEG_INF(-3.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNotPosInf1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_INF(2.0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNotPosInf2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_NOT_INF(2.0);
+#endif
+}
+
+void testDoubleIsNotNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NEG_INF(-999.876);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNan1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_NAN(0.0 / d_zero);
+#endif
+}
+
+void testDoubleIsNan2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NOT_NAN(0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNotNan1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NAN(234.9);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNotNan2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_NOT_NAN(234.9);
+#endif
+}
+
+void testDoubleInfIsNotNan(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NAN(1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleNanIsNotInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_INF(0.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsDeterminate1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_DETERMINATE(0.0);
+ TEST_ASSERT_DOUBLE_IS_DETERMINATE(123.3);
+ TEST_ASSERT_DOUBLE_IS_DETERMINATE(-88.3);
+#endif
+}
+
+void testDoubleIsDeterminate2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(-88.3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleIsNotDeterminate1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(1.0 / d_zero);
+ TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(-1.0 / d_zero);
+ TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(0.0 / d_zero);
+#endif
+}
+
+void testDoubleIsNotDeterminate2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_IS_DETERMINATE(-1.0 / d_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleTraitFailsOnInvalidTrait(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ UnityAssertDoubleSpecial(1.0, NULL, __LINE__, UNITY_FLOAT_INVALID_TRAIT);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualDoubleArrays(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, -8.0, 25.4, -0.123};
+ double p1[] = {1.0, -8.0, 25.4, -0.123};
+ double p2[] = {1.0, -8.0, 25.4, -0.2};
+ double p3[] = {1.0, -23.0, 25.0, -0.26};
+
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p3, 1);
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(NULL, NULL, 1);
+#endif
+}
+
+void testNotEqualDoubleArraysExpectedNull(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double* p0 = NULL;
+ double p1[] = {1.0, 8.0, 25.4, 0.252};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArraysActualNull(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 8.0, 25.4, 0.253};
+ double* p1 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArrays1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 8.0, 25.4, 0.25666666667};
+ double p1[] = {1.0, 8.0, 25.4, 0.25666666666};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArrays2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 8.0, 25.4, 0.253};
+ double p1[] = {2.0, 8.0, 25.4, 0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArrays3(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 8.0, 25.4, 0.253};
+ double p1[] = {1.0, 8.0, 25.5, 0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArraysNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-1.0, -8.0, -25.4, -0.2566666667};
+ double p1[] = {-1.0, -8.0, -25.4, -0.2566666666};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArraysNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-1.0, -8.0, -25.4, -0.253};
+ double p1[] = {-2.0, -8.0, -25.4, -0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleArraysNegative3(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-1.0, -8.0, -25.4, -0.253};
+ double p1[] = {-1.0, -8.0, -25.5, -0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualDoubleArraysNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 0.0 / d_zero, 25.4, 0.253};
+ double p1[] = {1.0, 0.0 / d_zero, 25.4, 0.253};
+
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+#endif
+}
+
+void testEqualDoubleArraysInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 1.0 / d_zero, 25.4, 0.253};
+ double p1[] = {1.0, 1.0 / d_zero, 25.4, 0.253};
+
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 4);
+#endif
+}
+
+void testNotEqualDoubleArraysLengthZero(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[1] = {0.0};
+ double p1[1] = {0.0};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_DOUBLE_ARRAY(p0, p1, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoubleArraysWithin(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, -8.0, 25.4, -0.123};
+ double p1[] = {1.0, -8.0, 25.4, -0.123};
+ double p2[] = {1.0, -8.0, 25.4, -0.2};
+ double p3[] = {1.0, -23.0, 25.0, -0.26};
+ double p4[] = {2.0, -9.0, 26.2, 0.26};
+ double p5[] = {-1.0, -7.0, 29.0, 2.6};
+
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p0, 1);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p0, 4);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p1, 4);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p2, 3);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p3, 1);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p4, 1);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, p0, p4, 4);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(2.0, p0, p5, 1);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(2.0, p0, p5, 2);
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(1.0, NULL, NULL, 1);
+#endif
+}
+
+void testDoubleArraysWithinUnusualDelta(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-INFINITY, -8.0, 25.4, -0.123};
+ double p1[] = {INFINITY, 10.1};
+
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(INFINITY, p0, p1, 2);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_DOUBLE_ARRAY_WITHIN(NAN, p0, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualDoubleEachEqual(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 1.0, 1.0, 1.0};
+ double p1[] = {-0.123, -0.123, -0.123, -0.123};
+ double p2[] = {25.4, 25.4, 25.4, -0.2};
+ double p3[] = {1.0, -23.0, 25.0, -0.26};
+
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(1.0, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(1.0, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(-0.123, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(25.4, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(1.0, p3, 1);
+#endif
+}
+
+void testNotEqualDoubleEachEqualActualNull(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double* p0 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(5, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqual1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {0.253, 8.0, 0.253, 0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(0.253, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqual2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {8.0, 8.0, 8.0, 0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(8.0, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqual3(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0, 1.0, 1.0, 0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(1.0, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqualNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-1.0, -0.253, -0.253, -0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(-0.253, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqualNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-25.4, -8.0, -25.4, -25.4};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(-25.4, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualDoubleEachEqualNegative3(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {-8.0, -8.0, -8.0, -0.253};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(-8.0, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualDoubleEachEqualNaN(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {0.0 / d_zero, 0.0 / d_zero, 0.0 / d_zero, 0.0 / d_zero};
+
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(0.0 / d_zero, p0, 4);
+#endif
+}
+
+void testEqualDoubleEachEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[] = {1.0 / d_zero, 1.0 / d_zero, 25.4, 0.253};
+
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(1.0 / d_zero, p0, 2);
+#endif
+}
+
+void testNotEqualDoubleEachEqualLengthZero(void)
+{
+#ifdef UNITY_EXCLUDE_DOUBLE
+ TEST_IGNORE();
+#else
+ double p0[1] = {0.0};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_DOUBLE(0.0, p0, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testDoublePrinting(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || defined(UNITY_EXCLUDE_DOUBLE) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0", 0.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("4.99e-07", 0.000000499);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("5.0000005e-07", 0.00000050000005);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0.100469499", 0.100469499);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1", 0.9999999995); /*Rounding to int place*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1", 1.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.25", 1.25);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("7.99999999", 7.99999999); /*Not rounding*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.0000002", 16.0000002);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.0000004", 16.0000004);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.0000006", 16.0000006);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("999999999", 999999999.0); /*Last full print integer*/
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0", -0.0); /* -0 no supported on all targets */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-4.99e-07", -0.000000499);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-5.0000005e-07", -0.00000050000005);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-0.100469499", -0.100469499);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1", -0.9999999995); /*Rounding to int place*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1", -1.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1.25", -1.25);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-7.99999999", -7.99999999); /*Not rounding*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.0000002", -16.0000002);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.0000004", -16.0000004);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.0000006", -16.0000006);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-999999999", -999999999.0); /*Last full print integer*/
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0.1004695", 0.10046949999999999);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("4.2949673e+09", 4294967295.9);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("4.2949673e+09", 4294967296.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1e+10", 9999999995.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("9.00719925e+15", 9007199254740990.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("7e+100", 7.0e+100);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("3e+200", 3.0e+200);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("9.23456789e+300", 9.23456789e+300);
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-0.1004695", -0.10046949999999999);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-4.2949673e+09", -4294967295.9);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-4.2949673e+09", -4294967296.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-7e+100", -7.0e+100);
+#endif
+}
+
+void testDoublePrintingRoundTiesToEven(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || defined(UNITY_EXCLUDE_DOUBLE) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ #ifdef UNITY_ROUND_TIES_AWAY_FROM_ZERO
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.00000001e+10", 10000000050.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("9.00719925e+15", 9007199245000000.0);
+ #else /* Default to Round ties to even */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1e+10", 10000000050.0);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("9.00719924e+15", 9007199245000000.0);
+ #endif
+#endif
+}
+
+void testDoublePrintingInfinityAndNaN(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || defined(UNITY_EXCLUDE_DOUBLE) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("inf", 1.0 / d_zero);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-inf", -1.0 / d_zero);
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("nan", 0.0 / d_zero);
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_floats.c b/deps/Unity/test/tests/test_unity_floats.c
new file mode 100644
index 0000000..9e92f96
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_floats.c
@@ -0,0 +1,1394 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testFloatsWithinDelta(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_WITHIN(0.00003f, 187245.03485f, 187245.03488f);
+ TEST_ASSERT_FLOAT_WITHIN(1.0f, 187245.0f, 187246.0f);
+ TEST_ASSERT_FLOAT_WITHIN(0.05f, 9273.2549f, 9273.2049f);
+ TEST_ASSERT_FLOAT_WITHIN(0.007f, -726.93724f, -726.94424f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_NOT_WITHIN(0.05f, 9273.2549f, 9273.2049f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotWithinDelta(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_NOT_WITHIN(0.05f, 9273.2649f, 9273.2049f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_WITHIN(0.05f, 9273.2649f, 9273.2049f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_FLOAT(187245.0f, 187246.0f);
+ TEST_ASSERT_EQUAL_FLOAT(18724.5f, 18724.6f);
+ TEST_ASSERT_EQUAL_FLOAT(9273.2549f, 9273.2599f);
+ TEST_ASSERT_EQUAL_FLOAT(-726.93724f, -726.9374f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_FLOAT(-726.93724f, -726.9374f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(9273.9649f, 9273.0049f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(9273.9649f, 9273.0049f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(-9273.9649f, -9273.0049f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(-9273.9649f, -9273.0049f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(-9273.0049f, -9273.9649f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(-9273.0049f, -9273.9649f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualActualNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(85.963f, 0.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(85.963f, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualExpectedNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(0.0f / f_zero, 85.963f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(0.0f / f_zero, 85.963f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsEqualBothNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualInfNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(1.0f / f_zero, 0.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(1.0f / f_zero, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualNaNInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(0.0f / f_zero, 1.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(0.0f / f_zero, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualActualInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(321.642f, 1.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(321.642f, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualExpectedInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(1.0f / f_zero, 321.642f);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(1.0f / f_zero, 321.642f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotEqualPlusMinusInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_NOT_EQUAL_FLOAT(1.0f / f_zero, -1.0f / f_zero);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT(1.0f / f_zero, -1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsGreaterThan(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f, 2.0f);
+ TEST_ASSERT_GREATER_THAN_FLOAT(-1.0f, 1.0f);
+ TEST_ASSERT_GREATER_THAN_FLOAT(-2.0f, -1.0f);
+#endif
+}
+
+void testFloatsGreaterThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f, 1.0f / f_zero);
+ TEST_ASSERT_GREATER_THAN_FLOAT(-1.0f / f_zero, 1.0f / f_zero);
+ TEST_ASSERT_GREATER_THAN_FLOAT(-1.0f / f_zero, 1.0f);
+#endif
+}
+
+void testFloatsNotGreaterThan(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(2.0f, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(0.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanInfActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f, -1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterThanBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_FLOAT(-1.0f / f_zero, -1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsGreaterOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f, 2.0f);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(2.0f, 2.0f);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-1.0f, 1.0f);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-2.0f, -1.0f);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-2.0f, -2.0f);
+#endif
+}
+
+void testFloatsGreaterOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f, 1.0f / f_zero);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-1.0f / f_zero, 1.0f / f_zero);
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-1.0f / f_zero, 1.0f);
+#endif
+}
+
+void testFloatsNotGreaterOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(2.0f, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterOrEqualNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterOrEqualNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(0.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsGreaterOrEqualNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+#endif
+}
+
+void testFloatsNotGreaterOrEqualInfActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotGreaterOrEqualNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f, -1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsGreaterOrEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+#endif
+}
+
+void testFloatsGreaterOrEqualBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_GREATER_OR_EQUAL_FLOAT(-1.0f / f_zero, -1.0f / f_zero);
+#endif
+}
+
+void testFloatsLessThan(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_THAN_FLOAT(2.0f, 1.0f);
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f, -1.0f);
+ TEST_ASSERT_LESS_THAN_FLOAT(-1.0f, -2.0f);
+#endif
+}
+
+void testFloatsLessThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f / f_zero, 1.0f);
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f / f_zero, -1.0f / f_zero);
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f, -1.0f / f_zero);
+#endif
+}
+
+void testFloatsNotLessThan(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f, 2.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(0.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(-1.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessThanBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_FLOAT(-1.0f / f_zero, -1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+void testFloatsLessOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(2.0f, 1.0f);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(2.0f, 2.0f);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f, -1.0f);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(-1.0f, -2.0f);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(-2.0f, -2.0f);
+#endif
+}
+
+void testFloatsLessOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f / f_zero, 1.0f);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f / f_zero, -1.0f / f_zero);
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f, -1.0f / f_zero);
+#endif
+}
+
+void testFloatsNotLessOrEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f, 2.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessOrEqualNanActual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f, 0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessOrEqualNanThreshold(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(0.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsLessOrEqualNanBoth(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(0.0f / f_zero, 0.0f / f_zero);
+#endif
+}
+
+void testFloatsNotLessOrEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f, 1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsNotLessOrEqualNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(-1.0f / f_zero, 1.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatsLessOrEqualBothInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(1.0f / f_zero, 1.0f / f_zero);
+#endif
+}
+
+void testFloatsLessOrEqualBothNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_LESS_OR_EQUAL_FLOAT(-1.0f / f_zero, -1.0f / f_zero);
+#endif
+}
+
+void testFloatIsPosInf1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_INF(2.0f / f_zero);
+#endif
+}
+
+void testFloatIsPosInf2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NOT_INF(2.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNegInf1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_NEG_INF(-3.0f / f_zero);
+#endif
+}
+
+void testFloatIsNegInf2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NOT_NEG_INF(-3.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNotPosInf1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_INF(2.0f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNotPosInf2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_NOT_INF(2.0f);
+#endif
+}
+
+void testFloatIsNotNegInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NEG_INF(-999.876f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNan1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_NAN(0.0f / f_zero);
+#endif
+}
+
+void testFloatIsNan2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NOT_NAN(0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNotNan1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NAN(234.9f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNotNan2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_NOT_NAN(234.9f);
+#endif
+}
+
+void testFloatInfIsNotNan(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NAN(1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatNanIsNotInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_INF(0.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsDeterminate1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_DETERMINATE(0.0f);
+ TEST_ASSERT_FLOAT_IS_DETERMINATE(123.3f);
+ TEST_ASSERT_FLOAT_IS_DETERMINATE(-88.3f);
+#endif
+}
+
+void testFloatIsDeterminate2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_NOT_DETERMINATE(-88.3f);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatIsNotDeterminate1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_FLOAT_IS_NOT_DETERMINATE(1.0f / f_zero);
+ TEST_ASSERT_FLOAT_IS_NOT_DETERMINATE(-1.0f / f_zero);
+ TEST_ASSERT_FLOAT_IS_NOT_DETERMINATE(0.0f / f_zero);
+#endif
+}
+
+void testFloatIsNotDeterminate2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_IS_DETERMINATE(-1.0f / f_zero);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatTraitFailsOnInvalidTrait(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ UnityAssertFloatSpecial(1.0f, NULL, __LINE__, UNITY_FLOAT_INVALID_TRAIT);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualFloatArrays(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, -8.0f, 25.4f, -0.123f};
+ float p1[] = {1.0f, -8.0f, 25.4f, -0.123f};
+ float p2[] = {1.0f, -8.0f, 25.4f, -0.2f};
+ float p3[] = {1.0f, -23.0f, 25.0f, -0.26f};
+
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p0, 1);
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p0, 4);
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p2, 3);
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p3, 1);
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(NULL, NULL, 1);
+#endif
+}
+
+void testNotEqualFloatArraysExpectedNull(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float* p0 = NULL;
+ float p1[] = {1.0f, 8.0f, 25.4f, 0.252f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArraysActualNull(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 8.0f, 25.4f, 0.253f};
+ float* p1 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArrays1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 8.0f, 25.4f, 0.253f};
+ float p1[] = {1.0f, 8.0f, 25.4f, 0.252f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArrays2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 8.0f, 25.4f, 0.253f};
+ float p1[] = {2.0f, 8.0f, 25.4f, 0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArrays3(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 8.0f, 25.4f, 0.253f};
+ float p1[] = {1.0f, 8.0f, 25.5f, 0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArraysNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-1.0f, -8.0f, -25.4f, -0.253f};
+ float p1[] = {-1.0f, -8.0f, -25.4f, -0.252f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArraysNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-1.0f, -8.0f, -25.4f, -0.253f};
+ float p1[] = {-2.0f, -8.0f, -25.4f, -0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatArraysNegative3(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-1.0f, -8.0f, -25.4f, -0.253f};
+ float p1[] = {-1.0f, -8.0f, -25.5f, -0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualFloatArraysNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 0.0f / f_zero, 25.4f, 0.253f};
+ float p1[] = {1.0f, 0.0f / f_zero, 25.4f, 0.253f};
+
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+#endif
+}
+
+void testEqualFloatArraysInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 1.0f / f_zero, 25.4f, 0.253f};
+ float p1[] = {1.0f, 1.0f / f_zero, 25.4f, 0.253f};
+
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 4);
+#endif
+}
+
+void testNotEqualFloatArraysLengthZero(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[1] = {0.0f};
+ float p1[1] = {0.0f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_FLOAT_ARRAY(p0, p1, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatArraysWithin(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, -8.0f, 25.4f, -0.123f};
+ float p1[] = {1.0f, -8.0f, 25.4f, -0.123f};
+ float p2[] = {1.0f, -8.0f, 25.4f, -0.2f};
+ float p3[] = {1.0f, -23.0f, 25.0f, -0.26f};
+ float p4[] = {2.0f, -9.0f, 26.2f, 0.26f};
+ float p5[] = {-1.0f, -7.0f, 29.0f, 2.6f};
+
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p0, 1);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p0, 4);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p1, 4);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p2, 3);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p3, 1);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p4, 1);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, p0, p4, 4);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(2.0f, p0, p5, 1);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(2.0f, p0, p5, 2);
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(1.0f, NULL, NULL, 1);
+#endif
+}
+
+void testFloatArraysWithinUnusualDelta(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {(float)-INFINITY, -8.0f, 25.4f, -0.123f};
+ float p1[] = {(float)INFINITY, 10.1f};
+
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(INFINITY, p0, p1, 2);
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_FLOAT_ARRAY_WITHIN(NAN, p0, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualFloatEachEqual(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 1.0f, 1.0f, 1.0f};
+ float p1[] = {-0.123f, -0.123f, -0.123f, -0.123f};
+ float p2[] = {25.4f, 25.4f, 25.4f, -0.2f};
+ float p3[] = {1.0f, -23.0f, 25.0f, -0.26f};
+
+ TEST_ASSERT_EACH_EQUAL_FLOAT(1.0f, p0, 1);
+ TEST_ASSERT_EACH_EQUAL_FLOAT(1.0f, p0, 4);
+ TEST_ASSERT_EACH_EQUAL_FLOAT(-0.123f, p1, 4);
+ TEST_ASSERT_EACH_EQUAL_FLOAT(25.4f, p2, 3);
+ TEST_ASSERT_EACH_EQUAL_FLOAT(1.0f, p3, 1);
+#endif
+}
+
+void testNotEqualFloatEachEqualActualNull(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float* p0 = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(5, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqual1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {0.253f, 8.0f, 0.253f, 0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(0.253f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqual2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {8.0f, 8.0f, 8.0f, 0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(8.0f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqual3(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f, 1.0f, 1.0f, 0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(1.0f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqualNegative1(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-1.0f, -0.253f, -0.253f, -0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(-0.253f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqualNegative2(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-25.4f, -8.0f, -25.4f, -25.4f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(-25.4f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualFloatEachEqualNegative3(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {-8.0f, -8.0f, -8.0f, -0.253f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(-8.0f, p0, 4);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testEqualFloatEachEqualNaN(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {0.0f / f_zero, 0.0f / f_zero, 0.0f / f_zero, 0.0f / f_zero};
+
+ TEST_ASSERT_EACH_EQUAL_FLOAT(0.0f / f_zero, p0, 4);
+#endif
+}
+
+void testEqualFloatEachEqualInf(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[] = {1.0f / f_zero, 1.0f / f_zero, 25.4f, 0.253f};
+
+ TEST_ASSERT_EACH_EQUAL_FLOAT(1.0f / f_zero, p0, 2);
+#endif
+}
+
+void testNotEqualFloatEachEqualLengthZero(void)
+{
+#ifdef UNITY_EXCLUDE_FLOAT
+ TEST_IGNORE();
+#else
+ float p0[1] = {0.0f};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_FLOAT(0.0f, p0, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testFloatPrinting(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || defined(UNITY_INCLUDE_DOUBLE) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0", 0.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("4.99e-07", 0.000000499f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0.1004695", 0.100469499f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("2", 1.9999995f); /*Rounding to int place*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1", 1.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.25", 1.25f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("7.999999", 7.999999f); /*Not rounding*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.00002", 16.00002f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.00004", 16.00004f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("16.00006", 16.00006f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("9999999", 9999999.0f); /*Last full print integer*/
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-0", -0.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-4.99e-07", -0.000000499f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-0.1004695", -0.100469499f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-2", -1.9999995f); /*Rounding to int place*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1", -1.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1.25", -1.25f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-7.999999", -7.999999f); /*Not rounding*/
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.00002", -16.00002f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.00004", -16.00004f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-16.00006", -16.00006f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-9999999", -9999999.0f); /*Last full print integer*/
+
+ /* Fails, prints "4.294968e+09" due to FP math imprecision
+ * TEST_ASSERT_EQUAL_PRINT_FLOATING("4.294967e+09", 4294967296.0f); */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("5e+09", 5000000000.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("8e+09", 8.0e+09f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("8.309999e+09", 8309999104.0f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1e+10", 1.0e+10f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1e+10", 10000000000.0f);
+ /* Some compilers have trouble with inexact float constants, a float cast works generally */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.000055e+10", (float)1.000055e+10f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.1e+38", (float)1.10000005e+38f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("1.635299e+10", 1.63529943e+10f);
+ /* Fails, prints "3.402824e+38" due to FP math imprecision
+ * TEST_ASSERT_EQUAL_PRINT_FLOATING("3.402823e+38", 3.40282346638e38f); */
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-1e+10", -1.0e+10f);
+ /* Fails, prints "-3.402824e+38" due to FP math imprecision
+ * TEST_ASSERT_EQUAL_PRINT_FLOATING("-3.402823e+38", -3.40282346638e38f); */
+#endif
+}
+
+void testFloatPrintingRoundTiesToEven(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || defined(UNITY_INCLUDE_DOUBLE) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ #ifdef UNITY_ROUND_TIES_AWAY_FROM_ZERO
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0.0004882813", 0.00048828125f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("488281.3", 488281.25f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("5.000001e-07", 0.00000050000005f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-5.000001e-07", -0.00000050000005f);
+ #else /* Default to Round ties to even */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("0.0004882812", 0.00048828125f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("488281.2", 488281.25f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("5e-07", 0.00000050000005f);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-5e-07", -0.00000050000005f);
+ #endif
+#endif
+}
+
+void testFloatPrintingInfinityAndNaN(void)
+{
+#if defined(UNITY_EXCLUDE_FLOAT_PRINT) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("inf", 1.0f / f_zero);
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("-inf", -1.0f / f_zero);
+
+ TEST_ASSERT_EQUAL_PRINT_FLOATING("nan", 0.0f / f_zero);
+#endif
+}
+
+#if defined(UNITY_TEST_ALL_FLOATS_PRINT_OK) && defined(USING_OUTPUT_SPY)
+#ifdef UNITY_INCLUDE_DOUBLE
+static void printFloatValue(float f)
+{
+ char expected[18];
+
+ startPutcharSpy();
+ UnityPrintFloat(f);
+
+ sprintf(expected, "%.9g", f);
+ /* We print all NaN's as "nan", not "-nan" */
+ if (strcmp(expected, "-nan") == 0) strcpy(expected, "nan");
+
+ if (strcmp(expected, getBufferPutcharSpy()))
+ {
+ /* Fail with diagnostic printing */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING(expected, f);
+ }
+}
+#else
+static void printFloatValue(float f)
+{
+ char expected[18];
+ char expected_lower[18];
+ char expected_lower2[18];
+ char expected_lower3[18];
+ char expected_higher[18];
+ char expected_higher2[18];
+ char expected_higher3[18];
+
+ startPutcharSpy();
+ UnityPrintFloat(f);
+
+ sprintf(expected, "%.7g", f);
+ /* We print all NaN's as "nan", not "-nan" */
+ if (strcmp(expected, "-nan") == 0) strcpy(expected, "nan");
+
+ strcpy(expected_lower, expected);
+ strcpy(expected_lower2, expected);
+ strcpy(expected_lower3, expected);
+ strcpy(expected_higher, expected);
+ strcpy(expected_higher2, expected);
+ strcpy(expected_higher3, expected);
+
+ /* Allow for rounding differences in the last digit */
+ double lower = (double)f * 0.99999995;
+ double higher = (double)f * 1.00000005;
+
+ if(isfinite(lower)) sprintf(expected_lower, "%.7g", lower);
+ if(isfinite(higher)) sprintf(expected_higher, "%.7g", higher);
+
+ /* Outside [1,10000000] allow for relative error of +/-2.5e-7 */
+ if (f < 1.0 || f > 10000000)
+ {
+ double lower2 = (double)f * 0.99999985;
+ double lower3 = (double)f * 0.99999975;
+ double higher2 = (double)f * 1.00000015;
+ double higher3 = (double)f * 1.00000025;
+
+ if (isfinite(lower2)) sprintf(expected_lower2, "%.7g", lower2);
+ if (isfinite(lower3)) sprintf(expected_lower3, "%.7g", lower3);
+ if (isfinite(higher2)) sprintf(expected_higher2, "%.7g", higher2);
+ if (isfinite(higher3)) sprintf(expected_higher3, "%.7g", higher3);
+ }
+
+ if (strcmp(expected, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_lower, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_lower2, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_lower3, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_higher, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_higher2, getBufferPutcharSpy()) != 0 &&
+ strcmp(expected_higher3, getBufferPutcharSpy()) != 0)
+ {
+ /* Fail with diagnostic printing */
+ TEST_ASSERT_EQUAL_PRINT_FLOATING(expected, f);
+ }
+}
+#endif
+#endif
+
+void testFloatPrintingRandomSamples(void)
+{
+#if !defined(UNITY_TEST_ALL_FLOATS_PRINT_OK) || !defined(USING_OUTPUT_SPY)
+ TEST_IGNORE();
+#else
+ union { float f_value; uint32_t int_value; } u;
+
+ /* These values are not covered by the MINSTD generator */
+ u.int_value = 0x00000000; printFloatValue(u.f_value);
+ u.int_value = 0x80000000; printFloatValue(u.f_value);
+ u.int_value = 0x7fffffff; printFloatValue(u.f_value);
+ u.int_value = 0xffffffff; printFloatValue(u.f_value);
+
+ uint32_t a = 1;
+ for(int num_tested = 0; num_tested < 1000000; num_tested++)
+ {
+ /* MINSTD pseudo-random number generator */
+ a = (uint32_t)(((uint64_t)a * 48271u) % 2147483647u);
+
+ /* MINSTD does not set the highest bit; test both possibilities */
+ u.int_value = a; printFloatValue(u.f_value);
+ u.int_value = a | 0x80000000; printFloatValue(u.f_value);
+ }
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_integers.c b/deps/Unity/test/tests/test_unity_integers.c
new file mode 100644
index 0000000..d615e5f
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_integers.c
@@ -0,0 +1,2862 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testNotEqualInts(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT(3982, 3983);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualInt8s(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT8(-127, -126);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualChars(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_CHAR('A', 'a');
+ VERIFY_FAILS_END
+}
+
+void testNotEqualInt16s(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT16(-16383, -16382);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualInt32s(void)
+{
+ EXPECT_ABORT_BEGIN
+ /*use largest 32 bit negative to test printability*/
+ /*note: (-2147483647 - 1) is used instead of -2147483648 because of C90 casting rules */
+ TEST_ASSERT_EQUAL_INT32(-2147483647, (-2147483647 - 1));
+ VERIFY_FAILS_END
+}
+
+void testNotEqualBits(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_BITS(0xFF00, 0x5555, 0x5A55);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUInts(void)
+{
+ UNITY_UINT16 v0, v1;
+
+ v0 = 9000;
+ v1 = 9001;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUInt8s(void)
+{
+ UNITY_UINT8 v0, v1;
+
+ v0 = 254;
+ v1 = 255;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT8(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUInt16s(void)
+{
+ UNITY_UINT16 v0, v1;
+
+ v0 = 65535u;
+ v1 = 65534u;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT16(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUInt32s(void)
+{
+ UNITY_UINT32 v0, v1;
+
+ v0 = 4294967295u;
+ v1 = 4294967294u;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT32(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex8s(void)
+{
+ UNITY_UINT8 v0, v1;
+
+ v0 = 0x23;
+ v1 = 0x22;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex8sIfSigned(void)
+{
+ UNITY_INT8 v0, v1;
+
+ v0 = -2;
+ v1 = 2;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX8(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex16s(void)
+{
+ UNITY_UINT16 v0, v1;
+
+ v0 = 0x1234;
+ v1 = 0x1235;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX16(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex16sIfSigned(void)
+{
+ UNITY_INT16 v0, v1;
+
+ v0 = -1024;
+ v1 = -1028;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX16(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex32s(void)
+{
+ UNITY_UINT32 v0, v1;
+
+ v0 = 900000;
+ v1 = 900001;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHex32sIfSigned(void)
+{
+ UNITY_INT32 v0, v1;
+
+ v0 = -900000;
+ v1 = 900001;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX32(v0, v1);
+ VERIFY_FAILS_END
+}
+
+void testEqualInts(void)
+{
+ int v0, v1;
+ int *p0, *p1;
+
+ v0 = 19467;
+ v1 = 19467;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT(1837, 1837);
+ TEST_ASSERT_EQUAL_INT(-27365, -27365);
+ TEST_ASSERT_EQUAL_INT(v0, v1);
+ TEST_ASSERT_EQUAL_INT(19467, v1);
+ TEST_ASSERT_EQUAL_INT(v0, 19467);
+ TEST_ASSERT_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_EQUAL_INT(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT(*p0, 19467);
+}
+
+void testEqualInt8s(void)
+{
+ UNITY_INT8 v0, v1;
+ UNITY_INT8 *p0, *p1;
+
+ v0 = 0x22;
+ v1 = 0x22;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT8(0x22, 0x22);
+ TEST_ASSERT_EQUAL_INT8(v0, v1);
+ TEST_ASSERT_EQUAL_INT8(0x22, v1);
+ TEST_ASSERT_EQUAL_INT8(v0, 0x22);
+ TEST_ASSERT_EQUAL_INT8(*p0, v1);
+ TEST_ASSERT_EQUAL_INT8(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT8(*p0, 0x22);
+}
+
+void testEqualInt8sWhenThereAreDifferencesOutside8Bits(void)
+{
+ TEST_ASSERT_EQUAL_INT8(0x321,0x421);
+ TEST_ASSERT_EQUAL_INT8(0xFF21,0x0021);
+}
+
+void testEqualChars(void)
+{
+ char v0, v1;
+ char *p0, *p1;
+
+ v0 = 'A';
+ v1 = 'A';
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_CHAR('A', 'A');
+ TEST_ASSERT_EQUAL_CHAR(v0, v1);
+ TEST_ASSERT_EQUAL_CHAR('A', v1);
+ TEST_ASSERT_EQUAL_CHAR(v0, 'A');
+ TEST_ASSERT_EQUAL_CHAR(*p0, v1);
+ TEST_ASSERT_EQUAL_CHAR(*p0, *p1);
+ TEST_ASSERT_EQUAL_CHAR(*p0, 'A');
+}
+
+void testEqualCharsWhenThereAreDifferencesOutside8Bits(void)
+{
+ TEST_ASSERT_EQUAL_CHAR(0x321,0x421);
+ TEST_ASSERT_EQUAL_CHAR(0xFF21,0x0021);
+}
+
+
+void testEqualInt16s(void)
+{
+ UNITY_INT16 v0, v1;
+ UNITY_INT16 *p0, *p1;
+
+ v0 = 0x7876;
+ v1 = 0x7876;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT16(0x7876, 0x7876);
+ TEST_ASSERT_EQUAL_INT16(v0, v1);
+ TEST_ASSERT_EQUAL_INT16(0x7876, v1);
+ TEST_ASSERT_EQUAL_INT16(v0, 0x7876);
+ TEST_ASSERT_EQUAL_INT16(*p0, v1);
+ TEST_ASSERT_EQUAL_INT16(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT16(*p0, 0x7876);
+}
+
+void testEqualInt16sNegatives(void)
+{
+ UNITY_INT16 v0, v1;
+ UNITY_INT16 *p0, *p1;
+
+ v0 = -7876;
+ v1 = -7876;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT16(-7876, -7876);
+ TEST_ASSERT_EQUAL_INT16(v0, v1);
+ TEST_ASSERT_EQUAL_INT16(-7876, v1);
+ TEST_ASSERT_EQUAL_INT16(v0, -7876);
+ TEST_ASSERT_EQUAL_INT16(*p0, v1);
+ TEST_ASSERT_EQUAL_INT16(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT16(*p0, -7876);
+}
+
+void testEqualInt16sWhenThereAreDifferencesOutside16Bits(void)
+{
+ TEST_ASSERT_EQUAL_INT16(0x54321,0x64321);
+ TEST_ASSERT_EQUAL_INT16(0xFFFF4321,0x00004321);
+}
+
+void testEqualInt32s(void)
+{
+ UNITY_INT32 v0, v1;
+ UNITY_INT32 *p0, *p1;
+
+ v0 = 0x78760000;
+ v1 = 0x78760000;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT32(0x78760000, 0x78760000);
+ TEST_ASSERT_EQUAL_INT32(v0, v1);
+ TEST_ASSERT_EQUAL_INT32(0x78760000, v1);
+ TEST_ASSERT_EQUAL_INT32(v0, 0x78760000);
+ TEST_ASSERT_EQUAL_INT32(*p0, v1);
+ TEST_ASSERT_EQUAL_INT32(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT32(*p0, 0x78760000);
+}
+
+void testEqualInt32sNegatives(void)
+{
+ UNITY_INT32 v0, v1;
+ UNITY_INT32 *p0, *p1;
+
+ v0 = -123456789;
+ v1 = -123456789;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT32(-123456789, -123456789);
+ TEST_ASSERT_EQUAL_INT32(v0, v1);
+ TEST_ASSERT_EQUAL_INT32(-123456789, v1);
+ TEST_ASSERT_EQUAL_INT32(v0, -123456789);
+ TEST_ASSERT_EQUAL_INT32(*p0, v1);
+ TEST_ASSERT_EQUAL_INT32(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT32(*p0, -123456789);
+}
+
+
+void testEqualUints(void)
+{
+ unsigned int v0, v1;
+ unsigned int *p0, *p1;
+
+ v0 = 19467;
+ v1 = 19467;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT(1837, 1837);
+ TEST_ASSERT_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_EQUAL_UINT(19467, v1);
+ TEST_ASSERT_EQUAL_UINT(v0, 19467);
+ TEST_ASSERT_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT(*p0, 19467);
+ TEST_ASSERT_EQUAL_UINT(60872u, 60872u);
+}
+
+
+void testEqualUint8s(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0x22;
+ v1 = 0x22;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT8(0x22, 0x22);
+ TEST_ASSERT_EQUAL_UINT8(v0, v1);
+ TEST_ASSERT_EQUAL_UINT8(0x22, v1);
+ TEST_ASSERT_EQUAL_UINT8(v0, 0x22);
+ TEST_ASSERT_EQUAL_UINT8(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT8(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT8(*p0, 0x22);
+}
+
+void testEqualUint8sWhenThereAreDifferencesOutside8Bits(void)
+{
+ TEST_ASSERT_EQUAL_UINT8(0x321,0x421);
+ TEST_ASSERT_EQUAL_UINT8(0xFF21,0x0021);
+}
+
+void testEqualUint16s(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0x9876;
+ v1 = 0x9876;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT16(0x9876, 0x9876);
+ TEST_ASSERT_EQUAL_UINT16(v0, v1);
+ TEST_ASSERT_EQUAL_UINT16(0x9876, v1);
+ TEST_ASSERT_EQUAL_UINT16(v0, 0x9876);
+ TEST_ASSERT_EQUAL_UINT16(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT16(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT16(*p0, 0x9876);
+}
+
+void testEqualUint16sWhenThereAreDifferencesOutside16Bits(void)
+{
+ TEST_ASSERT_EQUAL_UINT16(0x54321,0x64321);
+ TEST_ASSERT_EQUAL_UINT16(0xFFFF4321,0x00004321);
+}
+
+void testEqualUint32s(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0x98760000;
+ v1 = 0x98760000;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT32(0x98760000, 0x98760000);
+ TEST_ASSERT_EQUAL_UINT32(v0, v1);
+ TEST_ASSERT_EQUAL_UINT32(0x98760000, v1);
+ TEST_ASSERT_EQUAL_UINT32(v0, 0x98760000);
+ TEST_ASSERT_EQUAL_UINT32(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT32(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT32(*p0, 0x98760000);
+}
+
+void testNotEqual(void)
+{
+ TEST_ASSERT_NOT_EQUAL(0, 1);
+ TEST_ASSERT_NOT_EQUAL(1, 0);
+ TEST_ASSERT_NOT_EQUAL(100, 101);
+ TEST_ASSERT_NOT_EQUAL(0, -1);
+ TEST_ASSERT_NOT_EQUAL(65535, -65535);
+ TEST_ASSERT_NOT_EQUAL(75, 900);
+ TEST_ASSERT_NOT_EQUAL(-100, -101);
+}
+
+void testEqualHex8s(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0x22;
+ v1 = 0x22;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_HEX8(0x22, 0x22);
+ TEST_ASSERT_EQUAL_HEX8(v0, v1);
+ TEST_ASSERT_EQUAL_HEX8(0x22, v1);
+ TEST_ASSERT_EQUAL_HEX8(v0, 0x22);
+ TEST_ASSERT_EQUAL_HEX8(*p0, v1);
+ TEST_ASSERT_EQUAL_HEX8(*p0, *p1);
+ TEST_ASSERT_EQUAL_HEX8(*p0, 0x22);
+}
+
+void testEqualHex8sWhenThereAreDifferencesOutside8Bits(void)
+{
+ TEST_ASSERT_EQUAL_HEX8(0x321,0x421);
+ TEST_ASSERT_EQUAL_HEX8(0xFF21,0x0021);
+}
+
+void testEqualHex8sNegatives(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0xDD;
+ v1 = 0xDD;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_HEX8(0xDD, 0xDD);
+ TEST_ASSERT_EQUAL_HEX8(v0, v1);
+ TEST_ASSERT_EQUAL_HEX8(0xDD, v1);
+ TEST_ASSERT_EQUAL_HEX8(v0, 0xDD);
+ TEST_ASSERT_EQUAL_HEX8(*p0, v1);
+ TEST_ASSERT_EQUAL_HEX8(*p0, *p1);
+ TEST_ASSERT_EQUAL_HEX8(*p0, 0xDD);
+}
+
+void testEqualHex16s(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0x9876;
+ v1 = 0x9876;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_HEX16(0x9876, 0x9876);
+ TEST_ASSERT_EQUAL_HEX16(v0, v1);
+ TEST_ASSERT_EQUAL_HEX16(0x9876, v1);
+ TEST_ASSERT_EQUAL_HEX16(v0, 0x9876);
+ TEST_ASSERT_EQUAL_HEX16(*p0, v1);
+ TEST_ASSERT_EQUAL_HEX16(*p0, *p1);
+ TEST_ASSERT_EQUAL_HEX16(*p0, 0x9876);
+}
+
+void testEqualHex16sWhenThereAreDifferencesOutside16Bits(void)
+{
+ TEST_ASSERT_EQUAL_HEX16(0x54321,0x64321);
+ TEST_ASSERT_EQUAL_HEX16(0xFFFF4321,0x00004321);
+}
+
+void testEqualHex32s(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0x98765432ul;
+ v1 = 0x98765432ul;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_HEX32(0x98765432ul, 0x98765432ul);
+ TEST_ASSERT_EQUAL_HEX32(v0, v1);
+ TEST_ASSERT_EQUAL_HEX32(0x98765432ul, v1);
+ TEST_ASSERT_EQUAL_HEX32(v0, 0x98765432ul);
+ TEST_ASSERT_EQUAL_HEX32(*p0, v1);
+ TEST_ASSERT_EQUAL_HEX32(*p0, *p1);
+ TEST_ASSERT_EQUAL_HEX32(*p0, 0x98765432ul);
+}
+
+void testEqualBits(void)
+{
+ UNITY_UINT32 v0 = 0xFF55AA00;
+ UNITY_UINT32 v1 = 0x55550000;
+
+ TEST_ASSERT_BITS(v1, v0, 0x55550000);
+ TEST_ASSERT_BITS(v1, v0, 0xFF55CC00);
+ TEST_ASSERT_BITS(0xFFFFFFFF, v0, 0xFF55AA00);
+ TEST_ASSERT_BITS(0xFFFFFFFF, v0, v0);
+ TEST_ASSERT_BITS(0xF0F0F0F0, v0, 0xFC5DAE0F);
+ TEST_ASSERT_BITS_HIGH(v1, v0);
+ TEST_ASSERT_BITS_LOW(0x000055FF, v0);
+ TEST_ASSERT_BIT_HIGH(30, v0);
+ TEST_ASSERT_BIT_LOW(5, v0);
+}
+
+void testNotEqualBitHigh(void)
+{
+ UNITY_UINT32 v0 = 0x7F55AA00;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_BIT_HIGH(31, v0);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualBitLow(void)
+{
+ UNITY_UINT32 v0 = 0xFF55AA00;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_BIT_LOW(30, v0);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualBitsHigh(void)
+{
+ UNITY_UINT32 v0 = 0xFF55AA00;
+ UNITY_UINT32 v1 = 0x55550000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_BITS_HIGH(v0, v1);
+ VERIFY_FAILS_END
+
+}
+
+void testNotEqualBitsLow(void)
+{
+ UNITY_UINT32 v0 = 0xFF55AA00;
+ UNITY_UINT32 v1 = 0x55550000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_BITS_LOW(v0, v1);
+ VERIFY_FAILS_END
+}
+
+
+void testEqualShorts(void)
+{
+ short v0, v1;
+ short *p0, *p1;
+
+ v0 = 19467;
+ v1 = 19467;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT(1837, 1837);
+ TEST_ASSERT_EQUAL_INT(-2987, -2987);
+ TEST_ASSERT_EQUAL_INT(v0, v1);
+ TEST_ASSERT_EQUAL_INT(19467, v1);
+ TEST_ASSERT_EQUAL_INT(v0, 19467);
+ TEST_ASSERT_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_EQUAL_INT(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT(*p0, 19467);
+}
+
+void testEqualUShorts(void)
+{
+ unsigned short v0, v1;
+ unsigned short *p0, *p1;
+
+ v0 = 19467;
+ v1 = 19467;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT(1837, 1837);
+ TEST_ASSERT_EQUAL_UINT(2987, 2987);
+ TEST_ASSERT_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_EQUAL_UINT(19467, v1);
+ TEST_ASSERT_EQUAL_UINT(v0, 19467);
+ TEST_ASSERT_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT(*p0, 19467);
+}
+
+void testEqualUInts(void)
+{
+ unsigned char v0, v1;
+ unsigned char *p0, *p1;
+
+ v0 = 109;
+ v1 = 109;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT(42, 42);
+ TEST_ASSERT_EQUAL_UINT(-116, -116);
+ TEST_ASSERT_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_EQUAL_UINT(109, v1);
+ TEST_ASSERT_EQUAL_UINT(v0, 109);
+ TEST_ASSERT_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT(*p0, 109);
+}
+
+void testEqualUChars(void)
+{
+ unsigned char v0, v1;
+ unsigned char *p0, *p1;
+
+ v0 = 251;
+ v1 = 251;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT(42, 42);
+ TEST_ASSERT_EQUAL_INT(v0, v1);
+ TEST_ASSERT_EQUAL_INT(251, v1);
+ TEST_ASSERT_EQUAL_INT(v0, 251);
+ TEST_ASSERT_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_EQUAL_INT(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT(*p0, 251);
+}
+
+void testEqualPointers(void)
+{
+ int v0, v1;
+ int *p0, *p1, *p2;
+
+ v0 = 19467;
+ v1 = 18271;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v1;
+
+ TEST_ASSERT_EQUAL_PTR(p0, &v0);
+ TEST_ASSERT_EQUAL_PTR(&v1, p1);
+ TEST_ASSERT_EQUAL_PTR(p2, p1);
+ TEST_ASSERT_EQUAL_PTR(&v0, &v0);
+}
+
+void testNotEqualPointers(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_PTR(0x12345678, 0x12345677);
+ VERIFY_FAILS_END
+}
+
+void testIntsWithinDelta(void)
+{
+ TEST_ASSERT_INT_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_INT_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_INT_WITHIN(5, 5000, 5005);
+ TEST_ASSERT_INT_WITHIN(500, 50, -440);
+
+ TEST_ASSERT_INT_WITHIN(2, -1, -1);
+ TEST_ASSERT_INT_WITHIN(5, 1, -1);
+ TEST_ASSERT_INT_WITHIN(5, -1, 1);
+}
+
+void testIntsWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_INT_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_INT_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_INT_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+ TEST_ASSERT_INT_WITHIN_MESSAGE(500, 50, -440, "Custom Message.");
+
+ TEST_ASSERT_INT_WITHIN_MESSAGE(2, -1, -1, "Custom Message.");
+ TEST_ASSERT_INT_WITHIN_MESSAGE(5, 1, -1, "Custom Message.");
+ TEST_ASSERT_INT_WITHIN_MESSAGE(5, -1, 1, "Custom Message.");
+}
+
+void testIntsNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_WITHIN(5, 5000, 5006);
+ VERIFY_FAILS_END
+}
+
+void testIntsNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT_WITHIN_MESSAGE(5, 5000, 5006, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntsWithinDelta(void)
+{
+ TEST_ASSERT_UINT_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_UINT_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_UINT_WITHIN(5, 5000, 5005);
+}
+
+void testUIntsWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+}
+
+void testUIntsNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN(1, 2147483647u, 2147483649u);
+ VERIFY_FAILS_END
+}
+
+void testUIntsNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(1, 2147483647u, 2147483649u, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntsNotWithinDeltaEvenThoughASignedIntWouldPassSmallFirst(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN(5, 1, -1);
+ VERIFY_FAILS_END
+}
+
+void testUIntsNotWithinDeltaEvenThoughASignedIntWouldPassSmallFirstAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(5, 1, -1, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUIntsNotWithinDeltaEvenThoughASignedIntWouldPassBigFirst(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN(5, -1, 1);
+ VERIFY_FAILS_END
+}
+
+void testUIntsNotWithinDeltaEvenThoughASignedIntWouldPassBigFirstAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT_WITHIN_MESSAGE(5, -1, 1, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32sWithinDelta(void)
+{
+ TEST_ASSERT_HEX32_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_HEX32_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_HEX32_WITHIN(5, 5000, 5005);
+}
+
+void testHEX32sWithinDeltaShouldIgnoreSign(void)
+{
+ TEST_ASSERT_HEX32_WITHIN(1, 0x7FFFFFFF, 0x80000000);
+}
+
+void testHEX32sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_HEX32_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_HEX32_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_HEX32_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+}
+
+void testHEX32sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_WITHIN(1, 2147483647u, 2147483649u);
+ VERIFY_FAILS_END
+}
+
+void testHEX32sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_WITHIN_MESSAGE(1, 2147483647u, 2147483649u, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX32sNotWithinDeltaEvenThoughASignedIntWouldPass(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_WITHIN(5, 1, -1);
+ VERIFY_FAILS_END
+}
+
+void testHEX32sNotWithinDeltaEvenThoughASignedIntWouldPassAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX32_WITHIN_MESSAGE(5, 1, -1, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX16sWithinDelta(void)
+{
+ TEST_ASSERT_HEX16_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_HEX16_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_HEX16_WITHIN(5, 5000, 5005);
+}
+
+void testHEX16sWithinDeltaShouldIgnoreSign(void)
+{
+ TEST_ASSERT_HEX16_WITHIN(1, 0x7FFF, 0x8000);
+}
+
+void testHEX16sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_HEX16_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_HEX16_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_HEX16_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+}
+
+void testHEX16sWithinDeltaWhenThereAreDifferenceOutsideOf16Bits(void)
+{
+ TEST_ASSERT_HEX16_WITHIN(5, 0x54321, 0x44321);
+}
+
+void testHEX16sWithinDeltaWhenThereAreDifferenceOutsideOf16BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_HEX16_WITHIN_MESSAGE(5, 0x54321, 0x44321, "Custom Message.");
+}
+
+void testHEX16sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_WITHIN(2, 65535, 0);
+ VERIFY_FAILS_END
+}
+
+void testHEX16sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX16_WITHIN_MESSAGE(2, 65535, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testHEX8sWithinDelta(void)
+{
+ TEST_ASSERT_HEX8_WITHIN(1, 254, 255);
+ TEST_ASSERT_HEX8_WITHIN(5, 251, 255);
+ TEST_ASSERT_HEX8_WITHIN(5, 1, 4);
+}
+
+void testHEX8sWithinDeltaShouldIgnoreSign(void)
+{
+ TEST_ASSERT_HEX8_WITHIN(1, 0x7F, 0x80);
+}
+
+void testHEX8sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_HEX8_WITHIN_MESSAGE(1, 254, 255, "Custom Message.");
+ TEST_ASSERT_HEX8_WITHIN_MESSAGE(5, 251, 255, "Custom Message.");
+ TEST_ASSERT_HEX8_WITHIN_MESSAGE(5, 1, 4, "Custom Message.");
+}
+
+void testHEX8sWithinDeltaWhenThereAreDifferenceOutsideOf8Bits(void)
+{
+ TEST_ASSERT_HEX8_WITHIN(5, 0x123, 0xF23);
+}
+
+void testHEX8sWithinDeltaWhenThereAreDifferenceOutsideOf8BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_HEX8_WITHIN_MESSAGE(5, 0x123, 0xF23, "Custom Message.");
+}
+
+void testHEX8sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_WITHIN(2, 255, 0);
+ VERIFY_FAILS_END
+}
+
+void testHEX8sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX8_WITHIN_MESSAGE(2, 255, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+/*-----------------*/
+
+void testUINT32sWithinDelta(void)
+{
+ TEST_ASSERT_UINT32_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_UINT32_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_UINT32_WITHIN(5, 5000, 5005);
+}
+
+void testUINT32sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT32_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_UINT32_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_UINT32_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+}
+
+void testUINT32sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT32_WITHIN(1, 2147483647u, 2147483649u);
+ VERIFY_FAILS_END
+}
+
+void testUINT32sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT32_WITHIN_MESSAGE(1, 2147483647u, 2147483649u, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUINT32sNotWithinDeltaEvenThoughASignedIntWouldPass(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT32_WITHIN(5, 1, -1);
+ VERIFY_FAILS_END
+}
+
+void testUINT32sNotWithinDeltaEvenThoughASignedIntWouldPassAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT32_WITHIN_MESSAGE(5, 1, -1, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUINT16sWithinDelta(void)
+{
+ TEST_ASSERT_UINT16_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_UINT16_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_UINT16_WITHIN(5, 5000, 5005);
+}
+
+void testUINT16sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT16_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+ TEST_ASSERT_UINT16_WITHIN_MESSAGE(5, 5000, 4996, "Custom Message.");
+ TEST_ASSERT_UINT16_WITHIN_MESSAGE(5, 5000, 5005, "Custom Message.");
+}
+
+void testUINT16sWithinDeltaWhenThereAreDifferenceOutsideOf16Bits(void)
+{
+ TEST_ASSERT_UINT16_WITHIN(5, 0x54321, 0x44321);
+}
+
+void testUINT16sWithinDeltaWhenThereAreDifferenceOutsideOf16BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT16_WITHIN_MESSAGE(5, 0x54321, 0x44321, "Custom Message.");
+}
+
+void testUINT16sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_WITHIN(2, 65535, 0);
+ VERIFY_FAILS_END
+}
+
+void testUINT16sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT16_WITHIN_MESSAGE(2, 65535, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testUINT8sWithinDelta(void)
+{
+ TEST_ASSERT_UINT8_WITHIN(1, 254, 255);
+ TEST_ASSERT_UINT8_WITHIN(5, 251, 255);
+ TEST_ASSERT_UINT8_WITHIN(5, 1, 4);
+}
+
+void testUINT8sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT8_WITHIN_MESSAGE(1, 254, 255, "Custom Message.");
+ TEST_ASSERT_UINT8_WITHIN_MESSAGE(5, 251, 255, "Custom Message.");
+ TEST_ASSERT_UINT8_WITHIN_MESSAGE(5, 1, 4, "Custom Message.");
+}
+
+void testUINT8sWithinDeltaWhenThereAreDifferenceOutsideOf8Bits(void)
+{
+ TEST_ASSERT_UINT8_WITHIN(5, 0x123, 0xF23);
+}
+
+void testUINT8sWithinDeltaWhenThereAreDifferenceOutsideOf8BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_UINT8_WITHIN_MESSAGE(5, 0x123, 0xF23, "Custom Message.");
+}
+
+void testUINT8sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_WITHIN(2, 255, 0);
+ VERIFY_FAILS_END
+}
+
+void testUINT8sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT8_WITHIN_MESSAGE(2, 255, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testINT32sWithinDelta(void)
+{
+ TEST_ASSERT_INT32_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_INT32_WITHIN(5, 1, -2);
+ TEST_ASSERT_INT32_WITHIN(5, -2, 1);
+}
+
+void testINT32sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_INT32_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+}
+
+void testINT32sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT32_WITHIN(1, -3, 1);
+ VERIFY_FAILS_END
+}
+
+void testINT32sNotWithinDeltaAndDifferenceOverflows(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT32_WITHIN(1, -1, 0x7FFFFFFF);
+ VERIFY_FAILS_END
+}
+void testINT32sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT32_WITHIN_MESSAGE(1, -2, 1, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testINT16sWithinDelta(void)
+{
+ TEST_ASSERT_INT16_WITHIN(1, 5000, 5001);
+ TEST_ASSERT_INT16_WITHIN(5, 2, -2);
+ TEST_ASSERT_INT16_WITHIN(5, -2, 2);
+}
+
+void testINT16sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_INT16_WITHIN_MESSAGE(1, 5000, 5001, "Custom Message.");
+}
+
+void testINT16sWithinDeltaWhenThereAreDifferenceOutsideOf16Bits(void)
+{
+ TEST_ASSERT_INT16_WITHIN(5, 0x54321, 0x44321);
+}
+
+void testINT16sWithinDeltaWhenThereAreDifferenceOutsideOf16BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_INT16_WITHIN_MESSAGE(5, 0x54321, 0x44321, "Custom Message.");
+}
+
+void testINT16sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_WITHIN(2, 4, -2);
+ VERIFY_FAILS_END
+}
+
+void testINT16sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT16_WITHIN_MESSAGE(2, 3, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testINT8sWithinDelta(void)
+{
+ TEST_ASSERT_INT8_WITHIN(1, 127, 126);
+ TEST_ASSERT_INT8_WITHIN(5, -2, 2);
+ TEST_ASSERT_INT8_WITHIN(5, 2, -2);
+}
+
+void testINT8sWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_INT8_WITHIN_MESSAGE(5, 1, 4, "Custom Message.");
+}
+
+void testINT8sWithinDeltaWhenThereAreDifferenceOutsideOf8Bits(void)
+{
+ TEST_ASSERT_INT8_WITHIN(5, 0x123, 0xF23);
+}
+
+void testINT8sWithinDeltaWhenThereAreDifferenceOutsideOf8BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_INT8_WITHIN_MESSAGE(5, 0x123, 0xF23, "Custom Message.");
+}
+
+void testINT8sNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_WITHIN(2, -3, 0);
+ VERIFY_FAILS_END
+}
+
+void testINT8sNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT8_WITHIN_MESSAGE(2, -4, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testCHARsWithinDelta(void)
+{
+ TEST_ASSERT_CHAR_WITHIN(1, 'M', 'L');
+ TEST_ASSERT_CHAR_WITHIN(5, -2, 2);
+ TEST_ASSERT_CHAR_WITHIN(5, 2, -2);
+}
+
+void testCHARsWithinDeltaAndCustomMessage(void)
+{
+ TEST_ASSERT_CHAR_WITHIN_MESSAGE(5, 1, 4, "Custom Message.");
+}
+
+void testCHARsWithinDeltaWhenThereAreDifferenceOutsideOf8Bits(void)
+{
+ TEST_ASSERT_CHAR_WITHIN(5, 0x123, 0xF23);
+}
+
+void testCHARsWithinDeltaWhenThereAreDifferenceOutsideOf8BitsAndCustomMessage(void)
+{
+ TEST_ASSERT_CHAR_WITHIN_MESSAGE(5, 0x123, 0xF23, "Custom Message.");
+}
+
+void testCHARsNotWithinDelta(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_WITHIN(2, -3, 0);
+ VERIFY_FAILS_END
+}
+
+void testCHARsNotWithinDeltaAndCustomMessage(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_CHAR_WITHIN_MESSAGE(2, -4, 0, "Custom Message.");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualINT(void)
+{
+ UNITY_INT v0, v1;
+ UNITY_INT *p0, *p1;
+
+ v0 = 302;
+ v1 = 3334;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_INT(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_INT(*p1, *p0);
+}
+
+void testNotNotEqualINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_INT(302, 302);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualINT8(void)
+{
+ UNITY_INT8 v0, v1;
+ UNITY_INT8 *p0, *p1;
+
+ v0 = -128;
+ v1 = 127;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_INT8(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT8(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT8(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_INT8(*p1, *p0);
+}
+
+void testNotNotEqualINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_INT8(-128, -128);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualCHAR(void)
+{
+ char v0, v1;
+ char *p0, *p1;
+
+ v0 = -128;
+ v1 = 127;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_CHAR(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_CHAR(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_CHAR(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_CHAR(*p1, *p0);
+}
+
+void testNotNotEqualCHAR(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_CHAR(127, 127);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualINT16(void)
+{
+ UNITY_INT16 v0, v1;
+ UNITY_INT16 *p0, *p1;
+
+ v0 = -32768;
+ v1 = 32767;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_INT16(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT16(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT16(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_INT16(*p1, *p0);
+}
+
+void testNotNotEqualINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_INT16(-32768, -32768);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualINT32(void)
+{
+ UNITY_INT32 v0, v1;
+ UNITY_INT32 *p0, *p1;
+
+ v0 = -214783648;
+ v1 = 214783647;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_INT32(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT32(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_INT32(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_INT32(*p1, *p0);
+}
+
+void testNotNotEqualINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_INT32(-214783648, -214783648);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT(void)
+{
+ UNITY_UINT v0, v1;
+ UNITY_UINT *p0, *p1;
+
+ v0 = 0;
+ v1 = 1;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_UINT(*p1, *p0);
+}
+
+void testNotNotEqualUINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_UINT(1, 1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0;
+ v1 = 255;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_UINT8(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT8(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT8(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_UINT8(*p1, *p0);
+}
+
+void testNotNotEqualUINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_UINT8(255, 255);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0;
+ v1 = 65535;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_UINT16(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT16(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT16(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_UINT16(*p1, *p0);
+}
+
+void testNotNotEqualUINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_UINT16(65535, 65535);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualUINT32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0u;
+ v1 = 4294967295u;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_UINT32(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT32(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_UINT32(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_UINT32(*p1, *p0);
+}
+
+void testNotNotEqualUINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_UINT32(4294967295u, 4294967295u);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0x00;
+ v1 = 0xFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_HEX8(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX8(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX8(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_HEX8(*p1, *p0);
+}
+
+void testNotNotEqualHEX8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_HEX8(0xFF, 0xFF);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0x0000;
+ v1 = 0xFFFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_HEX16(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX16(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX16(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_HEX16(*p1, *p0);
+}
+
+void testNotNotEqualHEX16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_HEX16(0xFFFF, 0xFFFF);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualHEX32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0x00000000;
+ v1 = 0xFFFFFFFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_NOT_EQUAL_HEX32(v0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX32(*p0, v1);
+ TEST_ASSERT_NOT_EQUAL_HEX32(v0, *p1);
+ TEST_ASSERT_NOT_EQUAL_HEX32(*p1, *p0);
+}
+
+void testNotNotEqualHEX32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_NOT_EQUAL_HEX32(0xFFFFFFFF, 0xFFFFFFFF);
+ VERIFY_FAILS_END
+}
+
+/*-----------------*/
+
+void testGreaterThan(void)
+{
+ UNITY_INT v0, v1;
+ UNITY_INT *p0, *p1;
+
+ v0 = 0;
+ v1 = 1;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN(v0, v1);
+ TEST_ASSERT_GREATER_THAN(*p0, v1);
+ TEST_ASSERT_GREATER_THAN(v0, *p1);
+ TEST_ASSERT_GREATER_THAN(*p0, *p1);
+}
+
+void testNotGreaterThan(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN(0, -1);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanINT(void)
+{
+ UNITY_INT v0, v1;
+ UNITY_INT *p0, *p1;
+
+ v0 = 302;
+ v1 = 3334;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_INT(v0, v1);
+ TEST_ASSERT_GREATER_THAN_INT(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_INT(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_INT(*p0, *p1);
+}
+
+void testNotGreaterThanINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_INT(3334, 302);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanINT8(void)
+{
+ UNITY_INT8 v0, v1;
+ UNITY_INT8 *p0, *p1;
+
+ v0 = -128;
+ v1 = 127;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_INT8(v0, v1);
+ TEST_ASSERT_GREATER_THAN_INT8(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_INT8(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_INT8(*p0, *p1);
+}
+
+void testNotGreaterThanINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_INT8(127, -128);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanCHAR(void)
+{
+ char v0, v1;
+ char *p0, *p1;
+
+ v0 = -128;
+ v1 = 127;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_CHAR(v0, v1);
+ TEST_ASSERT_GREATER_THAN_CHAR(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_CHAR(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_CHAR(*p0, *p1);
+}
+
+void testNotGreaterThanCHAR(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_CHAR(127, -128);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanINT16(void)
+{
+ UNITY_INT16 v0, v1;
+ UNITY_INT16 *p0, *p1;
+
+ v0 = -32768;
+ v1 = 32767;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_INT16(v0, v1);
+ TEST_ASSERT_GREATER_THAN_INT16(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_INT16(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_INT16(*p0, *p1);
+}
+
+void testNotGreaterThanINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_INT16(32768, -32768);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanINT32(void)
+{
+ UNITY_INT32 v0, v1;
+ UNITY_INT32 *p0, *p1;
+
+ v0 = -214783648;
+ v1 = 214783647;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_INT32(v0, v1);
+ TEST_ASSERT_GREATER_THAN_INT32(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_INT32(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_INT32(*p0, *p1);
+}
+
+void testNotGreaterThanINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_INT32(214783647, -214783648);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanUINT(void)
+{
+ UNITY_UINT v0, v1;
+ UNITY_UINT *p0, *p1;
+
+ v0 = 0;
+ v1 = 1;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_UINT(v0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_UINT(*p0, *p1);
+}
+
+void testNotGreaterThanUINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_UINT(1, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanUINT8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0;
+ v1 = 255;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_UINT8(v0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT8(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT8(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_UINT8(*p0, *p1);
+}
+
+void testNotGreaterThanUINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_UINT8(255, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanUINT16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0;
+ v1 = 65535;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_UINT16(v0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT16(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT16(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_UINT16(*p0, *p1);
+}
+
+void testNotGreaterThanUINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_UINT16(65535, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanUINT32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0u;
+ v1 = 4294967295u;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_UINT32(v0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT32(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_UINT32(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_UINT32(*p0, *p1);
+}
+
+void testNotGreaterThanUINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_UINT32(4294967295u, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanHEX8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0x00;
+ v1 = 0xFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_HEX8(v0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX8(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX8(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_HEX8(*p0, *p1);
+}
+
+void testNotGreaterThanHEX8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_HEX8(0xFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanHEX16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0x0000;
+ v1 = 0xFFFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_HEX16(v0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX16(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX16(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_HEX16(*p0, *p1);
+}
+
+void testNotGreaterThanHEX16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_HEX16(0xFFFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+void testGreaterThanHEX32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0x00000000;
+ v1 = 0xFFFFFFFF;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_GREATER_THAN_HEX32(v0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX32(*p0, v1);
+ TEST_ASSERT_GREATER_THAN_HEX32(v0, *p1);
+ TEST_ASSERT_GREATER_THAN_HEX32(*p0, *p1);
+}
+
+void testNotGreaterThanHEX32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_THAN_HEX32(0xFFFFFFFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqual(void)
+{
+ UNITY_INT v0, v1, v2;
+ UNITY_INT *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = 1;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL(*p0, *p2);
+}
+
+void testNotGreaterOrEqual(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL(0, -1);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualINT(void)
+{
+ UNITY_INT v0, v1, v2;
+ UNITY_INT *p0, *p1, *p2;
+
+ v0 = 302;
+ v1 = 3334;
+ v2 = 302;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(*p0, *p2);
+}
+
+void testNotGreaterOrEqualINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_INT(3334, 302);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualINT8(void)
+{
+ UNITY_INT8 v0, v1, v2;
+ UNITY_INT8 *p0, *p1, *p2;
+
+ v0 = -128;
+ v1 = 127;
+ v2 = -128;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(*p0, *p2);
+}
+
+void testNotGreaterOrEqualINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_INT8(127, -128);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualCHAR(void)
+{
+ char v0, v1, v2;
+ char *p0, *p1, *p2;
+
+ v0 = -128;
+ v1 = 127;
+ v2 = -128;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(*p0, *p2);
+}
+
+void testNotGreaterOrEqualCHAR(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_CHAR(127, -128);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualINT16(void)
+{
+ UNITY_INT16 v0, v1, v2;
+ UNITY_INT16 *p0, *p1, *p2;
+
+ v0 = -32768;
+ v1 = 32767;
+ v2 = -32768;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(*p0, *p2);
+}
+
+void testNotGreaterOrEqualINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_INT16(32767, -32768);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualINT32(void)
+{
+ UNITY_INT32 v0, v1, v2;
+ UNITY_INT32 *p0, *p1, *p2;
+
+ v0 = -214783648;
+ v1 = 214783647;
+ v2 = -214783648;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(*p0, *p2);
+}
+
+void testNotGreaterOrEqualINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_INT32(214783647, -214783648);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualUINT(void)
+{
+ UNITY_UINT v0, v1, v2;
+ UNITY_UINT *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = 1;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(*p0, *p2);
+}
+
+void testNotGreaterOrEqualUINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT(1, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualUINT8(void)
+{
+ UNITY_UINT8 v0, v1, v2;
+ UNITY_UINT8 *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = 255;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(*p0, *p2);
+}
+
+void testNotGreaterOrEqualUINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT8(255, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualUINT16(void)
+{
+ UNITY_UINT16 v0, v1, v2;
+ UNITY_UINT16 *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = 65535;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(*p0, *p2);
+}
+
+void testNotGreaterOrEqualUINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT16(65535, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualUINT32(void)
+{
+ UNITY_UINT32 v0, v1, v2;
+ UNITY_UINT32 *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = 4294967295u;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(*p0, *p2);
+}
+
+void testNotGreaterOrEqualUINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_UINT32(4294967295u, 0);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualHEX8(void)
+{
+ UNITY_UINT8 v0, v1, v2;
+ UNITY_UINT8 *p0, *p1, *p2;
+
+ v0 = 0x00;
+ v1 = 0xFF;
+ v2 = 0x00;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(*p0, *p2);
+}
+
+void testNotGreaterOrEqualHEX8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX8(0xFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualHEX16(void)
+{
+ UNITY_UINT16 v0, v1, v2;
+ UNITY_UINT16 *p0, *p1, *p2;
+
+ v0 = 0x0000;
+ v1 = 0xFFFF;
+ v2 = 0x0000;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(*p0, *p2);
+}
+
+void testNotGreaterOrEqualHEX16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX16(0xFFFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+void testGreaterOrEqualHEX32(void)
+{
+ UNITY_UINT32 v0, v1, v2;
+ UNITY_UINT32 *p0, *p1, *p2;
+
+ v0 = 0x00000000;
+ v1 = 0xFFFFFFFF;
+ v2 = 0x00000000;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(v0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(*p0, v1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(v0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(*p0, *p1);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(v0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(*p0, v2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(v0, *p2);
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(*p0, *p2);
+}
+
+void testNotGreaterOrEqualHEX32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_GREATER_OR_EQUAL_HEX32(0xFFFFFFFF, 0x00);
+ VERIFY_FAILS_END
+}
+
+/*-----------------*/
+
+void testLessThan(void)
+{
+ UNITY_INT v0, v1;
+ UNITY_INT *p0, *p1;
+
+ v0 = 0;
+ v1 = -1;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN(v0, v1);
+ TEST_ASSERT_LESS_THAN(*p0, v1);
+ TEST_ASSERT_LESS_THAN(v0, *p1);
+ TEST_ASSERT_LESS_THAN(*p0, *p1);
+}
+
+void testNotLessThan(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN(0, 1);
+ VERIFY_FAILS_END
+}
+
+void testLessThanINT(void)
+{
+ UNITY_INT v0, v1;
+ UNITY_INT *p0, *p1;
+
+ v0 = 3334;
+ v1 = 302;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_INT(v0, v1);
+ TEST_ASSERT_LESS_THAN_INT(*p0, v1);
+ TEST_ASSERT_LESS_THAN_INT(v0, *p1);
+ TEST_ASSERT_LESS_THAN_INT(*p0, *p1);
+}
+
+void testNotLessThanINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_INT(302, 3334);
+ VERIFY_FAILS_END
+}
+
+void testLessThanINT8(void)
+{
+ UNITY_INT8 v0, v1;
+ UNITY_INT8 *p0, *p1;
+
+ v0 = 127;
+ v1 = -128;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_INT8(v0, v1);
+ TEST_ASSERT_LESS_THAN_INT8(*p0, v1);
+ TEST_ASSERT_LESS_THAN_INT8(v0, *p1);
+ TEST_ASSERT_LESS_THAN_INT8(*p0, *p1);
+}
+
+void testNotLessThanINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_INT8(-128, 127);
+ VERIFY_FAILS_END
+}
+
+void testLessThanCHAR(void)
+{
+ char v0, v1;
+ char *p0, *p1;
+
+ v0 = 127;
+ v1 = -128;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_CHAR(v0, v1);
+ TEST_ASSERT_LESS_THAN_CHAR(*p0, v1);
+ TEST_ASSERT_LESS_THAN_CHAR(v0, *p1);
+ TEST_ASSERT_LESS_THAN_CHAR(*p0, *p1);
+}
+
+void testNotLessThanCHAR(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_CHAR(-128, 127);
+ VERIFY_FAILS_END
+}
+
+void testLessThanINT16(void)
+{
+ UNITY_INT16 v0, v1;
+ UNITY_INT16 *p0, *p1;
+
+ v0 = 32767;
+ v1 = -32768;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_INT16(v0, v1);
+ TEST_ASSERT_LESS_THAN_INT16(*p0, v1);
+ TEST_ASSERT_LESS_THAN_INT16(v0, *p1);
+ TEST_ASSERT_LESS_THAN_INT16(*p0, *p1);
+}
+
+void testNotLessThanINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_INT16(-32768, 32767);
+ VERIFY_FAILS_END
+}
+
+void testLessThanINT32(void)
+{
+ UNITY_INT32 v0, v1;
+ UNITY_INT32 *p0, *p1;
+
+ v0 = 214783647;
+ v1 = -214783648;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_INT32(v0, v1);
+ TEST_ASSERT_LESS_THAN_INT32(*p0, v1);
+ TEST_ASSERT_LESS_THAN_INT32(v0, *p1);
+ TEST_ASSERT_LESS_THAN_INT32(*p0, *p1);
+}
+
+void testNotLessThanINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_INT32(-214783648, 214783647);
+ VERIFY_FAILS_END
+}
+
+void testLessThanUINT(void)
+{
+ UNITY_UINT v0, v1;
+ UNITY_UINT *p0, *p1;
+
+ v0 = 1;
+ v1 = 0;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_UINT(v0, v1);
+ TEST_ASSERT_LESS_THAN_UINT(*p0, v1);
+ TEST_ASSERT_LESS_THAN_UINT(v0, *p1);
+ TEST_ASSERT_LESS_THAN_UINT(*p0, *p1);
+}
+
+void testNotLessThanUINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_UINT(0, 1);
+ VERIFY_FAILS_END
+}
+
+void testLessThanUINT8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 255;
+ v1 = 0;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_UINT8(v0, v1);
+ TEST_ASSERT_LESS_THAN_UINT8(*p0, v1);
+ TEST_ASSERT_LESS_THAN_UINT8(v0, *p1);
+ TEST_ASSERT_LESS_THAN_UINT8(*p0, *p1);
+}
+
+void testNotLessThanUINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_UINT8(0, 255);
+ VERIFY_FAILS_END
+}
+
+void testLessThanUINT16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 65535;
+ v1 = 0;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_UINT16(v0, v1);
+ TEST_ASSERT_LESS_THAN_UINT16(*p0, v1);
+ TEST_ASSERT_LESS_THAN_UINT16(v0, *p1);
+ TEST_ASSERT_LESS_THAN_UINT16(*p0, *p1);
+}
+
+void testNotLessThanUINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_UINT16(0, 65535);
+ VERIFY_FAILS_END
+}
+
+void testLessThanUINT32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 4294967295u;
+ v1 = 0;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_UINT32(v0, v1);
+ TEST_ASSERT_LESS_THAN_UINT32(*p0, v1);
+ TEST_ASSERT_LESS_THAN_UINT32(v0, *p1);
+ TEST_ASSERT_LESS_THAN_UINT32(*p0, *p1);
+}
+
+void testNotLessThanUINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_UINT32(0, 4294967295u);
+ VERIFY_FAILS_END
+}
+
+void testLessThanHEX8(void)
+{
+ UNITY_UINT8 v0, v1;
+ UNITY_UINT8 *p0, *p1;
+
+ v0 = 0xFF;
+ v1 = 0x00;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_HEX8(v0, v1);
+ TEST_ASSERT_LESS_THAN_HEX8(*p0, v1);
+ TEST_ASSERT_LESS_THAN_HEX8(v0, *p1);
+ TEST_ASSERT_LESS_THAN_HEX8(*p0, *p1);
+}
+
+void testNotLessThanHEX8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_HEX8(0x00, 0xFF);
+ VERIFY_FAILS_END
+}
+
+void testLessThanHEX16(void)
+{
+ UNITY_UINT16 v0, v1;
+ UNITY_UINT16 *p0, *p1;
+
+ v0 = 0xFFFF;
+ v1 = 0x0000;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_HEX16(v0, v1);
+ TEST_ASSERT_LESS_THAN_HEX16(*p0, v1);
+ TEST_ASSERT_LESS_THAN_HEX16(v0, *p1);
+ TEST_ASSERT_LESS_THAN_HEX16(*p0, *p1);
+}
+
+void testNotLessThanHEX16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_HEX16(0x0000, 0xFFFF);
+ VERIFY_FAILS_END
+}
+
+void testLessThanHEX32(void)
+{
+ UNITY_UINT32 v0, v1;
+ UNITY_UINT32 *p0, *p1;
+
+ v0 = 0xFFFFFFFF;
+ v1 = 0x00000000;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_LESS_THAN_HEX32(v0, v1);
+ TEST_ASSERT_LESS_THAN_HEX32(*p0, v1);
+ TEST_ASSERT_LESS_THAN_HEX32(v0, *p1);
+ TEST_ASSERT_LESS_THAN_HEX32(*p0, *p1);
+}
+
+void testNotLessThanHEX32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_THAN_HEX32(0x00000000, 0xFFFFFFFF);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqual(void)
+{
+ UNITY_INT v0, v1, v2;
+ UNITY_INT *p0, *p1, *p2;
+
+ v0 = 0;
+ v1 = -1;
+ v2 = 0;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL(*p0, *p2);
+}
+
+void testNotLessOrEqual(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL(0, 1);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualINT(void)
+{
+ UNITY_INT v0, v1, v2;
+ UNITY_INT *p0, *p1, *p2;
+
+ v0 = 3334;
+ v1 = 302;
+ v2 = 3334;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_INT(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT(*p0, *p2);
+}
+
+void testNotLessOrEqualINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_INT(302, 3334);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualINT8(void)
+{
+ UNITY_INT8 v0, v1, v2;
+ UNITY_INT8 *p0, *p1, *p2;
+
+ v0 = 127;
+ v1 = -128;
+ v2 = 127;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(*p0, *p2);
+}
+
+void testNotLessOrEqualINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_INT8(-128, 127);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualCHAR(void)
+{
+ char v0, v1, v2;
+ char *p0, *p1, *p2;
+
+ v0 = 127;
+ v1 = -128;
+ v2 = 127;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(*p0, *p2);
+}
+
+void testNotLessOrEqualCHAR(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_CHAR(-128, 127);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualINT16(void)
+{
+ UNITY_INT16 v0, v1, v2;
+ UNITY_INT16 *p0, *p1, *p2;
+
+ v0 = 32767;
+ v1 = -32768;
+ v2 = 32767;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(*p0, *p2);
+}
+
+void testNotLessOrEqualINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_INT16(-32768, 32767);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualINT32(void)
+{
+ UNITY_INT32 v0, v1, v2;
+ UNITY_INT32 *p0, *p1, *p2;
+
+ v0 = 214783647;
+ v1 = -214783648;
+ v2 = 214783647;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(*p0, *p2);
+}
+
+void testNotLessOrEqualINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_INT32(-214783648, 214783647);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualUINT(void)
+{
+ UNITY_UINT v0, v1, v2;
+ UNITY_UINT *p0, *p1, *p2;
+
+ v0 = 1;
+ v1 = 0;
+ v2 = 1;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(*p0, *p2);
+}
+
+void testNotLessOrEqualUINT(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_UINT(0, 1);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualUINT8(void)
+{
+ UNITY_UINT8 v0, v1, v2;
+ UNITY_UINT8 *p0, *p1, *p2;
+
+ v0 = 255;
+ v1 = 0;
+ v2 = 255;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(*p0, *p2);
+}
+
+void testNotLessOrEqualUINT8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_UINT8(0, 255);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualUINT16(void)
+{
+ UNITY_UINT16 v0, v1, v2;
+ UNITY_UINT16 *p0, *p1, *p2;
+
+ v0 = 65535;
+ v1 = 0;
+ v2 = 65535;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(*p0, *p2);
+}
+
+void testNotLessOrEqualUINT16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_UINT16(0, 65535);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualUINT32(void)
+{
+ UNITY_UINT32 v0, v1, v2;
+ UNITY_UINT32 *p0, *p1, *p2;
+
+ v0 = 4294967295u;
+ v1 = 0;
+ v2 = 4294967295u;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(*p0, *p2);
+}
+
+void testNotLessOrEqualUINT32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_UINT32(0, 4294967295u);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualHEX8(void)
+{
+ UNITY_UINT8 v0, v1, v2;
+ UNITY_UINT8 *p0, *p1, *p2;
+
+ v0 = 0xFF;
+ v1 = 0x00;
+ v2 = 0xFF;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(*p0, *p2);
+}
+
+void testNotLessOrEqualHEX8(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_HEX8(0x00, 0xFF);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualHEX16(void)
+{
+ UNITY_UINT16 v0, v1, v2;
+ UNITY_UINT16 *p0, *p1, *p2;
+
+ v0 = 0xFFFF;
+ v1 = 0x0000;
+ v2 = 0xFFFF;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(*p0, *p2);
+}
+
+void testNotLessOrEqualHEX16(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_HEX16(0x0000, 0xFFFF);
+ VERIFY_FAILS_END
+}
+
+void testLessOrEqualHEX32(void)
+{
+ UNITY_UINT32 v0, v1, v2;
+ UNITY_UINT32 *p0, *p1, *p2;
+
+ v0 = 0xFFFFFFFF;
+ v1 = 0x00000000;
+ v2 = 0xFFFFFFFF;
+ p0 = &v0;
+ p1 = &v1;
+ p2 = &v2;
+
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(v0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(*p0, v1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(v0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(*p0, *p1);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(v0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(*p0, v2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(v0, *p2);
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(*p0, *p2);
+}
+
+void testNotLessOrEqualHEX32(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_LESS_OR_EQUAL_HEX32(0x00000000, 0xFFFFFFFF);
+ VERIFY_FAILS_END
+}
+
+void testHexPrintsUpToMaxNumberOfNibbles(void)
+{
+#ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+#else
+ startPutcharSpy();
+ UnityPrintNumberHex(0xBEE, 21);
+ endPutcharSpy();
+#ifdef UNITY_SUPPORT_64
+ TEST_ASSERT_EQUAL_INT(16, strlen(getBufferPutcharSpy()));
+#else
+ TEST_ASSERT_EQUAL_INT( 8, strlen(getBufferPutcharSpy()));
+#endif
+#endif
+}
+
+void testPrintNumbers32(void)
+{
+#ifndef USING_OUTPUT_SPY
+ TEST_IGNORE_MESSAGE("Compile with '-D UNITY_OUTPUT_CHAR=putcharSpy' to enable print testing");
+#else
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("0", 0);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("1", 1);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("-1", -1);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("2000000000", 2000000000);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("-2147483648", (UNITY_INT32)0x80000000);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("-1", (UNITY_INT32)0xFFFFFFFF);
+#endif
+}
+
+void testPrintNumbersUnsigned32(void)
+{
+#ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("0", 0);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("1", 1);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("1500000000", 1500000000);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("2147483648", (UNITY_UINT32)0x80000000);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("4294967295", (UNITY_UINT32)0xFFFFFFFF);
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_integers_64.c b/deps/Unity/test/tests/test_unity_integers_64.c
new file mode 100644
index 0000000..867d1e7
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_integers_64.c
@@ -0,0 +1,782 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testInt64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualSmallDelta[] = {12345001, -12344996, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+#endif
+}
+
+void testInt64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualSmallDelta[] = {12345001, -12344996, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void tesUInt64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 actualBigDelta[] = {12345101, -12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testInt64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, expected, 3);
+#endif
+}
+
+void testInt64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 expected[] = {12345000, -12344995, 12345005};
+
+ TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testUInt64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualSmallDelta[] = {12345001, 12344996, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualSmallDelta, 3);
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, actualBigDelta, 3);
+#endif
+}
+
+void testUInt64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualSmallDelta[] = {12345001, 12344996, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(1, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void testUInt64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(1, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(1, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {12345101, 12344896, 12345055};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUInt64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN(110, expected, expected, 3);
+#endif
+}
+
+void testUInt64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {12345000, 12344995, 12345005};
+
+ TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(110, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testHEX64ArrayWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualSmallDelta[] = {0xABCD123500000000, 0xABCD112100000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x100000000, expected, actualSmallDelta, 3);
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, actualBigDelta, 3);
+#endif
+}
+
+void testHEX64ArrayWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualSmallDelta[] = {0xABCD123500000000, 0xABCD112100000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x100000000, expected, actualSmallDelta, 3, "Custom Message.");
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, actualBigDelta, 3, "Custom Message.");
+#endif
+}
+
+void testHEX64ArrayNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x100000000, expected, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayNotWithinDeltaAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x100000000, expected, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaPointless(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, actualBigDelta, 0);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaPointlessAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, actualBigDelta, 0, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaExpectedNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, NULL, actualBigDelta, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaExpectedNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 actualBigDelta[] = {0xABCD126700000000, 0xABCD118800000000, 0xABCD12AC00000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, NULL, actualBigDelta, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaActualNull(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, NULL, 3);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaActualNullAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, NULL, 3, "Custom Message.");
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64ArrayWithinDeltaSamePointer(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN(0x6E00000000, expected, expected, 3);
+#endif
+}
+
+void testHEX64ArrayWithinDeltaSamePointerAndMessage(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 expected[] = {0xABCD123400000000, 0xABCD112200000000, 0xABCD127700000000};
+
+ TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(0x6E00000000, expected, expected, 3, "Custom Message.");
+#endif
+}
+
+void testEqualHex64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 v0, v1;
+ UNITY_UINT64 *p0, *p1;
+
+ v0 = 0x9876543201234567;
+ v1 = 0x9876543201234567;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_HEX64(0x9876543201234567, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_HEX64(v0, v1);
+ TEST_ASSERT_EQUAL_HEX64(0x9876543201234567, v1);
+ TEST_ASSERT_EQUAL_HEX64(v0, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_HEX64(*p0, v1);
+ TEST_ASSERT_EQUAL_HEX64(*p0, *p1);
+ TEST_ASSERT_EQUAL_HEX64(*p0, 0x9876543201234567);
+#endif
+}
+
+void testEqualUint64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 v0, v1;
+ UNITY_UINT64 *p0, *p1;
+
+ v0 = 0x9876543201234567;
+ v1 = 0x9876543201234567;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_UINT64(0x9876543201234567, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_UINT64(v0, v1);
+ TEST_ASSERT_EQUAL_UINT64(0x9876543201234567, v1);
+ TEST_ASSERT_EQUAL_UINT64(v0, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_UINT64(*p0, v1);
+ TEST_ASSERT_EQUAL_UINT64(*p0, *p1);
+ TEST_ASSERT_EQUAL_UINT64(*p0, 0x9876543201234567);
+#endif
+}
+
+void testEqualInt64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 v0, v1;
+ UNITY_INT64 *p0, *p1;
+
+ v0 = (UNITY_INT64)0x9876543201234567;
+ v1 = (UNITY_INT64)0x9876543201234567;
+ p0 = &v0;
+ p1 = &v1;
+
+ TEST_ASSERT_EQUAL_INT64(0x9876543201234567, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_INT64(v0, v1);
+ TEST_ASSERT_EQUAL_INT64(0x9876543201234567, v1);
+ TEST_ASSERT_EQUAL_INT64(v0, 0x9876543201234567);
+ TEST_ASSERT_EQUAL_INT64(*p0, v1);
+ TEST_ASSERT_EQUAL_INT64(*p0, *p1);
+ TEST_ASSERT_EQUAL_INT64(*p0, 0x9876543201234567);
+#endif
+}
+
+
+void testNotEqualHex64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 v0, v1;
+
+ v0 = 9000000000;
+ v1 = 9100000000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX64(v0, v1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualUint64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_UINT64 v0, v1;
+
+ v0 = 9000000000;
+ v1 = 9100000000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_UINT64(v0, v1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualInt64s(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 v0, v1;
+
+ v0 = -9000000000;
+ v1 = 9100000000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_INT64(v0, v1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testNotEqualHex64sIfSigned(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ UNITY_INT64 v0, v1;
+
+ v0 = -9000000000;
+ v1 = 9000000000;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_HEX64(v0, v1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64sWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_HEX64_WITHIN(1, 0x7FFFFFFFFFFFFFFF,0x7FFFFFFFFFFFFFFE);
+ TEST_ASSERT_HEX64_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_HEX64_WITHIN(5, 5000, 5005);
+#endif
+}
+
+void testHEX32sWithinDeltaShouldIgnoreSign(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_HEX64_WITHIN(1, 0x7FFFFFFFFFFFFFFF,0x8000000000000000);
+#endif
+}
+
+void testHEX64sNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_WITHIN(1, 0x7FFFFFFFFFFFFFFF, 0x7FFFFFFFFFFFFFFC);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testHEX64sNotWithinDeltaEvenThoughASignedIntWouldPass(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_HEX64_WITHIN(5, 1, -1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUINT64sWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_UINT64_WITHIN(1, 0x7FFFFFFFFFFFFFFF,0x7FFFFFFFFFFFFFFE);
+ TEST_ASSERT_UINT64_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_UINT64_WITHIN(5, 5000, 5005);
+#endif
+}
+
+void testUINT64sNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_WITHIN(1, 0x7FFFFFFFFFFFFFFF, 0x7FFFFFFFFFFFFFFC);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testUINT64sNotWithinDeltaEvenThoughASignedIntWouldPass(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_UINT64_WITHIN(5, 1, -1);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testINT64sWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ TEST_ASSERT_INT64_WITHIN(1, 0x7FFFFFFFFFFFFFFF,0x7FFFFFFFFFFFFFFE);
+ TEST_ASSERT_INT64_WITHIN(5, 5000, 4996);
+ TEST_ASSERT_INT64_WITHIN(5, 5000, 5005);
+#endif
+}
+
+void testINT64sNotWithinDelta(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_WITHIN(1, 0x7FFFFFFFFFFFFFFF, 0x7FFFFFFFFFFFFFFC);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testINT64sNotWithinDeltaAndDifferenceOverflows(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_INT64_WITHIN(1, 0x8000000000000000, 0x7FFFFFFFFFFFFFFF);
+ VERIFY_FAILS_END
+#endif
+}
+
+void testPrintNumbersInt64(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ #ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+ #else
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("0", 0);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("10000000000", 10000000000);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("-9223372036854775808", (UNITY_INT)0x8000000000000000);
+ TEST_ASSERT_EQUAL_PRINT_NUMBERS("-1", (UNITY_INT)0xFFFFFFFFFFFFFFFF);
+ #endif
+#endif
+}
+
+void testPrintNumbersUInt64(void)
+{
+#ifndef UNITY_SUPPORT_64
+ TEST_IGNORE();
+#else
+ #ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+ #else
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("0", 0);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("70000000000", 70000000000);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("9223372036854775808", (UNITY_UINT)0x8000000000000000);
+ TEST_ASSERT_EQUAL_PRINT_UNSIGNED_NUMBERS("18446744073709551615", (UNITY_UINT)0xFFFFFFFFFFFFFFFF);
+ #endif
+#endif
+}
diff --git a/deps/Unity/test/tests/test_unity_memory.c b/deps/Unity/test/tests/test_unity_memory.c
new file mode 100644
index 0000000..b3cff13
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_memory.c
@@ -0,0 +1,81 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testEqualMemory(void)
+{
+ const char *testString = "whatever";
+
+ TEST_ASSERT_EQUAL_MEMORY(testString, testString, 8);
+ TEST_ASSERT_EQUAL_MEMORY("whatever", "whatever", 8);
+ TEST_ASSERT_EQUAL_MEMORY("whatever", testString, 8);
+ TEST_ASSERT_EQUAL_MEMORY(testString, "whatever", 8);
+ TEST_ASSERT_EQUAL_MEMORY(testString, "whatever", 2);
+ TEST_ASSERT_EQUAL_MEMORY(NULL, NULL, 1);
+}
+
+void testNotEqualMemory1(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_MEMORY("foo", "bar", 3);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualMemory2(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_MEMORY("fool", "food", 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualMemory3(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_MEMORY(NULL, "food", 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualMemory4(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_MEMORY("fool", NULL, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualMemoryLengthZero(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_MEMORY(NULL, NULL, 0);
+ VERIFY_FAILS_END
+}
diff --git a/deps/Unity/test/tests/test_unity_parameterized.c b/deps/Unity/test/tests/test_unity_parameterized.c
new file mode 100644
index 0000000..aa9f9c1
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_parameterized.c
@@ -0,0 +1,308 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include <setjmp.h>
+#include <stdio.h>
+#include "unity.h"
+#include "types_for_test.h"
+
+/* Include Passthroughs for Linking Tests */
+void putcharSpy(int c) { (void)putchar(c);}
+void flushSpy(void) {}
+
+#define EXPECT_ABORT_BEGIN \
+ if (TEST_PROTECT()) \
+ {
+
+#define VERIFY_FAILS_END \
+ } \
+ Unity.CurrentTestFailed = (Unity.CurrentTestFailed != 0) ? 0 : 1; \
+ if (Unity.CurrentTestFailed == 1) { \
+ SetToOneMeanWeAlreadyCheckedThisGuy = 1; \
+ UnityPrintNumberUnsigned(Unity.CurrentTestLineNumber); \
+ UNITY_OUTPUT_CHAR(':'); \
+ UnityPrint(Unity.CurrentTestName); \
+ UnityPrint(":FAIL: [[[[ Test Should Have Failed But Did Not ]]]]"); \
+ UNITY_OUTPUT_CHAR('\n'); \
+ }
+
+#define VERIFY_IGNORES_END \
+ } \
+ Unity.CurrentTestFailed = (Unity.CurrentTestIgnored != 0) ? 0 : 1; \
+ Unity.CurrentTestIgnored = 0; \
+ if (Unity.CurrentTestFailed == 1) { \
+ SetToOneMeanWeAlreadyCheckedThisGuy = 1; \
+ UnityPrintNumberUnsigned(Unity.CurrentTestLineNumber); \
+ UNITY_OUTPUT_CHAR(':'); \
+ UnityPrint(Unity.CurrentTestName); \
+ UnityPrint(":FAIL: [[[[ Test Should Have Ignored But Did Not ]]]]"); \
+ UNITY_OUTPUT_CHAR('\n'); \
+ }
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+static unsigned NextExpectedStringIndex;
+static unsigned NextExpectedCharIndex;
+static unsigned NextExpectedSpaceIndex;
+
+void suiteSetUp(void)
+{
+ NextExpectedStringIndex = 0;
+ NextExpectedCharIndex = 0;
+ NextExpectedSpaceIndex = 0;
+}
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ if (SetToOneToFailInTearDown == 1)
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+TEST_CASE(0)
+TEST_CASE(44)
+TEST_CASE((90)+9)
+void test_TheseShouldAllPass(int Num)
+{
+ TEST_ASSERT_TRUE(Num < 100);
+}
+
+TEST_CASE(3)
+TEST_CASE(77)
+TEST_CASE( (99) + 1 - (1))
+void test_TheseShouldAllFail(int Num)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_TRUE(Num > 100);
+ VERIFY_FAILS_END
+}
+
+TEST_CASE(1)
+TEST_CASE(44)
+TEST_CASE(99)
+TEST_CASE(98)
+void test_TheseAreEveryOther(int Num)
+{
+ if (Num & 1)
+ {
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_TRUE(Num > 100);
+ VERIFY_FAILS_END
+ }
+ else
+ {
+ TEST_ASSERT_TRUE(Num < 100);
+ }
+}
+
+void test_NormalPassesStillWork(void)
+{
+ TEST_ASSERT_TRUE(1);
+}
+
+void test_NormalFailsStillWork(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_TRUE(0);
+ VERIFY_FAILS_END
+}
+
+TEST_CASE(0, "abc")
+TEST_CASE(1, "{")
+TEST_CASE(2, "}")
+TEST_CASE(3, ";")
+TEST_CASE(4, "\"quoted\"")
+void test_StringsArePreserved(unsigned index, const char * str)
+{
+ static const char * const expected[] =
+ {
+ "abc",
+ "{",
+ "}",
+ ";",
+ "\"quoted\""
+ };
+
+ /* Ensure that no test cases are skipped by tracking the next expected index */
+ TEST_ASSERT_EQUAL_UINT32(NextExpectedStringIndex, index);
+ TEST_ASSERT_LESS_THAN(sizeof(expected) / sizeof(expected[0]), index);
+ TEST_ASSERT_EQUAL_STRING(expected[index], str);
+
+ NextExpectedStringIndex++;
+}
+
+TEST_CASE(0, 'x')
+TEST_CASE(1, '{')
+TEST_CASE(2, '}')
+TEST_CASE(3, ';')
+TEST_CASE(4, '\'')
+TEST_CASE(5, '"')
+void test_CharsArePreserved(unsigned index, char c)
+{
+ static const char expected[] =
+ {
+ 'x',
+ '{',
+ '}',
+ ';',
+ '\'',
+ '"'
+ };
+
+ /* Ensure that no test cases are skipped by tracking the next expected index */
+ TEST_ASSERT_EQUAL_UINT32(NextExpectedCharIndex, index);
+ TEST_ASSERT_LESS_THAN(sizeof(expected) / sizeof(expected[0]), index);
+ TEST_ASSERT_EQUAL(expected[index], c);
+
+ NextExpectedCharIndex++;
+}
+
+TEST_RANGE([0, 10, 2])
+void test_SingleRange(unsigned value)
+{
+ TEST_ASSERT_EQUAL(0, value % 2);
+ TEST_ASSERT_LESS_OR_EQUAL(10, value);
+}
+
+TEST_RANGE([1, 2, 1], [2, 1, -1])
+void test_TwoRanges(unsigned first, unsigned second)
+{
+ TEST_ASSERT_LESS_OR_EQUAL(4, first * second);
+}
+
+TEST_RANGE(<0, 10, 2>)
+void test_SingleExclusiveRange(unsigned value)
+{
+ TEST_ASSERT_EQUAL(0, value % 2);
+ TEST_ASSERT_LESS_THAN(10, value);
+}
+
+TEST_RANGE([2, 4, 1], <1, 2, 1>)
+void test_BothInclusiveAndExclusiveRange(unsigned first, unsigned second)
+{
+ TEST_ASSERT_LESS_THAN(first, second);
+}
+
+TEST_CASE(0,
+
+ 1)
+TEST_CASE(1,
+
+ 2
+
+ )
+TEST_RANGE([2,
+ 5 ,
+ 1], [6, 6, 1])
+TEST_CASE(
+
+ 6 , 7)
+TEST_MATRIX([7,
+ 8 ,
+
+ 9, 10],
+ [
+ 11]
+
+ )
+void test_SpaceInTestCase(unsigned index, unsigned bigger)
+{
+ TEST_ASSERT_EQUAL_UINT32(NextExpectedSpaceIndex, index);
+ TEST_ASSERT_LESS_THAN(bigger, index);
+
+ NextExpectedSpaceIndex++;
+}
+
+TEST_MATRIX([1, 5, (2*2)+1, 4])
+void test_SingleMatix(unsigned value)
+{
+ TEST_ASSERT_LESS_OR_EQUAL(10, value);
+}
+
+TEST_MATRIX([2, 5l, 4u+3, 4ul], [-2, 3])
+void test_TwoMatrices(unsigned first, signed second)
+{
+ static unsigned idx = 0;
+ static const unsigned expected[] =
+ {
+ // -2 3
+ -4, 6, // 2
+ -10, 15, // 5
+ -14, 21, // 7
+ -8, 12, // 4
+ };
+ TEST_ASSERT_EQUAL_INT(expected[idx++], first * second);
+}
+
+TEST_MATRIX(["String1", "String,2", "Stri" "ng3", "String[4]", "String\"5\""], [-5, 12.5f])
+void test_StringsAndNumbersMatrices(const char* str, float number)
+{
+ static unsigned idx = 0;
+ static const char* expected[] =
+ {
+ "String1_-05.00",
+ "String1_+12.50",
+ "String,2_-05.00",
+ "String,2_+12.50",
+ "String3_-05.00",
+ "String3_+12.50",
+ "String[4]_-05.00",
+ "String[4]_+12.50",
+ "String\"5\"_-05.00",
+ "String\"5\"_+12.50",
+ };
+ char buf[200] = {0};
+ snprintf(buf, sizeof(buf), "%s_%+06.2f", str, number);
+ TEST_ASSERT_EQUAL_STRING(expected[idx++], buf);
+}
+
+TEST_MATRIX(
+ [ENUM_A, ENUM_4, ENUM_C],
+ [test_arr[0], 7.8f, test_arr[2]],
+ ['a', 'f', '[', ']', '\'', '"'],
+)
+void test_EnumCharAndArrayMatrices(test_enum_t e, float n, char c)
+{
+ static unsigned enum_idx = 0;
+ static const test_enum_t exp_enum[3] = {
+ ENUM_A, ENUM_4, ENUM_C,
+ };
+
+ static unsigned float_idx = 0;
+ float exp_float[3] = {0};
+ exp_float[0] = test_arr[0];
+ exp_float[1] = 7.8f;
+ exp_float[2] = test_arr[2];
+
+ static unsigned char_idx = 0;
+ static const test_enum_t exp_char[] = {
+ 'a', 'f', '[', ']', '\'', '"'
+ };
+
+ TEST_ASSERT_EQUAL_INT(exp_enum[enum_idx], e);
+ TEST_ASSERT_EQUAL_FLOAT(exp_float[float_idx], n);
+ TEST_ASSERT_EQUAL_CHAR(exp_char[char_idx], c);
+
+ char_idx = (char_idx + 1) % 6;
+ if (char_idx == 0.0f)
+ {
+ float_idx = (float_idx + 1) % 3;
+ if (float_idx == 0.0f)
+ {
+ enum_idx = (enum_idx + 1) % 3;
+ }
+ }
+}
diff --git a/deps/Unity/test/tests/test_unity_parameterizedDemo.c b/deps/Unity/test/tests/test_unity_parameterizedDemo.c
new file mode 100644
index 0000000..83dfad6
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_parameterizedDemo.c
@@ -0,0 +1,21 @@
+#include "unity.h"
+
+/* Support for Meta Test Rig */
+#ifndef TEST_CASE
+#define TEST_CASE(...)
+#endif
+#ifndef TEST_RANGE
+#define TEST_RANGE(...)
+#endif
+#ifndef TEST_MATRIX
+#define TEST_MATRIX(...)
+#endif
+
+TEST_CASE(1, 2, 5)
+TEST_CASE(10, 7, 20)
+TEST_RANGE([3, 4, 1], [10, 5, -2], <30, 31, 1>)
+TEST_MATRIX([3, 4, 7], [10, 8, 2, 1],[30u, 20.0f])
+void test_demoParamFunction(int a, int b, int c)
+{
+ TEST_ASSERT_GREATER_THAN_INT(a + b, c);
+}
diff --git a/deps/Unity/test/tests/test_unity_strings.c b/deps/Unity/test/tests/test_unity_strings.c
new file mode 100644
index 0000000..964c553
--- /dev/null
+++ b/deps/Unity/test/tests/test_unity_strings.c
@@ -0,0 +1,329 @@
+/* ==========================================
+ Unity Project - A Test Framework for C
+ Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
+ [Released under MIT License. Please refer to license.txt for details]
+========================================== */
+
+#include "unity.h"
+#define TEST_INSTANCES
+#include "self_assessment_utils.h"
+
+static int SetToOneToFailInTearDown;
+static int SetToOneMeanWeAlreadyCheckedThisGuy;
+
+void setUp(void)
+{
+ SetToOneToFailInTearDown = 0;
+ SetToOneMeanWeAlreadyCheckedThisGuy = 0;
+}
+
+void tearDown(void)
+{
+ endPutcharSpy(); /* Stop suppressing test output */
+ if (SetToOneToFailInTearDown == 1)
+ {
+ /* These will be skipped internally if already failed/ignored */
+ TEST_FAIL_MESSAGE("<= Failed in tearDown");
+ TEST_IGNORE_MESSAGE("<= Ignored in tearDown");
+ }
+ if ((SetToOneMeanWeAlreadyCheckedThisGuy == 0) && (Unity.CurrentTestFailed > 0))
+ {
+ UnityPrint(": [[[[ Test Should Have Passed But Did Not ]]]]");
+ UNITY_OUTPUT_CHAR('\n');
+ }
+}
+
+void testEqualStrings(void)
+{
+ const char *testString = "foo";
+
+ TEST_ASSERT_EQUAL_STRING(testString, testString);
+ TEST_ASSERT_EQUAL_STRING_MESSAGE("foo", "foo", "foo isn't foo");
+ TEST_ASSERT_EQUAL_STRING("foo", testString);
+ TEST_ASSERT_EQUAL_STRING(testString, "foo");
+ TEST_ASSERT_EQUAL_STRING("", "");
+}
+
+void testEqualStringsLen(void)
+{
+ const char *testString = "foobar";
+ TEST_ASSERT_EQUAL_STRING_LEN(testString, testString, strlen(testString));
+ TEST_ASSERT_EQUAL_STRING_LEN_MESSAGE("foobar", "foobaz", 5, "fooba isn't fooba");
+ TEST_ASSERT_EQUAL_STRING_LEN("foo", testString, 3);
+ TEST_ASSERT_EQUAL_STRING_LEN(testString, "foo", 3);
+ TEST_ASSERT_EQUAL_STRING_LEN("", "", 3);
+}
+
+void testEqualStringsWithCarriageReturnsAndLineFeeds(void)
+{
+ const char *testString = "foo\r\nbar";
+
+ TEST_ASSERT_EQUAL_STRING(testString, testString);
+ TEST_ASSERT_EQUAL_STRING("foo\r\nbar", "foo\r\nbar");
+ TEST_ASSERT_EQUAL_STRING("foo\r\nbar", testString);
+ TEST_ASSERT_EQUAL_STRING(testString, "foo\r\nbar");
+ TEST_ASSERT_EQUAL_STRING("", "");
+}
+
+void testNotEqualString1(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("foo", "bar");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen1(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN("foobar", "foobaz", 6);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString2(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("foo", "");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen2(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN("foo", "", 3);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString3(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("", "bar");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen3(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN("", "bar", 3);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString4(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("bar\r", "bar\n");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen4(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN("ba\r\x16", "ba\r\n", 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString5(void)
+{
+ const char str1[] = { 0x41, 0x42, 0x03, 0x00 };
+ const char str2[] = { 0x41, 0x42, 0x04, 0x00 };
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING(str1, str2);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString_ExpectedStringIsNull(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING(NULL, "bar");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen_ExpectedStringIsNull(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN(NULL, "bar", 1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString_ActualStringIsNull(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("foo", NULL);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringLen_ActualStringIsNull(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_LEN("foo", NULL, 1);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString_ExpectedStringIsLonger(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("foo2", "foo");
+ VERIFY_FAILS_END
+}
+
+void testNotEqualString_ActualStringIsLonger(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING("foo", "foo2");
+ VERIFY_FAILS_END
+}
+
+void testEqualStringArrays(void)
+{
+ const char *testStrings[] = { "foo", "boo", "woo", "moo" };
+ const char *expStrings[] = { "foo", "boo", "woo", "zoo" };
+
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, expStrings, 3);
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 3);
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 2);
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 1);
+}
+
+void testNotEqualStringArray1(void)
+{
+ const char *testStrings[] = { "foo", "boo", "woo", "moo" };
+ const char *expStrings[] = { "foo", "boo", "woo", "zoo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringArray2(void)
+{
+ const char *testStrings[] = { "zoo", "boo", "woo", "moo" };
+ const char *expStrings[] = { "foo", "boo", "woo", "moo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringArray3(void)
+{
+ const char *testStrings[] = { "foo", "boo", "woo", NULL };
+ const char *expStrings[] = { "foo", "boo", "woo", "zoo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringArray4(void)
+{
+ const char *testStrings[] = { "foo", "boo", "woo", "moo" };
+ const char *expStrings[] = { "foo", NULL, "woo", "moo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringArray5(void)
+{
+ const char **testStrings = NULL;
+ const char *expStrings[] = { "foo", "boo", "woo", "zoo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringArray6(void)
+{
+ const char *testStrings[] = { "foo", "boo", "woo", "zoo" };
+ const char **expStrings = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testEqualStringArrayIfBothNulls(void)
+{
+ const char **testStrings = NULL;
+ const char **expStrings = NULL;
+
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 4);
+}
+
+void testNotEqualStringArrayLengthZero(void)
+{
+ const char *testStrings[] = {NULL};
+ const char **expStrings = NULL;
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EQUAL_STRING_ARRAY(expStrings, testStrings, 0);
+ VERIFY_FAILS_END
+}
+
+void testEqualStringEachEqual(void)
+{
+ const char *testStrings1[] = { "foo", "foo", "foo", "foo" };
+ const char *testStrings2[] = { "boo", "boo", "boo", "zoo" };
+ const char *testStrings3[] = { "", "", "", "" };
+
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings1, 4);
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings1, 1);
+ TEST_ASSERT_EACH_EQUAL_STRING("boo", testStrings2, 3);
+ TEST_ASSERT_EACH_EQUAL_STRING("", testStrings3, 4);
+}
+
+void testNotEqualStringEachEqual1(void)
+{
+ const char *testStrings[] = { "foo", "foo", "foo", "moo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringEachEqual2(void)
+{
+ const char *testStrings[] = { "boo", "foo", "foo", "foo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringEachEqual3(void)
+{
+ const char *testStrings[] = { "foo", "foo", "foo", NULL };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringEachEqual4(void)
+{
+ const char *testStrings[] = { "foo", "foo", "woo", "foo" };
+
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", testStrings, 4);
+ VERIFY_FAILS_END
+}
+
+void testNotEqualStringEachEqual5(void)
+{
+ EXPECT_ABORT_BEGIN
+ TEST_ASSERT_EACH_EQUAL_STRING("foo", NULL, 1);
+ VERIFY_FAILS_END
+}
+
+void testCstringsEscapeSequence(void)
+{
+#ifndef USING_OUTPUT_SPY
+ TEST_IGNORE();
+#else
+ startPutcharSpy();
+ UnityPrint("\x16\x10");
+ endPutcharSpy();
+ TEST_ASSERT_EQUAL_STRING("\\x16\\x10", getBufferPutcharSpy());
+#endif
+}
diff --git a/deps/Unity/test/tests/types_for_test.h b/deps/Unity/test/tests/types_for_test.h
new file mode 100644
index 0000000..6da4e51
--- /dev/null
+++ b/deps/Unity/test/tests/types_for_test.h
@@ -0,0 +1,14 @@
+#pragma once
+
+typedef enum {
+ ENUM_A,
+ ENUM_2,
+ ENUM_C,
+ ENUM_4,
+} test_enum_t;
+
+static const float test_arr[] = {
+ 1.2f,
+ 2.3f,
+ 3.4f,
+};