mirror of
https://github.com/ThrowTheSwitch/Unity.git
synced 2026-01-23 08:25:58 +01:00
Compare commits
362 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0b899aec14 | ||
|
|
d8eb8414f4 | ||
|
|
05994f5061 | ||
|
|
fcab680286 | ||
|
|
3c1c5338af | ||
|
|
9e7c259822 | ||
|
|
ce132da37f | ||
|
|
ffb51ecb7e | ||
|
|
0b078cdb6e | ||
|
|
53e1449f89 | ||
|
|
830f77f9ee | ||
|
|
038dd81213 | ||
|
|
99fb90a939 | ||
|
|
b7469138a5 | ||
|
|
418c1635f2 | ||
|
|
386c540510 | ||
|
|
723b9fee53 | ||
|
|
76c3755fe3 | ||
|
|
c3afe99a77 | ||
|
|
98045925af | ||
|
|
62d0e7d68e | ||
|
|
52d5f59b72 | ||
|
|
09acb0b64f | ||
|
|
e640949eb3 | ||
|
|
6fecc8eb38 | ||
|
|
777ad17420 | ||
|
|
8bbfe1f5ac | ||
|
|
0126e4804c | ||
|
|
b4b1994bd7 | ||
|
|
fedd1495c2 | ||
|
|
a6a4e9766d | ||
|
|
06a668579f | ||
|
|
9760c4f14f | ||
|
|
f5ff3504b5 | ||
|
|
b0032caca4 | ||
|
|
dcb30731f8 | ||
|
|
77c394e975 | ||
|
|
87f382fbb2 | ||
|
|
97f6d55256 | ||
|
|
cf949f45ca | ||
|
|
fd80d514ee | ||
|
|
9f4b2251de | ||
|
|
c5413ce16b | ||
|
|
cdfb7e092c | ||
|
|
ae8b98e80b | ||
|
|
ec31dfacad | ||
|
|
a2af08c773 | ||
|
|
b397a72e89 | ||
|
|
2a2a4d19c5 | ||
|
|
a78e6c8566 | ||
|
|
2485d49d13 | ||
|
|
d603ccdc3b | ||
|
|
10fd84f02b | ||
|
|
ff479e9aa0 | ||
|
|
87d8de6d55 | ||
|
|
615cf2349e | ||
|
|
8c4ae7aacd | ||
|
|
2c3e75e859 | ||
|
|
371e062555 | ||
|
|
f61a7ea8e4 | ||
|
|
a67cb27dd4 | ||
|
|
99199515fd | ||
|
|
3e4dfec147 | ||
|
|
75754de04e | ||
|
|
6e3ecbf92b | ||
|
|
d7a05a56df | ||
|
|
6a86a83207 | ||
|
|
3ee46e3da3 | ||
|
|
a58054b013 | ||
|
|
71e77ce6fb | ||
|
|
bad429428d | ||
|
|
5e9acef74f | ||
|
|
22a047ebb5 | ||
|
|
3da0b4652c | ||
|
|
3b80ba73fe | ||
|
|
8a3a31f7b3 | ||
|
|
c101cfa7d2 | ||
|
|
218fa2cbe8 | ||
|
|
d0714178a8 | ||
|
|
04858be38f | ||
|
|
622918a7df | ||
|
|
3b5b491860 | ||
|
|
e449210977 | ||
|
|
f3b87bb91c | ||
|
|
e276e1a458 | ||
|
|
d271759bcd | ||
|
|
47b630391d | ||
|
|
fb45e3010b | ||
|
|
ef0cf704d9 | ||
|
|
461c6b3978 | ||
|
|
3f71d10b2e | ||
|
|
f39c856a37 | ||
|
|
5e3fb620fb | ||
|
|
1d1de74153 | ||
|
|
5c5773720f | ||
|
|
e59185cd8d | ||
|
|
86caf7ec97 | ||
|
|
e3132cdddd | ||
|
|
c5c36ab29f | ||
|
|
2f79302d5c | ||
|
|
de1cb75e4c | ||
|
|
3fb17f33e2 | ||
|
|
e2682ae43a | ||
|
|
c3d7662a1e | ||
|
|
ded22fef63 | ||
|
|
37a0f7184c | ||
|
|
2aaf3c4504 | ||
|
|
d34f72282f | ||
|
|
179b492e18 | ||
|
|
5dd5931114 | ||
|
|
94dc637d03 | ||
|
|
e40b0bf2b5 | ||
|
|
efd02920ca | ||
|
|
fbded74349 | ||
|
|
3fb86421b2 | ||
|
|
8072c5c946 | ||
|
|
32e6d93ab0 | ||
|
|
a303e08859 | ||
|
|
34ebd82d8c | ||
|
|
9c82fac380 | ||
|
|
cf5b2d2568 | ||
|
|
74d47e8afa | ||
|
|
354e2b4da6 | ||
|
|
60b23dc8a4 | ||
|
|
e1dca8fa48 | ||
|
|
3f334b8be6 | ||
|
|
be87d790c7 | ||
|
|
b75b19c969 | ||
|
|
15631f1c78 | ||
|
|
8d044e60c6 | ||
|
|
368a7d8970 | ||
|
|
d16c27b085 | ||
|
|
748efa26b5 | ||
|
|
86b19304ed | ||
|
|
eb0bd42f0d | ||
|
|
addd60edab | ||
|
|
277e844bed | ||
|
|
d10cf6645d | ||
|
|
68cc45a918 | ||
|
|
5fc72fbca1 | ||
|
|
ff697ad29c | ||
|
|
ac427b28fc | ||
|
|
2d8a69e0d1 | ||
|
|
cb8744c496 | ||
|
|
c19e3f99ce | ||
|
|
9fdcc2d3ff | ||
|
|
d9b0edf282 | ||
|
|
0793de9ef1 | ||
|
|
9842a4d03d | ||
|
|
77008edca9 | ||
|
|
210b7759dd | ||
|
|
1748f00fc7 | ||
|
|
8227ea2c36 | ||
|
|
bcbb476e20 | ||
|
|
8ce41ede72 | ||
|
|
53916f823c | ||
|
|
5cb2b63490 | ||
|
|
50db1a7e67 | ||
|
|
e1381748f8 | ||
|
|
380103ab8c | ||
|
|
7df6cca794 | ||
|
|
75e88a9bc4 | ||
|
|
fc14856321 | ||
|
|
7e3804545c | ||
|
|
f4251bf87d | ||
|
|
bc7d89a891 | ||
|
|
e6f38c2792 | ||
|
|
31ab99b860 | ||
|
|
29af4c0e0d | ||
|
|
964a58c053 | ||
|
|
f2711a87a6 | ||
|
|
822e244bd4 | ||
|
|
c2c42ce14f | ||
|
|
9578a382cc | ||
|
|
46263fc148 | ||
|
|
2939c420ed | ||
|
|
7514b89fa6 | ||
|
|
3ac73efe62 | ||
|
|
1100c5d8f0 | ||
|
|
3afc0412e1 | ||
|
|
0892db2376 | ||
|
|
3e82c0a96f | ||
|
|
0000f1e6d2 | ||
|
|
a2f25d05d8 | ||
|
|
a54d58a8fd | ||
|
|
45020b0d3b | ||
|
|
bc72eeb211 | ||
|
|
6b2eb52468 | ||
|
|
4661e67233 | ||
|
|
af4c20fa20 | ||
|
|
c10f87f1e6 | ||
|
|
c7185b3a5a | ||
|
|
e89b281e43 | ||
|
|
b1fd5ad887 | ||
|
|
ab9f8d0959 | ||
|
|
c30730faf6 | ||
|
|
f2d826c7c5 | ||
|
|
bd4d35ddd0 | ||
|
|
7dbfc4be56 | ||
|
|
10f10b5e58 | ||
|
|
a59db2bdbf | ||
|
|
2b250055bc | ||
|
|
06ddace18d | ||
|
|
885ae9638e | ||
|
|
ae3aad7b89 | ||
|
|
8168382b91 | ||
|
|
c9b1d217fd | ||
|
|
ca1c7fa823 | ||
|
|
01a907393a | ||
|
|
18430d3b4f | ||
|
|
197bf351ae | ||
|
|
e9f9638497 | ||
|
|
071044bdd6 | ||
|
|
d70047881e | ||
|
|
2697770ae9 | ||
|
|
6a1c0590a9 | ||
|
|
fc7317f103 | ||
|
|
94446cdb5e | ||
|
|
2b0d093837 | ||
|
|
25c15f632e | ||
|
|
7514de0582 | ||
|
|
93fbc3fbd0 | ||
|
|
9340582797 | ||
|
|
89465c88b0 | ||
|
|
f51e658e8a | ||
|
|
480d505cd7 | ||
|
|
0bd6bf7b2b | ||
|
|
f69fbe8a95 | ||
|
|
d01e32299e | ||
|
|
52ff8613a2 | ||
|
|
2191b2ba8e | ||
|
|
8507757c6a | ||
|
|
aecc642594 | ||
|
|
2663cb9d0d | ||
|
|
6315c4c4c3 | ||
|
|
49ffac33ec | ||
|
|
0dafa0b306 | ||
|
|
a78c799701 | ||
|
|
ead95b3ab8 | ||
|
|
3e4d064c42 | ||
|
|
9dc7cb1b5c | ||
|
|
076f0fff56 | ||
|
|
145691519b | ||
|
|
9ef1088eb7 | ||
|
|
b723c9f250 | ||
|
|
d451148907 | ||
|
|
bc2ab233ee | ||
|
|
9d1ffe26d6 | ||
|
|
38c48704c5 | ||
|
|
a6e9f85f71 | ||
|
|
69cebb5c30 | ||
|
|
5074a3d8b2 | ||
|
|
92a345b264 | ||
|
|
4f8656f658 | ||
|
|
95ccc6edc1 | ||
|
|
5918ee0cdf | ||
|
|
a284984365 | ||
|
|
516f7be045 | ||
|
|
38d8263741 | ||
|
|
5db2a3dbd9 | ||
|
|
f433480f7f | ||
|
|
8e0f54d23b | ||
|
|
d09f4953ff | ||
|
|
8a77f48634 | ||
|
|
39fbd13cae | ||
|
|
58be52f088 | ||
|
|
5cd1c33b0e | ||
|
|
6b657c6f17 | ||
|
|
28bf7954f2 | ||
|
|
e8ba63cf7b | ||
|
|
100c73d37f | ||
|
|
eab9283a98 | ||
|
|
7dd21c333e | ||
|
|
695dd04d53 | ||
|
|
27f631aaa8 | ||
|
|
50ce8a880a | ||
|
|
96127581a0 | ||
|
|
be765649f1 | ||
|
|
f1100dd19a | ||
|
|
b4ab81bbe9 | ||
|
|
e84cb29acc | ||
|
|
7d2bf62b7e | ||
|
|
01cbce870a | ||
|
|
e4dfeaa14d | ||
|
|
7cc3cf478b | ||
|
|
e025b8cd1d | ||
|
|
e2e549a22f | ||
|
|
e0d52d1a79 | ||
|
|
56f1646087 | ||
|
|
8ba35a0e52 | ||
|
|
5d2ef07054 | ||
|
|
c64cc7d4f4 | ||
|
|
f60ab920c9 | ||
|
|
ea5e51ffcc | ||
|
|
020a531e4b | ||
|
|
bfd7828e66 | ||
|
|
9987824da7 | ||
|
|
031f3bbe45 | ||
|
|
a6a35b78ae | ||
|
|
e72dfafd44 | ||
|
|
fb4b139043 | ||
|
|
f0e4571c96 | ||
|
|
ccb7faf3bd | ||
|
|
18e4fbe2ae | ||
|
|
6a1d2e8d44 | ||
|
|
ac3cde30f5 | ||
|
|
1f6c782040 | ||
|
|
2c5d09bf20 | ||
|
|
40af5e23eb | ||
|
|
199b13c099 | ||
|
|
ceecf1fae8 | ||
|
|
d915bf7ae5 | ||
|
|
e2ee98e3d6 | ||
|
|
38e1ee872c | ||
|
|
1994bf9d68 | ||
|
|
7a43766586 | ||
|
|
ea51e2b35c | ||
|
|
0937bf728c | ||
|
|
e038ae2ade | ||
|
|
436a46d8ef | ||
|
|
2480a6124e | ||
|
|
5f67ac6ab2 | ||
|
|
37271e8a13 | ||
|
|
25804f3ab4 | ||
|
|
456759296b | ||
|
|
fe950b9fa3 | ||
|
|
8efa8ffc62 | ||
|
|
d9cd6988f3 | ||
|
|
4dfb512a27 | ||
|
|
7a1157d6f6 | ||
|
|
dc9c7a7b4b | ||
|
|
9bada282f4 | ||
|
|
a6b925a01f | ||
|
|
91a2353526 | ||
|
|
0760230829 | ||
|
|
b4aca70fd9 | ||
|
|
62f6cb247a | ||
|
|
4325773e76 | ||
|
|
29803b65ac | ||
|
|
53f0f95ef8 | ||
|
|
287e076962 | ||
|
|
a6d3f3a59a | ||
|
|
2d4e32cda1 | ||
|
|
74ba70283a | ||
|
|
8ff74d6000 | ||
|
|
774da10e00 | ||
|
|
629b86d541 | ||
|
|
0914d80121 | ||
|
|
5ee55fefda | ||
|
|
38c387b76f | ||
|
|
17d4ea92e1 | ||
|
|
031b1ba469 | ||
|
|
df78aade4b | ||
|
|
a7e8797e0c | ||
|
|
94a3008a9d | ||
|
|
b119919c4f | ||
|
|
91bcbe186d | ||
|
|
8caade7e68 | ||
|
|
1381a1a4cb | ||
|
|
2593c31bb7 | ||
|
|
60def109a7 | ||
|
|
cc909efed3 |
27
.editorconfig
Normal file
27
.editorconfig
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
###############################################################################
|
||||||
|
# Unity Project - A Test Framework for C
|
||||||
|
# .editorconfig - F. Zahn 2019
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
# This is the topmost .editorconfig file
|
||||||
|
root = true
|
||||||
|
|
||||||
|
# Settings that apply to all languages / files
|
||||||
|
[*]
|
||||||
|
charset = utf-8
|
||||||
|
indent_size = 4
|
||||||
|
indent_style = space
|
||||||
|
insert_final_newline = true
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
|
||||||
|
[*.md]
|
||||||
|
trim_trailing_whitespace = false
|
||||||
|
|
||||||
|
[*.txt]
|
||||||
|
trim_trailing_whitespace = false
|
||||||
|
|
||||||
|
[*.rb]
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
[*.yml]
|
||||||
|
indent_size = 2
|
||||||
1
.gitattributes
vendored
1
.gitattributes
vendored
@@ -16,6 +16,7 @@
|
|||||||
*.md text
|
*.md text
|
||||||
makefile text
|
makefile text
|
||||||
rakefile text
|
rakefile text
|
||||||
|
meson.build text
|
||||||
|
|
||||||
|
|
||||||
#These files are binary and should not be normalized
|
#These files are binary and should not be normalized
|
||||||
|
|||||||
32
.github/workflows/main.yml
vendored
Normal file
32
.github/workflows/main.yml
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
---
|
||||||
|
# Continuous Integration Workflow: Test case suite run + validation build check
|
||||||
|
name: CI
|
||||||
|
|
||||||
|
# Controls when the action will run.
|
||||||
|
# Triggers the workflow on push or pull request events but only for the master branch
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ master ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
# Job: Unit test suite
|
||||||
|
unit-tests:
|
||||||
|
name: "Unit Tests"
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
# Install Ruby Testing Tools
|
||||||
|
- name: Setup Ruby Testing Tools
|
||||||
|
run: |
|
||||||
|
sudo gem install rspec
|
||||||
|
sudo gem install rubocop -v 0.57.2
|
||||||
|
|
||||||
|
# Checks out repository under $GITHUB_WORKSPACE
|
||||||
|
- name: Checkout Latest Repo
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
# Run Tests
|
||||||
|
- name: Run All Unit Tests
|
||||||
|
run: |
|
||||||
|
cd test && rake ci
|
||||||
4
.gitignore
vendored
4
.gitignore
vendored
@@ -1,4 +1,5 @@
|
|||||||
build/
|
build/
|
||||||
|
builddir/
|
||||||
test/sandbox
|
test/sandbox
|
||||||
.DS_Store
|
.DS_Store
|
||||||
examples/example_1/test1.exe
|
examples/example_1/test1.exe
|
||||||
@@ -7,3 +8,6 @@ examples/example_2/all_tests.exe
|
|||||||
examples/example_1/test1.out
|
examples/example_1/test1.out
|
||||||
examples/example_1/test2.out
|
examples/example_1/test2.out
|
||||||
examples/example_2/all_tests.out
|
examples/example_2/all_tests.out
|
||||||
|
examples/example_4/builddir
|
||||||
|
*.sublime-project
|
||||||
|
*.sublime-workspace
|
||||||
|
|||||||
27
.travis.yml
27
.travis.yml
@@ -1,27 +0,0 @@
|
|||||||
language: c
|
|
||||||
|
|
||||||
matrix:
|
|
||||||
include:
|
|
||||||
- os: osx
|
|
||||||
compiler: clang
|
|
||||||
osx_image: xcode7.3
|
|
||||||
- os: linux
|
|
||||||
dist: trusty
|
|
||||||
compiler: gcc
|
|
||||||
|
|
||||||
before_install:
|
|
||||||
- if [ "$TRAVIS_OS_NAME" == "osx" ]; then rvm install 2.1 && rvm use 2.1 && ruby -v; fi
|
|
||||||
- if [ "$TRAVIS_OS_NAME" == "linux" ]; then sudo apt-get install --assume-yes --quiet gcc-multilib; fi
|
|
||||||
install:
|
|
||||||
- gem install rspec
|
|
||||||
- gem install rubocop
|
|
||||||
script:
|
|
||||||
- cd test && rake ci
|
|
||||||
- make -s
|
|
||||||
- make -s DEBUG=-m32
|
|
||||||
- cd ../extras/fixture/test && rake ci
|
|
||||||
- make -s default noStdlibMalloc
|
|
||||||
- make -s C89
|
|
||||||
- cd ../../../examples/example_1 && make -s ci
|
|
||||||
- cd ../example_2 && make -s ci
|
|
||||||
- cd ../example_3 && rake
|
|
||||||
159
CMakeLists.txt
Normal file
159
CMakeLists.txt
Normal file
@@ -0,0 +1,159 @@
|
|||||||
|
###################################################################################
|
||||||
|
# #
|
||||||
|
# NAME: CMakeLists.txt #
|
||||||
|
# #
|
||||||
|
# AUTHOR: Mike Karlesky, Mark VanderVoord, Greg Williams. #
|
||||||
|
# WRITTEN BY: Michael Brockus. #
|
||||||
|
# #
|
||||||
|
# License: MIT #
|
||||||
|
# #
|
||||||
|
###################################################################################
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.12)
|
||||||
|
|
||||||
|
# Read src/unity.h file and get project version from it
|
||||||
|
set(UNITY_HEADER "src/unity.h")
|
||||||
|
|
||||||
|
file(STRINGS "${UNITY_HEADER}" UNITY_HEADER_CONTENT
|
||||||
|
REGEX "^#define UNITY_VERSION_(MAJOR|MINOR|BUILD) +[0-9]+$"
|
||||||
|
)
|
||||||
|
|
||||||
|
set(UNITY_HEADER_VERSION_MAJOR 0)
|
||||||
|
set(UNITY_HEADER_VERSION_MINOR 0)
|
||||||
|
set(UNITY_HEADER_VERSION_BUILD 0)
|
||||||
|
|
||||||
|
foreach(VERSION_LINE IN LISTS UNITY_HEADER_CONTENT)
|
||||||
|
foreach(VERSION_PART MAJOR MINOR BUILD)
|
||||||
|
string(CONCAT REGEX_STRING "#define UNITY_VERSION_"
|
||||||
|
"${VERSION_PART}"
|
||||||
|
" +([0-9]+)"
|
||||||
|
)
|
||||||
|
|
||||||
|
if(VERSION_LINE MATCHES "${REGEX_STRING}")
|
||||||
|
set(UNITY_HEADER_VERSION_${VERSION_PART} "${CMAKE_MATCH_1}")
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
project(unity
|
||||||
|
VERSION ${UNITY_HEADER_VERSION_MAJOR}.${UNITY_HEADER_VERSION_MINOR}.${UNITY_HEADER_VERSION_BUILD}
|
||||||
|
LANGUAGES C
|
||||||
|
DESCRIPTION "C Unit testing framework."
|
||||||
|
)
|
||||||
|
|
||||||
|
# Options to Build With Extras -------------------------------------------------
|
||||||
|
option(UNITY_EXTENSION_FIXTURE "Compiles Unity with the \"fixture\" extension." OFF)
|
||||||
|
option(UNITY_EXTENSION_MEMORY "Compiles Unity with the \"memory\" extension." OFF)
|
||||||
|
|
||||||
|
set(UNITY_EXTENSION_FIXTURE_ENABLED $<BOOL:${UNITY_EXTENSION_FIXTURE}>)
|
||||||
|
set(UNITY_EXTENSION_MEMORY_ENABLED $<OR:${UNITY_EXTENSION_FIXTURE_ENABLED},$<BOOL:${UNITY_EXTENSION_MEMORY}>>)
|
||||||
|
|
||||||
|
if(${UNITY_EXTENSION_FIXTURE})
|
||||||
|
message(STATUS "Unity: Bulding with the fixture extension.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(${UNITY_EXTENSION_MEMORY})
|
||||||
|
message(STATUS "Unity: Bulding with the memory extension.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Main target ------------------------------------------------------------------
|
||||||
|
add_library(${PROJECT_NAME} STATIC)
|
||||||
|
add_library(${PROJECT_NAME}::framework ALIAS ${PROJECT_NAME})
|
||||||
|
|
||||||
|
# Includes ---------------------------------------------------------------------
|
||||||
|
include(GNUInstallDirs)
|
||||||
|
include(CMakePackageConfigHelpers)
|
||||||
|
|
||||||
|
target_sources(${PROJECT_NAME}
|
||||||
|
PRIVATE
|
||||||
|
src/unity.c
|
||||||
|
$<$<BOOL:${UNITY_EXTENSION_FIXTURE_ENABLED}>:extras/fixture/src/unity_fixture.c>
|
||||||
|
$<$<BOOL:${UNITY_EXTENSION_MEMORY_ENABLED}>:extras/memory/src/unity_memory.c>
|
||||||
|
)
|
||||||
|
|
||||||
|
target_include_directories(${PROJECT_NAME}
|
||||||
|
PUBLIC
|
||||||
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/src>
|
||||||
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}>
|
||||||
|
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}>
|
||||||
|
$<BUILD_INTERFACE:$<$<BOOL:${UNITY_EXTENSION_MEMORY_ENABLED}>:${CMAKE_CURRENT_SOURCE_DIR}/extras/memory/src>>
|
||||||
|
$<BUILD_INTERFACE:$<$<BOOL:${UNITY_EXTENSION_FIXTURE_ENABLED}>:${CMAKE_CURRENT_SOURCE_DIR}/extras/fixture/src>>
|
||||||
|
)
|
||||||
|
|
||||||
|
set(${PROJECT_NAME}_PUBLIC_HEADERS
|
||||||
|
src/unity.h
|
||||||
|
src/unity_internals.h
|
||||||
|
$<$<BOOL:${UNITY_EXTENSION_FIXTURE_ENABLED}>:${CMAKE_CURRENT_SOURCE_DIR}/extras/fixture/src/unity_fixture.h>
|
||||||
|
$<$<BOOL:${UNITY_EXTENSION_FIXTURE_ENABLED}>:${CMAKE_CURRENT_SOURCE_DIR}/extras/fixture/src/unity_fixture_internals.h>
|
||||||
|
$<$<BOOL:${UNITY_EXTENSION_MEMORY_ENABLED}>:${CMAKE_CURRENT_SOURCE_DIR}/extras/memory/src/unity_memory.h>
|
||||||
|
)
|
||||||
|
|
||||||
|
set_target_properties(${PROJECT_NAME}
|
||||||
|
PROPERTIES
|
||||||
|
C_STANDARD 11
|
||||||
|
C_STANDARD_REQUIRED ON
|
||||||
|
C_EXTENSIONS OFF
|
||||||
|
PUBLIC_HEADER "${${PROJECT_NAME}_PUBLIC_HEADERS}"
|
||||||
|
EXPORT_NAME framework
|
||||||
|
)
|
||||||
|
|
||||||
|
target_compile_options(${PROJECT_NAME}
|
||||||
|
PRIVATE
|
||||||
|
$<$<C_COMPILER_ID:Clang>:-Wcast-align
|
||||||
|
-Wcast-qual
|
||||||
|
-Wconversion
|
||||||
|
-Wexit-time-destructors
|
||||||
|
-Wglobal-constructors
|
||||||
|
-Wmissing-noreturn
|
||||||
|
-Wmissing-prototypes
|
||||||
|
-Wno-missing-braces
|
||||||
|
-Wold-style-cast
|
||||||
|
-Wshadow
|
||||||
|
-Wweak-vtables
|
||||||
|
-Werror
|
||||||
|
-Wall>
|
||||||
|
$<$<C_COMPILER_ID:GNU>:-Waddress
|
||||||
|
-Waggregate-return
|
||||||
|
-Wformat-nonliteral
|
||||||
|
-Wformat-security
|
||||||
|
-Wformat
|
||||||
|
-Winit-self
|
||||||
|
-Wmissing-declarations
|
||||||
|
-Wmissing-include-dirs
|
||||||
|
-Wno-multichar
|
||||||
|
-Wno-parentheses
|
||||||
|
-Wno-type-limits
|
||||||
|
-Wno-unused-parameter
|
||||||
|
-Wunreachable-code
|
||||||
|
-Wwrite-strings
|
||||||
|
-Wpointer-arith
|
||||||
|
-Werror
|
||||||
|
-Wall>
|
||||||
|
$<$<C_COMPILER_ID:MSVC>:/Wall>
|
||||||
|
)
|
||||||
|
|
||||||
|
write_basic_package_version_file(${PROJECT_NAME}ConfigVersion.cmake
|
||||||
|
VERSION ${PROJECT_VERSION}
|
||||||
|
COMPATIBILITY SameMajorVersion
|
||||||
|
)
|
||||||
|
|
||||||
|
## Target installation
|
||||||
|
install(TARGETS ${PROJECT_NAME}
|
||||||
|
EXPORT ${PROJECT_NAME}Targets
|
||||||
|
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
|
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}
|
||||||
|
COMPONENT library
|
||||||
|
)
|
||||||
|
|
||||||
|
## Target's cmake files: targets export
|
||||||
|
install(EXPORT ${PROJECT_NAME}Targets
|
||||||
|
NAMESPACE ${PROJECT_NAME}::
|
||||||
|
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
|
||||||
|
)
|
||||||
|
|
||||||
|
## Target's cmake files: config and version config for find_package()
|
||||||
|
install(FILES ${PROJECT_NAME}Config.cmake
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake
|
||||||
|
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
|
||||||
|
)
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) <year> 2007-14 Mike Karlesky, Mark VanderVoord, Greg Williams
|
Copyright (c) <year> 2007-21 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
83
README.md
83
README.md
@@ -1,57 +1,26 @@
|
|||||||
Unity Test API
|
Unity Test 
|
||||||
==============
|
==========
|
||||||
|
__Copyright (c) 2007 - 2021 Unity Project by Mike Karlesky, Mark VanderVoord, and Greg Williams__
|
||||||
|
|
||||||
[](https://travis-ci.org/ThrowTheSwitch/Unity)
|
Welcome to the Unity Test Project, one of the main projects of ThrowTheSwitch.org. Unity Test is a
|
||||||
__Copyright (c) 2007 - 2017 Unity Project by Mike Karlesky, Mark VanderVoord, and Greg Williams__
|
unit testing framework built for C, with a focus on working with embedded toolchains.
|
||||||
|
|
||||||
Running Tests
|
This project is made to test code targetting microcontrollers big and small. The core project is a
|
||||||
-------------
|
single C file and a pair of headers, allowing it to the added to your existing build setup without
|
||||||
|
too much headache. You may use any compiler you wish, and may use most existing build systems
|
||||||
|
including make, cmake, etc. If you'd like to leave the hard work to us, you might be interested
|
||||||
|
in Ceedling, a build tool also by ThrowTheSwitch.org.
|
||||||
|
|
||||||
RUN_TEST(func, linenum)
|
If you're new to Unity, we encourage you to tour the [getting started guide](docs/UnityGettingStartedGuide.md)
|
||||||
|
|
||||||
Each Test is run within the macro `RUN_TEST`. This macro performs necessary setup before the test is called and handles cleanup and result tabulation afterwards.
|
|
||||||
|
|
||||||
Ignoring Tests
|
|
||||||
--------------
|
|
||||||
|
|
||||||
There are times when a test is incomplete or not valid for some reason. At these times, TEST_IGNORE can be called. Control will immediately be returned to the caller of the test, and no failures will be returned.
|
|
||||||
|
|
||||||
TEST_IGNORE()
|
|
||||||
|
|
||||||
Ignore this test and return immediately
|
|
||||||
|
|
||||||
TEST_IGNORE_MESSAGE (message)
|
|
||||||
|
|
||||||
Ignore this test and return immediately. Output a message stating why the test was ignored.
|
|
||||||
|
|
||||||
Aborting Tests
|
|
||||||
--------------
|
|
||||||
|
|
||||||
There are times when a test will contain an infinite loop on error conditions, or there may be reason to escape from the test early without executing the rest of the test. A pair of macros support this functionality in Unity. The first `TEST_PROTECT` sets up the feature, and handles emergency abort cases. `TEST_ABORT` can then be used at any time within the tests to return to the last `TEST_PROTECT` call.
|
|
||||||
|
|
||||||
TEST_PROTECT()
|
|
||||||
|
|
||||||
Setup and Catch macro
|
|
||||||
|
|
||||||
TEST_ABORT()
|
|
||||||
|
|
||||||
Abort Test macro
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
main()
|
|
||||||
{
|
|
||||||
if (TEST_PROTECT())
|
|
||||||
{
|
|
||||||
MyTest();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If MyTest calls `TEST_ABORT`, program control will immediately return to `TEST_PROTECT` with a return value of zero.
|
|
||||||
|
|
||||||
|
Getting Started
|
||||||
|
===============
|
||||||
|
The [docs](docs/) folder contains a [getting started guide](docs/UnityGettingStartedGuide.md)
|
||||||
|
and much more tips about using Unity.
|
||||||
|
|
||||||
Unity Assertion Summary
|
Unity Assertion Summary
|
||||||
=======================
|
=======================
|
||||||
|
For the full list, see [UnityAssertionsReference.md](docs/UnityAssertionsReference.md).
|
||||||
|
|
||||||
Basic Validity Tests
|
Basic Validity Tests
|
||||||
--------------------
|
--------------------
|
||||||
@@ -75,7 +44,7 @@ Another way of calling `TEST_ASSERT_FALSE`
|
|||||||
TEST_FAIL()
|
TEST_FAIL()
|
||||||
TEST_FAIL_MESSAGE(message)
|
TEST_FAIL_MESSAGE(message)
|
||||||
|
|
||||||
This test is automatically marked as a failure. The message is output stating why.
|
This test is automatically marked as a failure. The message is output stating why.
|
||||||
|
|
||||||
Numerical Assertions: Integers
|
Numerical Assertions: Integers
|
||||||
------------------------------
|
------------------------------
|
||||||
@@ -87,7 +56,7 @@ Numerical Assertions: Integers
|
|||||||
TEST_ASSERT_EQUAL_INT64(expected, actual)
|
TEST_ASSERT_EQUAL_INT64(expected, actual)
|
||||||
|
|
||||||
Compare two integers for equality and display errors as signed integers. A cast will be performed
|
Compare two integers for equality and display errors as signed integers. A cast will be performed
|
||||||
to your natural integer size so often this can just be used. When you need to specify the exact size,
|
to your natural integer size so often this can just be used. When you need to specify the exact size,
|
||||||
like when comparing arrays, you can use a specific version:
|
like when comparing arrays, you can use a specific version:
|
||||||
|
|
||||||
TEST_ASSERT_EQUAL_UINT(expected, actual)
|
TEST_ASSERT_EQUAL_UINT(expected, actual)
|
||||||
@@ -96,7 +65,7 @@ like when comparing arrays, you can use a specific version:
|
|||||||
TEST_ASSERT_EQUAL_UINT32(expected, actual)
|
TEST_ASSERT_EQUAL_UINT32(expected, actual)
|
||||||
TEST_ASSERT_EQUAL_UINT64(expected, actual)
|
TEST_ASSERT_EQUAL_UINT64(expected, actual)
|
||||||
|
|
||||||
Compare two integers for equality and display errors as unsigned integers. Like INT, there are
|
Compare two integers for equality and display errors as unsigned integers. Like INT, there are
|
||||||
variants for different sizes also.
|
variants for different sizes also.
|
||||||
|
|
||||||
TEST_ASSERT_EQUAL_HEX(expected, actual)
|
TEST_ASSERT_EQUAL_HEX(expected, actual)
|
||||||
@@ -105,7 +74,7 @@ variants for different sizes also.
|
|||||||
TEST_ASSERT_EQUAL_HEX32(expected, actual)
|
TEST_ASSERT_EQUAL_HEX32(expected, actual)
|
||||||
TEST_ASSERT_EQUAL_HEX64(expected, actual)
|
TEST_ASSERT_EQUAL_HEX64(expected, actual)
|
||||||
|
|
||||||
Compares two integers for equality and display errors as hexadecimal. Like the other integer comparisons,
|
Compares two integers for equality and display errors as hexadecimal. Like the other integer comparisons,
|
||||||
you can specify the size... here the size will also effect how many nibbles are shown (for example, `HEX16`
|
you can specify the size... here the size will also effect how many nibbles are shown (for example, `HEX16`
|
||||||
will show 4 nibbles).
|
will show 4 nibbles).
|
||||||
|
|
||||||
@@ -115,7 +84,7 @@ Another way of calling TEST_ASSERT_EQUAL_INT
|
|||||||
|
|
||||||
TEST_ASSERT_INT_WITHIN(delta, expected, actual)
|
TEST_ASSERT_INT_WITHIN(delta, expected, actual)
|
||||||
|
|
||||||
Asserts that the actual value is within plus or minus delta of the expected value. This also comes in
|
Asserts that the actual value is within plus or minus delta of the expected value. This also comes in
|
||||||
size specific variants.
|
size specific variants.
|
||||||
|
|
||||||
|
|
||||||
@@ -199,12 +168,12 @@ Compare two null-terminate strings. Fail if any character is different or if th
|
|||||||
|
|
||||||
TEST_ASSERT_EQUAL_STRING_LEN_MESSAGE(expected, actual, len, message)
|
TEST_ASSERT_EQUAL_STRING_LEN_MESSAGE(expected, actual, len, message)
|
||||||
|
|
||||||
Compare two strings. Fail if any character is different, stop comparing after len characters. Output a custom message on failure.
|
Compare two strings. Fail if any character is different, stop comparing after len characters. Output a custom message on failure.
|
||||||
|
|
||||||
Pointer Assertions
|
Pointer Assertions
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
Most pointer operations can be performed by simply using the integer comparisons above. However, a couple of special cases are added for clarity.
|
Most pointer operations can be performed by simply using the integer comparisons above. However, a couple of special cases are added for clarity.
|
||||||
|
|
||||||
TEST_ASSERT_NULL(pointer)
|
TEST_ASSERT_NULL(pointer)
|
||||||
|
|
||||||
@@ -222,10 +191,10 @@ Memory Assertions
|
|||||||
Compare two blocks of memory. This is a good generic assertion for types that can't be coerced into acting like
|
Compare two blocks of memory. This is a good generic assertion for types that can't be coerced into acting like
|
||||||
standard types... but since it's a memory compare, you have to be careful that your data types are packed.
|
standard types... but since it's a memory compare, you have to be careful that your data types are packed.
|
||||||
|
|
||||||
_MESSAGE
|
\_MESSAGE
|
||||||
--------
|
---------
|
||||||
|
|
||||||
you can append _MESSAGE to any of the macros to make them take an additional argument. This argument
|
you can append \_MESSAGE to any of the macros to make them take an additional argument. This argument
|
||||||
is a string that will be printed at the end of the failure strings. This is useful for specifying more
|
is a string that will be printed at the end of the failure strings. This is useful for specifying more
|
||||||
information about the problem.
|
information about the problem.
|
||||||
|
|
||||||
|
|||||||
@@ -22,9 +22,10 @@ end
|
|||||||
class ColourCommandLine
|
class ColourCommandLine
|
||||||
def initialize
|
def initialize
|
||||||
return unless RUBY_PLATFORM =~ /(win|w)32$/
|
return unless RUBY_PLATFORM =~ /(win|w)32$/
|
||||||
|
|
||||||
get_std_handle = Win32API.new('kernel32', 'GetStdHandle', ['L'], 'L')
|
get_std_handle = Win32API.new('kernel32', 'GetStdHandle', ['L'], 'L')
|
||||||
@set_console_txt_attrb =
|
@set_console_txt_attrb =
|
||||||
Win32API.new('kernel32', 'SetConsoleTextAttribute', %w(L N), 'I')
|
Win32API.new('kernel32', 'SetConsoleTextAttribute', %w[L N], 'I')
|
||||||
@hout = get_std_handle.call(-11)
|
@hout = get_std_handle.call(-11)
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -107,7 +108,7 @@ class ColourCommandLine
|
|||||||
$stdout.print("#{change_to(colour)}#{str}\033[0m") if mode == :print
|
$stdout.print("#{change_to(colour)}#{str}\033[0m") if mode == :print
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end # ColourCommandLine
|
end
|
||||||
|
|
||||||
def colour_puts(role, str)
|
def colour_puts(role, str)
|
||||||
ColourCommandLine.new.out_c(:puts, role, str)
|
ColourCommandLine.new.out_c(:puts, role, str)
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
# [Released under MIT License. Please refer to license.txt for details]
|
# [Released under MIT License. Please refer to license.txt for details]
|
||||||
# ==========================================
|
# ==========================================
|
||||||
|
|
||||||
require "#{File.expand_path(File.dirname(__FILE__))}/colour_prompt"
|
require_relative 'colour_prompt'
|
||||||
|
|
||||||
$colour_output = true
|
$colour_output = true
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,10 @@ require 'fileutils'
|
|||||||
require 'pathname'
|
require 'pathname'
|
||||||
|
|
||||||
# TEMPLATE_TST
|
# TEMPLATE_TST
|
||||||
TEMPLATE_TST ||= '#include "unity.h"
|
TEMPLATE_TST ||= '#ifdef TEST
|
||||||
|
|
||||||
|
#include "unity.h"
|
||||||
|
|
||||||
%2$s#include "%1$s.h"
|
%2$s#include "%1$s.h"
|
||||||
|
|
||||||
void setUp(void)
|
void setUp(void)
|
||||||
@@ -24,10 +27,12 @@ void tearDown(void)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_%1$s_NeedToImplement(void)
|
void test_%4$s_NeedToImplement(void)
|
||||||
{
|
{
|
||||||
TEST_IGNORE_MESSAGE("Need to Implement %1$s");
|
TEST_IGNORE_MESSAGE("Need to Implement %1$s");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif // TEST
|
||||||
'.freeze
|
'.freeze
|
||||||
|
|
||||||
# TEMPLATE_SRC
|
# TEMPLATE_SRC
|
||||||
@@ -35,18 +40,16 @@ TEMPLATE_SRC ||= '%2$s#include "%1$s.h"
|
|||||||
'.freeze
|
'.freeze
|
||||||
|
|
||||||
# TEMPLATE_INC
|
# TEMPLATE_INC
|
||||||
TEMPLATE_INC ||= '#ifndef _%3$s_H
|
TEMPLATE_INC ||= '#ifndef %3$s_H
|
||||||
#define _%3$s_H
|
#define %3$s_H
|
||||||
%2$s
|
%2$s
|
||||||
|
|
||||||
#endif // _%3$s_H
|
#endif // %3$s_H
|
||||||
'.freeze
|
'.freeze
|
||||||
|
|
||||||
class UnityModuleGenerator
|
class UnityModuleGenerator
|
||||||
############################
|
############################
|
||||||
def initialize(options = nil)
|
def initialize(options = nil)
|
||||||
here = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
||||||
|
|
||||||
@options = UnityModuleGenerator.default_options
|
@options = UnityModuleGenerator.default_options
|
||||||
case options
|
case options
|
||||||
when NilClass then @options
|
when NilClass then @options
|
||||||
@@ -56,9 +59,9 @@ class UnityModuleGenerator
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Create default file paths if none were provided
|
# Create default file paths if none were provided
|
||||||
@options[:path_src] = here + '../src/' if @options[:path_src].nil?
|
@options[:path_src] = "#{__dir__}/../src/" if @options[:path_src].nil?
|
||||||
@options[:path_inc] = @options[:path_src] if @options[:path_inc].nil?
|
@options[:path_inc] = @options[:path_src] if @options[:path_inc].nil?
|
||||||
@options[:path_tst] = here + '../test/' if @options[:path_tst].nil?
|
@options[:path_tst] = "#{__dir__}/../test/" if @options[:path_tst].nil?
|
||||||
@options[:path_src] += '/' unless @options[:path_src][-1] == 47
|
@options[:path_src] += '/' unless @options[:path_src][-1] == 47
|
||||||
@options[:path_inc] += '/' unless @options[:path_inc][-1] == 47
|
@options[:path_inc] += '/' unless @options[:path_inc][-1] == 47
|
||||||
@options[:path_tst] += '/' unless @options[:path_tst][-1] == 47
|
@options[:path_tst] += '/' unless @options[:path_tst][-1] == 47
|
||||||
@@ -164,24 +167,23 @@ class UnityModuleGenerator
|
|||||||
files
|
files
|
||||||
end
|
end
|
||||||
|
|
||||||
|
############################
|
||||||
|
def neutralize_filename(name, start_cap = true)
|
||||||
|
return name if name.empty?
|
||||||
|
name = name.split(/(?:\s+|_|(?=[A-Z][a-z]))|(?<=[a-z])(?=[A-Z])/).map { |v| v.capitalize }.join('_')
|
||||||
|
name = name[0].downcase + name[1..-1] unless start_cap
|
||||||
|
return name
|
||||||
|
end
|
||||||
|
|
||||||
############################
|
############################
|
||||||
def create_filename(part1, part2 = '')
|
def create_filename(part1, part2 = '')
|
||||||
if part2.empty?
|
name = part2.empty? ? part1 : part1 + '_' + part2
|
||||||
case (@options[:naming])
|
case (@options[:naming])
|
||||||
when 'bumpy' then part1
|
when 'bumpy' then neutralize_filename(name,false).delete('_')
|
||||||
when 'camel' then part1
|
when 'camel' then neutralize_filename(name).delete('_')
|
||||||
when 'snake' then part1.downcase
|
when 'snake' then neutralize_filename(name).downcase
|
||||||
when 'caps' then part1.upcase
|
when 'caps' then neutralize_filename(name).upcase
|
||||||
else part1
|
else name
|
||||||
end
|
|
||||||
else
|
|
||||||
case (@options[:naming])
|
|
||||||
when 'bumpy' then part1 + part2
|
|
||||||
when 'camel' then part1 + part2
|
|
||||||
when 'snake' then part1.downcase + '_' + part2.downcase
|
|
||||||
when 'caps' then part1.upcase + '_' + part2.upcase
|
|
||||||
else part1 + '_' + part2
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -209,7 +211,8 @@ class UnityModuleGenerator
|
|||||||
f.write("#{file[:boilerplate]}\n" % [file[:name]]) unless file[:boilerplate].nil?
|
f.write("#{file[:boilerplate]}\n" % [file[:name]]) unless file[:boilerplate].nil?
|
||||||
f.write(file[:template] % [file[:name],
|
f.write(file[:template] % [file[:name],
|
||||||
file[:includes].map { |ff| "#include \"#{ff}\"\n" }.join,
|
file[:includes].map { |ff| "#include \"#{ff}\"\n" }.join,
|
||||||
file[:name].upcase])
|
file[:name].upcase.gsub(/-/, '_'),
|
||||||
|
file[:name].gsub(/-/, '_')])
|
||||||
end
|
end
|
||||||
if @options[:update_svn]
|
if @options[:update_svn]
|
||||||
`svn add \"#{file[:path]}\"`
|
`svn add \"#{file[:path]}\"`
|
||||||
@@ -265,6 +268,7 @@ if $0 == __FILE__
|
|||||||
when /^-y\"?(.+)\"?/ then options = UnityModuleGenerator.grab_config(Regexp.last_match(1))
|
when /^-y\"?(.+)\"?/ then options = UnityModuleGenerator.grab_config(Regexp.last_match(1))
|
||||||
when /^(\w+)/
|
when /^(\w+)/
|
||||||
raise "ERROR: You can't have more than one Module name specified!" unless module_name.nil?
|
raise "ERROR: You can't have more than one Module name specified!" unless module_name.nil?
|
||||||
|
|
||||||
module_name = arg
|
module_name = arg
|
||||||
when /^-(h|-help)/
|
when /^-(h|-help)/
|
||||||
ARGV = [].freeze
|
ARGV = [].freeze
|
||||||
@@ -299,6 +303,7 @@ if $0 == __FILE__
|
|||||||
end
|
end
|
||||||
|
|
||||||
raise 'ERROR: You must have a Module name specified! (use option -h for help)' if module_name.nil?
|
raise 'ERROR: You must have a Module name specified! (use option -h for help)' if module_name.nil?
|
||||||
|
|
||||||
if destroy
|
if destroy
|
||||||
UnityModuleGenerator.new(options).destroy(module_name)
|
UnityModuleGenerator.new(options).destroy(module_name)
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -4,18 +4,25 @@
|
|||||||
# [Released under MIT License. Please refer to license.txt for details]
|
# [Released under MIT License. Please refer to license.txt for details]
|
||||||
# ==========================================
|
# ==========================================
|
||||||
|
|
||||||
File.expand_path(File.join(File.dirname(__FILE__), 'colour_prompt'))
|
|
||||||
|
|
||||||
class UnityTestRunnerGenerator
|
class UnityTestRunnerGenerator
|
||||||
def initialize(options = nil)
|
def initialize(options = nil)
|
||||||
@options = UnityTestRunnerGenerator.default_options
|
@options = UnityTestRunnerGenerator.default_options
|
||||||
case options
|
case options
|
||||||
when NilClass then @options
|
when NilClass
|
||||||
when String then @options.merge!(UnityTestRunnerGenerator.grab_config(options))
|
@options
|
||||||
when Hash then @options.merge!(options)
|
when String
|
||||||
else raise 'If you specify arguments, it should be a filename or a hash of options'
|
@options.merge!(UnityTestRunnerGenerator.grab_config(options))
|
||||||
|
when Hash
|
||||||
|
# Check if some of these have been specified
|
||||||
|
@options[:has_setup] = !options[:setup_name].nil?
|
||||||
|
@options[:has_teardown] = !options[:teardown_name].nil?
|
||||||
|
@options[:has_suite_setup] = !options[:suite_setup].nil?
|
||||||
|
@options[:has_suite_teardown] = !options[:suite_teardown].nil?
|
||||||
|
@options.merge!(options)
|
||||||
|
else
|
||||||
|
raise 'If you specify arguments, it should be a filename or a hash of options'
|
||||||
end
|
end
|
||||||
require "#{File.expand_path(File.dirname(__FILE__))}/type_sanitizer"
|
require_relative 'type_sanitizer'
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.default_options
|
def self.default_options
|
||||||
@@ -26,12 +33,18 @@ class UnityTestRunnerGenerator
|
|||||||
framework: :unity,
|
framework: :unity,
|
||||||
test_prefix: 'test|spec|should',
|
test_prefix: 'test|spec|should',
|
||||||
mock_prefix: 'Mock',
|
mock_prefix: 'Mock',
|
||||||
|
mock_suffix: '',
|
||||||
setup_name: 'setUp',
|
setup_name: 'setUp',
|
||||||
teardown_name: 'tearDown',
|
teardown_name: 'tearDown',
|
||||||
|
test_reset_name: 'resetTest',
|
||||||
|
test_verify_name: 'verifyTest',
|
||||||
main_name: 'main', # set to :auto to automatically generate each time
|
main_name: 'main', # set to :auto to automatically generate each time
|
||||||
main_export_decl: '',
|
main_export_decl: '',
|
||||||
cmdline_args: false,
|
cmdline_args: false,
|
||||||
use_param_tests: false
|
omit_begin_end: false,
|
||||||
|
use_param_tests: false,
|
||||||
|
include_extensions: '(?:hpp|hh|H|h)',
|
||||||
|
source_extensions: '(?:cpp|cc|ino|C|c)'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -52,12 +65,13 @@ class UnityTestRunnerGenerator
|
|||||||
# pull required data from source file
|
# pull required data from source file
|
||||||
source = File.read(input_file)
|
source = File.read(input_file)
|
||||||
source = source.force_encoding('ISO-8859-1').encode('utf-8', replace: nil)
|
source = source.force_encoding('ISO-8859-1').encode('utf-8', replace: nil)
|
||||||
tests = find_tests(source)
|
tests = find_tests(source)
|
||||||
headers = find_includes(source)
|
headers = find_includes(source)
|
||||||
testfile_includes = (headers[:local] + headers[:system])
|
testfile_includes = (headers[:local] + headers[:system])
|
||||||
used_mocks = find_mocks(testfile_includes)
|
used_mocks = find_mocks(testfile_includes)
|
||||||
testfile_includes = (testfile_includes - used_mocks)
|
testfile_includes = (testfile_includes - used_mocks)
|
||||||
testfile_includes.delete_if { |inc| inc =~ /(unity|cmock)/ }
|
testfile_includes.delete_if { |inc| inc =~ /(unity|cmock)/ }
|
||||||
|
find_setup_and_teardown(source)
|
||||||
|
|
||||||
# build runner file
|
# build runner file
|
||||||
generate(input_file, output_file, tests, used_mocks, testfile_includes)
|
generate(input_file, output_file, tests, used_mocks, testfile_includes)
|
||||||
@@ -75,9 +89,13 @@ class UnityTestRunnerGenerator
|
|||||||
create_header(output, used_mocks, testfile_includes)
|
create_header(output, used_mocks, testfile_includes)
|
||||||
create_externs(output, tests, used_mocks)
|
create_externs(output, tests, used_mocks)
|
||||||
create_mock_management(output, used_mocks)
|
create_mock_management(output, used_mocks)
|
||||||
|
create_setup(output)
|
||||||
|
create_teardown(output)
|
||||||
create_suite_setup(output)
|
create_suite_setup(output)
|
||||||
create_suite_teardown(output)
|
create_suite_teardown(output)
|
||||||
create_reset(output, used_mocks)
|
create_reset(output)
|
||||||
|
create_run_test(output) unless tests.empty?
|
||||||
|
create_args_wrappers(output, tests)
|
||||||
create_main(output, input_file, tests, used_mocks)
|
create_main(output, input_file, tests, used_mocks)
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -91,27 +109,57 @@ class UnityTestRunnerGenerator
|
|||||||
def find_tests(source)
|
def find_tests(source)
|
||||||
tests_and_line_numbers = []
|
tests_and_line_numbers = []
|
||||||
|
|
||||||
|
# contains characters which will be substituted from within strings, doing
|
||||||
|
# this prevents these characters from interfering with scrubbers
|
||||||
|
# @ is not a valid C character, so there should be no clashes with files genuinely containing these markers
|
||||||
|
substring_subs = { '{' => '@co@', '}' => '@cc@', ';' => '@ss@', '/' => '@fs@' }
|
||||||
|
substring_re = Regexp.union(substring_subs.keys)
|
||||||
|
substring_unsubs = substring_subs.invert # the inverse map will be used to fix the strings afterwords
|
||||||
|
substring_unsubs['@quote@'] = '\\"'
|
||||||
|
substring_unsubs['@apos@'] = '\\\''
|
||||||
|
substring_unre = Regexp.union(substring_unsubs.keys)
|
||||||
source_scrubbed = source.clone
|
source_scrubbed = source.clone
|
||||||
source_scrubbed = source_scrubbed.gsub(/"[^"\n]*"/, '') # remove things in strings
|
source_scrubbed = source_scrubbed.gsub(/\\"/, '@quote@') # hide escaped quotes to allow capture of the full string/char
|
||||||
source_scrubbed = source_scrubbed.gsub(/\/\/.*$/, '') # remove line comments
|
source_scrubbed = source_scrubbed.gsub(/\\'/, '@apos@') # hide escaped apostrophes to allow capture of the full string/char
|
||||||
source_scrubbed = source_scrubbed.gsub(/\/\*.*?\*\//m, '') # remove block comments
|
source_scrubbed = source_scrubbed.gsub(/("[^"\n]*")|('[^'\n]*')/) { |s| s.gsub(substring_re, substring_subs) } # temporarily hide problematic characters within strings
|
||||||
lines = source_scrubbed.split(/(^\s*\#.*$) # Treat preprocessor directives as a logical line
|
source_scrubbed = source_scrubbed.gsub(/\/\/(?:.+\/\*|\*(?:$|[^\/])).*$/, '') # remove line comments that comment out the start of blocks
|
||||||
| (;|\{|\}) /x) # Match ;, {, and } as end of lines
|
source_scrubbed = source_scrubbed.gsub(/\/\*.*?\*\//m, '') # remove block comments
|
||||||
|
source_scrubbed = source_scrubbed.gsub(/\/\/.*$/, '') # remove line comments (all that remain)
|
||||||
|
lines = source_scrubbed.split(/(^\s*\#.*$) | (;|\{|\}) /x) # Treat preprocessor directives as a logical line. Match ;, {, and } as end of lines
|
||||||
|
.map { |line| line.gsub(substring_unre, substring_unsubs) } # unhide the problematic characters previously removed
|
||||||
|
|
||||||
lines.each_with_index do |line, _index|
|
lines.each_with_index do |line, _index|
|
||||||
# find tests
|
# find tests
|
||||||
next unless line =~ /^((?:\s*TEST_CASE\s*\(.*?\)\s*)*)\s*void\s+((?:#{@options[:test_prefix]}).*)\s*\(\s*(.*)\s*\)/
|
next unless line =~ /^((?:\s*(?:TEST_CASE|TEST_RANGE)\s*\(.*?\)\s*)*)\s*void\s+((?:#{@options[:test_prefix]}).*)\s*\(\s*(.*)\s*\)/m
|
||||||
|
|
||||||
arguments = Regexp.last_match(1)
|
arguments = Regexp.last_match(1)
|
||||||
name = Regexp.last_match(2)
|
name = Regexp.last_match(2)
|
||||||
call = Regexp.last_match(3)
|
call = Regexp.last_match(3)
|
||||||
params = Regexp.last_match(4)
|
params = Regexp.last_match(4)
|
||||||
args = nil
|
args = nil
|
||||||
|
|
||||||
if @options[:use_param_tests] && !arguments.empty?
|
if @options[:use_param_tests] && !arguments.empty?
|
||||||
args = []
|
args = []
|
||||||
arguments.scan(/\s*TEST_CASE\s*\((.*)\)\s*$/) { |a| args << a[0] }
|
arguments.scan(/\s*TEST_CASE\s*\((.*)\)\s*$/) { |a| args << a[0] }
|
||||||
|
|
||||||
|
arguments.scan(/\s*TEST_RANGE\s*\((.*)\)\s*$/).flatten.each do |range_str|
|
||||||
|
args += range_str.scan(/\[(-?\d+.?\d*), *(-?\d+.?\d*), *(-?\d+.?\d*)\]/).map do |arg_values_str|
|
||||||
|
arg_values_str.map do |arg_value_str|
|
||||||
|
arg_value_str.include?('.') ? arg_value_str.to_f : arg_value_str.to_i
|
||||||
|
end
|
||||||
|
end.map do |arg_values|
|
||||||
|
(arg_values[0]..arg_values[1]).step(arg_values[2]).to_a
|
||||||
|
end.reduce do |result, arg_range_expanded|
|
||||||
|
result.product(arg_range_expanded)
|
||||||
|
end.map do |arg_combinations|
|
||||||
|
arg_combinations.flatten.join(', ')
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
tests_and_line_numbers << { test: name, args: args, call: call, params: params, line_number: 0 }
|
tests_and_line_numbers << { test: name, args: args, call: call, params: params, line_number: 0 }
|
||||||
end
|
end
|
||||||
|
|
||||||
tests_and_line_numbers.uniq! { |v| v[:test] }
|
tests_and_line_numbers.uniq! { |v| v[:test] }
|
||||||
|
|
||||||
# determine line numbers and create tests to run
|
# determine line numbers and create tests to run
|
||||||
@@ -120,6 +168,7 @@ class UnityTestRunnerGenerator
|
|||||||
tests_and_line_numbers.size.times do |i|
|
tests_and_line_numbers.size.times do |i|
|
||||||
source_lines[source_index..-1].each_with_index do |line, index|
|
source_lines[source_index..-1].each_with_index do |line, index|
|
||||||
next unless line =~ /\s+#{tests_and_line_numbers[i][:test]}(?:\s|\()/
|
next unless line =~ /\s+#{tests_and_line_numbers[i][:test]}(?:\s|\()/
|
||||||
|
|
||||||
source_index += index
|
source_index += index
|
||||||
tests_and_line_numbers[i][:line_number] = source_index + 1
|
tests_and_line_numbers[i][:line_number] = source_index + 1
|
||||||
break
|
break
|
||||||
@@ -137,9 +186,9 @@ class UnityTestRunnerGenerator
|
|||||||
|
|
||||||
# parse out includes
|
# parse out includes
|
||||||
includes = {
|
includes = {
|
||||||
local: source.scan(/^\s*#include\s+\"\s*(.+)\.[hH]\s*\"/).flatten,
|
local: source.scan(/^\s*#include\s+\"\s*(.+\.#{@options[:include_extensions]})\s*\"/).flatten,
|
||||||
system: source.scan(/^\s*#include\s+<\s*(.+)\s*>/).flatten.map { |inc| "<#{inc}>" },
|
system: source.scan(/^\s*#include\s+<\s*(.+)\s*>/).flatten.map { |inc| "<#{inc}>" },
|
||||||
linkonly: source.scan(/^TEST_FILE\(\s*\"\s*(.+)\.[cC]\w*\s*\"/).flatten
|
linkonly: source.scan(/^TEST_FILE\(\s*\"\s*(.+\.#{@options[:source_extensions]})\s*\"/).flatten
|
||||||
}
|
}
|
||||||
includes
|
includes
|
||||||
end
|
end
|
||||||
@@ -148,34 +197,38 @@ class UnityTestRunnerGenerator
|
|||||||
mock_headers = []
|
mock_headers = []
|
||||||
includes.each do |include_path|
|
includes.each do |include_path|
|
||||||
include_file = File.basename(include_path)
|
include_file = File.basename(include_path)
|
||||||
mock_headers << include_path if include_file =~ /^#{@options[:mock_prefix]}/i
|
mock_headers << include_path if include_file =~ /^#{@options[:mock_prefix]}.*#{@options[:mock_suffix]}\.h$/i
|
||||||
end
|
end
|
||||||
mock_headers
|
mock_headers
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def find_setup_and_teardown(source)
|
||||||
|
@options[:has_setup] = source =~ /void\s+#{@options[:setup_name]}\s*\(/
|
||||||
|
@options[:has_teardown] = source =~ /void\s+#{@options[:teardown_name]}\s*\(/
|
||||||
|
@options[:has_suite_setup] ||= (source =~ /void\s+suiteSetUp\s*\(/)
|
||||||
|
@options[:has_suite_teardown] ||= (source =~ /int\s+suiteTearDown\s*\(int\s+([a-zA-Z0-9_])+\s*\)/)
|
||||||
|
end
|
||||||
|
|
||||||
def create_header(output, mocks, testfile_includes = [])
|
def create_header(output, mocks, testfile_includes = [])
|
||||||
output.puts('/* AUTOGENERATED FILE. DO NOT EDIT. */')
|
output.puts('/* AUTOGENERATED FILE. DO NOT EDIT. */')
|
||||||
create_runtest(output, mocks)
|
|
||||||
output.puts("\n/*=======Automagically Detected Files To Include=====*/")
|
output.puts("\n/*=======Automagically Detected Files To Include=====*/")
|
||||||
output.puts("#include \"#{@options[:framework]}.h\"")
|
output.puts("#include \"#{@options[:framework]}.h\"")
|
||||||
output.puts('#include "cmock.h"') unless mocks.empty?
|
output.puts('#include "cmock.h"') unless mocks.empty?
|
||||||
output.puts('#include <setjmp.h>')
|
|
||||||
output.puts('#include <stdio.h>')
|
|
||||||
if @options[:defines] && !@options[:defines].empty?
|
if @options[:defines] && !@options[:defines].empty?
|
||||||
@options[:defines].each { |d| output.puts("#define #{d}") }
|
@options[:defines].each { |d| output.puts("#ifndef #{d}\n#define #{d}\n#endif /* #{d} */") }
|
||||||
end
|
end
|
||||||
if @options[:header_file] && !@options[:header_file].empty?
|
if @options[:header_file] && !@options[:header_file].empty?
|
||||||
output.puts("#include \"#{File.basename(@options[:header_file])}\"")
|
output.puts("#include \"#{File.basename(@options[:header_file])}\"")
|
||||||
else
|
else
|
||||||
@options[:includes].flatten.uniq.compact.each do |inc|
|
@options[:includes].flatten.uniq.compact.each do |inc|
|
||||||
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc.gsub('.h', '')}.h\""}")
|
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc}\""}")
|
||||||
end
|
end
|
||||||
testfile_includes.each do |inc|
|
testfile_includes.each do |inc|
|
||||||
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc.gsub('.h', '')}.h\""}")
|
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc}\""}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
mocks.each do |mock|
|
mocks.each do |mock|
|
||||||
output.puts("#include \"#{mock.gsub('.h', '')}.h\"")
|
output.puts("#include \"#{mock}\"")
|
||||||
end
|
end
|
||||||
output.puts('#include "CException.h"') if @options[:plugins].include?(:cexception)
|
output.puts('#include "CException.h"') if @options[:plugins].include?(:cexception)
|
||||||
|
|
||||||
@@ -191,15 +244,15 @@ class UnityTestRunnerGenerator
|
|||||||
output.puts("\n/*=======External Functions This Runner Calls=====*/")
|
output.puts("\n/*=======External Functions This Runner Calls=====*/")
|
||||||
output.puts("extern void #{@options[:setup_name]}(void);")
|
output.puts("extern void #{@options[:setup_name]}(void);")
|
||||||
output.puts("extern void #{@options[:teardown_name]}(void);")
|
output.puts("extern void #{@options[:teardown_name]}(void);")
|
||||||
|
output.puts("\n#ifdef __cplusplus\nextern \"C\"\n{\n#endif") if @options[:externc]
|
||||||
tests.each do |test|
|
tests.each do |test|
|
||||||
output.puts("extern void #{test[:test]}(#{test[:call] || 'void'});")
|
output.puts("extern void #{test[:test]}(#{test[:call] || 'void'});")
|
||||||
end
|
end
|
||||||
|
output.puts("#ifdef __cplusplus\n}\n#endif") if @options[:externc]
|
||||||
output.puts('')
|
output.puts('')
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_mock_management(output, mock_headers)
|
def create_mock_management(output, mock_headers)
|
||||||
return if mock_headers.empty?
|
|
||||||
|
|
||||||
output.puts("\n/*=======Mock Management=====*/")
|
output.puts("\n/*=======Mock Management=====*/")
|
||||||
output.puts('static void CMock_Init(void)')
|
output.puts('static void CMock_Init(void)')
|
||||||
output.puts('{')
|
output.puts('{')
|
||||||
@@ -210,7 +263,7 @@ class UnityTestRunnerGenerator
|
|||||||
output.puts(' GlobalOrderError = NULL;')
|
output.puts(' GlobalOrderError = NULL;')
|
||||||
end
|
end
|
||||||
|
|
||||||
mocks = mock_headers.map { |mock| File.basename(mock) }
|
mocks = mock_headers.map { |mock| File.basename(mock, '.*') }
|
||||||
mocks.each do |mock|
|
mocks.each do |mock|
|
||||||
mock_clean = TypeSanitizer.sanitize_c_identifier(mock)
|
mock_clean = TypeSanitizer.sanitize_c_identifier(mock)
|
||||||
output.puts(" #{mock_clean}_Init();")
|
output.puts(" #{mock_clean}_Init();")
|
||||||
@@ -234,11 +287,25 @@ class UnityTestRunnerGenerator
|
|||||||
output.puts("}\n")
|
output.puts("}\n")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def create_setup(output)
|
||||||
|
return if @options[:has_setup]
|
||||||
|
|
||||||
|
output.puts("\n/*=======Setup (stub)=====*/")
|
||||||
|
output.puts("void #{@options[:setup_name]}(void) {}")
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_teardown(output)
|
||||||
|
return if @options[:has_teardown]
|
||||||
|
|
||||||
|
output.puts("\n/*=======Teardown (stub)=====*/")
|
||||||
|
output.puts("void #{@options[:teardown_name]}(void) {}")
|
||||||
|
end
|
||||||
|
|
||||||
def create_suite_setup(output)
|
def create_suite_setup(output)
|
||||||
return if @options[:suite_setup].nil?
|
return if @options[:suite_setup].nil?
|
||||||
|
|
||||||
output.puts("\n/*=======Suite Setup=====*/")
|
output.puts("\n/*=======Suite Setup=====*/")
|
||||||
output.puts('static void suite_setup(void)')
|
output.puts('void suiteSetUp(void)')
|
||||||
output.puts('{')
|
output.puts('{')
|
||||||
output.puts(@options[:suite_setup])
|
output.puts(@options[:suite_setup])
|
||||||
output.puts('}')
|
output.puts('}')
|
||||||
@@ -248,60 +315,54 @@ class UnityTestRunnerGenerator
|
|||||||
return if @options[:suite_teardown].nil?
|
return if @options[:suite_teardown].nil?
|
||||||
|
|
||||||
output.puts("\n/*=======Suite Teardown=====*/")
|
output.puts("\n/*=======Suite Teardown=====*/")
|
||||||
output.puts('static int suite_teardown(int num_failures)')
|
output.puts('int suiteTearDown(int num_failures)')
|
||||||
output.puts('{')
|
output.puts('{')
|
||||||
output.puts(@options[:suite_teardown])
|
output.puts(@options[:suite_teardown])
|
||||||
output.puts('}')
|
output.puts('}')
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_runtest(output, used_mocks)
|
def create_reset(output)
|
||||||
cexception = @options[:plugins].include? :cexception
|
output.puts("\n/*=======Test Reset Options=====*/")
|
||||||
va_args1 = @options[:use_param_tests] ? ', ...' : ''
|
output.puts("void #{@options[:test_reset_name]}(void);")
|
||||||
va_args2 = @options[:use_param_tests] ? '__VA_ARGS__' : ''
|
output.puts("void #{@options[:test_reset_name]}(void)")
|
||||||
output.puts("\n/*=======Test Runner Used To Run Each Test Below=====*/")
|
|
||||||
output.puts('#define RUN_TEST_NO_ARGS') if @options[:use_param_tests]
|
|
||||||
output.puts("#define RUN_TEST(TestFunc, TestLineNum#{va_args1}) \\")
|
|
||||||
output.puts('{ \\')
|
|
||||||
output.puts(" Unity.CurrentTestName = #TestFunc#{va_args2.empty? ? '' : " \"(\" ##{va_args2} \")\""}; \\")
|
|
||||||
output.puts(' Unity.CurrentTestLineNumber = TestLineNum; \\')
|
|
||||||
output.puts(' if (UnityTestMatches()) { \\') if @options[:cmdline_args]
|
|
||||||
output.puts(' Unity.NumberOfTests++; \\')
|
|
||||||
output.puts(' CMock_Init(); \\') unless used_mocks.empty?
|
|
||||||
output.puts(' UNITY_CLR_DETAILS(); \\') unless used_mocks.empty?
|
|
||||||
output.puts(' if (TEST_PROTECT()) \\')
|
|
||||||
output.puts(' { \\')
|
|
||||||
output.puts(' CEXCEPTION_T e; \\') if cexception
|
|
||||||
output.puts(' Try { \\') if cexception
|
|
||||||
output.puts(" #{@options[:setup_name]}(); \\")
|
|
||||||
output.puts(" TestFunc(#{va_args2}); \\")
|
|
||||||
output.puts(' } Catch(e) { TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!"); } \\') if cexception
|
|
||||||
output.puts(' } \\')
|
|
||||||
output.puts(' if (TEST_PROTECT()) \\')
|
|
||||||
output.puts(' { \\')
|
|
||||||
output.puts(" #{@options[:teardown_name]}(); \\")
|
|
||||||
output.puts(' CMock_Verify(); \\') unless used_mocks.empty?
|
|
||||||
output.puts(' } \\')
|
|
||||||
output.puts(' CMock_Destroy(); \\') unless used_mocks.empty?
|
|
||||||
output.puts(' UnityConcludeTest(); \\')
|
|
||||||
output.puts(' } \\') if @options[:cmdline_args]
|
|
||||||
output.puts("}\n")
|
|
||||||
end
|
|
||||||
|
|
||||||
def create_reset(output, used_mocks)
|
|
||||||
output.puts("\n/*=======Test Reset Option=====*/")
|
|
||||||
output.puts('void resetTest(void);')
|
|
||||||
output.puts('void resetTest(void)')
|
|
||||||
output.puts('{')
|
output.puts('{')
|
||||||
output.puts(' CMock_Verify();') unless used_mocks.empty?
|
|
||||||
output.puts(' CMock_Destroy();') unless used_mocks.empty?
|
|
||||||
output.puts(" #{@options[:teardown_name]}();")
|
output.puts(" #{@options[:teardown_name]}();")
|
||||||
output.puts(' CMock_Init();') unless used_mocks.empty?
|
output.puts(' CMock_Verify();')
|
||||||
|
output.puts(' CMock_Destroy();')
|
||||||
|
output.puts(' CMock_Init();')
|
||||||
output.puts(" #{@options[:setup_name]}();")
|
output.puts(" #{@options[:setup_name]}();")
|
||||||
output.puts('}')
|
output.puts('}')
|
||||||
|
output.puts("void #{@options[:test_verify_name]}(void);")
|
||||||
|
output.puts("void #{@options[:test_verify_name]}(void)")
|
||||||
|
output.puts('{')
|
||||||
|
output.puts(' CMock_Verify();')
|
||||||
|
output.puts('}')
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_run_test(output)
|
||||||
|
require 'erb'
|
||||||
|
template = ERB.new(File.read(File.join(__dir__, 'run_test.erb')), nil, '<>')
|
||||||
|
output.puts("\n" + template.result(binding))
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_args_wrappers(output, tests)
|
||||||
|
return unless @options[:use_param_tests]
|
||||||
|
|
||||||
|
output.puts("\n/*=======Parameterized Test Wrappers=====*/")
|
||||||
|
tests.each do |test|
|
||||||
|
next if test[:args].nil? || test[:args].empty?
|
||||||
|
|
||||||
|
test[:args].each.with_index(1) do |args, idx|
|
||||||
|
output.puts("static void runner_args#{idx}_#{test[:test]}(void)")
|
||||||
|
output.puts('{')
|
||||||
|
output.puts(" #{test[:test]}(#{args});")
|
||||||
|
output.puts("}\n")
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_main(output, filename, tests, used_mocks)
|
def create_main(output, filename, tests, used_mocks)
|
||||||
output.puts("\n\n/*=======MAIN=====*/")
|
output.puts("\n/*=======MAIN=====*/")
|
||||||
main_name = @options[:main_name].to_sym == :auto ? "main_#{filename.gsub('.c', '')}" : (@options[:main_name]).to_s
|
main_name = @options[:main_name].to_sym == :auto ? "main_#{filename.gsub('.c', '')}" : (@options[:main_name]).to_s
|
||||||
if @options[:cmdline_args]
|
if @options[:cmdline_args]
|
||||||
if main_name != 'main'
|
if main_name != 'main'
|
||||||
@@ -316,48 +377,57 @@ class UnityTestRunnerGenerator
|
|||||||
output.puts(' {')
|
output.puts(' {')
|
||||||
output.puts(" UnityPrint(\"#{filename.gsub('.c', '')}.\");")
|
output.puts(" UnityPrint(\"#{filename.gsub('.c', '')}.\");")
|
||||||
output.puts(' UNITY_PRINT_EOL();')
|
output.puts(' UNITY_PRINT_EOL();')
|
||||||
if @options[:use_param_tests]
|
tests.each do |test|
|
||||||
tests.each do |test|
|
if (!@options[:use_param_tests]) || test[:args].nil? || test[:args].empty?
|
||||||
if test[:args].nil? || test[:args].empty?
|
output.puts(" UnityPrint(\" #{test[:test]}\");")
|
||||||
output.puts(" UnityPrint(\" #{test[:test]}(RUN_TEST_NO_ARGS)\");")
|
output.puts(' UNITY_PRINT_EOL();')
|
||||||
|
else
|
||||||
|
test[:args].each do |args|
|
||||||
|
output.puts(" UnityPrint(\" #{test[:test]}(#{args})\");")
|
||||||
output.puts(' UNITY_PRINT_EOL();')
|
output.puts(' UNITY_PRINT_EOL();')
|
||||||
else
|
|
||||||
test[:args].each do |args|
|
|
||||||
output.puts(" UnityPrint(\" #{test[:test]}(#{args})\");")
|
|
||||||
output.puts(' UNITY_PRINT_EOL();')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
|
||||||
tests.each { |test| output.puts(" UnityPrint(\" #{test[:test]}\");\n UNITY_PRINT_EOL();") }
|
|
||||||
end
|
end
|
||||||
output.puts(' return 0;')
|
output.puts(' return 0;')
|
||||||
output.puts(' }')
|
output.puts(' }')
|
||||||
output.puts(' return parse_status;')
|
output.puts(' return parse_status;')
|
||||||
output.puts(' }')
|
output.puts(' }')
|
||||||
else
|
else
|
||||||
|
main_return = @options[:omit_begin_end] ? 'void' : 'int'
|
||||||
if main_name != 'main'
|
if main_name != 'main'
|
||||||
output.puts("#{@options[:main_export_decl]} int #{main_name}(void);")
|
output.puts("#{@options[:main_export_decl]} #{main_return} #{main_name}(void);")
|
||||||
end
|
end
|
||||||
output.puts("int #{main_name}(void)")
|
output.puts("#{main_return} #{main_name}(void)")
|
||||||
output.puts('{')
|
output.puts('{')
|
||||||
end
|
end
|
||||||
output.puts(' suite_setup();') unless @options[:suite_setup].nil?
|
output.puts(' suiteSetUp();') if @options[:has_suite_setup]
|
||||||
output.puts(" UnityBegin(\"#{filename.gsub(/\\/, '\\\\\\')}\");")
|
if @options[:omit_begin_end]
|
||||||
if @options[:use_param_tests]
|
output.puts(" UnitySetTestFile(\"#{filename.gsub(/\\/, '\\\\\\')}\");")
|
||||||
tests.each do |test|
|
else
|
||||||
if test[:args].nil? || test[:args].empty?
|
output.puts(" UnityBegin(\"#{filename.gsub(/\\/, '\\\\\\')}\");")
|
||||||
output.puts(" RUN_TEST(#{test[:test]}, #{test[:line_number]}, RUN_TEST_NO_ARGS);")
|
end
|
||||||
else
|
tests.each do |test|
|
||||||
test[:args].each { |args| output.puts(" RUN_TEST(#{test[:test]}, #{test[:line_number]}, #{args});") }
|
if (!@options[:use_param_tests]) || test[:args].nil? || test[:args].empty?
|
||||||
|
output.puts(" run_test(#{test[:test]}, \"#{test[:test]}\", #{test[:line_number]});")
|
||||||
|
else
|
||||||
|
test[:args].each.with_index(1) do |args, idx|
|
||||||
|
wrapper = "runner_args#{idx}_#{test[:test]}"
|
||||||
|
testname = "#{test[:test]}(#{args})".dump
|
||||||
|
output.puts(" run_test(#{wrapper}, #{testname}, #{test[:line_number]});")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
|
||||||
tests.each { |test| output.puts(" RUN_TEST(#{test[:test]}, #{test[:line_number]});") }
|
|
||||||
end
|
end
|
||||||
output.puts
|
output.puts
|
||||||
output.puts(' CMock_Guts_MemFreeFinal();') unless used_mocks.empty?
|
output.puts(' CMock_Guts_MemFreeFinal();') unless used_mocks.empty?
|
||||||
output.puts(" return #{@options[:suite_teardown].nil? ? '' : 'suite_teardown'}(UnityEnd());")
|
if @options[:has_suite_teardown]
|
||||||
|
if @options[:omit_begin_end]
|
||||||
|
output.puts(' (void) suite_teardown(0);')
|
||||||
|
else
|
||||||
|
output.puts(' return suiteTearDown(UnityEnd());')
|
||||||
|
end
|
||||||
|
else
|
||||||
|
output.puts(' return UnityEnd();') unless @options[:omit_begin_end]
|
||||||
|
end
|
||||||
output.puts('}')
|
output.puts('}')
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -369,10 +439,10 @@ class UnityTestRunnerGenerator
|
|||||||
output.puts("#include \"#{@options[:framework]}.h\"")
|
output.puts("#include \"#{@options[:framework]}.h\"")
|
||||||
output.puts('#include "cmock.h"') unless used_mocks.empty?
|
output.puts('#include "cmock.h"') unless used_mocks.empty?
|
||||||
@options[:includes].flatten.uniq.compact.each do |inc|
|
@options[:includes].flatten.uniq.compact.each do |inc|
|
||||||
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc.gsub('.h', '')}.h\""}")
|
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc}\""}")
|
||||||
end
|
end
|
||||||
testfile_includes.each do |inc|
|
testfile_includes.each do |inc|
|
||||||
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc.gsub('.h', '')}.h\""}")
|
output.puts("#include #{inc.include?('<') ? inc : "\"#{inc}\""}")
|
||||||
end
|
end
|
||||||
output.puts "\n"
|
output.puts "\n"
|
||||||
tests.each do |test|
|
tests.each do |test|
|
||||||
@@ -395,13 +465,13 @@ if $0 == __FILE__
|
|||||||
when '-cexception'
|
when '-cexception'
|
||||||
options[:plugins] = [:cexception]
|
options[:plugins] = [:cexception]
|
||||||
true
|
true
|
||||||
when /\.*\.ya?ml/
|
when /\.*\.ya?ml$/
|
||||||
options = UnityTestRunnerGenerator.grab_config(arg)
|
options = UnityTestRunnerGenerator.grab_config(arg)
|
||||||
true
|
true
|
||||||
when /--(\w+)=\"?(.*)\"?/
|
when /--(\w+)=\"?(.*)\"?/
|
||||||
options[Regexp.last_match(1).to_sym] = Regexp.last_match(2)
|
options[Regexp.last_match(1).to_sym] = Regexp.last_match(2)
|
||||||
true
|
true
|
||||||
when /\.*\.h/
|
when /\.*\.(?:hpp|hh|H|h)$/
|
||||||
options[:includes] << arg
|
options[:includes] << arg
|
||||||
true
|
true
|
||||||
else false
|
else false
|
||||||
@@ -419,13 +489,17 @@ if $0 == __FILE__
|
|||||||
' *.h - header files are added as #includes in runner',
|
' *.h - header files are added as #includes in runner',
|
||||||
' options:',
|
' options:',
|
||||||
' -cexception - include cexception support',
|
' -cexception - include cexception support',
|
||||||
|
' -externc - add extern "C" for cpp support',
|
||||||
' --setup_name="" - redefine setUp func name to something else',
|
' --setup_name="" - redefine setUp func name to something else',
|
||||||
' --teardown_name="" - redefine tearDown func name to something else',
|
' --teardown_name="" - redefine tearDown func name to something else',
|
||||||
' --main_name="" - redefine main func name to something else',
|
' --main_name="" - redefine main func name to something else',
|
||||||
' --test_prefix="" - redefine test prefix from default test|spec|should',
|
' --test_prefix="" - redefine test prefix from default test|spec|should',
|
||||||
|
' --test_reset_name="" - redefine resetTest func name to something else',
|
||||||
|
' --test_verify_name="" - redefine verifyTest func name to something else',
|
||||||
' --suite_setup="" - code to execute for setup of entire suite',
|
' --suite_setup="" - code to execute for setup of entire suite',
|
||||||
' --suite_teardown="" - code to execute for teardown of entire suite',
|
' --suite_teardown="" - code to execute for teardown of entire suite',
|
||||||
' --use_param_tests=1 - enable parameterized tests (disabled by default)',
|
' --use_param_tests=1 - enable parameterized tests (disabled by default)',
|
||||||
|
' --omit_begin_end=1 - omit calls to UnityBegin and UnityEnd (disabled by default)',
|
||||||
' --header_file="" - path/name of test header file to generate too'].join("\n")
|
' --header_file="" - path/name of test header file to generate too'].join("\n")
|
||||||
exit 1
|
exit 1
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,206 +1,308 @@
|
|||||||
#============================================================
|
#============================================================
|
||||||
# Author: John Theofanopoulos
|
# Author: John Theofanopoulos
|
||||||
# A simple parser. Takes the output files generated during the build process and
|
# A simple parser. Takes the output files generated during the
|
||||||
# extracts information relating to the tests.
|
# build process and extracts information relating to the tests.
|
||||||
#
|
#
|
||||||
# Notes:
|
# Notes:
|
||||||
# To capture an output file under VS builds use the following:
|
# To capture an output file under VS builds use the following:
|
||||||
# devenv [build instructions] > Output.txt & type Output.txt
|
# devenv [build instructions] > Output.txt & type Output.txt
|
||||||
#
|
#
|
||||||
# To capture an output file under GCC/Linux builds use the following:
|
# To capture an output file under Linux builds use the following:
|
||||||
# make | tee Output.txt
|
# make | tee Output.txt
|
||||||
#
|
#
|
||||||
|
# This script can handle the following output formats:
|
||||||
|
# - normal output (raw unity)
|
||||||
|
# - fixture output (unity_fixture.h/.c)
|
||||||
|
# - fixture output with verbose flag set ("-v")
|
||||||
|
#
|
||||||
# To use this parser use the following command
|
# To use this parser use the following command
|
||||||
# ruby parseOutput.rb [options] [file]
|
# ruby parseOutput.rb [options] [file]
|
||||||
# options: -xml : produce a JUnit compatible XML file
|
# options: -xml : produce a JUnit compatible XML file
|
||||||
# file : file to scan for results
|
# file: file to scan for results
|
||||||
#============================================================
|
#============================================================
|
||||||
|
|
||||||
|
# Parser class for handling the input file
|
||||||
class ParseOutput
|
class ParseOutput
|
||||||
def initialize
|
def initialize
|
||||||
@test_flag = false
|
# internal data
|
||||||
|
@class_name_idx = 0
|
||||||
|
@path_delim = nil
|
||||||
|
|
||||||
|
# xml output related
|
||||||
@xml_out = false
|
@xml_out = false
|
||||||
@array_list = false
|
@array_list = false
|
||||||
@total_tests = false
|
|
||||||
@class_index = false
|
# current suite name and statistics
|
||||||
|
@test_suite = nil
|
||||||
|
@total_tests = 0
|
||||||
|
@test_passed = 0
|
||||||
|
@test_failed = 0
|
||||||
|
@test_ignored = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
# Set the flag to indicate if there will be an XML output file or not
|
# Set the flag to indicate if there will be an XML output file or not
|
||||||
def set_xml_output
|
def set_xml_output
|
||||||
@xml_out = true
|
@xml_out = true
|
||||||
end
|
end
|
||||||
|
|
||||||
# if write our output to XML
|
# If write our output to XML
|
||||||
def write_xml_output
|
def write_xml_output
|
||||||
output = File.open('report.xml', 'w')
|
output = File.open('report.xml', 'w')
|
||||||
output << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
|
output << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
|
||||||
@array_list.each do |item|
|
@array_list.each do |item|
|
||||||
output << item << "\n"
|
output << item << "\n"
|
||||||
end
|
end
|
||||||
output << "</testsuite>\n"
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# This function will try and determine when the suite is changed. This is
|
# Pushes the suite info as xml to the array list, which will be written later
|
||||||
|
def push_xml_output_suite_info
|
||||||
|
# Insert opening tag at front
|
||||||
|
heading = '<testsuite name="Unity" tests="' + @total_tests.to_s + '" failures="' + @test_failed.to_s + '"' + ' skips="' + @test_ignored.to_s + '">'
|
||||||
|
@array_list.insert(0, heading)
|
||||||
|
# Push back the closing tag
|
||||||
|
@array_list.push '</testsuite>'
|
||||||
|
end
|
||||||
|
|
||||||
|
# Pushes xml output data to the array list, which will be written later
|
||||||
|
def push_xml_output_passed(test_name)
|
||||||
|
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '"/>'
|
||||||
|
end
|
||||||
|
|
||||||
|
# Pushes xml output data to the array list, which will be written later
|
||||||
|
def push_xml_output_failed(test_name, reason)
|
||||||
|
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '">'
|
||||||
|
@array_list.push ' <failure type="ASSERT FAILED">' + reason + '</failure>'
|
||||||
|
@array_list.push ' </testcase>'
|
||||||
|
end
|
||||||
|
|
||||||
|
# Pushes xml output data to the array list, which will be written later
|
||||||
|
def push_xml_output_ignored(test_name, reason)
|
||||||
|
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '">'
|
||||||
|
@array_list.push ' <skipped type="TEST IGNORED">' + reason + '</skipped>'
|
||||||
|
@array_list.push ' </testcase>'
|
||||||
|
end
|
||||||
|
|
||||||
|
# This function will try and determine when the suite is changed. This is
|
||||||
# is the name that gets added to the classname parameter.
|
# is the name that gets added to the classname parameter.
|
||||||
def test_suite_verify(test_suite_name)
|
def test_suite_verify(test_suite_name)
|
||||||
return if @test_flag
|
|
||||||
|
|
||||||
@test_flag = true
|
|
||||||
# Split the path name
|
# Split the path name
|
||||||
test_name = test_suite_name.split('/')
|
test_name = test_suite_name.split(@path_delim)
|
||||||
# Remove the extension
|
|
||||||
base_name = test_name[test_name.size - 1].split('.')
|
# Remove the extension and extract the base_name
|
||||||
@test_suite = 'test.' + base_name[0]
|
base_name = test_name[test_name.size - 1].split('.')[0]
|
||||||
|
|
||||||
|
# Return if the test suite hasn't changed
|
||||||
|
return unless base_name.to_s != @test_suite.to_s
|
||||||
|
|
||||||
|
@test_suite = base_name
|
||||||
printf "New Test: %s\n", @test_suite
|
printf "New Test: %s\n", @test_suite
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Prepares the line for verbose fixture output ("-v")
|
||||||
|
def prepare_fixture_line(line)
|
||||||
|
line = line.sub('IGNORE_TEST(', '')
|
||||||
|
line = line.sub('TEST(', '')
|
||||||
|
line = line.sub(')', ',')
|
||||||
|
line = line.chomp
|
||||||
|
array = line.split(',')
|
||||||
|
array.map { |x| x.to_s.lstrip.chomp }
|
||||||
|
end
|
||||||
|
|
||||||
|
# Test was flagged as having passed so format the output.
|
||||||
|
# This is using the Unity fixture output and not the original Unity output.
|
||||||
|
def test_passed_unity_fixture(array)
|
||||||
|
class_name = array[0]
|
||||||
|
test_name = array[1]
|
||||||
|
test_suite_verify(class_name)
|
||||||
|
printf "%-40s PASS\n", test_name
|
||||||
|
|
||||||
|
push_xml_output_passed(test_name) if @xml_out
|
||||||
|
end
|
||||||
|
|
||||||
|
# Test was flagged as having failed so format the output.
|
||||||
|
# This is using the Unity fixture output and not the original Unity output.
|
||||||
|
def test_failed_unity_fixture(array)
|
||||||
|
class_name = array[0]
|
||||||
|
test_name = array[1]
|
||||||
|
test_suite_verify(class_name)
|
||||||
|
reason_array = array[2].split(':')
|
||||||
|
reason = reason_array[-1].lstrip.chomp + ' at line: ' + reason_array[-4]
|
||||||
|
|
||||||
|
printf "%-40s FAILED\n", test_name
|
||||||
|
|
||||||
|
push_xml_output_failed(test_name, reason) if @xml_out
|
||||||
|
end
|
||||||
|
|
||||||
|
# Test was flagged as being ignored so format the output.
|
||||||
|
# This is using the Unity fixture output and not the original Unity output.
|
||||||
|
def test_ignored_unity_fixture(array)
|
||||||
|
class_name = array[0]
|
||||||
|
test_name = array[1]
|
||||||
|
reason = 'No reason given'
|
||||||
|
if array.size > 2
|
||||||
|
reason_array = array[2].split(':')
|
||||||
|
tmp_reason = reason_array[-1].lstrip.chomp
|
||||||
|
reason = tmp_reason == 'IGNORE' ? 'No reason given' : tmp_reason
|
||||||
|
end
|
||||||
|
test_suite_verify(class_name)
|
||||||
|
printf "%-40s IGNORED\n", test_name
|
||||||
|
|
||||||
|
push_xml_output_ignored(test_name, reason) if @xml_out
|
||||||
|
end
|
||||||
|
|
||||||
# Test was flagged as having passed so format the output
|
# Test was flagged as having passed so format the output
|
||||||
def test_passed(array)
|
def test_passed(array)
|
||||||
last_item = array.length - 1
|
last_item = array.length - 1
|
||||||
test_name = array[last_item - 1]
|
test_name = array[last_item - 1]
|
||||||
test_suite_verify(array[@class_name])
|
test_suite_verify(array[@class_name_idx])
|
||||||
printf "%-40s PASS\n", test_name
|
printf "%-40s PASS\n", test_name
|
||||||
|
|
||||||
return unless @xml_out
|
return unless @xml_out
|
||||||
|
|
||||||
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '"/>'
|
push_xml_output_passed(test_name) if @xml_out
|
||||||
end
|
end
|
||||||
|
|
||||||
# Test was flagged as having passed so format the output.
|
# Test was flagged as having failed so format the line
|
||||||
# This is using the Unity fixture output and not the original Unity output.
|
|
||||||
def test_passed_unity_fixture(array)
|
|
||||||
test_suite = array[0].sub('TEST(', '')
|
|
||||||
test_suite = test_suite.sub(',', '')
|
|
||||||
test_name = array[1].sub(')', '')
|
|
||||||
|
|
||||||
return unless @xml_out
|
|
||||||
|
|
||||||
@array_list.push ' <testcase classname="' + test_suite + '" name="' + test_name + '"/>'
|
|
||||||
end
|
|
||||||
|
|
||||||
# Test was flagged as being ingored so format the output
|
|
||||||
def test_ignored(array)
|
|
||||||
last_item = array.length - 1
|
|
||||||
test_name = array[last_item - 2]
|
|
||||||
reason = array[last_item].chomp
|
|
||||||
test_suite_verify(array[@class_name])
|
|
||||||
printf "%-40s IGNORED\n", test_name
|
|
||||||
|
|
||||||
if test_name.start_with? 'TEST('
|
|
||||||
array2 = test_name.split(' ')
|
|
||||||
@test_suite = array2[0].sub('TEST(', '')
|
|
||||||
@test_suite = @test_suite.sub(',', '')
|
|
||||||
test_name = array2[1].sub(')', '')
|
|
||||||
end
|
|
||||||
|
|
||||||
return unless @xml_out
|
|
||||||
|
|
||||||
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '">'
|
|
||||||
@array_list.push ' <skipped type="TEST IGNORED"> ' + reason + ' </skipped>'
|
|
||||||
@array_list.push ' </testcase>'
|
|
||||||
end
|
|
||||||
|
|
||||||
# Test was flagged as having failed so format the line
|
|
||||||
def test_failed(array)
|
def test_failed(array)
|
||||||
last_item = array.length - 1
|
last_item = array.length - 1
|
||||||
test_name = array[last_item - 2]
|
test_name = array[last_item - 2]
|
||||||
reason = array[last_item].chomp + ' at line: ' + array[last_item - 3]
|
reason = array[last_item].chomp.lstrip + ' at line: ' + array[last_item - 3]
|
||||||
test_suite_verify(array[@class_name])
|
class_name = array[@class_name_idx]
|
||||||
printf "%-40s FAILED\n", test_name
|
|
||||||
|
|
||||||
if test_name.start_with? 'TEST('
|
if test_name.start_with? 'TEST('
|
||||||
array2 = test_name.split(' ')
|
array2 = test_name.split(' ')
|
||||||
@test_suite = array2[0].sub('TEST(', '')
|
|
||||||
@test_suite = @test_suite.sub(',', '')
|
test_suite = array2[0].sub('TEST(', '')
|
||||||
|
test_suite = test_suite.sub(',', '')
|
||||||
|
class_name = test_suite
|
||||||
|
|
||||||
test_name = array2[1].sub(')', '')
|
test_name = array2[1].sub(')', '')
|
||||||
end
|
end
|
||||||
|
|
||||||
return unless @xml_out
|
test_suite_verify(class_name)
|
||||||
|
printf "%-40s FAILED\n", test_name
|
||||||
|
|
||||||
@array_list.push ' <testcase classname="' + @test_suite + '" name="' + test_name + '">'
|
push_xml_output_failed(test_name, reason) if @xml_out
|
||||||
@array_list.push ' <failure type="ASSERT FAILED"> ' + reason + ' </failure>'
|
|
||||||
@array_list.push ' </testcase>'
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Figure out what OS we are running on. For now we are assuming if it's not Windows it must
|
# Test was flagged as being ignored so format the output
|
||||||
# be Unix based.
|
def test_ignored(array)
|
||||||
def detect_os
|
last_item = array.length - 1
|
||||||
os = RUBY_PLATFORM.split('-')
|
test_name = array[last_item - 2]
|
||||||
@class_name = if os.size == 2
|
reason = array[last_item].chomp.lstrip
|
||||||
if os[1] == 'mingw32'
|
class_name = array[@class_name_idx]
|
||||||
1
|
|
||||||
else
|
if test_name.start_with? 'TEST('
|
||||||
0
|
array2 = test_name.split(' ')
|
||||||
end
|
|
||||||
else
|
test_suite = array2[0].sub('TEST(', '')
|
||||||
0
|
test_suite = test_suite.sub(',', '')
|
||||||
end
|
class_name = test_suite
|
||||||
|
|
||||||
|
test_name = array2[1].sub(')', '')
|
||||||
|
end
|
||||||
|
|
||||||
|
test_suite_verify(class_name)
|
||||||
|
printf "%-40s IGNORED\n", test_name
|
||||||
|
|
||||||
|
push_xml_output_ignored(test_name, reason) if @xml_out
|
||||||
|
end
|
||||||
|
|
||||||
|
# Adjusts the os specific members according to the current path style
|
||||||
|
# (Windows or Unix based)
|
||||||
|
def detect_os_specifics(line)
|
||||||
|
if line.include? '\\'
|
||||||
|
# Windows X:\Y\Z
|
||||||
|
@class_name_idx = 1
|
||||||
|
@path_delim = '\\'
|
||||||
|
else
|
||||||
|
# Unix Based /X/Y/Z
|
||||||
|
@class_name_idx = 0
|
||||||
|
@path_delim = '/'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Main function used to parse the file that was captured.
|
# Main function used to parse the file that was captured.
|
||||||
def process(name)
|
def process(file_name)
|
||||||
@test_flag = false
|
|
||||||
@array_list = []
|
@array_list = []
|
||||||
|
|
||||||
detect_os
|
puts 'Parsing file: ' + file_name
|
||||||
|
|
||||||
puts 'Parsing file: ' + name
|
@test_passed = 0
|
||||||
|
@test_failed = 0
|
||||||
test_pass = 0
|
@test_ignored = 0
|
||||||
test_fail = 0
|
|
||||||
test_ignore = 0
|
|
||||||
puts ''
|
puts ''
|
||||||
puts '=================== RESULTS ====================='
|
puts '=================== RESULTS ====================='
|
||||||
puts ''
|
puts ''
|
||||||
File.open(name).each do |line|
|
File.open(file_name).each do |line|
|
||||||
# Typical test lines look like this:
|
# Typical test lines look like these:
|
||||||
|
# ----------------------------------------------------
|
||||||
|
# 1. normal output:
|
||||||
# <path>/<test_file>.c:36:test_tc1000_opsys:FAIL: Expected 1 Was 0
|
# <path>/<test_file>.c:36:test_tc1000_opsys:FAIL: Expected 1 Was 0
|
||||||
# <path>/<test_file>.c:112:test_tc5004_initCanChannel:IGNORE: Not Yet Implemented
|
# <path>/<test_file>.c:112:test_tc5004_initCanChannel:IGNORE: Not Yet Implemented
|
||||||
# <path>/<test_file>.c:115:test_tc5100_initCanVoidPtrs:PASS
|
# <path>/<test_file>.c:115:test_tc5100_initCanVoidPtrs:PASS
|
||||||
#
|
#
|
||||||
# where path is different on Unix vs Windows devices (Windows leads with a drive letter)
|
# 2. fixture output
|
||||||
|
# <path>/<test_file>.c:63:TEST(<test_group>, <test_function>):FAIL: Expected 0x00001234 Was 0x00005A5A
|
||||||
|
# <path>/<test_file>.c:36:TEST(<test_group>, <test_function>):IGNORE
|
||||||
|
# Note: "PASS" information won't be generated in this mode
|
||||||
|
#
|
||||||
|
# 3. fixture output with verbose information ("-v")
|
||||||
|
# TEST(<test_group, <test_file>)<path>/<test_file>:168::FAIL: Expected 0x8D Was 0x8C
|
||||||
|
# TEST(<test_group>, <test_file>)<path>/<test_file>:22::IGNORE: This Test Was Ignored On Purpose
|
||||||
|
# IGNORE_TEST(<test_group, <test_file>)
|
||||||
|
# TEST(<test_group, <test_file>) PASS
|
||||||
|
#
|
||||||
|
# Note: Where path is different on Unix vs Windows devices (Windows leads with a drive letter)!
|
||||||
|
detect_os_specifics(line)
|
||||||
line_array = line.split(':')
|
line_array = line.split(':')
|
||||||
|
|
||||||
# If we were able to split the line then we can look to see if any of our target words
|
# If we were able to split the line then we can look to see if any of our target words
|
||||||
# were found. Case is important.
|
# were found. Case is important.
|
||||||
if (line_array.size >= 4) || (line.start_with? 'TEST(')
|
next unless (line_array.size >= 4) || (line.start_with? 'TEST(') || (line.start_with? 'IGNORE_TEST(')
|
||||||
# Determine if this test passed
|
|
||||||
if line.include? ':PASS'
|
# check if the output is fixture output (with verbose flag "-v")
|
||||||
test_passed(line_array)
|
if (line.start_with? 'TEST(') || (line.start_with? 'IGNORE_TEST(')
|
||||||
test_pass += 1
|
line_array = prepare_fixture_line(line)
|
||||||
elsif line.include? ':FAIL:'
|
if line.include? ' PASS'
|
||||||
test_failed(line_array)
|
test_passed_unity_fixture(line_array)
|
||||||
test_fail += 1
|
@test_passed += 1
|
||||||
elsif line.include? ':IGNORE:'
|
elsif line.include? 'FAIL'
|
||||||
test_ignored(line_array)
|
test_failed_unity_fixture(line_array)
|
||||||
test_ignore += 1
|
@test_failed += 1
|
||||||
elsif line.start_with? 'TEST('
|
elsif line.include? 'IGNORE'
|
||||||
if line.include? ' PASS'
|
test_ignored_unity_fixture(line_array)
|
||||||
line_array = line.split(' ')
|
@test_ignored += 1
|
||||||
test_passed_unity_fixture(line_array)
|
|
||||||
test_pass += 1
|
|
||||||
end
|
|
||||||
# If none of the keywords are found there are no more tests for this suite so clear
|
|
||||||
# the test flag
|
|
||||||
else
|
|
||||||
@test_flag = false
|
|
||||||
end
|
end
|
||||||
else
|
# normal output / fixture output (without verbose "-v")
|
||||||
@test_flag = false
|
elsif line.include? ':PASS'
|
||||||
|
test_passed(line_array)
|
||||||
|
@test_passed += 1
|
||||||
|
elsif line.include? ':FAIL'
|
||||||
|
test_failed(line_array)
|
||||||
|
@test_failed += 1
|
||||||
|
elsif line.include? ':IGNORE:'
|
||||||
|
test_ignored(line_array)
|
||||||
|
@test_ignored += 1
|
||||||
|
elsif line.include? ':IGNORE'
|
||||||
|
line_array.push('No reason given')
|
||||||
|
test_ignored(line_array)
|
||||||
|
@test_ignored += 1
|
||||||
end
|
end
|
||||||
|
@total_tests = @test_passed + @test_failed + @test_ignored
|
||||||
end
|
end
|
||||||
puts ''
|
puts ''
|
||||||
puts '=================== SUMMARY ====================='
|
puts '=================== SUMMARY ====================='
|
||||||
puts ''
|
puts ''
|
||||||
puts 'Tests Passed : ' + test_pass.to_s
|
puts 'Tests Passed : ' + @test_passed.to_s
|
||||||
puts 'Tests Failed : ' + test_fail.to_s
|
puts 'Tests Failed : ' + @test_failed.to_s
|
||||||
puts 'Tests Ignored : ' + test_ignore.to_s
|
puts 'Tests Ignored : ' + @test_ignored.to_s
|
||||||
@total_tests = test_pass + test_fail + test_ignore
|
|
||||||
|
|
||||||
return unless @xml_out
|
return unless @xml_out
|
||||||
|
|
||||||
heading = '<testsuite tests="' + @total_tests.to_s + '" failures="' + test_fail.to_s + '"' + ' skips="' + test_ignore.to_s + '">'
|
# push information about the suite
|
||||||
@array_list.insert(0, heading)
|
push_xml_output_suite_info
|
||||||
|
# write xml output file
|
||||||
write_xml_output
|
write_xml_output
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -209,11 +311,11 @@ end
|
|||||||
parse_my_file = ParseOutput.new
|
parse_my_file = ParseOutput.new
|
||||||
|
|
||||||
if ARGV.size >= 1
|
if ARGV.size >= 1
|
||||||
ARGV.each do |a|
|
ARGV.each do |arg|
|
||||||
if a == '-xml'
|
if arg == '-xml'
|
||||||
parse_my_file.set_xml_output
|
parse_my_file.set_xml_output
|
||||||
else
|
else
|
||||||
parse_my_file.process(a)
|
parse_my_file.process(arg)
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
37
auto/run_test.erb
Normal file
37
auto/run_test.erb
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
/*=======Test Runner Used To Run Each Test=====*/
|
||||||
|
static void run_test(UnityTestFunction func, const char* name, UNITY_LINE_TYPE line_num)
|
||||||
|
{
|
||||||
|
Unity.CurrentTestName = name;
|
||||||
|
Unity.CurrentTestLineNumber = line_num;
|
||||||
|
#ifdef UNITY_USE_COMMAND_LINE_ARGS
|
||||||
|
if (!UnityTestMatches())
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
Unity.NumberOfTests++;
|
||||||
|
UNITY_CLR_DETAILS();
|
||||||
|
UNITY_EXEC_TIME_START();
|
||||||
|
CMock_Init();
|
||||||
|
if (TEST_PROTECT())
|
||||||
|
{
|
||||||
|
<% if @options[:plugins].include?(:cexception) %>
|
||||||
|
CEXCEPTION_T e;
|
||||||
|
Try {
|
||||||
|
<%= @options[:setup_name] %>();
|
||||||
|
func();
|
||||||
|
} Catch(e) {
|
||||||
|
TEST_ASSERT_EQUAL_HEX32_MESSAGE(CEXCEPTION_NONE, e, "Unhandled Exception!");
|
||||||
|
}
|
||||||
|
<% else %>
|
||||||
|
<%= @options[:setup_name] %>();
|
||||||
|
func();
|
||||||
|
<% end %>
|
||||||
|
}
|
||||||
|
if (TEST_PROTECT())
|
||||||
|
{
|
||||||
|
<%= @options[:teardown_name] %>();
|
||||||
|
CMock_Verify();
|
||||||
|
}
|
||||||
|
CMock_Destroy();
|
||||||
|
UNITY_EXEC_TIME_STOP();
|
||||||
|
UnityConcludeTest();
|
||||||
|
}
|
||||||
@@ -61,8 +61,8 @@ class ArgvParser
|
|||||||
|
|
||||||
opts.parse!(args)
|
opts.parse!(args)
|
||||||
options
|
options
|
||||||
end # parse()
|
end
|
||||||
end # class OptparseExample
|
end
|
||||||
|
|
||||||
class UnityToJUnit
|
class UnityToJUnit
|
||||||
include FileUtils::Verbose
|
include FileUtils::Verbose
|
||||||
@@ -152,11 +152,8 @@ class UnityToJUnit
|
|||||||
|
|
||||||
def parse_test_summary(summary)
|
def parse_test_summary(summary)
|
||||||
raise "Couldn't parse test results: #{summary}" unless summary.find { |v| v =~ /(\d+) Tests (\d+) Failures (\d+) Ignored/ }
|
raise "Couldn't parse test results: #{summary}" unless summary.find { |v| v =~ /(\d+) Tests (\d+) Failures (\d+) Ignored/ }
|
||||||
[Regexp.last_match(1).to_i, Regexp.last_match(2).to_i, Regexp.last_match(3).to_i]
|
|
||||||
end
|
|
||||||
|
|
||||||
def here
|
[Regexp.last_match(1).to_i, Regexp.last_match(2).to_i, Regexp.last_match(3).to_i]
|
||||||
File.expand_path(File.dirname(__FILE__))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
@@ -221,9 +218,9 @@ class UnityToJUnit
|
|||||||
def write_suites_footer(stream)
|
def write_suites_footer(stream)
|
||||||
stream.puts '</testsuites>'
|
stream.puts '</testsuites>'
|
||||||
end
|
end
|
||||||
end # UnityToJUnit
|
end
|
||||||
|
|
||||||
if __FILE__ == $0
|
if $0 == __FILE__
|
||||||
# parse out the command options
|
# parse out the command options
|
||||||
options = ArgvParser.parse(ARGV)
|
options = ArgvParser.parse(ARGV)
|
||||||
|
|
||||||
@@ -234,7 +231,9 @@ if __FILE__ == $0
|
|||||||
targets = "#{options.results_dir.tr('\\', '/')}**/*.test*"
|
targets = "#{options.results_dir.tr('\\', '/')}**/*.test*"
|
||||||
|
|
||||||
results = Dir[targets]
|
results = Dir[targets]
|
||||||
|
|
||||||
raise "No *.testpass, *.testfail, or *.testresults files found in '#{targets}'" if results.empty?
|
raise "No *.testpass, *.testfail, or *.testresults files found in '#{targets}'" if results.empty?
|
||||||
|
|
||||||
utj.targets = results
|
utj.targets = results
|
||||||
|
|
||||||
# set the root path
|
# set the root path
|
||||||
|
|||||||
@@ -11,8 +11,8 @@ module RakefileHelpers
|
|||||||
def initialize(all_files = false)
|
def initialize(all_files = false)
|
||||||
@all_files = all_files
|
@all_files = all_files
|
||||||
|
|
||||||
return false unless @all_files
|
return unless @all_files
|
||||||
return false unless File.exist?('test_file_filter.yml')
|
return unless File.exist?('test_file_filter.yml')
|
||||||
|
|
||||||
filters = YAML.load_file('test_file_filter.yml')
|
filters = YAML.load_file('test_file_filter.yml')
|
||||||
@all_files = filters[:all_files]
|
@all_files = filters[:all_files]
|
||||||
|
|||||||
@@ -121,7 +121,7 @@ if __name__ == '__main__':
|
|||||||
targets_dir = sys.argv[1]
|
targets_dir = sys.argv[1]
|
||||||
else:
|
else:
|
||||||
targets_dir = './'
|
targets_dir = './'
|
||||||
targets = list(map(lambda x: x.replace('\\', '/'), glob(targets_dir + '*.test*')))
|
targets = list(map(lambda x: x.replace('\\', '/'), glob(targets_dir + '**/*.test*', recursive=True)))
|
||||||
if len(targets) == 0:
|
if len(targets) == 0:
|
||||||
raise Exception("No *.testpass or *.testfail files found in '%s'" % targets_dir)
|
raise Exception("No *.testpass or *.testfail files found in '%s'" % targets_dir)
|
||||||
uts.set_targets(targets)
|
uts.set_targets(targets)
|
||||||
|
|||||||
@@ -99,11 +99,8 @@ class UnityTestSummary
|
|||||||
|
|
||||||
def parse_test_summary(summary)
|
def parse_test_summary(summary)
|
||||||
raise "Couldn't parse test results: #{summary}" unless summary.find { |v| v =~ /(\d+) Tests (\d+) Failures (\d+) Ignored/ }
|
raise "Couldn't parse test results: #{summary}" unless summary.find { |v| v =~ /(\d+) Tests (\d+) Failures (\d+) Ignored/ }
|
||||||
[Regexp.last_match(1).to_i, Regexp.last_match(2).to_i, Regexp.last_match(3).to_i]
|
|
||||||
end
|
|
||||||
|
|
||||||
def here
|
[Regexp.last_match(1).to_i, Regexp.last_match(2).to_i, Regexp.last_match(3).to_i]
|
||||||
File.expand_path(File.dirname(__FILE__))
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -121,7 +118,9 @@ if $0 == __FILE__
|
|||||||
args[0] ||= './'
|
args[0] ||= './'
|
||||||
targets = "#{ARGV[0].tr('\\', '/')}**/*.test*"
|
targets = "#{ARGV[0].tr('\\', '/')}**/*.test*"
|
||||||
results = Dir[targets]
|
results = Dir[targets]
|
||||||
|
|
||||||
raise "No *.testpass, *.testfail, or *.testresults files found in '#{targets}'" if results.empty?
|
raise "No *.testpass, *.testfail, or *.testresults files found in '#{targets}'" if results.empty?
|
||||||
|
|
||||||
uts.targets = results
|
uts.targets = results
|
||||||
|
|
||||||
# set the root path
|
# set the root path
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# ThrowTheSwitch.org Coding Standard
|
# ThrowTheSwitch.org Coding Standard
|
||||||
|
|
||||||
Hi. Welcome to the coding standard for ThrowTheSwitch.org. For the most part,
|
Hi. Welcome to the coding standard for ThrowTheSwitch.org. For the most part,
|
||||||
we try to follow these standards to unify our contributors' code into a cohesive
|
we try to follow these standards to unify our contributors' code into a cohesive
|
||||||
@@ -11,7 +11,7 @@ and we'll try to be polite when we notice yours.
|
|||||||
|
|
||||||
## Why Have A Coding Standard?
|
## Why Have A Coding Standard?
|
||||||
|
|
||||||
Being consistent makes code easier to understand. We've made an attempt to keep
|
Being consistent makes code easier to understand. We've tried to keep
|
||||||
our standard simple because we also believe that we can only expect someone to
|
our standard simple because we also believe that we can only expect someone to
|
||||||
follow something that is understandable. Please do your best.
|
follow something that is understandable. Please do your best.
|
||||||
|
|
||||||
@@ -51,11 +51,11 @@ much as they can, but give the user the power to override it when it's wrong.
|
|||||||
|
|
||||||
Let's talk about naming things. Programming is all about naming things. We name
|
Let's talk about naming things. Programming is all about naming things. We name
|
||||||
files, functions, variables, and so much more. While we're not always going to
|
files, functions, variables, and so much more. While we're not always going to
|
||||||
find the best name for something, we actually put quite a bit of effort into
|
find the best name for something, we actually put a bit of effort into
|
||||||
finding *What Something WANTS to be Called*™.
|
finding *What Something WANTS to be Called*™.
|
||||||
|
|
||||||
When naming things, we more or less follow this hierarchy, the first being the
|
When naming things, we follow this hierarchy, the first being the
|
||||||
most important to us (but we do all four whenever possible):
|
most important to us (but we do all four when possible):
|
||||||
1. Readable
|
1. Readable
|
||||||
2. Descriptive
|
2. Descriptive
|
||||||
3. Consistent
|
3. Consistent
|
||||||
@@ -74,7 +74,7 @@ abbreviations (sticking to ones we feel are common).
|
|||||||
We like descriptive names for things, especially functions and variables.
|
We like descriptive names for things, especially functions and variables.
|
||||||
Finding the right name for something is an important endeavor. You might notice
|
Finding the right name for something is an important endeavor. You might notice
|
||||||
from poking around our code that this often results in names that are a little
|
from poking around our code that this often results in names that are a little
|
||||||
longer than the average. Guilty. We're okay with a tiny bit more typing if it
|
longer than the average. Guilty. We're okay with a bit more typing if it
|
||||||
means our code is easier to understand.
|
means our code is easier to understand.
|
||||||
|
|
||||||
There are two exceptions to this rule that we also stick to as religiously as
|
There are two exceptions to this rule that we also stick to as religiously as
|
||||||
@@ -82,8 +82,7 @@ possible:
|
|||||||
|
|
||||||
First, while we realize hungarian notation (and similar systems for encoding
|
First, while we realize hungarian notation (and similar systems for encoding
|
||||||
type information into variable names) is providing a more descriptive name, we
|
type information into variable names) is providing a more descriptive name, we
|
||||||
feel that (for the average developer) it takes away from readability and
|
feel that (for the average developer) it takes away from readability and is to be avoided.
|
||||||
therefore is to be avoided.
|
|
||||||
|
|
||||||
Second, loop counters and other local throw-away variables often have a purpose
|
Second, loop counters and other local throw-away variables often have a purpose
|
||||||
which is obvious. There's no need, therefore, to get carried away with complex
|
which is obvious. There's no need, therefore, to get carried away with complex
|
||||||
@@ -128,7 +127,7 @@ the same. It will only hurt a little. We promise.
|
|||||||
#### Whitespace
|
#### Whitespace
|
||||||
|
|
||||||
Our C-style is to use spaces and to use 4 of them per indent level. It's a nice
|
Our C-style is to use spaces and to use 4 of them per indent level. It's a nice
|
||||||
power-of-2 number that looks decent on a wide screen. We have no more reason
|
power-of-2 number that looks decent on a wide-screen. We have no more reason
|
||||||
than that. We break that rule when we have lines that wrap (macros or function
|
than that. We break that rule when we have lines that wrap (macros or function
|
||||||
arguments or whatnot). When that happens, we like to indent further to line
|
arguments or whatnot). When that happens, we like to indent further to line
|
||||||
things up in nice tidy columns.
|
things up in nice tidy columns.
|
||||||
@@ -200,7 +199,7 @@ that happens, we like to indent further to line things up in nice tidy columns.
|
|||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
Egad. Really? We use markdown and we like pdf files because they can be made to
|
Egad. Really? We use mark down and we like pdf files because they can be made to
|
||||||
look nice while still being portable. Good enough?
|
look nice while still being portable. Good enough?
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -67,20 +67,22 @@ to be well designed code.
|
|||||||
|
|
||||||
The convention of assertion parameters generally follows this order:
|
The convention of assertion parameters generally follows this order:
|
||||||
|
|
||||||
TEST_ASSERT_X( {modifiers}, {expected}, actual, {size/count} )
|
```
|
||||||
|
TEST_ASSERT_X( {modifiers}, {expected}, actual, {size/count} )
|
||||||
|
```
|
||||||
|
|
||||||
The very simplest assertion possible uses only a single "actual" parameter (e.g.
|
The very simplest assertion possible uses only a single `actual` parameter (e.g.
|
||||||
a simple null check).
|
a simple null check).
|
||||||
|
|
||||||
"Actual" is the value being tested and unlike the other parameters in an
|
- `Actual` is the value being tested and unlike the other parameters in an
|
||||||
assertion construction is the only parameter present in all assertion variants.
|
assertion construction is the only parameter present in all assertion variants.
|
||||||
"Modifiers" are masks, ranges, bit flag specifiers, floating point deltas.
|
- `Modifiers` are masks, ranges, bit flag specifiers, floating point deltas.
|
||||||
"Expected" is your expected value (duh) to compare to an "actual" value; it's
|
- `Expected` is your expected value (duh) to compare to an `actual` value; it's
|
||||||
marked as an optional parameter because some assertions only need a single
|
marked as an optional parameter because some assertions only need a single
|
||||||
"actual" parameter (e.g. null check).
|
`actual` parameter (e.g. null check).
|
||||||
"Size/count" refers to string lengths, number of array elements, etc.
|
- `Size/count` refers to string lengths, number of array elements, etc.
|
||||||
|
|
||||||
Many of Unity's assertions are apparent duplications in that the same data type
|
Many of Unity's assertions are clear duplications in that the same data type
|
||||||
is handled by several assertions. The differences among these are in how failure
|
is handled by several assertions. The differences among these are in how failure
|
||||||
messages are presented. For instance, a `_HEX` variant of an assertion prints
|
messages are presented. For instance, a `_HEX` variant of an assertion prints
|
||||||
the expected and actual values of that assertion formatted as hexadecimal.
|
the expected and actual values of that assertion formatted as hexadecimal.
|
||||||
@@ -98,11 +100,24 @@ the reference list below and add a string as the final parameter.
|
|||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
|
|
||||||
TEST_ASSERT_X( {modifiers}, {expected}, actual, {size/count} )
|
```
|
||||||
|
TEST_ASSERT_X( {modifiers}, {expected}, actual, {size/count} )
|
||||||
|
```
|
||||||
|
|
||||||
becomes messageified like thus...
|
becomes messageified like thus...
|
||||||
|
|
||||||
TEST_ASSERT_X_MESSAGE( {modifiers}, {expected}, actual, {size/count}, message )
|
```
|
||||||
|
TEST_ASSERT_X_MESSAGE( {modifiers}, {expected}, actual, {size/count}, message )
|
||||||
|
```
|
||||||
|
|
||||||
|
Notes:
|
||||||
|
- The `_MESSAGE` variants intentionally do not support `printf` style formatting
|
||||||
|
since many embedded projects don't support or avoid `printf` for various reasons.
|
||||||
|
It is possible to use `sprintf` before the assertion to assemble a complex fail
|
||||||
|
message, if necessary.
|
||||||
|
- If you want to output a counter value within an assertion fail message (e.g. from
|
||||||
|
a loop) , building up an array of results and then using one of the `_ARRAY`
|
||||||
|
assertions (see below) might be a handy alternative to `sprintf`.
|
||||||
|
|
||||||
|
|
||||||
#### TEST_ASSERT_X_ARRAY Variants
|
#### TEST_ASSERT_X_ARRAY Variants
|
||||||
@@ -113,18 +128,21 @@ with the `_MESSAGE`variants of Unity's Asserts in that for pretty much any Unity
|
|||||||
type assertion you can tack on `_ARRAY` and run assertions on an entire block of
|
type assertion you can tack on `_ARRAY` and run assertions on an entire block of
|
||||||
memory.
|
memory.
|
||||||
|
|
||||||
|
```
|
||||||
TEST_ASSERT_EQUAL_TYPEX_ARRAY( expected, actual, {size/count} )
|
TEST_ASSERT_EQUAL_TYPEX_ARRAY( expected, actual, {size/count} )
|
||||||
|
```
|
||||||
|
|
||||||
"Expected" is an array itself.
|
- `Expected` is an array itself.
|
||||||
"Size/count" is one or two parameters necessary to establish the number of array
|
- `Size/count` is one or two parameters necessary to establish the number of array
|
||||||
elements and perhaps the length of elements within the array.
|
elements and perhaps the length of elements within the array.
|
||||||
|
|
||||||
Notes:
|
Notes:
|
||||||
- The `_MESSAGE` variant convention still applies here to array assertions. The
|
|
||||||
`_MESSAGE` variants of the `_ARRAY` assertions have names ending with
|
- The `_MESSAGE` variant convention still applies here to array assertions. The
|
||||||
`_ARRAY_MESSAGE`.
|
`_MESSAGE` variants of the `_ARRAY` assertions have names ending with
|
||||||
- Assertions for handling arrays of floating point values are grouped with float
|
`_ARRAY_MESSAGE`.
|
||||||
and double assertions (see immediately following section).
|
- Assertions for handling arrays of floating point values are grouped with float
|
||||||
|
and double assertions (see immediately following section).
|
||||||
|
|
||||||
|
|
||||||
### TEST_ASSERT_EACH_EQUAL_X Variants
|
### TEST_ASSERT_EACH_EQUAL_X Variants
|
||||||
@@ -133,19 +151,22 @@ Unity provides a collection of assertions for arrays containing a variety of
|
|||||||
types which can be compared to a single value as well. These are documented in
|
types which can be compared to a single value as well. These are documented in
|
||||||
the Each Equal section below. these are almost on par with the `_MESSAGE`
|
the Each Equal section below. these are almost on par with the `_MESSAGE`
|
||||||
variants of Unity's Asserts in that for pretty much any Unity type assertion you
|
variants of Unity's Asserts in that for pretty much any Unity type assertion you
|
||||||
can inject _EACH_EQUAL and run assertions on an entire block of memory.
|
can inject `_EACH_EQUAL` and run assertions on an entire block of memory.
|
||||||
|
|
||||||
TEST_ASSERT_EACH_EQUAL_TYPEX( expected, actual, {size/count} )
|
```
|
||||||
|
TEST_ASSERT_EACH_EQUAL_TYPEX( expected, actual, {size/count} )
|
||||||
|
```
|
||||||
|
|
||||||
"Expected" is a single value to compare to.
|
- `Expected` is a single value to compare to.
|
||||||
"Actual" is an array where each element will be compared to the expected value.
|
- `Actual` is an array where each element will be compared to the expected value.
|
||||||
"Size/count" is one of two parameters necessary to establish the number of array
|
- `Size/count` is one of two parameters necessary to establish the number of array
|
||||||
elements and perhaps the length of elements within the array.
|
elements and perhaps the length of elements within the array.
|
||||||
|
|
||||||
Notes:
|
Notes:
|
||||||
- The `_MESSAGE` variant convention still applies here to Each Equal assertions.
|
|
||||||
- Assertions for handling Each Equal of floating point values are grouped with
|
- The `_MESSAGE` variant convention still applies here to Each Equal assertions.
|
||||||
float and double assertions (see immediately following section).
|
- Assertions for handling Each Equal of floating point values are grouped with
|
||||||
|
float and double assertions (see immediately following section).
|
||||||
|
|
||||||
|
|
||||||
### Configuration
|
### Configuration
|
||||||
@@ -169,27 +190,47 @@ documentation for specifics.
|
|||||||
|
|
||||||
## The Assertions in All Their Blessed Glory
|
## The Assertions in All Their Blessed Glory
|
||||||
|
|
||||||
### Basic Fail and Ignore
|
### Basic Fail, Pass and Ignore
|
||||||
|
|
||||||
##### `TEST_FAIL()`
|
##### `TEST_FAIL()`
|
||||||
|
|
||||||
|
##### `TEST_FAIL_MESSAGE("message")`
|
||||||
|
|
||||||
This fella is most often used in special conditions where your test code is
|
This fella is most often used in special conditions where your test code is
|
||||||
performing logic beyond a simple assertion. That is, in practice, `TEST_FAIL()`
|
performing logic beyond a simple assertion. That is, in practice, `TEST_FAIL()`
|
||||||
will always be found inside a conditional code block.
|
will always be found inside a conditional code block.
|
||||||
|
|
||||||
_Examples:_
|
_Examples:_
|
||||||
|
|
||||||
- Executing a state machine multiple times that increments a counter your test
|
- Executing a state machine multiple times that increments a counter your test
|
||||||
code then verifies as a final step.
|
code then verifies as a final step.
|
||||||
- Triggering an exception and verifying it (as in Try / Catch / Throw - see the
|
- Triggering an exception and verifying it (as in Try / Catch / Throw - see the
|
||||||
[CException](https://github.com/ThrowTheSwitch/CException) project).
|
[CException](https://github.com/ThrowTheSwitch/CException) project).
|
||||||
|
|
||||||
|
##### `TEST_PASS()`
|
||||||
|
|
||||||
|
##### `TEST_PASS_MESSAGE("message")`
|
||||||
|
|
||||||
|
This will abort the remainder of the test, but count the test as a pass. Under
|
||||||
|
normal circumstances, it is not necessary to include this macro in your tests...
|
||||||
|
a lack of failure will automatically be counted as a `PASS`. It is occasionally
|
||||||
|
useful for tests with `#ifdef`s and such.
|
||||||
|
|
||||||
##### `TEST_IGNORE()`
|
##### `TEST_IGNORE()`
|
||||||
|
|
||||||
|
##### `TEST_IGNORE_MESSAGE("message")`
|
||||||
|
|
||||||
Marks a test case (i.e. function meant to contain test assertions) as ignored.
|
Marks a test case (i.e. function meant to contain test assertions) as ignored.
|
||||||
Usually this is employed as a breadcrumb to come back and implement a test case.
|
Usually this is employed as a breadcrumb to come back and implement a test case.
|
||||||
An ignored test case has effects if other assertions are in the enclosing test
|
An ignored test case has effects if other assertions are in the enclosing test
|
||||||
case (see Unity documentation for more).
|
case (see Unity documentation for more).
|
||||||
|
|
||||||
|
##### `TEST_MESSAGE(message)`
|
||||||
|
|
||||||
|
This can be useful for outputting `INFO` messages into the Unity output stream
|
||||||
|
without actually ending the test. Like pass and fail messages, it will be output
|
||||||
|
with the filename and line number.
|
||||||
|
|
||||||
### Boolean
|
### Boolean
|
||||||
|
|
||||||
##### `TEST_ASSERT (condition)`
|
##### `TEST_ASSERT (condition)`
|
||||||
@@ -208,6 +249,15 @@ conditional statements.
|
|||||||
|
|
||||||
##### `TEST_ASSERT_NOT_NULL (pointer)`
|
##### `TEST_ASSERT_NOT_NULL (pointer)`
|
||||||
|
|
||||||
|
Verify if a pointer is or is not NULL.
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_EMPTY (pointer)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_NOT_EMPTY (pointer)`
|
||||||
|
|
||||||
|
Verify if the first element dereferenced from a pointer is or is not zero. This
|
||||||
|
is particularly useful for checking for empty (or non-empty) null-terminated
|
||||||
|
C strings, but can be just as easily used for other null-terminated arrays.
|
||||||
|
|
||||||
### Signed and Unsigned Integers (of all sizes)
|
### Signed and Unsigned Integers (of all sizes)
|
||||||
|
|
||||||
@@ -228,10 +278,6 @@ sizes.
|
|||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_INT64 (expected, actual)`
|
##### `TEST_ASSERT_EQUAL_INT64 (expected, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL (expected, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_NOT_EQUAL (expected, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_UINT (expected, actual)`
|
##### `TEST_ASSERT_EQUAL_UINT (expected, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_UINT8 (expected, actual)`
|
##### `TEST_ASSERT_EQUAL_UINT8 (expected, actual)`
|
||||||
@@ -260,6 +306,15 @@ in hexadecimal. Unity output is big endian.
|
|||||||
##### `TEST_ASSERT_EQUAL_HEX64 (expected, actual)`
|
##### `TEST_ASSERT_EQUAL_HEX64 (expected, actual)`
|
||||||
|
|
||||||
|
|
||||||
|
### Characters
|
||||||
|
|
||||||
|
While you can use the 8-bit integer assertions to compare `char`, another option is
|
||||||
|
to use this specialized assertion which will show printable characters as printables,
|
||||||
|
otherwise showing the HEX escape code for the characters.
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_EQUAL_CHAR (expected, actual)`
|
||||||
|
|
||||||
|
|
||||||
### Masked and Bit-level Assertions
|
### Masked and Bit-level Assertions
|
||||||
|
|
||||||
Masked and bit-level assertions produce output formatted in hexadecimal. Unity
|
Masked and bit-level assertions produce output formatted in hexadecimal. Unity
|
||||||
@@ -294,55 +349,18 @@ Asserts the specified bit of the `actual` parameter is low.
|
|||||||
|
|
||||||
These assertions verify that the `actual` parameter is less than or greater
|
These assertions verify that the `actual` parameter is less than or greater
|
||||||
than `threshold` (exclusive). For example, if the threshold value is 0 for the
|
than `threshold` (exclusive). For example, if the threshold value is 0 for the
|
||||||
greater than assertion will fail if it is 0 or less.
|
greater than assertion will fail if it is 0 or less. There are assertions for
|
||||||
|
all the various sizes of ints, as for the equality assertions. Some examples:
|
||||||
##### `TEST_ASSERT_GREATER_THAN (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_INT (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_INT8 (threshold, actual)`
|
##### `TEST_ASSERT_GREATER_THAN_INT8 (threshold, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_INT16 (threshold, actual)`
|
##### `TEST_ASSERT_GREATER_OR_EQUAL_INT16 (threshold, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_INT32 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_UINT (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_UINT8 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_UINT16 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_UINT32 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_HEX8 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_HEX16 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_GREATER_THAN_HEX32 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_INT (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_INT8 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_INT16 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_INT32 (threshold, actual)`
|
##### `TEST_ASSERT_LESS_THAN_INT32 (threshold, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_UINT (threshold, actual)`
|
##### `TEST_ASSERT_LESS_OR_EQUAL_UINT (threshold, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_UINT8 (threshold, actual)`
|
##### `TEST_ASSERT_NOT_EQUAL_UINT8 (threshold, actual)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_UINT16 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_UINT32 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_HEX8 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_HEX16 (threshold, actual)`
|
|
||||||
|
|
||||||
##### `TEST_ASSERT_LESS_THAN_HEX32 (threshold, actual)`
|
|
||||||
|
|
||||||
|
|
||||||
### Integer Ranges (of all sizes)
|
### Integer Ranges (of all sizes)
|
||||||
@@ -382,6 +400,7 @@ of 7 - 13.
|
|||||||
|
|
||||||
##### `TEST_ASSERT_HEX64_WITHIN (delta, expected, actual)`
|
##### `TEST_ASSERT_HEX64_WITHIN (delta, expected, actual)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_CHAR_WITHIN (delta, expected, actual)`
|
||||||
|
|
||||||
### Structs and Strings
|
### Structs and Strings
|
||||||
|
|
||||||
@@ -449,6 +468,8 @@ match. Failure messages specify the array index of the failed comparison.
|
|||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_HEX64_ARRAY (expected, actual, num_elements)`
|
##### `TEST_ASSERT_EQUAL_HEX64_ARRAY (expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_EQUAL_CHAR_ARRAY (expected, actual, num_elements)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_PTR_ARRAY (expected, actual, num_elements)`
|
##### `TEST_ASSERT_EQUAL_PTR_ARRAY (expected, actual, num_elements)`
|
||||||
|
|
||||||
##### `TEST_ASSERT_EQUAL_STRING_ARRAY (expected, actual, num_elements)`
|
##### `TEST_ASSERT_EQUAL_STRING_ARRAY (expected, actual, num_elements)`
|
||||||
@@ -457,6 +478,44 @@ match. Failure messages specify the array index of the failed comparison.
|
|||||||
|
|
||||||
`len` is the memory in bytes to be compared at each array element.
|
`len` is the memory in bytes to be compared at each array element.
|
||||||
|
|
||||||
|
### Integer Array Ranges (of all sizes)
|
||||||
|
|
||||||
|
These assertions verify that the `expected` array parameter is within +/- `delta`
|
||||||
|
(inclusive) of the `actual` array parameter. For example, if the expected value is
|
||||||
|
\[10, 12\] and the delta is 3 then the assertion will fail for any value
|
||||||
|
outside the range of \[7 - 13, 9 - 15\].
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_INT_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_INT8_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_INT16_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_INT32_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_INT64_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_UINT_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_UINT8_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_UINT16_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_UINT32_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_UINT64_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_HEX_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_HEX8_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_HEX16_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_HEX32_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_HEX64_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
|
##### `TEST_ASSERT_CHAR_ARRAY_WITHIN (delta, expected, actual, num_elements)`
|
||||||
|
|
||||||
### Each Equal (Arrays to Single Value)
|
### Each Equal (Arrays to Single Value)
|
||||||
|
|
||||||
@@ -499,6 +558,8 @@ match. Failure messages specify the array index of the failed comparison.
|
|||||||
|
|
||||||
#### `TEST_ASSERT_EACH_EQUAL_HEX64 (expected, actual, num_elements)`
|
#### `TEST_ASSERT_EACH_EQUAL_HEX64 (expected, actual, num_elements)`
|
||||||
|
|
||||||
|
#### `TEST_ASSERT_EACH_EQUAL_CHAR (expected, actual, num_elements)`
|
||||||
|
|
||||||
#### `TEST_ASSERT_EACH_EQUAL_PTR (expected, actual, num_elements)`
|
#### `TEST_ASSERT_EACH_EQUAL_PTR (expected, actual, num_elements)`
|
||||||
|
|
||||||
#### `TEST_ASSERT_EACH_EQUAL_STRING (expected, actual, num_elements)`
|
#### `TEST_ASSERT_EACH_EQUAL_STRING (expected, actual, num_elements)`
|
||||||
@@ -694,7 +755,7 @@ point value.
|
|||||||
|
|
||||||
So what happens when it's zero? Zero - even more than other floating point
|
So what happens when it's zero? Zero - even more than other floating point
|
||||||
values - can be represented many different ways. It doesn't matter if you have
|
values - can be represented many different ways. It doesn't matter if you have
|
||||||
0 x 20or 0 x 263.It's still zero, right? Luckily, if you
|
0 x 20 or 0 x 263.It's still zero, right? Luckily, if you
|
||||||
subtract these values from each other, they will always produce a difference of
|
subtract these values from each other, they will always produce a difference of
|
||||||
zero, which will still fall between 0 plus or minus a delta of 0. So it still
|
zero, which will still fall between 0 plus or minus a delta of 0. So it still
|
||||||
works!
|
works!
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ definitions. A couple are macros with arguments. They live inside the
|
|||||||
unity_internals.h header file. We don't necessarily recommend opening that file
|
unity_internals.h header file. We don't necessarily recommend opening that file
|
||||||
unless you really need to. That file is proof that a cross-platform library is
|
unless you really need to. That file is proof that a cross-platform library is
|
||||||
challenging to build. From a more positive perspective, it is also proof that a
|
challenging to build. From a more positive perspective, it is also proof that a
|
||||||
great deal of complexity can be centralized primarily to one place in order to
|
great deal of complexity can be centralized primarily to one place to
|
||||||
provide a more consistent and simple experience elsewhere.
|
provide a more consistent and simple experience elsewhere.
|
||||||
|
|
||||||
|
|
||||||
@@ -39,6 +39,10 @@ toolchain's search paths). In this file, you will list definitions and macros
|
|||||||
specific to your target. All you must do is define `UNITY_INCLUDE_CONFIG_H` and
|
specific to your target. All you must do is define `UNITY_INCLUDE_CONFIG_H` and
|
||||||
Unity will rely on `unity_config.h` for any further definitions it may need.
|
Unity will rely on `unity_config.h` for any further definitions it may need.
|
||||||
|
|
||||||
|
Unfortunately, it doesn't usually work well to just #define these things in the
|
||||||
|
test itself. These defines need to take effect where ever unity.h is included.
|
||||||
|
This would be test test, the test runner (if you're generating one), and from
|
||||||
|
unity.c when it's compiled.
|
||||||
|
|
||||||
## The Options
|
## The Options
|
||||||
|
|
||||||
@@ -58,7 +62,7 @@ sizes. It starts off by trying to do it automatically.
|
|||||||
##### `UNITY_EXCLUDE_STDINT_H`
|
##### `UNITY_EXCLUDE_STDINT_H`
|
||||||
|
|
||||||
The first thing that Unity does to guess your types is check `stdint.h`.
|
The first thing that Unity does to guess your types is check `stdint.h`.
|
||||||
This file includes defines like `UINT_MAX` that Unity can make use of to
|
This file includes defines like `UINT_MAX` that Unity can use to
|
||||||
learn a lot about your system. It's possible you don't want it to do this
|
learn a lot about your system. It's possible you don't want it to do this
|
||||||
(um. why not?) or (more likely) it's possible that your system doesn't
|
(um. why not?) or (more likely) it's possible that your system doesn't
|
||||||
support `stdint.h`. If that's the case, you're going to want to define this.
|
support `stdint.h`. If that's the case, you're going to want to define this.
|
||||||
@@ -66,7 +70,9 @@ That way, Unity will know to skip the inclusion of this file and you won't
|
|||||||
be left with a compiler error.
|
be left with a compiler error.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_EXCLUDE_STDINT_H
|
```C
|
||||||
|
#define UNITY_EXCLUDE_STDINT_H
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_EXCLUDE_LIMITS_H`
|
##### `UNITY_EXCLUDE_LIMITS_H`
|
||||||
@@ -76,21 +82,11 @@ that don't support `stdint.h` could include `limits.h` instead. If you don't
|
|||||||
want Unity to check this file either, define this to make it skip the inclusion.
|
want Unity to check this file either, define this to make it skip the inclusion.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_EXCLUDE_LIMITS_H
|
```C
|
||||||
|
#define UNITY_EXCLUDE_LIMITS_H
|
||||||
|
```
|
||||||
|
|
||||||
|
If you've disabled both of the automatic options above, you're going to have to
|
||||||
##### `UNITY_EXCLUDE_SIZEOF`
|
|
||||||
|
|
||||||
The third and final attempt to guess your types is to use the `sizeof()`
|
|
||||||
operator. Even if the first two options don't work, this one covers most cases.
|
|
||||||
There _is_ a rare compiler or two out there that doesn't support sizeof() in the
|
|
||||||
preprocessing stage, though. For these, you have the ability to disable this
|
|
||||||
feature as well.
|
|
||||||
|
|
||||||
_Example:_
|
|
||||||
#define UNITY_EXCLUDE_SIZEOF
|
|
||||||
|
|
||||||
If you've disabled all of the automatic options above, you're going to have to
|
|
||||||
do the configuration yourself. Don't worry. Even this isn't too bad... there are
|
do the configuration yourself. Don't worry. Even this isn't too bad... there are
|
||||||
just a handful of defines that you are going to specify if you don't like the
|
just a handful of defines that you are going to specify if you don't like the
|
||||||
defaults.
|
defaults.
|
||||||
@@ -102,7 +98,9 @@ Define this to be the number of bits an `int` takes up on your system. The
|
|||||||
default, if not autodetected, is 32 bits.
|
default, if not autodetected, is 32 bits.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_INT_WIDTH 16
|
```C
|
||||||
|
#define UNITY_INT_WIDTH 16
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_LONG_WIDTH`
|
##### `UNITY_LONG_WIDTH`
|
||||||
@@ -114,7 +112,9 @@ of 64-bit support your system can handle. Does it need to specify a `long` or a
|
|||||||
ignored.
|
ignored.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_LONG_WIDTH 16
|
```C
|
||||||
|
#define UNITY_LONG_WIDTH 16
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_POINTER_WIDTH`
|
##### `UNITY_POINTER_WIDTH`
|
||||||
@@ -123,11 +123,21 @@ Define this to be the number of bits a pointer takes up on your system. The
|
|||||||
default, if not autodetected, is 32-bits. If you're getting ugly compiler
|
default, if not autodetected, is 32-bits. If you're getting ugly compiler
|
||||||
warnings about casting from pointers, this is the one to look at.
|
warnings about casting from pointers, this is the one to look at.
|
||||||
|
|
||||||
|
_Hint:_ In order to support exotic processors (for example TI C55x with a pointer
|
||||||
|
width of 23-bit), choose the next power of two (in this case 32-bit).
|
||||||
|
|
||||||
|
_Supported values:_ 16, 32 and 64
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_POINTER_WIDTH 64
|
```C
|
||||||
|
// Choose on of these #defines to set your pointer width (if not autodetected)
|
||||||
|
//#define UNITY_POINTER_WIDTH 16
|
||||||
|
//#define UNITY_POINTER_WIDTH 32
|
||||||
|
#define UNITY_POINTER_WIDTH 64 // Set UNITY_POINTER_WIDTH to 64-bit
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_INCLUDE_64`
|
##### `UNITY_SUPPORT_64`
|
||||||
|
|
||||||
Unity will automatically include 64-bit support if it auto-detects it, or if
|
Unity will automatically include 64-bit support if it auto-detects it, or if
|
||||||
your `int`, `long`, or pointer widths are greater than 32-bits. Define this to
|
your `int`, `long`, or pointer widths are greater than 32-bits. Define this to
|
||||||
@@ -136,7 +146,9 @@ can be a significant size and speed impact to enabling 64-bit support on small
|
|||||||
targets, so don't define it if you don't need it.
|
targets, so don't define it if you don't need it.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_INCLUDE_64
|
```C
|
||||||
|
#define UNITY_SUPPORT_64
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
### Floating Point Types
|
### Floating Point Types
|
||||||
@@ -164,30 +176,29 @@ suits your needs. For features that are enabled, the following floating point
|
|||||||
options also become available.
|
options also become available.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
|
```C
|
||||||
//what manner of strange processor is this?
|
//what manner of strange processor is this?
|
||||||
#define UNITY_EXCLUDE_FLOAT
|
#define UNITY_EXCLUDE_FLOAT
|
||||||
#define UNITY_INCLUDE_DOUBLE
|
#define UNITY_INCLUDE_DOUBLE
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_FLOAT_VERBOSE`
|
##### `UNITY_EXCLUDE_FLOAT_PRINT`
|
||||||
|
|
||||||
##### `UNITY_DOUBLE_VERBOSE`
|
|
||||||
|
|
||||||
Unity aims for as small of a footprint as possible and avoids most standard
|
Unity aims for as small of a footprint as possible and avoids most standard
|
||||||
library calls (some embedded platforms don't have a standard library!). Because
|
library calls (some embedded platforms don’t have a standard library!). Because
|
||||||
of this, its routines for printing integer values are minimalist and hand-coded.
|
of this, its routines for printing integer values are minimalist and hand-coded.
|
||||||
To keep Unity universal, though, we chose to _not_ develop our own floating
|
Therefore, the display of floating point values during a failure are optional.
|
||||||
point print routines. Instead, the display of floating point values during a
|
By default, Unity will print the actual results of floating point assertion
|
||||||
failure are optional. By default, Unity will not print the actual results of
|
failure (e.g. ”Expected 4.56 Was 4.68”). To not include this extra support, you
|
||||||
floating point assertion failure. So a failed assertion will produce a message
|
can use this define to instead respond to a failed assertion with a message like
|
||||||
like `"Values Not Within Delta"`. If you would like verbose failure messages for
|
”Values Not Within Delta”. If you would like verbose failure messages for floating
|
||||||
floating point assertions, use these options to give more explicit failure
|
point assertions, use these options to give more explicit failure messages.
|
||||||
messages (e.g. `"Expected 4.56 Was 4.68"`). Note that this feature requires the
|
|
||||||
use of `sprintf` so might not be desirable in all cases.
|
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_DOUBLE_VERBOSE
|
```C
|
||||||
|
#define UNITY_EXCLUDE_FLOAT_PRINT
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_FLOAT_TYPE`
|
##### `UNITY_FLOAT_TYPE`
|
||||||
@@ -197,7 +208,9 @@ floats. If your compiler supports a specialty floating point type, you can
|
|||||||
always override this behavior by using this definition.
|
always override this behavior by using this definition.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_FLOAT_TYPE float16_t
|
```C
|
||||||
|
#define UNITY_FLOAT_TYPE float16_t
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_DOUBLE_TYPE`
|
##### `UNITY_DOUBLE_TYPE`
|
||||||
@@ -209,7 +222,9 @@ could enable gargantuan floating point types on your 64-bit processor instead of
|
|||||||
the standard `double`.
|
the standard `double`.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_DOUBLE_TYPE long double
|
```C
|
||||||
|
#define UNITY_DOUBLE_TYPE long double
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_FLOAT_PRECISION`
|
##### `UNITY_FLOAT_PRECISION`
|
||||||
@@ -228,7 +243,62 @@ For further details on how this works, see the appendix of the Unity Assertion
|
|||||||
Guide.
|
Guide.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_FLOAT_PRECISION 0.001f
|
```C
|
||||||
|
#define UNITY_FLOAT_PRECISION 0.001f
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
### Miscellaneous
|
||||||
|
|
||||||
|
##### `UNITY_EXCLUDE_STDDEF_H`
|
||||||
|
|
||||||
|
Unity uses the `NULL` macro, which defines the value of a null pointer constant,
|
||||||
|
defined in `stddef.h` by default. If you want to provide
|
||||||
|
your own macro for this, you should exclude the `stddef.h` header file by adding this
|
||||||
|
define to your configuration.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_EXCLUDE_STDDEF_H
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
#### `UNITY_INCLUDE_PRINT_FORMATTED`
|
||||||
|
|
||||||
|
Unity provides a simple (and very basic) printf-like string output implementation,
|
||||||
|
which is able to print a string modified by the following format string modifiers:
|
||||||
|
|
||||||
|
- __%d__ - signed value (decimal)
|
||||||
|
- __%i__ - same as __%i__
|
||||||
|
- __%u__ - unsigned value (decimal)
|
||||||
|
- __%f__ - float/Double (if float support is activated)
|
||||||
|
- __%g__ - same as __%f__
|
||||||
|
- __%b__ - binary prefixed with "0b"
|
||||||
|
- __%x__ - hexadecimal (upper case) prefixed with "0x"
|
||||||
|
- __%X__ - same as __%x__
|
||||||
|
- __%p__ - pointer (same as __%x__ or __%X__)
|
||||||
|
- __%c__ - a single character
|
||||||
|
- __%s__ - a string (e.g. "string")
|
||||||
|
- __%%__ - The "%" symbol (escaped)
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_INCLUDE_PRINT_FORMATTED
|
||||||
|
|
||||||
|
int a = 0xfab1;
|
||||||
|
TEST_PRINTF("Decimal %d\n", -7);
|
||||||
|
TEST_PRINTF("Unsigned %u\n", 987);
|
||||||
|
TEST_PRINTF("Float %f\n", 3.1415926535897932384);
|
||||||
|
TEST_PRINTF("Binary %b\n", 0xA);
|
||||||
|
TEST_PRINTF("Hex %X\n", 0xFAB);
|
||||||
|
TEST_PRINTF("Pointer %p\n", &a);
|
||||||
|
TEST_PRINTF("Character %c\n", 'F');
|
||||||
|
TEST_PRINTF("String %s\n", "My string");
|
||||||
|
TEST_PRINTF("Percent %%\n");
|
||||||
|
TEST_PRINTF("Color Red \033[41mFAIL\033[00m\n");
|
||||||
|
TEST_PRINTF("\n");
|
||||||
|
TEST_PRINTF("Multiple (%d) (%i) (%u) (%x)\n", -100, 0, 200, 0x12345);
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
### Toolset Customization
|
### Toolset Customization
|
||||||
@@ -237,7 +307,7 @@ In addition to the options listed above, there are a number of other options
|
|||||||
which will come in handy to customize Unity's behavior for your specific
|
which will come in handy to customize Unity's behavior for your specific
|
||||||
toolchain. It is possible that you may not need to touch any of these... but
|
toolchain. It is possible that you may not need to touch any of these... but
|
||||||
certain platforms, particularly those running in simulators, may need to jump
|
certain platforms, particularly those running in simulators, may need to jump
|
||||||
through extra hoops to operate properly. These macros will help in those
|
through extra hoops to run properly. These macros will help in those
|
||||||
situations.
|
situations.
|
||||||
|
|
||||||
|
|
||||||
@@ -263,39 +333,30 @@ _Example:_
|
|||||||
Say you are forced to run your test suite on an embedded processor with no
|
Say you are forced to run your test suite on an embedded processor with no
|
||||||
`stdout` option. You decide to route your test result output to a custom serial
|
`stdout` option. You decide to route your test result output to a custom serial
|
||||||
`RS232_putc()` function you wrote like thus:
|
`RS232_putc()` function you wrote like thus:
|
||||||
|
```C
|
||||||
#define UNITY_OUTPUT_CHAR(a) RS232_putc(a)
|
#include "RS232_header.h"
|
||||||
#define UNITY_OUTPUT_START() RS232_config(115200,1,8,0)
|
...
|
||||||
#define UNITY_OUTPUT_FLUSH() RS232_flush()
|
#define UNITY_OUTPUT_CHAR(a) RS232_putc(a)
|
||||||
#define UNITY_OUTPUT_COMPLETE() RS232_close()
|
#define UNITY_OUTPUT_START() RS232_config(115200,1,8,0)
|
||||||
|
#define UNITY_OUTPUT_FLUSH() RS232_flush()
|
||||||
|
#define UNITY_OUTPUT_COMPLETE() RS232_close()
|
||||||
|
```
|
||||||
|
|
||||||
_Note:_
|
_Note:_
|
||||||
`UNITY_OUTPUT_FLUSH()` can be set to the standard out flush function simply by
|
`UNITY_OUTPUT_FLUSH()` can be set to the standard out flush function simply by
|
||||||
specifying `UNITY_USE_FLUSH_STDOUT`. No other defines are required. If you
|
specifying `UNITY_USE_FLUSH_STDOUT`. No other defines are required.
|
||||||
specify a custom flush function instead with `UNITY_OUTPUT_FLUSH` directly, it
|
|
||||||
will declare an instance of your function by default. If you want to disable
|
|
||||||
this behavior, add `UNITY_OMIT_OUTPUT_FLUSH_HEADER_DECLARATION`.
|
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_SUPPORT_WEAK`
|
##### `UNITY_OUTPUT_FOR_ECLIPSE`
|
||||||
|
|
||||||
For some targets, Unity can make the otherwise required `setUp()` and
|
##### `UNITY_OUTPUT_FOR_IAR_WORKBENCH`
|
||||||
`tearDown()` functions optional. This is a nice convenience for test writers
|
|
||||||
since `setUp` and `tearDown` don't often actually _do_ anything. If you're using
|
|
||||||
gcc or clang, this option is automatically defined for you. Other compilers can
|
|
||||||
also support this behavior, if they support a C feature called weak functions. A
|
|
||||||
weak function is a function that is compiled into your executable _unless_ a
|
|
||||||
non-weak version of the same function is defined elsewhere. If a non-weak
|
|
||||||
version is found, the weak version is ignored as if it never existed. If your
|
|
||||||
compiler supports this feature, you can let Unity know by defining
|
|
||||||
`UNITY_SUPPORT_WEAK` as the function attributes that would need to be applied to
|
|
||||||
identify a function as weak. If your compiler lacks support for weak functions,
|
|
||||||
you will always need to define `setUp` and `tearDown` functions (though they can
|
|
||||||
be and often will be just empty). The most common options for this feature are:
|
|
||||||
|
|
||||||
_Example:_
|
##### `UNITY_OUTPUT_FOR_QT_CREATOR`
|
||||||
#define UNITY_SUPPORT_WEAK weak
|
|
||||||
#define UNITY_SUPPORT_WEAK __attribute__((weak))
|
When managing your own builds, it is often handy to have messages output in a format which is
|
||||||
|
recognized by your IDE. These are some standard formats which can be supported. If you're using
|
||||||
|
Ceedling to manage your builds, it is better to stick with the standard format (leaving these
|
||||||
|
all undefined) and allow Ceedling to use its own decorators.
|
||||||
|
|
||||||
|
|
||||||
##### `UNITY_PTR_ATTRIBUTE`
|
##### `UNITY_PTR_ATTRIBUTE`
|
||||||
@@ -305,9 +366,109 @@ Some compilers require a custom attribute to be assigned to pointers, like
|
|||||||
defining this option with the attribute you would like.
|
defining this option with the attribute you would like.
|
||||||
|
|
||||||
_Example:_
|
_Example:_
|
||||||
#define UNITY_PTR_ATTRIBUTE __attribute__((far))
|
```C
|
||||||
#define UNITY_PTR_ATTRIBUTE near
|
#define UNITY_PTR_ATTRIBUTE __attribute__((far))
|
||||||
|
#define UNITY_PTR_ATTRIBUTE near
|
||||||
|
```
|
||||||
|
|
||||||
|
##### `UNITY_PRINT_EOL`
|
||||||
|
|
||||||
|
By default, Unity outputs \n at the end of each line of output. This is easy
|
||||||
|
to parse by the scripts, by Ceedling, etc, but it might not be ideal for YOUR
|
||||||
|
system. Feel free to override this and to make it whatever you wish.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_PRINT_EOL { UNITY_OUTPUT_CHAR('\r'); UNITY_OUTPUT_CHAR('\n') }
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
##### `UNITY_EXCLUDE_DETAILS`
|
||||||
|
|
||||||
|
This is an option for if you absolutely must squeeze every byte of memory out of
|
||||||
|
your system. Unity stores a set of internal scratchpads which are used to pass
|
||||||
|
extra detail information around. It's used by systems like CMock in order to
|
||||||
|
report which function or argument flagged an error. If you're not using CMock and
|
||||||
|
you're not using these details for other things, then you can exclude them.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_EXCLUDE_DETAILS
|
||||||
|
```
|
||||||
|
|
||||||
|
##### `UNITY_PRINT_TEST_CONTEXT`
|
||||||
|
|
||||||
|
This option allows you to specify your own function to print additional context
|
||||||
|
as part of the error message when a test has failed. It can be useful if you
|
||||||
|
want to output some specific information about the state of the test at the point
|
||||||
|
of failure, and `UNITY_SET_DETAILS` isn't flexible enough for your needs.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_PRINT_TEST_CONTEXT PrintIterationCount
|
||||||
|
|
||||||
|
extern int iteration_count;
|
||||||
|
|
||||||
|
void PrintIterationCount(void)
|
||||||
|
{
|
||||||
|
UnityPrintFormatted("At iteration #%d: ", iteration_count);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
##### `UNITY_EXCLUDE_SETJMP`
|
||||||
|
|
||||||
|
If your embedded system doesn't support the standard library setjmp, you can
|
||||||
|
exclude Unity's reliance on this by using this define. This dropped dependence
|
||||||
|
comes at a price, though. You will be unable to use custom helper functions for
|
||||||
|
your tests, and you will be unable to use tools like CMock. Very likely, if your
|
||||||
|
compiler doesn't support setjmp, you wouldn't have had the memory space for those
|
||||||
|
things anyway, though... so this option exists for those situations.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_EXCLUDE_SETJMP
|
||||||
|
```
|
||||||
|
|
||||||
|
##### `UNITY_OUTPUT_COLOR`
|
||||||
|
|
||||||
|
If you want to add color using ANSI escape codes you can use this define.
|
||||||
|
|
||||||
|
_Example:_
|
||||||
|
```C
|
||||||
|
#define UNITY_OUTPUT_COLOR
|
||||||
|
```
|
||||||
|
|
||||||
|
##### `UNITY_SHORTHAND_AS_INT`
|
||||||
|
##### `UNITY_SHORTHAND_AS_MEM`
|
||||||
|
##### `UNITY_SHORTHAND_AS_RAW`
|
||||||
|
##### `UNITY_SHORTHAND_AS_NONE`
|
||||||
|
|
||||||
|
These options give you control of the `TEST_ASSERT_EQUAL` and the
|
||||||
|
`TEST_ASSERT_NOT_EQUAL` shorthand assertions. Historically, Unity treated the
|
||||||
|
former as an alias for an integer comparison. It treated the latter as a direct
|
||||||
|
comparison using `!=`. This assymetry was confusing, but there was much
|
||||||
|
disagreement as to how best to treat this pair of assertions. These four options
|
||||||
|
will allow you to specify how Unity will treat these assertions.
|
||||||
|
|
||||||
|
- AS INT - the values will be cast to integers and directly compared. Arguments
|
||||||
|
that don't cast easily to integers will cause compiler errors.
|
||||||
|
- AS MEM - the address of both values will be taken and the entire object's
|
||||||
|
memory footprint will be compared byte by byte. Directly placing
|
||||||
|
constant numbers like `456` as expected values will cause errors.
|
||||||
|
- AS_RAW - Unity assumes that you can compare the two values using `==` and `!=`
|
||||||
|
and will do so. No details are given about mismatches, because it
|
||||||
|
doesn't really know what type it's dealing with.
|
||||||
|
- AS_NONE - Unity will disallow the use of these shorthand macros altogether,
|
||||||
|
insisting that developers choose a more descriptive option.
|
||||||
|
|
||||||
|
#### `UNITY_SUPPORT_VARIADIC_MACROS`
|
||||||
|
|
||||||
|
This will force Unity to support variadic macros when using its own built-in
|
||||||
|
RUN_TEST macro. This will rarely be necessary. Most often, Unity will automatically
|
||||||
|
detect if the compiler supports variadic macros by checking to see if it's C99+
|
||||||
|
compatible. In the event that the compiler supports variadic macros, but is primarily
|
||||||
|
C89 (ANSI), defining this option will allow you to use them. This option is also not
|
||||||
|
necessary when using Ceedling or the test runner generator script.
|
||||||
|
|
||||||
## Getting Into The Guts
|
## Getting Into The Guts
|
||||||
|
|
||||||
@@ -333,13 +494,15 @@ output of your test results.
|
|||||||
|
|
||||||
A simple main function looks something like this:
|
A simple main function looks something like this:
|
||||||
|
|
||||||
int main(void) {
|
```C
|
||||||
UNITY_BEGIN();
|
int main(void) {
|
||||||
RUN_TEST(test_TheFirst);
|
UNITY_BEGIN();
|
||||||
RUN_TEST(test_TheSecond);
|
RUN_TEST(test_TheFirst);
|
||||||
RUN_TEST(test_TheThird);
|
RUN_TEST(test_TheSecond);
|
||||||
return UNITY_END();
|
RUN_TEST(test_TheThird);
|
||||||
}
|
return UNITY_END();
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
You can see that our main function doesn't bother taking any arguments. For our
|
You can see that our main function doesn't bother taking any arguments. For our
|
||||||
most barebones case, we'll never have arguments because we just run all the
|
most barebones case, we'll never have arguments because we just run all the
|
||||||
@@ -362,15 +525,17 @@ case function. This includes catching failures, calling the test module's
|
|||||||
using CMock or test coverage, there will be additional stubs in use here. A
|
using CMock or test coverage, there will be additional stubs in use here. A
|
||||||
simple minimalist RUN_TEST macro looks something like this:
|
simple minimalist RUN_TEST macro looks something like this:
|
||||||
|
|
||||||
#define RUN_TEST(testfunc) \
|
```C
|
||||||
UNITY_NEW_TEST(#testfunc) \
|
#define RUN_TEST(testfunc) \
|
||||||
if (TEST_PROTECT()) { \
|
UNITY_NEW_TEST(#testfunc) \
|
||||||
setUp(); \
|
if (TEST_PROTECT()) { \
|
||||||
testfunc(); \
|
setUp(); \
|
||||||
} \
|
testfunc(); \
|
||||||
if (TEST_PROTECT() && (!TEST_IS_IGNORED)) \
|
} \
|
||||||
tearDown(); \
|
if (TEST_PROTECT() && (!TEST_IS_IGNORED)) \
|
||||||
UnityConcludeTest();
|
tearDown(); \
|
||||||
|
UnityConcludeTest();
|
||||||
|
```
|
||||||
|
|
||||||
So that's quite a macro, huh? It gives you a glimpse of what kind of stuff Unity
|
So that's quite a macro, huh? It gives you a glimpse of what kind of stuff Unity
|
||||||
has to deal with for every single test case. For each test case, we declare that
|
has to deal with for every single test case. For each test case, we declare that
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ functional. The core Unity test framework is three files: a single C file and a
|
|||||||
couple header files. These team up to provide functions and macros to make
|
couple header files. These team up to provide functions and macros to make
|
||||||
testing easier.
|
testing easier.
|
||||||
|
|
||||||
Unity was designed to be cross platform. It works hard to stick with C standards
|
Unity was designed to be cross-platform. It works hard to stick with C standards
|
||||||
while still providing support for the many embedded C compilers that bend the
|
while still providing support for the many embedded C compilers that bend the
|
||||||
rules. Unity has been used with many compilers, including GCC, IAR, Clang,
|
rules. Unity has been used with many compilers, including GCC, IAR, Clang,
|
||||||
Green Hills, Microchip, and MS Visual Studio. It's not much work to get it to
|
Green Hills, Microchip, and MS Visual Studio. It's not much work to get it to
|
||||||
@@ -93,17 +93,19 @@ Next, a test file will include a `setUp()` and `tearDown()` function. The setUp
|
|||||||
function can contain anything you would like to run before each test. The
|
function can contain anything you would like to run before each test. The
|
||||||
tearDown function can contain anything you would like to run after each test.
|
tearDown function can contain anything you would like to run after each test.
|
||||||
Both functions accept no arguments and return nothing. You may leave either or
|
Both functions accept no arguments and return nothing. You may leave either or
|
||||||
both of these blank if you have no need for them. If you're using a compiler
|
both of these blank if you have no need for them.
|
||||||
that is configured to make these functions optional, you may leave them off
|
|
||||||
|
If you're using Ceedling or the test runner generator script, you may leave these off
|
||||||
completely. Not sure? Give it a try. If you compiler complains that it can't
|
completely. Not sure? Give it a try. If you compiler complains that it can't
|
||||||
find setUp or tearDown when it links, you'll know you need to at least include
|
find setUp or tearDown when it links, you'll know you need to at least include
|
||||||
an empty function for these.
|
an empty function for these.
|
||||||
|
|
||||||
The majority of the file will be a series of test functions. Test functions
|
The majority of the file will be a series of test functions. Test functions
|
||||||
follow the convention of starting with the word "test" or "spec". You don't HAVE
|
follow the convention of starting with the word "test_" or "spec_". You don't HAVE
|
||||||
to name them this way, but it makes it clear what functions are tests for other
|
to name them this way, but it makes it clear what functions are tests for other
|
||||||
developers. Test functions take no arguments and return nothing. All test
|
developers. Also, the automated scripts that come with Unity or Ceedling will default
|
||||||
accounting is handled internally in Unity.
|
to looking for test functions to be prefixed this way. Test functions take no arguments
|
||||||
|
and return nothing. All test accounting is handled internally in Unity.
|
||||||
|
|
||||||
Finally, at the bottom of your test file, you will write a `main()` function.
|
Finally, at the bottom of your test file, you will write a `main()` function.
|
||||||
This function will call `UNITY_BEGIN()`, then `RUN_TEST` for each test, and
|
This function will call `UNITY_BEGIN()`, then `RUN_TEST` for each test, and
|
||||||
@@ -113,10 +115,10 @@ call.
|
|||||||
|
|
||||||
Remembering to add each test to the main function can get to be tedious. If you
|
Remembering to add each test to the main function can get to be tedious. If you
|
||||||
enjoy using helper scripts in your build process, you might consider making use
|
enjoy using helper scripts in your build process, you might consider making use
|
||||||
of our handy generate_test_runner.rb script. This will create the main function
|
of our handy [generate_test_runner.rb](../auto/generate_test_runner.rb) script.
|
||||||
and all the calls for you, assuming that you have followed the suggested naming
|
This will create the main function and all the calls for you, assuming that you
|
||||||
conventions. In this case, there is no need for you to include the main function
|
have followed the suggested naming conventions. In this case, there is no need
|
||||||
in your test file at all.
|
for you to include the main function in your test file at all.
|
||||||
|
|
||||||
When you're done, your test file will look something like this:
|
When you're done, your test file will look something like this:
|
||||||
|
|
||||||
@@ -140,6 +142,7 @@ void test_function_should_doAlsoDoBlah(void) {
|
|||||||
//more test stuff
|
//more test stuff
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// not needed when using generate_test_runner.rb
|
||||||
int main(void) {
|
int main(void) {
|
||||||
UNITY_BEGIN();
|
UNITY_BEGIN();
|
||||||
RUN_TEST(test_function_should_doBlahAndBlah);
|
RUN_TEST(test_function_should_doBlahAndBlah);
|
||||||
@@ -148,10 +151,67 @@ int main(void) {
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
It's possible that you will require more customization than this, eventually.
|
It's possible that you will need more customization than this, eventually.
|
||||||
For that sort of thing, you're going to want to look at the configuration guide.
|
For that sort of thing, you're going to want to look at the configuration guide.
|
||||||
This should be enough to get you going, though.
|
This should be enough to get you going, though.
|
||||||
|
|
||||||
|
### Running Test Functions
|
||||||
|
When writing your own `main()` functions, for a test-runner. There are two ways
|
||||||
|
to execute the test.
|
||||||
|
|
||||||
|
The classic variant
|
||||||
|
``` c
|
||||||
|
RUN_TEST(func, linenum)
|
||||||
|
```
|
||||||
|
or its simpler replacement that starts at the beginning of the function.
|
||||||
|
``` c
|
||||||
|
RUN_TEST(func)
|
||||||
|
```
|
||||||
|
These macros perform the necessary setup before the test is called and
|
||||||
|
handles cleanup and result tabulation afterwards.
|
||||||
|
|
||||||
|
### Ignoring Test Functions
|
||||||
|
There are times when a test is incomplete or not valid for some reason.
|
||||||
|
At these times, TEST_IGNORE can be called. Control will immediately be
|
||||||
|
returned to the caller of the test, and no failures will be returned.
|
||||||
|
This is useful when your test runners are automatically generated.
|
||||||
|
|
||||||
|
``` c
|
||||||
|
TEST_IGNORE()
|
||||||
|
```
|
||||||
|
|
||||||
|
Ignore this test and return immediately
|
||||||
|
|
||||||
|
``` c
|
||||||
|
TEST_IGNORE_MESSAGE (message)
|
||||||
|
```
|
||||||
|
|
||||||
|
Ignore this test and return immediately. Output a message stating why the test was ignored.
|
||||||
|
|
||||||
|
### Aborting Tests
|
||||||
|
There are times when a test will contain an infinite loop on error conditions, or there may be reason to escape from the test early without executing the rest of the test. A pair of macros support this functionality in Unity. The first `TEST_PROTECT` sets up the feature, and handles emergency abort cases. `TEST_ABORT` can then be used at any time within the tests to return to the last `TEST_PROTECT` call.
|
||||||
|
|
||||||
|
TEST_PROTECT()
|
||||||
|
|
||||||
|
Setup and Catch macro
|
||||||
|
|
||||||
|
TEST_ABORT()
|
||||||
|
|
||||||
|
Abort Test macro
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
main()
|
||||||
|
{
|
||||||
|
if (TEST_PROTECT())
|
||||||
|
{
|
||||||
|
MyTest();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
If MyTest calls `TEST_ABORT`, program control will immediately return to `TEST_PROTECT` with a return value of zero.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## How to Build and Run A Test File
|
## How to Build and Run A Test File
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
## With a Little Help From Our Friends
|
## With a Little Help From Our Friends
|
||||||
|
|
||||||
Sometimes what it takes to be a really efficient C programmer is a little non-C.
|
Sometimes what it takes to be a really efficient C programmer is a little non-C.
|
||||||
The Unity project includes a couple Ruby scripts for making your life just a tad
|
The Unity project includes a couple of Ruby scripts for making your life just a tad
|
||||||
easier. They are completely optional. If you choose to use them, you'll need a
|
easier. They are completely optional. If you choose to use them, you'll need a
|
||||||
copy of Ruby, of course. Just install whatever the latest version is, and it is
|
copy of Ruby, of course. Just install whatever the latest version is, and it is
|
||||||
likely to work. You can find Ruby at [ruby-lang.org](https://ruby-labg.org/).
|
likely to work. You can find Ruby at [ruby-lang.org](https://ruby-labg.org/).
|
||||||
@@ -48,7 +48,7 @@ ruby generate_test_runner.rb TestFile.c NameOfRunner.c
|
|||||||
```
|
```
|
||||||
|
|
||||||
Alternatively, if you include only the test file parameter, the script will copy
|
Alternatively, if you include only the test file parameter, the script will copy
|
||||||
the name of the test file and automatically append "_Runner" to the name of the
|
the name of the test file and automatically append `_Runner` to the name of the
|
||||||
generated file. The example immediately below will create TestFile_Runner.c.
|
generated file. The example immediately below will create TestFile_Runner.c.
|
||||||
|
|
||||||
```Shell
|
```Shell
|
||||||
@@ -105,7 +105,7 @@ UnityTestRunnerGenerator.new.run(testfile, runner_name, options)
|
|||||||
|
|
||||||
If you have multiple files to generate in a build script (such as a Rakefile),
|
If you have multiple files to generate in a build script (such as a Rakefile),
|
||||||
you might want to instantiate a generator object with your options and call it
|
you might want to instantiate a generator object with your options and call it
|
||||||
to generate each runner thereafter. Like thus:
|
to generate each runner afterwards. Like thus:
|
||||||
|
|
||||||
```Ruby
|
```Ruby
|
||||||
gen = UnityTestRunnerGenerator.new(options)
|
gen = UnityTestRunnerGenerator.new(options)
|
||||||
@@ -124,7 +124,7 @@ demonstrates using a Ruby hash.
|
|||||||
|
|
||||||
##### `:includes`
|
##### `:includes`
|
||||||
|
|
||||||
This option specifies an array of file names to be ?#include?'d at the top of
|
This option specifies an array of file names to be `#include`'d at the top of
|
||||||
your runner C file. You might use it to reference custom types or anything else
|
your runner C file. You might use it to reference custom types or anything else
|
||||||
universally needed in your generated runners.
|
universally needed in your generated runners.
|
||||||
|
|
||||||
@@ -133,11 +133,23 @@ universally needed in your generated runners.
|
|||||||
|
|
||||||
Define this option with C code to be executed _before any_ test cases are run.
|
Define this option with C code to be executed _before any_ test cases are run.
|
||||||
|
|
||||||
|
Alternatively, if your C compiler supports weak symbols, you can leave this
|
||||||
|
option unset and instead provide a `void suiteSetUp(void)` function in your test
|
||||||
|
suite. The linker will look for this symbol and fall back to a Unity-provided
|
||||||
|
stub if it is not found.
|
||||||
|
|
||||||
|
|
||||||
##### `:suite_teardown`
|
##### `:suite_teardown`
|
||||||
|
|
||||||
Define this option with C code to be executed ?after all?test cases have
|
Define this option with C code to be executed _after all_ test cases have
|
||||||
finished.
|
finished. An integer variable `num_failures` is available for diagnostics.
|
||||||
|
The code should end with a `return` statement; the value returned will become
|
||||||
|
the exit code of `main`. You can normally just return `num_failures`.
|
||||||
|
|
||||||
|
Alternatively, if your C compiler supports weak symbols, you can leave this
|
||||||
|
option unset and instead provide a `int suiteTearDown(int num_failures)`
|
||||||
|
function in your test suite. The linker will look for this symbol and fall
|
||||||
|
back to a Unity-provided stub if it is not found.
|
||||||
|
|
||||||
|
|
||||||
##### `:enforce_strict_ordering`
|
##### `:enforce_strict_ordering`
|
||||||
@@ -148,6 +160,18 @@ everything to run smoothly. If you provide the same YAML to the generator as
|
|||||||
used in CMock's configuration, you've already configured the generator properly.
|
used in CMock's configuration, you've already configured the generator properly.
|
||||||
|
|
||||||
|
|
||||||
|
##### `:externc`
|
||||||
|
|
||||||
|
This option should be defined if you are mixing C and CPP and want your test
|
||||||
|
runners to automatically include extern "C" support when they are generated.
|
||||||
|
|
||||||
|
##### `:mock_prefix` and `:mock_suffix`
|
||||||
|
|
||||||
|
Unity automatically generates calls to Init, Verify and Destroy for every file
|
||||||
|
included in the main test file that starts with the given mock prefix and ends
|
||||||
|
with the given mock suffix, file extension not included. By default, Unity
|
||||||
|
assumes a `Mock` prefix and no suffix.
|
||||||
|
|
||||||
##### `:plugins`
|
##### `:plugins`
|
||||||
|
|
||||||
This option specifies an array of plugins to be used (of course, the array can
|
This option specifies an array of plugins to be used (of course, the array can
|
||||||
@@ -170,6 +194,18 @@ If you are using CMock, it is very likely that you are already passing an array
|
|||||||
of plugins to CMock. You can just use the same array here. This script will just
|
of plugins to CMock. You can just use the same array here. This script will just
|
||||||
ignore the plugins that don't require additional support.
|
ignore the plugins that don't require additional support.
|
||||||
|
|
||||||
|
##### `:include_extensions`
|
||||||
|
|
||||||
|
This option specifies the pattern for matching acceptable header file extensions.
|
||||||
|
By default it will accept hpp, hh, H, and h files. If you need a different combination
|
||||||
|
of files to search, update this from the default `'(?:hpp|hh|H|h)'`.
|
||||||
|
|
||||||
|
##### `:source_extensions`
|
||||||
|
|
||||||
|
This option specifies the pattern for matching acceptable source file extensions.
|
||||||
|
By default it will accept cpp, cc, C, c, and ino files. If you need a different combination
|
||||||
|
of files to search, update this from the default `'(?:cpp|cc|ino|C|c)'`.
|
||||||
|
|
||||||
|
|
||||||
### `unity_test_summary.rb`
|
### `unity_test_summary.rb`
|
||||||
|
|
||||||
|
|||||||
@@ -41,6 +41,7 @@ CFLAGS += -Wno-unknown-pragmas
|
|||||||
CFLAGS += -Wstrict-prototypes
|
CFLAGS += -Wstrict-prototypes
|
||||||
CFLAGS += -Wundef
|
CFLAGS += -Wundef
|
||||||
CFLAGS += -Wold-style-definition
|
CFLAGS += -Wold-style-definition
|
||||||
|
#CFLAGS += -Wno-misleading-indentation
|
||||||
|
|
||||||
TARGET_BASE1=test1
|
TARGET_BASE1=test1
|
||||||
TARGET_BASE2=test2
|
TARGET_BASE2=test2
|
||||||
@@ -57,7 +58,7 @@ default: $(SRC_FILES1) $(SRC_FILES2)
|
|||||||
$(C_COMPILER) $(CFLAGS) $(INC_DIRS) $(SYMBOLS) $(SRC_FILES1) -o $(TARGET1)
|
$(C_COMPILER) $(CFLAGS) $(INC_DIRS) $(SYMBOLS) $(SRC_FILES1) -o $(TARGET1)
|
||||||
$(C_COMPILER) $(CFLAGS) $(INC_DIRS) $(SYMBOLS) $(SRC_FILES2) -o $(TARGET2)
|
$(C_COMPILER) $(CFLAGS) $(INC_DIRS) $(SYMBOLS) $(SRC_FILES2) -o $(TARGET2)
|
||||||
- ./$(TARGET1)
|
- ./$(TARGET1)
|
||||||
./$(TARGET2)
|
- ./$(TARGET2)
|
||||||
|
|
||||||
test/test_runners/TestProductionCode_Runner.c: test/TestProductionCode.c
|
test/test_runners/TestProductionCode_Runner.c: test/TestProductionCode.c
|
||||||
ruby $(UNITY_ROOT)/auto/generate_test_runner.rb test/TestProductionCode.c test/test_runners/TestProductionCode_Runner.c
|
ruby $(UNITY_ROOT)/auto/generate_test_runner.rb test/TestProductionCode.c test/test_runners/TestProductionCode_Runner.c
|
||||||
|
|||||||
@@ -4,14 +4,14 @@
|
|||||||
int Counter = 0;
|
int Counter = 0;
|
||||||
int NumbersToFind[9] = { 0, 34, 55, 66, 32, 11, 1, 77, 888 }; /* some obnoxious array to search that is 1-based indexing instead of 0. */
|
int NumbersToFind[9] = { 0, 34, 55, 66, 32, 11, 1, 77, 888 }; /* some obnoxious array to search that is 1-based indexing instead of 0. */
|
||||||
|
|
||||||
/* This function is supposed to search through NumbersToFind and find a particular number.
|
/* This function is supposed to search through NumbersToFind and find a particular number.
|
||||||
* If it finds it, the index is returned. Otherwise 0 is returned which sorta makes sense since
|
* If it finds it, the index is returned. Otherwise 0 is returned which sorta makes sense since
|
||||||
* NumbersToFind is indexed from 1. Unfortunately it's broken
|
* NumbersToFind is indexed from 1. Unfortunately it's broken
|
||||||
* (and should therefore be caught by our tests) */
|
* (and should therefore be caught by our tests) */
|
||||||
int FindFunction_WhichIsBroken(int NumberToFind)
|
int FindFunction_WhichIsBroken(int NumberToFind)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
while (i <= 8) /* Notice I should have been in braces */
|
while (i < 8) /* Notice I should have been in braces */
|
||||||
i++;
|
i++;
|
||||||
if (NumbersToFind[i] == NumberToFind) /* Yikes! I'm getting run after the loop finishes instead of during it! */
|
if (NumbersToFind[i] == NumberToFind) /* Yikes! I'm getting run after the loop finishes instead of during it! */
|
||||||
return i;
|
return i;
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
/* sometimes you may want to get at local data in a module.
|
/* sometimes you may want to get at local data in a module.
|
||||||
* for example: If you plan to pass by reference, this could be useful
|
* for example: If you plan to pass by reference, this could be useful
|
||||||
* however, it should often be avoided */
|
* however, it should often be avoided */
|
||||||
extern int Counter;
|
extern int Counter;
|
||||||
|
|
||||||
void setUp(void)
|
void setUp(void)
|
||||||
{
|
{
|
||||||
@@ -21,7 +21,7 @@ void test_FindFunction_WhichIsBroken_ShouldReturnZeroIfItemIsNotInList_WhichWork
|
|||||||
{
|
{
|
||||||
/* All of these should pass */
|
/* All of these should pass */
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(78));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(78));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(1));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(2));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(33));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(33));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(999));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(999));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(-1));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(-1));
|
||||||
@@ -31,9 +31,9 @@ void test_FindFunction_WhichIsBroken_ShouldReturnTheIndexForItemsInList_WhichWil
|
|||||||
{
|
{
|
||||||
/* You should see this line fail in your test summary */
|
/* You should see this line fail in your test summary */
|
||||||
TEST_ASSERT_EQUAL(1, FindFunction_WhichIsBroken(34));
|
TEST_ASSERT_EQUAL(1, FindFunction_WhichIsBroken(34));
|
||||||
|
|
||||||
/* Notice the rest of these didn't get a chance to run because the line above failed.
|
/* Notice the rest of these didn't get a chance to run because the line above failed.
|
||||||
* Unit tests abort each test function on the first sign of trouble.
|
* Unit tests abort each test function on the first sign of trouble.
|
||||||
* Then NEXT test function runs as normal. */
|
* Then NEXT test function runs as normal. */
|
||||||
TEST_ASSERT_EQUAL(8, FindFunction_WhichIsBroken(8888));
|
TEST_ASSERT_EQUAL(8, FindFunction_WhichIsBroken(8888));
|
||||||
}
|
}
|
||||||
@@ -42,7 +42,7 @@ void test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValue(v
|
|||||||
{
|
{
|
||||||
/* This should be true because setUp set this up for us before this test */
|
/* This should be true because setUp set this up for us before this test */
|
||||||
TEST_ASSERT_EQUAL_HEX(0x5a5a, FunctionWhichReturnsLocalVariable());
|
TEST_ASSERT_EQUAL_HEX(0x5a5a, FunctionWhichReturnsLocalVariable());
|
||||||
|
|
||||||
/* This should be true because we can still change our answer */
|
/* This should be true because we can still change our answer */
|
||||||
Counter = 0x1234;
|
Counter = 0x1234;
|
||||||
TEST_ASSERT_EQUAL_HEX(0x1234, FunctionWhichReturnsLocalVariable());
|
TEST_ASSERT_EQUAL_HEX(0x1234, FunctionWhichReturnsLocalVariable());
|
||||||
|
|||||||
@@ -41,6 +41,7 @@ CFLAGS += -Wno-unknown-pragmas
|
|||||||
CFLAGS += -Wstrict-prototypes
|
CFLAGS += -Wstrict-prototypes
|
||||||
CFLAGS += -Wundef
|
CFLAGS += -Wundef
|
||||||
CFLAGS += -Wold-style-definition
|
CFLAGS += -Wold-style-definition
|
||||||
|
#CFLAGS += -Wno-misleading-indentation
|
||||||
|
|
||||||
TARGET_BASE1=all_tests
|
TARGET_BASE1=all_tests
|
||||||
TARGET1 = $(TARGET_BASE1)$(TARGET_EXTENSION)
|
TARGET1 = $(TARGET_BASE1)$(TARGET_EXTENSION)
|
||||||
@@ -55,7 +56,7 @@ SRC_FILES1=\
|
|||||||
test/test_runners/TestProductionCode2_Runner.c \
|
test/test_runners/TestProductionCode2_Runner.c \
|
||||||
test/test_runners/all_tests.c
|
test/test_runners/all_tests.c
|
||||||
INC_DIRS=-Isrc -I$(UNITY_ROOT)/src -I$(UNITY_ROOT)/extras/fixture/src
|
INC_DIRS=-Isrc -I$(UNITY_ROOT)/src -I$(UNITY_ROOT)/extras/fixture/src
|
||||||
SYMBOLS=
|
SYMBOLS=-DUNITY_FIXTURE_NO_EXTRAS
|
||||||
|
|
||||||
all: clean default
|
all: clean default
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ int NumbersToFind[9] = { 0, 34, 55, 66, 32, 11, 1, 77, 888 }; //some obnoxious a
|
|||||||
int FindFunction_WhichIsBroken(int NumberToFind)
|
int FindFunction_WhichIsBroken(int NumberToFind)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
while (i <= 8) //Notice I should have been in braces
|
while (i < 8) //Notice I should have been in braces
|
||||||
i++;
|
i++;
|
||||||
if (NumbersToFind[i] == NumberToFind) //Yikes! I'm getting run after the loop finishes instead of during it!
|
if (NumbersToFind[i] == NumberToFind) //Yikes! I'm getting run after the loop finishes instead of during it!
|
||||||
return i;
|
return i;
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ TEST(ProductionCode, FindFunction_WhichIsBroken_ShouldReturnZeroIfItemIsNotInLis
|
|||||||
{
|
{
|
||||||
//All of these should pass
|
//All of these should pass
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(78));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(78));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(1));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(2));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(33));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(33));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(999));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(999));
|
||||||
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(-1));
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(-1));
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
HERE = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
||||||
UNITY_ROOT = File.expand_path(File.dirname(__FILE__)) + '/../..'
|
|
||||||
|
|
||||||
require 'rake'
|
require 'rake'
|
||||||
require 'rake/clean'
|
require 'rake/clean'
|
||||||
require HERE + 'rakefile_helper'
|
require_relative 'rakefile_helper'
|
||||||
|
|
||||||
TEMP_DIRS = [
|
TEMP_DIRS = [
|
||||||
File.join(HERE, 'build')
|
File.join(__dir__, 'build')
|
||||||
].freeze
|
].freeze
|
||||||
|
|
||||||
TEMP_DIRS.each do |dir|
|
TEMP_DIRS.each do |dir|
|
||||||
@@ -16,8 +13,6 @@ end
|
|||||||
|
|
||||||
task prepare_for_tests: TEMP_DIRS
|
task prepare_for_tests: TEMP_DIRS
|
||||||
|
|
||||||
include RakefileHelpers
|
|
||||||
|
|
||||||
# Load default configuration, for now
|
# Load default configuration, for now
|
||||||
DEFAULT_CONFIG_FILE = 'target_gcc_32.yml'.freeze
|
DEFAULT_CONFIG_FILE = 'target_gcc_32.yml'.freeze
|
||||||
configure_toolchain(DEFAULT_CONFIG_FILE)
|
configure_toolchain(DEFAULT_CONFIG_FILE)
|
||||||
@@ -32,8 +27,8 @@ task :summary do
|
|||||||
end
|
end
|
||||||
|
|
||||||
desc 'Build and test Unity'
|
desc 'Build and test Unity'
|
||||||
task all: %i(clean unit summary)
|
task all: %i[clean unit summary]
|
||||||
task default: %i(clobber all)
|
task default: %i[clobber all]
|
||||||
task ci: [:default]
|
task ci: [:default]
|
||||||
task cruise: [:default]
|
task cruise: [:default]
|
||||||
|
|
||||||
|
|||||||
@@ -1,249 +1,250 @@
|
|||||||
require 'yaml'
|
require 'yaml'
|
||||||
require 'fileutils'
|
require 'fileutils'
|
||||||
require UNITY_ROOT + '/auto/unity_test_summary'
|
require_relative '../../auto/unity_test_summary'
|
||||||
require UNITY_ROOT + '/auto/generate_test_runner'
|
require_relative '../../auto/generate_test_runner'
|
||||||
require UNITY_ROOT + '/auto/colour_reporter'
|
require_relative '../../auto/colour_reporter'
|
||||||
|
|
||||||
module RakefileHelpers
|
C_EXTENSION = '.c'.freeze
|
||||||
C_EXTENSION = '.c'.freeze
|
|
||||||
|
|
||||||
def load_configuration(config_file)
|
def load_configuration(config_file)
|
||||||
$cfg_file = config_file
|
$cfg_file = config_file
|
||||||
$cfg = YAML.load(File.read($cfg_file))
|
$cfg = YAML.load(File.read($cfg_file))
|
||||||
|
end
|
||||||
|
|
||||||
|
def configure_clean
|
||||||
|
CLEAN.include($cfg['compiler']['build_path'] + '*.*') unless $cfg['compiler']['build_path'].nil?
|
||||||
|
end
|
||||||
|
|
||||||
|
def configure_toolchain(config_file = DEFAULT_CONFIG_FILE)
|
||||||
|
config_file += '.yml' unless config_file =~ /\.yml$/
|
||||||
|
load_configuration(config_file)
|
||||||
|
configure_clean
|
||||||
|
end
|
||||||
|
|
||||||
|
def unit_test_files
|
||||||
|
path = $cfg['compiler']['unit_tests_path'] + 'Test*' + C_EXTENSION
|
||||||
|
path.tr!('\\', '/')
|
||||||
|
FileList.new(path)
|
||||||
|
end
|
||||||
|
|
||||||
|
def local_include_dirs
|
||||||
|
include_dirs = $cfg['compiler']['includes']['items'].dup
|
||||||
|
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
|
end
|
||||||
|
includes
|
||||||
|
end
|
||||||
|
|
||||||
def configure_clean
|
def find_source_file(header, paths)
|
||||||
CLEAN.include($cfg['compiler']['build_path'] + '*.*') unless $cfg['compiler']['build_path'].nil?
|
paths.each do |dir|
|
||||||
|
src_file = dir + header.ext(C_EXTENSION)
|
||||||
|
return src_file if File.exist?(src_file)
|
||||||
end
|
end
|
||||||
|
nil
|
||||||
|
end
|
||||||
|
|
||||||
def configure_toolchain(config_file = DEFAULT_CONFIG_FILE)
|
def tackit(strings)
|
||||||
config_file += '.yml' unless config_file =~ /\.yml$/
|
result = if strings.is_a?(Array)
|
||||||
load_configuration(config_file)
|
"\"#{strings.join}\""
|
||||||
configure_clean
|
else
|
||||||
end
|
strings
|
||||||
|
end
|
||||||
|
result
|
||||||
|
end
|
||||||
|
|
||||||
def unit_test_files
|
def squash(prefix, items)
|
||||||
path = $cfg['compiler']['unit_tests_path'] + 'Test*' + C_EXTENSION
|
result = ''
|
||||||
path.tr!('\\', '/')
|
items.each { |item| result += " #{prefix}#{tackit(item)}" }
|
||||||
FileList.new(path)
|
result
|
||||||
end
|
end
|
||||||
|
|
||||||
def local_include_dirs
|
def build_compiler_fields
|
||||||
include_dirs = $cfg['compiler']['includes']['items'].dup
|
command = tackit($cfg['compiler']['path'])
|
||||||
include_dirs.delete_if { |dir| dir.is_a?(Array) }
|
defines = if $cfg['compiler']['defines']['items'].nil?
|
||||||
include_dirs
|
''
|
||||||
end
|
else
|
||||||
|
squash($cfg['compiler']['defines']['prefix'], $cfg['compiler']['defines']['items'])
|
||||||
|
end
|
||||||
|
options = squash('', $cfg['compiler']['options'])
|
||||||
|
includes = squash($cfg['compiler']['includes']['prefix'], $cfg['compiler']['includes']['items'])
|
||||||
|
includes = includes.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
||||||
|
|
||||||
def extract_headers(filename)
|
{ command: command, defines: defines, options: options, includes: includes }
|
||||||
includes = []
|
end
|
||||||
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)
|
def compile(file, _defines = [])
|
||||||
paths.each do |dir|
|
compiler = build_compiler_fields
|
||||||
src_file = dir + header.ext(C_EXTENSION)
|
cmd_str = "#{compiler[:command]}#{compiler[:defines]}#{compiler[:options]}#{compiler[:includes]} #{file} " \
|
||||||
return src_file if File.exist?(src_file)
|
"#{$cfg['compiler']['object_files']['prefix']}#{$cfg['compiler']['object_files']['destination']}"
|
||||||
end
|
obj_file = "#{File.basename(file, C_EXTENSION)}#{$cfg['compiler']['object_files']['extension']}"
|
||||||
nil
|
execute(cmd_str + obj_file)
|
||||||
end
|
obj_file
|
||||||
|
end
|
||||||
|
|
||||||
def tackit(strings)
|
def build_linker_fields
|
||||||
result = if strings.is_a?(Array)
|
command = tackit($cfg['linker']['path'])
|
||||||
"\"#{strings.join}\""
|
options = if $cfg['linker']['options'].nil?
|
||||||
|
''
|
||||||
|
else
|
||||||
|
squash('', $cfg['linker']['options'])
|
||||||
|
end
|
||||||
|
includes = if $cfg['linker']['includes'].nil? || $cfg['linker']['includes']['items'].nil?
|
||||||
|
''
|
||||||
else
|
else
|
||||||
strings
|
squash($cfg['linker']['includes']['prefix'], $cfg['linker']['includes']['items'])
|
||||||
end
|
end.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
||||||
result
|
|
||||||
end
|
|
||||||
|
|
||||||
def squash(prefix, items)
|
{ command: command, options: options, includes: includes }
|
||||||
result = ''
|
end
|
||||||
items.each { |item| result += " #{prefix}#{tackit(item)}" }
|
|
||||||
result
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_compiler_fields
|
def link_it(exe_name, obj_list)
|
||||||
command = tackit($cfg['compiler']['path'])
|
linker = build_linker_fields
|
||||||
defines = if $cfg['compiler']['defines']['items'].nil?
|
cmd_str = "#{linker[:command]}#{linker[:options]}#{linker[:includes]} " +
|
||||||
''
|
(obj_list.map { |obj| "#{$cfg['linker']['object_files']['path']}#{obj} " }).join +
|
||||||
else
|
$cfg['linker']['bin_files']['prefix'] + ' ' +
|
||||||
squash($cfg['compiler']['defines']['prefix'], $cfg['compiler']['defines']['items'])
|
$cfg['linker']['bin_files']['destination'] +
|
||||||
end
|
exe_name + $cfg['linker']['bin_files']['extension']
|
||||||
options = squash('', $cfg['compiler']['options'])
|
execute(cmd_str)
|
||||||
includes = squash($cfg['compiler']['includes']['prefix'], $cfg['compiler']['includes']['items'])
|
end
|
||||||
includes = includes.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ command: command, defines: defines, options: options, includes: includes }
|
def build_simulator_fields
|
||||||
end
|
return nil if $cfg['simulator'].nil?
|
||||||
|
|
||||||
def compile(file, _defines = [])
|
command = if $cfg['simulator']['path'].nil?
|
||||||
compiler = build_compiler_fields
|
''
|
||||||
cmd_str = "#{compiler[:command]}#{compiler[:defines]}#{compiler[:options]}#{compiler[:includes]} #{file} " \
|
else
|
||||||
"#{$cfg['compiler']['object_files']['prefix']}#{$cfg['compiler']['object_files']['destination']}"
|
(tackit($cfg['simulator']['path']) + ' ')
|
||||||
obj_file = "#{File.basename(file, C_EXTENSION)}#{$cfg['compiler']['object_files']['extension']}"
|
end
|
||||||
execute(cmd_str + obj_file)
|
pre_support = if $cfg['simulator']['pre_support'].nil?
|
||||||
obj_file
|
''
|
||||||
end
|
|
||||||
|
|
||||||
def build_linker_fields
|
|
||||||
command = tackit($cfg['linker']['path'])
|
|
||||||
options = if $cfg['linker']['options'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['linker']['options'])
|
|
||||||
end
|
|
||||||
includes = if $cfg['linker']['includes'].nil? || $cfg['linker']['includes']['items'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash($cfg['linker']['includes']['prefix'], $cfg['linker']['includes']['items'])
|
|
||||||
end.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ command: command, options: options, includes: includes }
|
|
||||||
end
|
|
||||||
|
|
||||||
def link_it(exe_name, obj_list)
|
|
||||||
linker = build_linker_fields
|
|
||||||
cmd_str = "#{linker[:command]}#{linker[:options]}#{linker[:includes]} " +
|
|
||||||
(obj_list.map { |obj| "#{$cfg['linker']['object_files']['path']}#{obj} " }).join +
|
|
||||||
$cfg['linker']['bin_files']['prefix'] + ' ' +
|
|
||||||
$cfg['linker']['bin_files']['destination'] +
|
|
||||||
exe_name + $cfg['linker']['bin_files']['extension']
|
|
||||||
execute(cmd_str)
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_simulator_fields
|
|
||||||
return nil if $cfg['simulator'].nil?
|
|
||||||
command = if $cfg['simulator']['path'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
(tackit($cfg['simulator']['path']) + ' ')
|
|
||||||
end
|
|
||||||
pre_support = if $cfg['simulator']['pre_support'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['pre_support'])
|
|
||||||
end
|
|
||||||
post_support = if $cfg['simulator']['post_support'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['post_support'])
|
|
||||||
end
|
|
||||||
|
|
||||||
{ command: command, pre_support: pre_support, post_support: post_support }
|
|
||||||
end
|
|
||||||
|
|
||||||
def execute(command_string, verbose = true, raise_on_fail = true)
|
|
||||||
report command_string
|
|
||||||
output = `#{command_string}`.chomp
|
|
||||||
report(output) if verbose && !output.nil? && !output.empty?
|
|
||||||
if !$?.exitstatus.zero? && raise_on_fail
|
|
||||||
raise "Command failed. (Returned #{$?.exitstatus})"
|
|
||||||
end
|
|
||||||
output
|
|
||||||
end
|
|
||||||
|
|
||||||
def report_summary
|
|
||||||
summary = UnityTestSummary.new
|
|
||||||
summary.root = HERE
|
|
||||||
results_glob = "#{$cfg['compiler']['build_path']}*.test*"
|
|
||||||
results_glob.tr!('\\', '/')
|
|
||||||
results = Dir[results_glob]
|
|
||||||
summary.targets = results
|
|
||||||
summary.run
|
|
||||||
fail_out 'FAIL: There were failures' if summary.failures > 0
|
|
||||||
end
|
|
||||||
|
|
||||||
def run_tests(test_files)
|
|
||||||
report 'Running system tests...'
|
|
||||||
|
|
||||||
# Tack on TEST define for compiling unit tests
|
|
||||||
load_configuration($cfg_file)
|
|
||||||
test_defines = ['TEST']
|
|
||||||
$cfg['compiler']['defines']['items'] = [] if $cfg['compiler']['defines']['items'].nil?
|
|
||||||
$cfg['compiler']['defines']['items'] << 'TEST'
|
|
||||||
|
|
||||||
include_dirs = local_include_dirs
|
|
||||||
|
|
||||||
# Build and execute each unit test
|
|
||||||
test_files.each do |test|
|
|
||||||
obj_list = []
|
|
||||||
|
|
||||||
# Detect dependencies and build required 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'
|
|
||||||
if $cfg['compiler']['runner_path'].nil?
|
|
||||||
runner_path = $cfg['compiler']['build_path'] + runner_name
|
|
||||||
test_gen = UnityTestRunnerGenerator.new($cfg_file)
|
|
||||||
test_gen.run(test, runner_path)
|
|
||||||
else
|
|
||||||
runner_path = $cfg['compiler']['runner_path'] + runner_name
|
|
||||||
end
|
|
||||||
|
|
||||||
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
|
|
||||||
simulator = build_simulator_fields
|
|
||||||
executable = $cfg['linker']['bin_files']['destination'] + test_base + $cfg['linker']['bin_files']['extension']
|
|
||||||
cmd_str = if simulator.nil?
|
|
||||||
executable
|
|
||||||
else
|
else
|
||||||
"#{simulator[:command]} #{simulator[:pre_support]} #{executable} #{simulator[:post_support]}"
|
squash('', $cfg['simulator']['pre_support'])
|
||||||
end
|
end
|
||||||
output = execute(cmd_str, true, false)
|
post_support = if $cfg['simulator']['post_support'].nil?
|
||||||
test_results = $cfg['compiler']['build_path'] + test_base
|
''
|
||||||
test_results += if output.match(/OK$/m).nil?
|
else
|
||||||
'.testfail'
|
squash('', $cfg['simulator']['post_support'])
|
||||||
else
|
end
|
||||||
'.testpass'
|
|
||||||
end
|
{ command: command, pre_support: pre_support, post_support: post_support }
|
||||||
File.open(test_results, 'w') { |f| f.print output }
|
end
|
||||||
end
|
|
||||||
|
def execute(command_string, verbose = true, raise_on_fail = true)
|
||||||
|
report command_string
|
||||||
|
output = `#{command_string}`.chomp
|
||||||
|
report(output) if verbose && !output.nil? && !output.empty?
|
||||||
|
|
||||||
|
if !$?.nil? && !$?.exitstatus.zero? && raise_on_fail
|
||||||
|
raise "Command failed. (Returned #{$?.exitstatus})"
|
||||||
end
|
end
|
||||||
|
|
||||||
def build_application(main)
|
output
|
||||||
report 'Building application...'
|
end
|
||||||
|
|
||||||
|
def report_summary
|
||||||
|
summary = UnityTestSummary.new
|
||||||
|
summary.root = __dir__
|
||||||
|
results_glob = "#{$cfg['compiler']['build_path']}*.test*"
|
||||||
|
results_glob.tr!('\\', '/')
|
||||||
|
results = Dir[results_glob]
|
||||||
|
summary.targets = results
|
||||||
|
summary.run
|
||||||
|
fail_out 'FAIL: There were failures' if summary.failures > 0
|
||||||
|
end
|
||||||
|
|
||||||
|
def run_tests(test_files)
|
||||||
|
report 'Running system tests...'
|
||||||
|
|
||||||
|
# Tack on TEST define for compiling unit tests
|
||||||
|
load_configuration($cfg_file)
|
||||||
|
test_defines = ['TEST']
|
||||||
|
$cfg['compiler']['defines']['items'] = [] if $cfg['compiler']['defines']['items'].nil?
|
||||||
|
$cfg['compiler']['defines']['items'] << 'TEST'
|
||||||
|
|
||||||
|
include_dirs = local_include_dirs
|
||||||
|
|
||||||
|
# Build and execute each unit test
|
||||||
|
test_files.each do |test|
|
||||||
obj_list = []
|
obj_list = []
|
||||||
load_configuration($cfg_file)
|
|
||||||
main_path = $cfg['compiler']['source_path'] + main + C_EXTENSION
|
|
||||||
|
|
||||||
# Detect dependencies and build required required modules
|
# Detect dependencies and build required required modules
|
||||||
include_dirs = get_local_include_dirs
|
extract_headers(test).each do |header|
|
||||||
extract_headers(main_path).each do |header|
|
# Compile corresponding source file if it exists
|
||||||
src_file = find_source_file(header, include_dirs)
|
src_file = find_source_file(header, include_dirs)
|
||||||
obj_list << compile(src_file) unless src_file.nil?
|
obj_list << compile(src_file, test_defines) unless src_file.nil?
|
||||||
end
|
end
|
||||||
|
|
||||||
# Build the main source file
|
# Build the test runner (generate if configured to do so)
|
||||||
main_base = File.basename(main_path, C_EXTENSION)
|
test_base = File.basename(test, C_EXTENSION)
|
||||||
obj_list << compile(main_path)
|
runner_name = test_base + '_Runner.c'
|
||||||
|
if $cfg['compiler']['runner_path'].nil?
|
||||||
|
runner_path = $cfg['compiler']['build_path'] + runner_name
|
||||||
|
test_gen = UnityTestRunnerGenerator.new($cfg_file)
|
||||||
|
test_gen.run(test, runner_path)
|
||||||
|
else
|
||||||
|
runner_path = $cfg['compiler']['runner_path'] + runner_name
|
||||||
|
end
|
||||||
|
|
||||||
# Create the executable
|
obj_list << compile(runner_path, test_defines)
|
||||||
link_it(main_base, obj_list)
|
|
||||||
end
|
|
||||||
|
|
||||||
def fail_out(msg)
|
# Build the test module
|
||||||
puts msg
|
obj_list << compile(test, test_defines)
|
||||||
puts 'Not returning exit code so continuous integration can pass'
|
|
||||||
# exit(-1) # Only removed to pass example_3, which has failing tests on purpose.
|
# Link the test executable
|
||||||
# Still fail if the build fails for any other reason.
|
link_it(test_base, obj_list)
|
||||||
|
|
||||||
|
# Execute unit test and generate results file
|
||||||
|
simulator = build_simulator_fields
|
||||||
|
executable = $cfg['linker']['bin_files']['destination'] + test_base + $cfg['linker']['bin_files']['extension']
|
||||||
|
cmd_str = if simulator.nil?
|
||||||
|
executable
|
||||||
|
else
|
||||||
|
"#{simulator[:command]} #{simulator[:pre_support]} #{executable} #{simulator[:post_support]}"
|
||||||
|
end
|
||||||
|
output = execute(cmd_str, true, false)
|
||||||
|
test_results = $cfg['compiler']['build_path'] + test_base
|
||||||
|
test_results += if output.match(/OK$/m).nil?
|
||||||
|
'.testfail'
|
||||||
|
else
|
||||||
|
'.testpass'
|
||||||
|
end
|
||||||
|
File.open(test_results, 'w') { |f| f.print output }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def build_application(main)
|
||||||
|
report 'Building application...'
|
||||||
|
|
||||||
|
obj_list = []
|
||||||
|
load_configuration($cfg_file)
|
||||||
|
main_path = $cfg['compiler']['source_path'] + main + C_EXTENSION
|
||||||
|
|
||||||
|
# Detect dependencies and build required required modules
|
||||||
|
include_dirs = get_local_include_dirs
|
||||||
|
extract_headers(main_path).each do |header|
|
||||||
|
src_file = find_source_file(header, include_dirs)
|
||||||
|
obj_list << compile(src_file) unless src_file.nil?
|
||||||
|
end
|
||||||
|
|
||||||
|
# Build the main source file
|
||||||
|
main_base = File.basename(main_path, C_EXTENSION)
|
||||||
|
obj_list << compile(main_path)
|
||||||
|
|
||||||
|
# Create the executable
|
||||||
|
link_it(main_base, obj_list)
|
||||||
|
end
|
||||||
|
|
||||||
|
def fail_out(msg)
|
||||||
|
puts msg
|
||||||
|
puts 'Not returning exit code so continuous integration can pass'
|
||||||
|
# exit(-1) # Only removed to pass example_3, which has failing tests on purpose.
|
||||||
|
# Still fail if the build fails for any other reason.
|
||||||
|
end
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ int NumbersToFind[9] = { 0, 34, 55, 66, 32, 11, 1, 77, 888 }; //some obnoxious a
|
|||||||
int FindFunction_WhichIsBroken(int NumberToFind)
|
int FindFunction_WhichIsBroken(int NumberToFind)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
while (i <= 8) //Notice I should have been in braces
|
while (i < 8) //Notice I should have been in braces
|
||||||
i++;
|
i++;
|
||||||
if (NumbersToFind[i] == NumberToFind) //Yikes! I'm getting run after the loop finishes instead of during it!
|
if (NumbersToFind[i] == NumberToFind) //Yikes! I'm getting run after the loop finishes instead of during it!
|
||||||
return i;
|
return i;
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
# Copied from ~Unity/targets/gcc_32.yml
|
# Copied from ~Unity/targets/gcc_32.yml
|
||||||
unity_root: &unity_root '../..'
|
unity_root: &unity_root '../..'
|
||||||
|
unity_source: &unity_source '../../src/'
|
||||||
compiler:
|
compiler:
|
||||||
path: gcc
|
path: gcc
|
||||||
source_path: 'src/'
|
source_path: &source_path 'src/'
|
||||||
unit_tests_path: &unit_tests_path 'test/'
|
unit_tests_path: &unit_tests_path 'test/'
|
||||||
build_path: &build_path 'build/'
|
build_path: &build_path 'build/'
|
||||||
options:
|
options:
|
||||||
@@ -15,8 +16,8 @@ compiler:
|
|||||||
includes:
|
includes:
|
||||||
prefix: '-I'
|
prefix: '-I'
|
||||||
items:
|
items:
|
||||||
- 'src/'
|
- *source_path
|
||||||
- '../../src/'
|
- *unity_source
|
||||||
- *unit_tests_path
|
- *unit_tests_path
|
||||||
defines:
|
defines:
|
||||||
prefix: '-D'
|
prefix: '-D'
|
||||||
|
|||||||
12
examples/example_4/meson.build
Normal file
12
examples/example_4/meson.build
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
project('example-4', 'c')
|
||||||
|
|
||||||
|
unity_dep = dependency('unity', fallback : ['unity', 'unity_dep'])
|
||||||
|
|
||||||
|
subdir('src')
|
||||||
|
subdir('test')
|
||||||
15
examples/example_4/readme.txt
Normal file
15
examples/example_4/readme.txt
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
Example 4
|
||||||
|
=========
|
||||||
|
|
||||||
|
Close to the simplest possible example of Unity, using only basic features.
|
||||||
|
to build this example run "meson setup <build dir name>".
|
||||||
|
|
||||||
|
Meson uses the Ninja build system to actually build the code. To start the
|
||||||
|
build, simply type the following command.
|
||||||
|
|
||||||
|
"ninja -C <build dir name>"
|
||||||
|
|
||||||
|
Meson provides native support for running tests. The command to do that is simple.
|
||||||
|
|
||||||
|
"meson test -C <build dir name>".
|
||||||
|
|
||||||
24
examples/example_4/src/ProductionCode.c
Normal file
24
examples/example_4/src/ProductionCode.c
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
|
||||||
|
#include "ProductionCode.h"
|
||||||
|
|
||||||
|
int Counter = 0;
|
||||||
|
int NumbersToFind[9] = { 0, 34, 55, 66, 32, 11, 1, 77, 888 }; /* some obnoxious array to search that is 1-based indexing instead of 0. */
|
||||||
|
|
||||||
|
/* This function is supposed to search through NumbersToFind and find a particular number.
|
||||||
|
* If it finds it, the index is returned. Otherwise 0 is returned which sorta makes sense since
|
||||||
|
* NumbersToFind is indexed from 1. Unfortunately it's broken
|
||||||
|
* (and should therefore be caught by our tests) */
|
||||||
|
int FindFunction_WhichIsBroken(int NumberToFind)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
while (i < 8) /* Notice I should have been in braces */
|
||||||
|
i++;
|
||||||
|
if (NumbersToFind[i] == NumberToFind) /* Yikes! I'm getting run after the loop finishes instead of during it! */
|
||||||
|
return i;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int FunctionWhichReturnsLocalVariable(void)
|
||||||
|
{
|
||||||
|
return Counter;
|
||||||
|
}
|
||||||
3
examples/example_4/src/ProductionCode.h
Normal file
3
examples/example_4/src/ProductionCode.h
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
|
||||||
|
int FindFunction_WhichIsBroken(int NumberToFind);
|
||||||
|
int FunctionWhichReturnsLocalVariable(void);
|
||||||
11
examples/example_4/src/ProductionCode2.c
Normal file
11
examples/example_4/src/ProductionCode2.c
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
|
||||||
|
#include "ProductionCode2.h"
|
||||||
|
|
||||||
|
char* ThisFunctionHasNotBeenTested(int Poor, char* LittleFunction)
|
||||||
|
{
|
||||||
|
(void)Poor;
|
||||||
|
(void)LittleFunction;
|
||||||
|
/* Since There Are No Tests Yet, This Function Could Be Empty For All We Know.
|
||||||
|
* Which isn't terribly useful... but at least we put in a TEST_IGNORE so we won't forget */
|
||||||
|
return (char*)0;
|
||||||
|
}
|
||||||
2
examples/example_4/src/ProductionCode2.h
Normal file
2
examples/example_4/src/ProductionCode2.h
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
char* ThisFunctionHasNotBeenTested(int Poor, char* LittleFunction);
|
||||||
16
examples/example_4/src/meson.build
Normal file
16
examples/example_4/src/meson.build
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
inc_dir = include_directories('.')
|
||||||
|
lib_list = {'a': ['ProductionCode.c' ], 'b': ['ProductionCode2.c']}
|
||||||
|
|
||||||
|
foreach lib, src : lib_list
|
||||||
|
set_variable(lib + '_lib',
|
||||||
|
static_library(lib + '_lib', sources: src, include_directories: inc_dir))
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
a_dep = declare_dependency(link_with: a_lib, include_directories: inc_dir)
|
||||||
|
b_dep = declare_dependency(link_with: b_lib, include_directories: inc_dir)
|
||||||
4
examples/example_4/subprojects/unity.wrap
Executable file
4
examples/example_4/subprojects/unity.wrap
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
[wrap-git]
|
||||||
|
directory = unity
|
||||||
|
url = https://github.com/ThrowTheSwitch/Unity.git
|
||||||
|
revision = head
|
||||||
63
examples/example_4/test/TestProductionCode.c
Normal file
63
examples/example_4/test/TestProductionCode.c
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
|
||||||
|
#include "ProductionCode.h"
|
||||||
|
#include "unity.h"
|
||||||
|
|
||||||
|
/* sometimes you may want to get at local data in a module.
|
||||||
|
* for example: If you plan to pass by reference, this could be useful
|
||||||
|
* however, it should often be avoided */
|
||||||
|
extern int Counter;
|
||||||
|
|
||||||
|
void setUp(void)
|
||||||
|
{
|
||||||
|
/* This is run before EACH TEST */
|
||||||
|
Counter = 0x5a5a;
|
||||||
|
}
|
||||||
|
|
||||||
|
void tearDown(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void test_FindFunction_WhichIsBroken_ShouldReturnZeroIfItemIsNotInList_WhichWorksEvenInOurBrokenCode(void)
|
||||||
|
{
|
||||||
|
/* All of these should pass */
|
||||||
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(78));
|
||||||
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(2));
|
||||||
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(33));
|
||||||
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(999));
|
||||||
|
TEST_ASSERT_EQUAL(0, FindFunction_WhichIsBroken(-1));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_FindFunction_WhichIsBroken_ShouldReturnTheIndexForItemsInList_WhichWillFailBecauseOurFunctionUnderTestIsBroken(void)
|
||||||
|
{
|
||||||
|
/* You should see this line fail in your test summary */
|
||||||
|
TEST_ASSERT_EQUAL(1, FindFunction_WhichIsBroken(34));
|
||||||
|
|
||||||
|
/* Notice the rest of these didn't get a chance to run because the line above failed.
|
||||||
|
* Unit tests abort each test function on the first sign of trouble.
|
||||||
|
* Then NEXT test function runs as normal. */
|
||||||
|
TEST_ASSERT_EQUAL(8, FindFunction_WhichIsBroken(8888));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValue(void)
|
||||||
|
{
|
||||||
|
/* This should be true because setUp set this up for us before this test */
|
||||||
|
TEST_ASSERT_EQUAL_HEX(0x5a5a, FunctionWhichReturnsLocalVariable());
|
||||||
|
|
||||||
|
/* This should be true because we can still change our answer */
|
||||||
|
Counter = 0x1234;
|
||||||
|
TEST_ASSERT_EQUAL_HEX(0x1234, FunctionWhichReturnsLocalVariable());
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValueAgain(void)
|
||||||
|
{
|
||||||
|
/* This should be true again because setup was rerun before this test (and after we changed it to 0x1234) */
|
||||||
|
TEST_ASSERT_EQUAL_HEX(0x5a5a, FunctionWhichReturnsLocalVariable());
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_FunctionWhichReturnsLocalVariable_ShouldReturnCurrentCounter_ButFailsBecauseThisTestIsActuallyFlawed(void)
|
||||||
|
{
|
||||||
|
/* Sometimes you get the test wrong. When that happens, you get a failure too... and a quick look should tell
|
||||||
|
* you what actually happened...which in this case was a failure to setup the initial condition. */
|
||||||
|
TEST_ASSERT_EQUAL_HEX(0x1234, FunctionWhichReturnsLocalVariable());
|
||||||
|
}
|
||||||
35
examples/example_4/test/TestProductionCode2.c
Normal file
35
examples/example_4/test/TestProductionCode2.c
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
|
||||||
|
#include "ProductionCode2.h"
|
||||||
|
#include "unity.h"
|
||||||
|
|
||||||
|
/* These should be ignored because they are commented out in various ways:
|
||||||
|
#include "whatever.h"
|
||||||
|
#include "somethingelse.h"
|
||||||
|
*/
|
||||||
|
|
||||||
|
void setUp(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void tearDown(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_IgnoredTest(void);
|
||||||
|
void test_AnotherIgnoredTest(void);
|
||||||
|
void test_ThisFunctionHasNotBeenTested_NeedsToBeImplemented(void);
|
||||||
|
|
||||||
|
void test_IgnoredTest(void)
|
||||||
|
{
|
||||||
|
TEST_IGNORE_MESSAGE("This Test Was Ignored On Purpose");
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_AnotherIgnoredTest(void)
|
||||||
|
{
|
||||||
|
TEST_IGNORE_MESSAGE("These Can Be Useful For Leaving Yourself Notes On What You Need To Do Yet");
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ThisFunctionHasNotBeenTested_NeedsToBeImplemented(void)
|
||||||
|
{
|
||||||
|
TEST_IGNORE(); /* Like This */
|
||||||
|
}
|
||||||
7
examples/example_4/test/meson.build
Normal file
7
examples/example_4/test/meson.build
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
subdir('test_runners')
|
||||||
@@ -0,0 +1,53 @@
|
|||||||
|
/* 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()) \
|
||||||
|
{ \
|
||||||
|
tearDown(); \
|
||||||
|
} \
|
||||||
|
UnityConcludeTest(); \
|
||||||
|
}
|
||||||
|
|
||||||
|
/*=======Automagically Detected Files To Include=====*/
|
||||||
|
#include "unity.h"
|
||||||
|
#include <setjmp.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "ProductionCode2.h"
|
||||||
|
|
||||||
|
/*=======External Functions This Runner Calls=====*/
|
||||||
|
extern void setUp(void);
|
||||||
|
extern void tearDown(void);
|
||||||
|
extern void test_IgnoredTest(void);
|
||||||
|
extern void test_AnotherIgnoredTest(void);
|
||||||
|
extern void test_ThisFunctionHasNotBeenTested_NeedsToBeImplemented(void);
|
||||||
|
|
||||||
|
|
||||||
|
/*=======Test Reset Option=====*/
|
||||||
|
void resetTest(void);
|
||||||
|
void resetTest(void)
|
||||||
|
{
|
||||||
|
tearDown();
|
||||||
|
setUp();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*=======MAIN=====*/
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
UnityBegin("test/TestProductionCode2.c");
|
||||||
|
RUN_TEST(test_IgnoredTest, 18);
|
||||||
|
RUN_TEST(test_AnotherIgnoredTest, 23);
|
||||||
|
RUN_TEST(test_ThisFunctionHasNotBeenTested_NeedsToBeImplemented, 28);
|
||||||
|
|
||||||
|
return (UnityEnd());
|
||||||
|
}
|
||||||
@@ -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()) \
|
||||||
|
{ \
|
||||||
|
tearDown(); \
|
||||||
|
} \
|
||||||
|
UnityConcludeTest(); \
|
||||||
|
}
|
||||||
|
|
||||||
|
/*=======Automagically Detected Files To Include=====*/
|
||||||
|
#include "unity.h"
|
||||||
|
#include <setjmp.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "ProductionCode.h"
|
||||||
|
|
||||||
|
/*=======External Functions This Runner Calls=====*/
|
||||||
|
extern void setUp(void);
|
||||||
|
extern void tearDown(void);
|
||||||
|
extern void test_FindFunction_WhichIsBroken_ShouldReturnZeroIfItemIsNotInList_WhichWorksEvenInOurBrokenCode(void);
|
||||||
|
extern void test_FindFunction_WhichIsBroken_ShouldReturnTheIndexForItemsInList_WhichWillFailBecauseOurFunctionUnderTestIsBroken(void);
|
||||||
|
extern void test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValue(void);
|
||||||
|
extern void test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValueAgain(void);
|
||||||
|
extern void test_FunctionWhichReturnsLocalVariable_ShouldReturnCurrentCounter_ButFailsBecauseThisTestIsActuallyFlawed(void);
|
||||||
|
|
||||||
|
|
||||||
|
/*=======Test Reset Option=====*/
|
||||||
|
void resetTest(void);
|
||||||
|
void resetTest(void)
|
||||||
|
{
|
||||||
|
tearDown();
|
||||||
|
setUp();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*=======MAIN=====*/
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
UnityBegin("test/TestProductionCode.c");
|
||||||
|
RUN_TEST(test_FindFunction_WhichIsBroken_ShouldReturnZeroIfItemIsNotInList_WhichWorksEvenInOurBrokenCode, 20);
|
||||||
|
RUN_TEST(test_FindFunction_WhichIsBroken_ShouldReturnTheIndexForItemsInList_WhichWillFailBecauseOurFunctionUnderTestIsBroken, 30);
|
||||||
|
RUN_TEST(test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValue, 41);
|
||||||
|
RUN_TEST(test_FunctionWhichReturnsLocalVariable_ShouldReturnTheCurrentCounterValueAgain, 51);
|
||||||
|
RUN_TEST(test_FunctionWhichReturnsLocalVariable_ShouldReturnCurrentCounter_ButFailsBecauseThisTestIsActuallyFlawed, 57);
|
||||||
|
|
||||||
|
return (UnityEnd());
|
||||||
|
}
|
||||||
13
examples/example_4/test/test_runners/meson.build
Normal file
13
examples/example_4/test/test_runners/meson.build
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
cases = [
|
||||||
|
['TestProductionCode_Runner.c', join_paths('..' ,'TestProductionCode.c' )],
|
||||||
|
['TestProductionCode2_Runner.c', join_paths('..' ,'TestProductionCode2.c')]
|
||||||
|
]
|
||||||
|
|
||||||
|
test('Running: 01-test-case', executable('01-test-case', cases[0], dependencies: [ a_dep, unity_dep ]))
|
||||||
|
test('Running: 02-test-case', executable('02-test-case', cases[1], dependencies: [ b_dep, unity_dep ]))
|
||||||
@@ -176,6 +176,22 @@
|
|||||||
/* #define UNITY_DOUBLE_PRECISION 0.001f */
|
/* #define UNITY_DOUBLE_PRECISION 0.001f */
|
||||||
|
|
||||||
|
|
||||||
|
/* *************************** MISCELLANEOUS ***********************************
|
||||||
|
* Miscellaneous configuration options for Unity
|
||||||
|
**************************************************************************** */
|
||||||
|
|
||||||
|
/* Unity uses the stddef.h header included in the C standard library for the
|
||||||
|
* "NULL" macro. Define this in order to disable the include of stddef.h. If you
|
||||||
|
* do this, you have to make sure to provide your own "NULL" definition.
|
||||||
|
*/
|
||||||
|
/* #define UNITY_EXCLUDE_STDDEF_H */
|
||||||
|
|
||||||
|
/* Define this to enable the unity formatted print macro:
|
||||||
|
* "TEST_PRINTF"
|
||||||
|
*/
|
||||||
|
/* #define UNITY_INCLUDE_PRINT_FORMATTED */
|
||||||
|
|
||||||
|
|
||||||
/* *************************** TOOLSET CUSTOMIZATION ***************************
|
/* *************************** TOOLSET CUSTOMIZATION ***************************
|
||||||
* In addition to the options listed above, there are a number of other options
|
* In addition to the options listed above, there are a number of other options
|
||||||
* which will come in handy to customize Unity's behavior for your specific
|
* which will come in handy to customize Unity's behavior for your specific
|
||||||
@@ -208,25 +224,6 @@
|
|||||||
/* #define UNITY_OUTPUT_START() RS232_config(115200,1,8,0) */
|
/* #define UNITY_OUTPUT_START() RS232_config(115200,1,8,0) */
|
||||||
/* #define UNITY_OUTPUT_COMPLETE() RS232_close() */
|
/* #define UNITY_OUTPUT_COMPLETE() RS232_close() */
|
||||||
|
|
||||||
/* For some targets, Unity can make the otherwise required `setUp()` and
|
|
||||||
* `tearDown()` functions optional. This is a nice convenience for test writers
|
|
||||||
* since `setUp` and `tearDown` don't often actually _do_ anything. If you're
|
|
||||||
* using gcc or clang, this option is automatically defined for you. Other
|
|
||||||
* compilers can also support this behavior, if they support a C feature called
|
|
||||||
* weak functions. A weak function is a function that is compiled into your
|
|
||||||
* executable _unless_ a non-weak version of the same function is defined
|
|
||||||
* elsewhere. If a non-weak version is found, the weak version is ignored as if
|
|
||||||
* it never existed. If your compiler supports this feature, you can let Unity
|
|
||||||
* know by defining `UNITY_SUPPORT_WEAK` as the function attributes that would
|
|
||||||
* need to be applied to identify a function as weak. If your compiler lacks
|
|
||||||
* support for weak functions, you will always need to define `setUp` and
|
|
||||||
* `tearDown` functions (though they can be and often will be just empty). The
|
|
||||||
* most common options for this feature are:
|
|
||||||
*/
|
|
||||||
/* #define UNITY_SUPPORT_WEAK weak */
|
|
||||||
/* #define UNITY_SUPPORT_WEAK __attribute__((weak)) */
|
|
||||||
/* #define UNITY_NO_WEAK */
|
|
||||||
|
|
||||||
/* Some compilers require a custom attribute to be assigned to pointers, like
|
/* Some compilers require a custom attribute to be assigned to pointers, like
|
||||||
* `near` or `far`. In these cases, you can give Unity a safe default for these
|
* `near` or `far`. In these cases, you can give Unity a safe default for these
|
||||||
* by defining this option with the attribute you would like.
|
* by defining this option with the attribute you would like.
|
||||||
@@ -236,4 +233,12 @@
|
|||||||
/* #define UNITY_PTR_ATTRIBUTE __attribute__((far)) */
|
/* #define UNITY_PTR_ATTRIBUTE __attribute__((far)) */
|
||||||
/* #define UNITY_PTR_ATTRIBUTE near */
|
/* #define UNITY_PTR_ATTRIBUTE near */
|
||||||
|
|
||||||
|
/* Print execution time of each test when executed in verbose mode
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* TEST - PASS (10 ms)
|
||||||
|
*/
|
||||||
|
/* #define UNITY_INCLUDE_EXEC_TIME */
|
||||||
|
|
||||||
#endif /* UNITY_CONFIG_H */
|
#endif /* UNITY_CONFIG_H */
|
||||||
|
|||||||
@@ -1,48 +0,0 @@
|
|||||||
# ==========================================
|
|
||||||
# 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]
|
|
||||||
# ==========================================
|
|
||||||
|
|
||||||
HERE = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
||||||
|
|
||||||
require 'rake'
|
|
||||||
require 'rake/clean'
|
|
||||||
require 'rake/testtask'
|
|
||||||
require HERE + 'rakefile_helper'
|
|
||||||
|
|
||||||
TEMP_DIRS = [
|
|
||||||
File.join(HERE, 'build')
|
|
||||||
].freeze
|
|
||||||
|
|
||||||
TEMP_DIRS.each do |dir|
|
|
||||||
directory(dir)
|
|
||||||
CLOBBER.include(dir)
|
|
||||||
end
|
|
||||||
|
|
||||||
task prepare_for_tests: TEMP_DIRS
|
|
||||||
|
|
||||||
include RakefileHelpers
|
|
||||||
|
|
||||||
# Load default configuration, for now
|
|
||||||
DEFAULT_CONFIG_FILE = 'gcc_auto_stdint.yml'.freeze
|
|
||||||
configure_toolchain(DEFAULT_CONFIG_FILE)
|
|
||||||
|
|
||||||
task unit: [:prepare_for_tests] do
|
|
||||||
run_tests
|
|
||||||
end
|
|
||||||
|
|
||||||
desc 'Build and test Unity Framework'
|
|
||||||
task all: %i(clean unit)
|
|
||||||
task default: %i(clobber all)
|
|
||||||
task ci: %i(no_color default)
|
|
||||||
task cruise: %i(no_color default)
|
|
||||||
|
|
||||||
desc 'Load configuration'
|
|
||||||
task :config, :config_file do |_t, args|
|
|
||||||
configure_toolchain(args[:config_file])
|
|
||||||
end
|
|
||||||
|
|
||||||
task :no_color do
|
|
||||||
$colour_output = false
|
|
||||||
end
|
|
||||||
@@ -1,178 +0,0 @@
|
|||||||
# ==========================================
|
|
||||||
# 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 'yaml'
|
|
||||||
require 'fileutils'
|
|
||||||
require HERE + '../../auto/unity_test_summary'
|
|
||||||
require HERE + '../../auto/generate_test_runner'
|
|
||||||
require HERE + '../../auto/colour_reporter'
|
|
||||||
|
|
||||||
module RakefileHelpers
|
|
||||||
C_EXTENSION = '.c'.freeze
|
|
||||||
|
|
||||||
def load_configuration(config_file)
|
|
||||||
return if $configured
|
|
||||||
|
|
||||||
$cfg_file = HERE + "../../test/targets/#{config_file}" unless config_file =~ /[\\|\/]/
|
|
||||||
$cfg = YAML.load(File.read($cfg_file))
|
|
||||||
$colour_output = false unless $cfg['colour']
|
|
||||||
$configured = true if config_file != DEFAULT_CONFIG_FILE
|
|
||||||
end
|
|
||||||
|
|
||||||
def configure_clean
|
|
||||||
CLEAN.include($cfg['compiler']['build_path'] + '*.*') unless $cfg['compiler']['build_path'].nil?
|
|
||||||
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 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 build_compiler_fields
|
|
||||||
command = tackit($cfg['compiler']['path'])
|
|
||||||
defines = if $cfg['compiler']['defines']['items'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash($cfg['compiler']['defines']['prefix'], $cfg['compiler']['defines']['items'] + ['UNITY_OUTPUT_CHAR=UnityOutputCharSpy_OutputChar'] + ['UNITY_OUTPUT_CHAR_HEADER_DECLARATION=UnityOutputCharSpy_OutputChar\(int\)'])
|
|
||||||
end
|
|
||||||
options = squash('', $cfg['compiler']['options'])
|
|
||||||
includes = squash($cfg['compiler']['includes']['prefix'], $cfg['compiler']['includes']['items'])
|
|
||||||
includes = includes.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ command: command, defines: defines, options: options, includes: includes }
|
|
||||||
end
|
|
||||||
|
|
||||||
def compile(file, _defines = [])
|
|
||||||
compiler = build_compiler_fields
|
|
||||||
unity_include = $cfg['compiler']['includes']['prefix'] + '../../src'
|
|
||||||
cmd_str = "#{compiler[:command]}#{compiler[:defines]}#{compiler[:options]}#{compiler[:includes]} #{unity_include} #{file} " \
|
|
||||||
"#{$cfg['compiler']['object_files']['prefix']}#{$cfg['compiler']['object_files']['destination']}" \
|
|
||||||
"#{File.basename(file, C_EXTENSION)}#{$cfg['compiler']['object_files']['extension']}"
|
|
||||||
|
|
||||||
execute(cmd_str)
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_linker_fields
|
|
||||||
command = tackit($cfg['linker']['path'])
|
|
||||||
options = if $cfg['linker']['options'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['linker']['options'])
|
|
||||||
end
|
|
||||||
includes = if $cfg['linker']['includes'].nil? || $cfg['linker']['includes']['items'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash($cfg['linker']['includes']['prefix'], $cfg['linker']['includes']['items'])
|
|
||||||
end.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ command: command, options: options, includes: includes }
|
|
||||||
end
|
|
||||||
|
|
||||||
def link_it(exe_name, obj_list)
|
|
||||||
linker = build_linker_fields
|
|
||||||
cmd_str = "#{linker[:command]}#{linker[:options]}#{linker[:includes]} " +
|
|
||||||
(obj_list.map { |obj| "#{$cfg['linker']['object_files']['path']}#{obj} " }).join +
|
|
||||||
$cfg['linker']['bin_files']['prefix'] + ' ' +
|
|
||||||
$cfg['linker']['bin_files']['destination'] +
|
|
||||||
exe_name + $cfg['linker']['bin_files']['extension']
|
|
||||||
execute(cmd_str)
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_simulator_fields
|
|
||||||
return nil if $cfg['simulator'].nil?
|
|
||||||
command = if $cfg['simulator']['path'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
(tackit($cfg['simulator']['path']) + ' ')
|
|
||||||
end
|
|
||||||
pre_support = if $cfg['simulator']['pre_support'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['pre_support'])
|
|
||||||
end
|
|
||||||
post_support = if $cfg['simulator']['post_support'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['post_support'])
|
|
||||||
end
|
|
||||||
{ command: command, pre_support: pre_support, post_support: post_support }
|
|
||||||
end
|
|
||||||
|
|
||||||
def execute(command_string, verbose = true)
|
|
||||||
report command_string
|
|
||||||
output = `#{command_string}`.chomp
|
|
||||||
report(output) if verbose && !output.nil? && !output.empty?
|
|
||||||
raise "Command failed. (Returned #{$?.exitstatus})" if $?.exitstatus != 0
|
|
||||||
output
|
|
||||||
end
|
|
||||||
|
|
||||||
def report_summary
|
|
||||||
summary = UnityTestSummary.new
|
|
||||||
summary.root = HERE
|
|
||||||
results_glob = "#{$cfg['compiler']['build_path']}*.test*"
|
|
||||||
results_glob.tr!('\\', '/')
|
|
||||||
results = Dir[results_glob]
|
|
||||||
summary.targets = results
|
|
||||||
summary.run
|
|
||||||
end
|
|
||||||
|
|
||||||
def run_tests
|
|
||||||
report 'Running Unity system tests...'
|
|
||||||
|
|
||||||
# Tack on TEST define for compiling unit tests
|
|
||||||
load_configuration($cfg_file)
|
|
||||||
test_defines = ['TEST']
|
|
||||||
$cfg['compiler']['defines']['items'] = [] if $cfg['compiler']['defines']['items'].nil?
|
|
||||||
|
|
||||||
# Get a list of all source files needed
|
|
||||||
src_files = Dir[HERE + 'src/*.c']
|
|
||||||
src_files += Dir[HERE + 'test/*.c']
|
|
||||||
src_files += Dir[HERE + 'test/main/*.c']
|
|
||||||
src_files << '../../src/unity.c'
|
|
||||||
|
|
||||||
# Build object files
|
|
||||||
src_files.each { |f| compile(f, test_defines) }
|
|
||||||
obj_list = src_files.map { |f| File.basename(f.ext($cfg['compiler']['object_files']['extension'])) }
|
|
||||||
|
|
||||||
# Link the test executable
|
|
||||||
test_base = 'framework_test'
|
|
||||||
link_it(test_base, obj_list)
|
|
||||||
|
|
||||||
# Execute unit test and generate results file
|
|
||||||
simulator = build_simulator_fields
|
|
||||||
executable = $cfg['linker']['bin_files']['destination'] + test_base + $cfg['linker']['bin_files']['extension']
|
|
||||||
cmd_str = if simulator.nil?
|
|
||||||
executable + ' -v -r'
|
|
||||||
else
|
|
||||||
"#{simulator[:command]} #{simulator[:pre_support]} #{executable} #{simulator[:post_support]}"
|
|
||||||
end
|
|
||||||
output = execute(cmd_str)
|
|
||||||
test_results = $cfg['compiler']['build_path'] + test_base
|
|
||||||
test_results += if output.match(/OK$/m).nil?
|
|
||||||
'.testfail'
|
|
||||||
else
|
|
||||||
'.testpass'
|
|
||||||
end
|
|
||||||
File.open(test_results, 'w') { |f| f.print output }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
29
extras/fixture/readme.md
Normal file
29
extras/fixture/readme.md
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
# Unity Fixtures
|
||||||
|
|
||||||
|
This Framework is an optional add-on to Unity. By including unity_framework.h in place of unity.h,
|
||||||
|
you may now work with Unity in a manner similar to CppUTest. This framework adds the concepts of
|
||||||
|
test groups and gives finer control of your tests over the command line.
|
||||||
|
|
||||||
|
This framework is primarily supplied for those working through James Grenning's book on Embedded
|
||||||
|
Test Driven Development, or those coming to Unity from CppUTest. We should note that using this
|
||||||
|
framework glosses over some of the features of Unity, and makes it more difficult
|
||||||
|
to integrate with other testing tools like Ceedling and CMock.
|
||||||
|
|
||||||
|
# Dependency Notification
|
||||||
|
|
||||||
|
Fixtures, by default, uses the Memory addon as well. This is to make it simple for those trying to
|
||||||
|
follow along with James' book. Using them together is completely optional. You may choose to use
|
||||||
|
Fixtures without Memory handling by defining `UNITY_FIXTURE_NO_EXTRAS`. It will then stop automatically
|
||||||
|
pulling in extras and leave you to do it as desired.
|
||||||
|
|
||||||
|
# Usage information
|
||||||
|
|
||||||
|
By default the test executables produced by Unity Fixtures run all tests once, but the behavior can
|
||||||
|
be configured with command-line flags. Run the test executable with the `--help` flag for more
|
||||||
|
information.
|
||||||
|
|
||||||
|
It's possible to add a custom line at the end of the help message, typically to point to
|
||||||
|
project-specific or company-specific unit test documentation. Define `UNITY_CUSTOM_HELP_MSG` to
|
||||||
|
provide a custom message, e.g.:
|
||||||
|
|
||||||
|
#define UNITY_CUSTOM_HELP_MSG "If any test fails see https://example.com/troubleshooting"
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
Copyright (c) 2010 James Grenning and Contributed to Unity Project
|
|
||||||
|
|
||||||
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]
|
|
||||||
|
|
||||||
This Framework is an optional add-on to Unity. By including unity_framework.h in place of unity.h,
|
|
||||||
you may now work with Unity in a manner similar to CppUTest. This framework adds the concepts of
|
|
||||||
test groups and gives finer control of your tests over the command line.
|
|
||||||
@@ -15,10 +15,8 @@ struct UNITY_FIXTURE_T UnityFixture;
|
|||||||
* Build with -D UNITY_OUTPUT_CHAR=outputChar and include <stdio.h>
|
* Build with -D UNITY_OUTPUT_CHAR=outputChar and include <stdio.h>
|
||||||
* int (*outputChar)(int) = putchar; */
|
* int (*outputChar)(int) = putchar; */
|
||||||
|
|
||||||
#if !defined(UNITY_WEAK_ATTRIBUTE) && !defined(UNITY_WEAK_PRAGMA)
|
|
||||||
void setUp(void) { /*does nothing*/ }
|
void setUp(void) { /*does nothing*/ }
|
||||||
void tearDown(void) { /*does nothing*/ }
|
void tearDown(void) { /*does nothing*/ }
|
||||||
#endif
|
|
||||||
|
|
||||||
static void announceTestRun(unsigned int runNumber)
|
static void announceTestRun(unsigned int runNumber)
|
||||||
{
|
{
|
||||||
@@ -79,20 +77,27 @@ void UnityTestRunner(unityfunction* setup,
|
|||||||
Unity.TestFile = file;
|
Unity.TestFile = file;
|
||||||
Unity.CurrentTestName = printableName;
|
Unity.CurrentTestName = printableName;
|
||||||
Unity.CurrentTestLineNumber = line;
|
Unity.CurrentTestLineNumber = line;
|
||||||
if (!UnityFixture.Verbose)
|
if (UnityFixture.Verbose)
|
||||||
UNITY_OUTPUT_CHAR('.');
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
UnityPrint(printableName);
|
UnityPrint(printableName);
|
||||||
#ifndef UNITY_REPEAT_TEST_NAME
|
#ifndef UNITY_REPEAT_TEST_NAME
|
||||||
Unity.CurrentTestName = NULL;
|
Unity.CurrentTestName = NULL;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
else if (UnityFixture.Silent)
|
||||||
|
{
|
||||||
|
/* Do Nothing */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
UNITY_OUTPUT_CHAR('.');
|
||||||
|
}
|
||||||
|
|
||||||
Unity.NumberOfTests++;
|
Unity.NumberOfTests++;
|
||||||
UnityMalloc_StartTest();
|
|
||||||
UnityPointer_Init();
|
UnityPointer_Init();
|
||||||
|
|
||||||
|
UNITY_EXEC_TIME_START();
|
||||||
|
|
||||||
if (TEST_PROTECT())
|
if (TEST_PROTECT())
|
||||||
{
|
{
|
||||||
setup();
|
setup();
|
||||||
@@ -105,8 +110,6 @@ void UnityTestRunner(unityfunction* setup,
|
|||||||
if (TEST_PROTECT())
|
if (TEST_PROTECT())
|
||||||
{
|
{
|
||||||
UnityPointer_UndoAllSets();
|
UnityPointer_UndoAllSets();
|
||||||
if (!Unity.CurrentTestFailed)
|
|
||||||
UnityMalloc_EndTest();
|
|
||||||
}
|
}
|
||||||
UnityConcludeFixtureTest();
|
UnityConcludeFixtureTest();
|
||||||
}
|
}
|
||||||
@@ -118,191 +121,22 @@ void UnityIgnoreTest(const char* printableName, const char* group, const char* n
|
|||||||
{
|
{
|
||||||
Unity.NumberOfTests++;
|
Unity.NumberOfTests++;
|
||||||
Unity.TestIgnores++;
|
Unity.TestIgnores++;
|
||||||
if (!UnityFixture.Verbose)
|
if (UnityFixture.Verbose)
|
||||||
UNITY_OUTPUT_CHAR('!');
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
UnityPrint(printableName);
|
UnityPrint(printableName);
|
||||||
UNITY_PRINT_EOL();
|
UNITY_PRINT_EOL();
|
||||||
}
|
}
|
||||||
|
else if (UnityFixture.Silent)
|
||||||
|
{
|
||||||
|
/* Do Nothing */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
UNITY_OUTPUT_CHAR('!');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*------------------------------------------------- */
|
|
||||||
/* Malloc and free stuff */
|
|
||||||
#define MALLOC_DONT_FAIL -1
|
|
||||||
static int malloc_count;
|
|
||||||
static int malloc_fail_countdown = MALLOC_DONT_FAIL;
|
|
||||||
|
|
||||||
void UnityMalloc_StartTest(void)
|
|
||||||
{
|
|
||||||
malloc_count = 0;
|
|
||||||
malloc_fail_countdown = MALLOC_DONT_FAIL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void UnityMalloc_EndTest(void)
|
|
||||||
{
|
|
||||||
malloc_fail_countdown = MALLOC_DONT_FAIL;
|
|
||||||
if (malloc_count != 0)
|
|
||||||
{
|
|
||||||
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "This test leaks!");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void UnityMalloc_MakeMallocFailAfterCount(int countdown)
|
|
||||||
{
|
|
||||||
malloc_fail_countdown = countdown;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* These definitions are always included from unity_fixture_malloc_overrides.h */
|
|
||||||
/* We undef to use them or avoid conflict with <stdlib.h> per the C standard */
|
|
||||||
#undef malloc
|
|
||||||
#undef free
|
|
||||||
#undef calloc
|
|
||||||
#undef realloc
|
|
||||||
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
static unsigned char unity_heap[UNITY_INTERNAL_HEAP_SIZE_BYTES];
|
|
||||||
static size_t heap_index;
|
|
||||||
#else
|
|
||||||
#include <stdlib.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct GuardBytes
|
|
||||||
{
|
|
||||||
size_t size;
|
|
||||||
size_t guard_space;
|
|
||||||
} Guard;
|
|
||||||
|
|
||||||
|
|
||||||
static const char end[] = "END";
|
|
||||||
|
|
||||||
void* unity_malloc(size_t size)
|
|
||||||
{
|
|
||||||
char* mem;
|
|
||||||
Guard* guard;
|
|
||||||
size_t total_size = size + sizeof(Guard) + sizeof(end);
|
|
||||||
|
|
||||||
if (malloc_fail_countdown != MALLOC_DONT_FAIL)
|
|
||||||
{
|
|
||||||
if (malloc_fail_countdown == 0)
|
|
||||||
return NULL;
|
|
||||||
malloc_fail_countdown--;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (size == 0) return NULL;
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
if (heap_index + total_size > UNITY_INTERNAL_HEAP_SIZE_BYTES)
|
|
||||||
{
|
|
||||||
guard = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
guard = (Guard*)&unity_heap[heap_index];
|
|
||||||
heap_index += total_size;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
guard = (Guard*)UNITY_FIXTURE_MALLOC(total_size);
|
|
||||||
#endif
|
|
||||||
if (guard == NULL) return NULL;
|
|
||||||
malloc_count++;
|
|
||||||
guard->size = size;
|
|
||||||
guard->guard_space = 0;
|
|
||||||
mem = (char*)&(guard[1]);
|
|
||||||
memcpy(&mem[size], end, sizeof(end));
|
|
||||||
|
|
||||||
return (void*)mem;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int isOverrun(void* mem)
|
|
||||||
{
|
|
||||||
Guard* guard = (Guard*)mem;
|
|
||||||
char* memAsChar = (char*)mem;
|
|
||||||
guard--;
|
|
||||||
|
|
||||||
return guard->guard_space != 0 || strcmp(&memAsChar[guard->size], end) != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void release_memory(void* mem)
|
|
||||||
{
|
|
||||||
Guard* guard = (Guard*)mem;
|
|
||||||
guard--;
|
|
||||||
|
|
||||||
malloc_count--;
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
if (mem == unity_heap + heap_index - guard->size - sizeof(end))
|
|
||||||
{
|
|
||||||
heap_index -= (guard->size + sizeof(Guard) + sizeof(end));
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
UNITY_FIXTURE_FREE(guard);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void unity_free(void* mem)
|
|
||||||
{
|
|
||||||
int overrun;
|
|
||||||
|
|
||||||
if (mem == NULL)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
overrun = isOverrun(mem);
|
|
||||||
release_memory(mem);
|
|
||||||
if (overrun)
|
|
||||||
{
|
|
||||||
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "Buffer overrun detected during free()");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void* unity_calloc(size_t num, size_t size)
|
|
||||||
{
|
|
||||||
void* mem = unity_malloc(num * size);
|
|
||||||
if (mem == NULL) return NULL;
|
|
||||||
memset(mem, 0, num * size);
|
|
||||||
return mem;
|
|
||||||
}
|
|
||||||
|
|
||||||
void* unity_realloc(void* oldMem, size_t size)
|
|
||||||
{
|
|
||||||
Guard* guard = (Guard*)oldMem;
|
|
||||||
void* newMem;
|
|
||||||
|
|
||||||
if (oldMem == NULL) return unity_malloc(size);
|
|
||||||
|
|
||||||
guard--;
|
|
||||||
if (isOverrun(oldMem))
|
|
||||||
{
|
|
||||||
release_memory(oldMem);
|
|
||||||
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "Buffer overrun detected during realloc()");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (size == 0)
|
|
||||||
{
|
|
||||||
release_memory(oldMem);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (guard->size >= size) return oldMem;
|
|
||||||
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC /* Optimization if memory is expandable */
|
|
||||||
if (oldMem == unity_heap + heap_index - guard->size - sizeof(end) &&
|
|
||||||
heap_index + size - guard->size <= UNITY_INTERNAL_HEAP_SIZE_BYTES)
|
|
||||||
{
|
|
||||||
release_memory(oldMem); /* Not thread-safe, like unity_heap generally */
|
|
||||||
return unity_malloc(size); /* No memcpy since data is in place */
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
newMem = unity_malloc(size);
|
|
||||||
if (newMem == NULL) return NULL; /* Do not release old memory */
|
|
||||||
memcpy(newMem, oldMem, guard->size);
|
|
||||||
release_memory(oldMem);
|
|
||||||
return newMem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*-------------------------------------------------------- */
|
/*-------------------------------------------------------- */
|
||||||
/*Automatic pointer restoration functions */
|
/*Automatic pointer restoration functions */
|
||||||
struct PointerPair
|
struct PointerPair
|
||||||
@@ -348,6 +182,7 @@ int UnityGetCommandLineOptions(int argc, const char* argv[])
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
UnityFixture.Verbose = 0;
|
UnityFixture.Verbose = 0;
|
||||||
|
UnityFixture.Silent = 0;
|
||||||
UnityFixture.GroupFilter = 0;
|
UnityFixture.GroupFilter = 0;
|
||||||
UnityFixture.NameFilter = 0;
|
UnityFixture.NameFilter = 0;
|
||||||
UnityFixture.RepeatCount = 1;
|
UnityFixture.RepeatCount = 1;
|
||||||
@@ -357,11 +192,51 @@ int UnityGetCommandLineOptions(int argc, const char* argv[])
|
|||||||
|
|
||||||
for (i = 1; i < argc; )
|
for (i = 1; i < argc; )
|
||||||
{
|
{
|
||||||
if (strcmp(argv[i], "-v") == 0)
|
if (strcmp(argv[i], "-h") == 0 || strcmp(argv[i], "--help") == 0)
|
||||||
|
{
|
||||||
|
/* Usage */
|
||||||
|
UnityPrint("Runs a series of unit tests.");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint("When no flag is specified, all tests are run.");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint("Optional flags:");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -v Verbose output: show all tests executed even if they pass");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -s Silent mode: minimal output showing only test failures");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -g NAME Only run tests in groups that contain the string NAME");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -n NAME Only run tests whose name contains the string NAME");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -r NUMBER Repeatedly run all tests NUMBER times");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UnityPrint(" -h, --help Display this help message");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
#ifdef UNITY_CUSTOM_HELP_MSG
|
||||||
|
/* User-defined help message, e.g. to point to project-specific documentation */
|
||||||
|
UnityPrint(UNITY_CUSTOM_HELP_MSG);
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
#else
|
||||||
|
/* Default help suffix if a custom one is not defined */
|
||||||
|
UnityPrint("More information about Unity: https://www.throwtheswitch.org/unity");
|
||||||
|
UNITY_PRINT_EOL();
|
||||||
|
#endif
|
||||||
|
return 1; /* Exit without running the tests */
|
||||||
|
}
|
||||||
|
else if (strcmp(argv[i], "-v") == 0)
|
||||||
{
|
{
|
||||||
UnityFixture.Verbose = 1;
|
UnityFixture.Verbose = 1;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
else if (strcmp(argv[i], "-s") == 0)
|
||||||
|
{
|
||||||
|
UnityFixture.Silent = 1;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
else if (strcmp(argv[i], "-g") == 0)
|
else if (strcmp(argv[i], "-g") == 0)
|
||||||
{
|
{
|
||||||
i++;
|
i++;
|
||||||
@@ -417,7 +292,10 @@ void UnityConcludeFixtureTest(void)
|
|||||||
{
|
{
|
||||||
if (UnityFixture.Verbose)
|
if (UnityFixture.Verbose)
|
||||||
{
|
{
|
||||||
UnityPrint(" PASS");
|
UnityPrint(" ");
|
||||||
|
UnityPrint(UnityStrPass);
|
||||||
|
UNITY_EXEC_TIME_STOP();
|
||||||
|
UNITY_PRINT_EXEC_TIME();
|
||||||
UNITY_PRINT_EOL();
|
UNITY_PRINT_EOL();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,9 +10,12 @@
|
|||||||
|
|
||||||
#include "unity.h"
|
#include "unity.h"
|
||||||
#include "unity_internals.h"
|
#include "unity_internals.h"
|
||||||
#include "unity_fixture_malloc_overrides.h"
|
|
||||||
#include "unity_fixture_internals.h"
|
#include "unity_fixture_internals.h"
|
||||||
|
|
||||||
|
#ifndef UNITY_FIXTURE_NO_EXTRAS
|
||||||
|
#include "unity_memory.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
int UnityMain(int argc, const char* argv[], void (*runAllTests)(void));
|
int UnityMain(int argc, const char* argv[], void (*runAllTests)(void));
|
||||||
|
|
||||||
|
|
||||||
@@ -77,7 +80,4 @@ int UnityMain(int argc, const char* argv[], void (*runAllTests)(void));
|
|||||||
#define DOUBLES_EQUAL(expected, actual, delta) TEST_ASSERT_DOUBLE_WITHIN((delta), (expected), (actual))
|
#define DOUBLES_EQUAL(expected, actual, delta) TEST_ASSERT_DOUBLE_WITHIN((delta), (expected), (actual))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* You must compile with malloc replacement, as defined in unity_fixture_malloc_overrides.h */
|
|
||||||
void UnityMalloc_MakeMallocFailAfterCount(int count);
|
|
||||||
|
|
||||||
#endif /* UNITY_FIXTURE_H_ */
|
#endif /* UNITY_FIXTURE_H_ */
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ extern "C"
|
|||||||
struct UNITY_FIXTURE_T
|
struct UNITY_FIXTURE_T
|
||||||
{
|
{
|
||||||
int Verbose;
|
int Verbose;
|
||||||
|
int Silent;
|
||||||
unsigned int RepeatCount;
|
unsigned int RepeatCount;
|
||||||
const char* NameFilter;
|
const char* NameFilter;
|
||||||
const char* GroupFilter;
|
const char* GroupFilter;
|
||||||
@@ -24,7 +25,7 @@ extern struct UNITY_FIXTURE_T UnityFixture;
|
|||||||
|
|
||||||
typedef void unityfunction(void);
|
typedef void unityfunction(void);
|
||||||
void UnityTestRunner(unityfunction* setup,
|
void UnityTestRunner(unityfunction* setup,
|
||||||
unityfunction* body,
|
unityfunction* testBody,
|
||||||
unityfunction* teardown,
|
unityfunction* teardown,
|
||||||
const char* printableName,
|
const char* printableName,
|
||||||
const char* group,
|
const char* group,
|
||||||
@@ -32,12 +33,10 @@ void UnityTestRunner(unityfunction* setup,
|
|||||||
const char* file, unsigned int line);
|
const char* file, unsigned int line);
|
||||||
|
|
||||||
void UnityIgnoreTest(const char* printableName, const char* group, const char* name);
|
void UnityIgnoreTest(const char* printableName, const char* group, const char* name);
|
||||||
void UnityMalloc_StartTest(void);
|
|
||||||
void UnityMalloc_EndTest(void);
|
|
||||||
int UnityGetCommandLineOptions(int argc, const char* argv[]);
|
int UnityGetCommandLineOptions(int argc, const char* argv[]);
|
||||||
void UnityConcludeFixtureTest(void);
|
void UnityConcludeFixtureTest(void);
|
||||||
|
|
||||||
void UnityPointer_Set(void** ptr, void* newValue, UNITY_LINE_TYPE line);
|
void UnityPointer_Set(void** pointer, void* newValue, UNITY_LINE_TYPE line);
|
||||||
void UnityPointer_UndoAllSets(void);
|
void UnityPointer_UndoAllSets(void);
|
||||||
void UnityPointer_Init(void);
|
void UnityPointer_Init(void);
|
||||||
#ifndef UNITY_MAX_POINTERS
|
#ifndef UNITY_MAX_POINTERS
|
||||||
|
|||||||
@@ -3,15 +3,12 @@ ifeq ($(shell uname -s), Darwin)
|
|||||||
CC = clang
|
CC = clang
|
||||||
endif
|
endif
|
||||||
#DEBUG = -O0 -g
|
#DEBUG = -O0 -g
|
||||||
CFLAGS += -std=c99 -pedantic -Wall -Wextra -Werror
|
CFLAGS += -std=c99 -pedantic -Wall -Wextra -Werror -DUNITY_FIXTURE_NO_EXTRAS
|
||||||
CFLAGS += $(DEBUG)
|
CFLAGS += $(DEBUG)
|
||||||
DEFINES = -D UNITY_OUTPUT_CHAR=UnityOutputCharSpy_OutputChar
|
|
||||||
DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=UnityOutputCharSpy_OutputChar\(int\)
|
|
||||||
SRC = ../src/unity_fixture.c \
|
SRC = ../src/unity_fixture.c \
|
||||||
../../../src/unity.c \
|
../../../src/unity.c \
|
||||||
unity_fixture_Test.c \
|
unity_fixture_Test.c \
|
||||||
unity_fixture_TestRunner.c \
|
unity_fixture_TestRunner.c \
|
||||||
unity_output_Spy.c \
|
|
||||||
main/AllTests.c
|
main/AllTests.c
|
||||||
|
|
||||||
INC_DIR = -I../src -I../../../src/
|
INC_DIR = -I../src -I../../../src/
|
||||||
|
|||||||
@@ -11,8 +11,6 @@ static void runAllTests(void)
|
|||||||
{
|
{
|
||||||
RUN_TEST_GROUP(UnityFixture);
|
RUN_TEST_GROUP(UnityFixture);
|
||||||
RUN_TEST_GROUP(UnityCommandOptions);
|
RUN_TEST_GROUP(UnityCommandOptions);
|
||||||
RUN_TEST_GROUP(LeakDetection);
|
|
||||||
RUN_TEST_GROUP(InternalMalloc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, const char* argv[])
|
int main(int argc, const char* argv[])
|
||||||
|
|||||||
@@ -6,7 +6,6 @@
|
|||||||
* ========================================== */
|
* ========================================== */
|
||||||
|
|
||||||
#include "unity_fixture.h"
|
#include "unity_fixture.h"
|
||||||
#include "unity_output_Spy.h"
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
@@ -44,71 +43,6 @@ TEST(UnityFixture, PointerSetting)
|
|||||||
TEST_ASSERT_POINTERS_EQUAL(pointer3, (int*)3);
|
TEST_ASSERT_POINTERS_EQUAL(pointer3, (int*)3);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(UnityFixture, ForceMallocFail)
|
|
||||||
{
|
|
||||||
void* m;
|
|
||||||
void* mfails;
|
|
||||||
UnityMalloc_MakeMallocFailAfterCount(1);
|
|
||||||
m = malloc(10);
|
|
||||||
CHECK(m);
|
|
||||||
mfails = malloc(10);
|
|
||||||
TEST_ASSERT_POINTERS_EQUAL(0, mfails);
|
|
||||||
free(m);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, ReallocSmallerIsUnchanged)
|
|
||||||
{
|
|
||||||
void* m1 = malloc(10);
|
|
||||||
void* m2 = realloc(m1, 5);
|
|
||||||
TEST_ASSERT_POINTERS_EQUAL(m1, m2);
|
|
||||||
free(m2);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, ReallocSameIsUnchanged)
|
|
||||||
{
|
|
||||||
void* m1 = malloc(10);
|
|
||||||
void* m2 = realloc(m1, 10);
|
|
||||||
TEST_ASSERT_POINTERS_EQUAL(m1, m2);
|
|
||||||
free(m2);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, ReallocLargerNeeded)
|
|
||||||
{
|
|
||||||
void* m1 = malloc(10);
|
|
||||||
void* m2;
|
|
||||||
CHECK(m1);
|
|
||||||
strcpy((char*)m1, "123456789");
|
|
||||||
m2 = realloc(m1, 15);
|
|
||||||
/* CHECK(m1 != m2); //Depends on implementation */
|
|
||||||
STRCMP_EQUAL("123456789", m2);
|
|
||||||
free(m2);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, ReallocNullPointerIsLikeMalloc)
|
|
||||||
{
|
|
||||||
void* m = realloc(0, 15);
|
|
||||||
CHECK(m != 0);
|
|
||||||
free(m);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, ReallocSizeZeroFreesMemAndReturnsNullPointer)
|
|
||||||
{
|
|
||||||
void* m1 = malloc(10);
|
|
||||||
void* m2 = realloc(m1, 0);
|
|
||||||
TEST_ASSERT_POINTERS_EQUAL(0, m2);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(UnityFixture, CallocFillsWithZero)
|
|
||||||
{
|
|
||||||
void* m = calloc(3, sizeof(char));
|
|
||||||
char* s = (char*)m;
|
|
||||||
CHECK(m);
|
|
||||||
TEST_ASSERT_BYTES_EQUAL(0, s[0]);
|
|
||||||
TEST_ASSERT_BYTES_EQUAL(0, s[1]);
|
|
||||||
TEST_ASSERT_BYTES_EQUAL(0, s[2]);
|
|
||||||
free(m);
|
|
||||||
}
|
|
||||||
|
|
||||||
static char *p1;
|
static char *p1;
|
||||||
static char *p2;
|
static char *p2;
|
||||||
|
|
||||||
@@ -140,12 +74,10 @@ TEST(UnityFixture, ConcludeTestIncrementsFailCount)
|
|||||||
{
|
{
|
||||||
UNITY_UINT savedFails = Unity.TestFailures;
|
UNITY_UINT savedFails = Unity.TestFailures;
|
||||||
UNITY_UINT savedIgnores = Unity.TestIgnores;
|
UNITY_UINT savedIgnores = Unity.TestIgnores;
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
Unity.CurrentTestFailed = 1;
|
Unity.CurrentTestFailed = 1;
|
||||||
UnityConcludeFixtureTest(); /* Resets TestFailed for this test to pass */
|
UnityConcludeFixtureTest(); /* Resets TestFailed for this test to pass */
|
||||||
Unity.CurrentTestIgnored = 1;
|
Unity.CurrentTestIgnored = 1;
|
||||||
UnityConcludeFixtureTest(); /* Resets TestIgnored */
|
UnityConcludeFixtureTest(); /* Resets TestIgnored */
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
TEST_ASSERT_EQUAL(savedFails + 1, Unity.TestFailures);
|
TEST_ASSERT_EQUAL(savedFails + 1, Unity.TestFailures);
|
||||||
TEST_ASSERT_EQUAL(savedIgnores + 1, Unity.TestIgnores);
|
TEST_ASSERT_EQUAL(savedIgnores + 1, Unity.TestIgnores);
|
||||||
Unity.TestFailures = savedFails;
|
Unity.TestFailures = savedFails;
|
||||||
@@ -311,233 +243,3 @@ IGNORE_TEST(UnityCommandOptions, TestShouldBeIgnored)
|
|||||||
{
|
{
|
||||||
TEST_FAIL_MESSAGE("This test should not run!");
|
TEST_FAIL_MESSAGE("This test should not run!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*------------------------------------------------------------ */
|
|
||||||
|
|
||||||
TEST_GROUP(LeakDetection);
|
|
||||||
|
|
||||||
TEST_SETUP(LeakDetection)
|
|
||||||
{
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
UnityOutputCharSpy_Create(200);
|
|
||||||
#else
|
|
||||||
UnityOutputCharSpy_Create(1000);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_TEAR_DOWN(LeakDetection)
|
|
||||||
{
|
|
||||||
UnityOutputCharSpy_Destroy();
|
|
||||||
}
|
|
||||||
|
|
||||||
#define EXPECT_ABORT_BEGIN \
|
|
||||||
{ \
|
|
||||||
jmp_buf TestAbortFrame; \
|
|
||||||
memcpy(TestAbortFrame, Unity.AbortFrame, sizeof(jmp_buf)); \
|
|
||||||
if (TEST_PROTECT()) \
|
|
||||||
{
|
|
||||||
|
|
||||||
#define EXPECT_ABORT_END \
|
|
||||||
} \
|
|
||||||
memcpy(Unity.AbortFrame, TestAbortFrame, sizeof(jmp_buf)); \
|
|
||||||
}
|
|
||||||
|
|
||||||
/* This tricky set of defines lets us see if we are using the Spy, returns 1 if true */
|
|
||||||
#ifdef __STDC_VERSION__
|
|
||||||
|
|
||||||
#if __STDC_VERSION__ >= 199901L
|
|
||||||
#define USING_SPY_AS(a) EXPAND_AND_USE_2ND(ASSIGN_VALUE(a), 0)
|
|
||||||
#define ASSIGN_VALUE(a) VAL_##a
|
|
||||||
#define VAL_UnityOutputCharSpy_OutputChar 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 /* UNITY_OUTPUT_CHAR = UnityOutputCharSpy_OutputChar */
|
|
||||||
#endif
|
|
||||||
#endif /* >= 199901 */
|
|
||||||
|
|
||||||
#else /* __STDC_VERSION__ else */
|
|
||||||
#define UnityOutputCharSpy_OutputChar 42
|
|
||||||
#if UNITY_OUTPUT_CHAR == UnityOutputCharSpy_OutputChar /* Works if no -Wundef -Werror */
|
|
||||||
#define USING_OUTPUT_SPY
|
|
||||||
#endif
|
|
||||||
#undef UnityOutputCharSpy_OutputChar
|
|
||||||
#endif /* __STDC_VERSION__ */
|
|
||||||
|
|
||||||
TEST(LeakDetection, DetectsLeak)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE_MESSAGE("Build with '-D UNITY_OUTPUT_CHAR=UnityOutputCharSpy_OutputChar' to enable tests");
|
|
||||||
#else
|
|
||||||
void* m = malloc(10);
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
UnityMalloc_EndTest();
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "This test leaks!"));
|
|
||||||
free(m);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(LeakDetection, BufferOverrunFoundDuringFree)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE();
|
|
||||||
#else
|
|
||||||
void* m = malloc(10);
|
|
||||||
char* s = (char*)m;
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
s[10] = (char)0xFF;
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
free(m);
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during free()"));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(LeakDetection, BufferOverrunFoundDuringRealloc)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE();
|
|
||||||
#else
|
|
||||||
void* m = malloc(10);
|
|
||||||
char* s = (char*)m;
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
s[10] = (char)0xFF;
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
m = realloc(m, 100);
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during realloc()"));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(LeakDetection, BufferGuardWriteFoundDuringFree)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE();
|
|
||||||
#else
|
|
||||||
void* m = malloc(10);
|
|
||||||
char* s = (char*)m;
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
s[-1] = (char)0x00; /* Will not detect 0 */
|
|
||||||
s[-2] = (char)0x01;
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
free(m);
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during free()"));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(LeakDetection, BufferGuardWriteFoundDuringRealloc)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE();
|
|
||||||
#else
|
|
||||||
void* m = malloc(10);
|
|
||||||
char* s = (char*)m;
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
s[-1] = (char)0x0A;
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
m = realloc(m, 100);
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during realloc()"));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(LeakDetection, PointerSettingMax)
|
|
||||||
{
|
|
||||||
#ifndef USING_OUTPUT_SPY
|
|
||||||
TEST_IGNORE();
|
|
||||||
#else
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < UNITY_MAX_POINTERS; i++) UT_PTR_SET(pointer1, &int1);
|
|
||||||
UnityOutputCharSpy_Enable(1);
|
|
||||||
EXPECT_ABORT_BEGIN
|
|
||||||
UT_PTR_SET(pointer1, &int1);
|
|
||||||
EXPECT_ABORT_END
|
|
||||||
UnityOutputCharSpy_Enable(0);
|
|
||||||
Unity.CurrentTestFailed = 0;
|
|
||||||
CHECK(strstr(UnityOutputCharSpy_Get(), "Too many pointers set"));
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/*------------------------------------------------------------ */
|
|
||||||
|
|
||||||
TEST_GROUP(InternalMalloc);
|
|
||||||
#define TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(first_mem_ptr, ptr) \
|
|
||||||
ptr = malloc(10); free(ptr); \
|
|
||||||
TEST_ASSERT_EQUAL_PTR_MESSAGE(first_mem_ptr, ptr, "Memory was stranded, free in LIFO order");
|
|
||||||
|
|
||||||
|
|
||||||
TEST_SETUP(InternalMalloc) { }
|
|
||||||
TEST_TEAR_DOWN(InternalMalloc) { }
|
|
||||||
|
|
||||||
TEST(InternalMalloc, MallocPastBufferFails)
|
|
||||||
{
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
|
||||||
void* n = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
|
||||||
free(m);
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
TEST_ASSERT_NULL(n);
|
|
||||||
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(InternalMalloc, CallocPastBufferFails)
|
|
||||||
{
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
void* m = calloc(1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
|
||||||
void* n = calloc(1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
|
||||||
free(m);
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
TEST_ASSERT_NULL(n);
|
|
||||||
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(InternalMalloc, MallocThenReallocGrowsMemoryInPlace)
|
|
||||||
{
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
|
||||||
void* n = realloc(m, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 9);
|
|
||||||
free(n);
|
|
||||||
TEST_ASSERT_NOT_NULL(m);
|
|
||||||
TEST_ASSERT_EQUAL(m, n);
|
|
||||||
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(InternalMalloc, ReallocFailDoesNotFreeMem)
|
|
||||||
{
|
|
||||||
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
|
||||||
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
|
||||||
void* n1 = malloc(10);
|
|
||||||
void* out_of_mem = realloc(n1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
|
||||||
void* n2 = malloc(10);
|
|
||||||
|
|
||||||
free(n2);
|
|
||||||
if (out_of_mem == NULL) free(n1);
|
|
||||||
free(m);
|
|
||||||
|
|
||||||
TEST_ASSERT_NOT_NULL(m); /* Got a real memory location */
|
|
||||||
TEST_ASSERT_NULL(out_of_mem); /* The realloc should have failed */
|
|
||||||
TEST_ASSERT_NOT_EQUAL(n2, n1); /* If n1 != n2 then realloc did not free n1 */
|
|
||||||
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n2);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -10,13 +10,6 @@
|
|||||||
TEST_GROUP_RUNNER(UnityFixture)
|
TEST_GROUP_RUNNER(UnityFixture)
|
||||||
{
|
{
|
||||||
RUN_TEST_CASE(UnityFixture, PointerSetting);
|
RUN_TEST_CASE(UnityFixture, PointerSetting);
|
||||||
RUN_TEST_CASE(UnityFixture, ForceMallocFail);
|
|
||||||
RUN_TEST_CASE(UnityFixture, ReallocSmallerIsUnchanged);
|
|
||||||
RUN_TEST_CASE(UnityFixture, ReallocSameIsUnchanged);
|
|
||||||
RUN_TEST_CASE(UnityFixture, ReallocLargerNeeded);
|
|
||||||
RUN_TEST_CASE(UnityFixture, ReallocNullPointerIsLikeMalloc);
|
|
||||||
RUN_TEST_CASE(UnityFixture, ReallocSizeZeroFreesMemAndReturnsNullPointer);
|
|
||||||
RUN_TEST_CASE(UnityFixture, CallocFillsWithZero);
|
|
||||||
RUN_TEST_CASE(UnityFixture, PointerSet);
|
RUN_TEST_CASE(UnityFixture, PointerSet);
|
||||||
RUN_TEST_CASE(UnityFixture, FreeNULLSafety);
|
RUN_TEST_CASE(UnityFixture, FreeNULLSafety);
|
||||||
RUN_TEST_CASE(UnityFixture, ConcludeTestIncrementsFailCount);
|
RUN_TEST_CASE(UnityFixture, ConcludeTestIncrementsFailCount);
|
||||||
@@ -37,21 +30,3 @@ TEST_GROUP_RUNNER(UnityCommandOptions)
|
|||||||
RUN_TEST_CASE(UnityCommandOptions, GroupFilterReallyFilters);
|
RUN_TEST_CASE(UnityCommandOptions, GroupFilterReallyFilters);
|
||||||
RUN_TEST_CASE(UnityCommandOptions, TestShouldBeIgnored);
|
RUN_TEST_CASE(UnityCommandOptions, TestShouldBeIgnored);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_GROUP_RUNNER(LeakDetection)
|
|
||||||
{
|
|
||||||
RUN_TEST_CASE(LeakDetection, DetectsLeak);
|
|
||||||
RUN_TEST_CASE(LeakDetection, BufferOverrunFoundDuringFree);
|
|
||||||
RUN_TEST_CASE(LeakDetection, BufferOverrunFoundDuringRealloc);
|
|
||||||
RUN_TEST_CASE(LeakDetection, BufferGuardWriteFoundDuringFree);
|
|
||||||
RUN_TEST_CASE(LeakDetection, BufferGuardWriteFoundDuringRealloc);
|
|
||||||
RUN_TEST_CASE(LeakDetection, PointerSettingMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_GROUP_RUNNER(InternalMalloc)
|
|
||||||
{
|
|
||||||
RUN_TEST_CASE(InternalMalloc, MallocPastBufferFails);
|
|
||||||
RUN_TEST_CASE(InternalMalloc, CallocPastBufferFails);
|
|
||||||
RUN_TEST_CASE(InternalMalloc, MallocThenReallocGrowsMemoryInPlace);
|
|
||||||
RUN_TEST_CASE(InternalMalloc, ReallocFailDoesNotFreeMem);
|
|
||||||
}
|
|
||||||
|
|||||||
49
extras/memory/readme.md
Normal file
49
extras/memory/readme.md
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
# Unity Memory
|
||||||
|
|
||||||
|
This Framework is an optional add-on to Unity. By including unity.h and then
|
||||||
|
unity_memory.h, you have the added ability to track malloc and free calls. This
|
||||||
|
addon requires that the stdlib functions be overridden by its own defines. These
|
||||||
|
defines will still malloc / realloc / free etc, but will also track the calls
|
||||||
|
in order to ensure that you don't have any memory leaks in your programs.
|
||||||
|
|
||||||
|
Note that this is only useful in situations where a unit is in charge of both
|
||||||
|
the allocation and deallocation of memory. When it is not symmetric, unit testing
|
||||||
|
can report a number of false failures. A more advanced runtime tool is required to
|
||||||
|
track complete system memory handling.
|
||||||
|
|
||||||
|
# Module API
|
||||||
|
|
||||||
|
## `UnityMalloc_StartTest` and `UnityMalloc_EndTest`
|
||||||
|
|
||||||
|
These must be called at the beginning and end of each test. For simplicity, they can
|
||||||
|
be added to `setUp` and `tearDown` in order to do their job. When using the test
|
||||||
|
runner generator scripts, these will be automatically added to the runner whenever
|
||||||
|
unity_memory.h is included.
|
||||||
|
|
||||||
|
## `UnityMalloc_MakeMallocFailAfterCount`
|
||||||
|
|
||||||
|
This can be called from the tests themselves. Passing this function a number will
|
||||||
|
force the reference counter to start keeping track of malloc calls. During that test,
|
||||||
|
if the number of malloc calls exceeds the number given, malloc will immediately
|
||||||
|
start returning `NULL`. This allows you to test error conditions. Think of it as a
|
||||||
|
simplified mock.
|
||||||
|
|
||||||
|
# Configuration
|
||||||
|
|
||||||
|
## `UNITY_MALLOC` and `UNITY_FREE`
|
||||||
|
|
||||||
|
By default, this module tries to use the real stdlib `malloc` and `free` internally.
|
||||||
|
If you would prefer it to use something else, like FreeRTOS's `pvPortMalloc` and
|
||||||
|
`pvPortFree`, then you can use these defines to make it so.
|
||||||
|
|
||||||
|
## `UNITY_EXCLUDE_STDLIB_MALLOC`
|
||||||
|
|
||||||
|
If you would like this library to ignore stdlib or other heap engines completely, and
|
||||||
|
manage the memory on its own, then define this. All memory will be handled internally
|
||||||
|
(and at likely lower overhead). Note that this is not a very featureful memory manager,
|
||||||
|
but is sufficient for most testing purposes.
|
||||||
|
|
||||||
|
## `UNITY_INTERNAL_HEAP_SIZE_BYTES`
|
||||||
|
|
||||||
|
When using the built-in memory manager (see `UNITY_EXCLUDE_STDLIB_MALLOC`) this define
|
||||||
|
allows you to set the heap size this library will use to manage the memory.
|
||||||
202
extras/memory/src/unity_memory.c
Normal file
202
extras/memory/src/unity_memory.c
Normal file
@@ -0,0 +1,202 @@
|
|||||||
|
/* ==========================================
|
||||||
|
* 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"
|
||||||
|
#include "unity_memory.h"
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#define MALLOC_DONT_FAIL -1
|
||||||
|
static int malloc_count;
|
||||||
|
static int malloc_fail_countdown = MALLOC_DONT_FAIL;
|
||||||
|
|
||||||
|
void UnityMalloc_StartTest(void)
|
||||||
|
{
|
||||||
|
malloc_count = 0;
|
||||||
|
malloc_fail_countdown = MALLOC_DONT_FAIL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void UnityMalloc_EndTest(void)
|
||||||
|
{
|
||||||
|
malloc_fail_countdown = MALLOC_DONT_FAIL;
|
||||||
|
if (malloc_count != 0)
|
||||||
|
{
|
||||||
|
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "This test leaks!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UnityMalloc_MakeMallocFailAfterCount(int countdown)
|
||||||
|
{
|
||||||
|
malloc_fail_countdown = countdown;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* These definitions are always included from unity_fixture_malloc_overrides.h */
|
||||||
|
/* We undef to use them or avoid conflict with <stdlib.h> per the C standard */
|
||||||
|
#undef malloc
|
||||||
|
#undef free
|
||||||
|
#undef calloc
|
||||||
|
#undef realloc
|
||||||
|
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
static unsigned char unity_heap[UNITY_INTERNAL_HEAP_SIZE_BYTES];
|
||||||
|
static size_t heap_index;
|
||||||
|
#else
|
||||||
|
#include <stdlib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct GuardBytes
|
||||||
|
{
|
||||||
|
size_t size;
|
||||||
|
size_t guard_space;
|
||||||
|
} Guard;
|
||||||
|
|
||||||
|
#define UNITY_MALLOC_ALIGNMENT (UNITY_POINTER_WIDTH / 8)
|
||||||
|
static const char end[] = "END";
|
||||||
|
|
||||||
|
static size_t unity_size_round_up(size_t size)
|
||||||
|
{
|
||||||
|
size_t rounded_size;
|
||||||
|
|
||||||
|
rounded_size = ((size + UNITY_MALLOC_ALIGNMENT - 1) / UNITY_MALLOC_ALIGNMENT) * UNITY_MALLOC_ALIGNMENT;
|
||||||
|
|
||||||
|
return rounded_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* unity_malloc(size_t size)
|
||||||
|
{
|
||||||
|
char* mem;
|
||||||
|
Guard* guard;
|
||||||
|
size_t total_size;
|
||||||
|
|
||||||
|
total_size = sizeof(Guard) + unity_size_round_up(size + sizeof(end));
|
||||||
|
|
||||||
|
if (malloc_fail_countdown != MALLOC_DONT_FAIL)
|
||||||
|
{
|
||||||
|
if (malloc_fail_countdown == 0)
|
||||||
|
return NULL;
|
||||||
|
malloc_fail_countdown--;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (size == 0) return NULL;
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
if (heap_index + total_size > UNITY_INTERNAL_HEAP_SIZE_BYTES)
|
||||||
|
{
|
||||||
|
guard = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* We know we can get away with this cast because we aligned memory already */
|
||||||
|
guard = (Guard*)(void*)(&unity_heap[heap_index]);
|
||||||
|
heap_index += total_size;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
guard = (Guard*)UNITY_MALLOC(total_size);
|
||||||
|
#endif
|
||||||
|
if (guard == NULL) return NULL;
|
||||||
|
malloc_count++;
|
||||||
|
guard->size = size;
|
||||||
|
guard->guard_space = 0;
|
||||||
|
mem = (char*)&(guard[1]);
|
||||||
|
memcpy(&mem[size], end, sizeof(end));
|
||||||
|
|
||||||
|
return (void*)mem;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int isOverrun(void* mem)
|
||||||
|
{
|
||||||
|
Guard* guard = (Guard*)mem;
|
||||||
|
char* memAsChar = (char*)mem;
|
||||||
|
guard--;
|
||||||
|
|
||||||
|
return guard->guard_space != 0 || strcmp(&memAsChar[guard->size], end) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void release_memory(void* mem)
|
||||||
|
{
|
||||||
|
Guard* guard = (Guard*)mem;
|
||||||
|
guard--;
|
||||||
|
|
||||||
|
malloc_count--;
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
{
|
||||||
|
size_t block_size;
|
||||||
|
|
||||||
|
block_size = unity_size_round_up(guard->size + sizeof(end));
|
||||||
|
|
||||||
|
if (mem == unity_heap + heap_index - block_size)
|
||||||
|
{
|
||||||
|
heap_index -= (sizeof(Guard) + block_size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
UNITY_FREE(guard);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void unity_free(void* mem)
|
||||||
|
{
|
||||||
|
int overrun;
|
||||||
|
|
||||||
|
if (mem == NULL)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
overrun = isOverrun(mem);
|
||||||
|
release_memory(mem);
|
||||||
|
if (overrun)
|
||||||
|
{
|
||||||
|
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "Buffer overrun detected during free()");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void* unity_calloc(size_t num, size_t size)
|
||||||
|
{
|
||||||
|
void* mem = unity_malloc(num * size);
|
||||||
|
if (mem == NULL) return NULL;
|
||||||
|
memset(mem, 0, num * size);
|
||||||
|
return mem;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* unity_realloc(void* oldMem, size_t size)
|
||||||
|
{
|
||||||
|
Guard* guard = (Guard*)oldMem;
|
||||||
|
void* newMem;
|
||||||
|
|
||||||
|
if (oldMem == NULL) return unity_malloc(size);
|
||||||
|
|
||||||
|
guard--;
|
||||||
|
if (isOverrun(oldMem))
|
||||||
|
{
|
||||||
|
release_memory(oldMem);
|
||||||
|
UNITY_TEST_FAIL(Unity.CurrentTestLineNumber, "Buffer overrun detected during realloc()");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (size == 0)
|
||||||
|
{
|
||||||
|
release_memory(oldMem);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (guard->size >= size) return oldMem;
|
||||||
|
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC /* Optimization if memory is expandable */
|
||||||
|
{
|
||||||
|
size_t old_total_size = unity_size_round_up(guard->size + sizeof(end));
|
||||||
|
|
||||||
|
if ((oldMem == unity_heap + heap_index - old_total_size) &&
|
||||||
|
((heap_index - old_total_size + unity_size_round_up(size + sizeof(end))) <= UNITY_INTERNAL_HEAP_SIZE_BYTES))
|
||||||
|
{
|
||||||
|
release_memory(oldMem); /* Not thread-safe, like unity_heap generally */
|
||||||
|
return unity_malloc(size); /* No memcpy since data is in place */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
newMem = unity_malloc(size);
|
||||||
|
if (newMem == NULL) return NULL; /* Do not release old memory */
|
||||||
|
memcpy(newMem, oldMem, guard->size);
|
||||||
|
release_memory(oldMem);
|
||||||
|
return newMem;
|
||||||
|
}
|
||||||
@@ -1,12 +1,16 @@
|
|||||||
/* Copyright (c) 2010 James Grenning and Contributed to Unity Project
|
/* ==========================================
|
||||||
* ==========================================
|
|
||||||
* Unity Project - A Test Framework for C
|
* Unity Project - A Test Framework for C
|
||||||
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
* [Released under MIT License. Please refer to license.txt for details]
|
* [Released under MIT License. Please refer to license.txt for details]
|
||||||
* ========================================== */
|
* ========================================== */
|
||||||
|
|
||||||
#ifndef UNITY_FIXTURE_MALLOC_OVERRIDES_H_
|
#ifndef UNITY_MEMORY_OVERRIDES_H_
|
||||||
#define UNITY_FIXTURE_MALLOC_OVERRIDES_H_
|
#define UNITY_MEMORY_OVERRIDES_H_
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
@@ -21,17 +25,17 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* These functions are used by the Unity Fixture to allocate and release memory
|
/* These functions are used by Unity to allocate and release memory
|
||||||
* on the heap and can be overridden with platform-specific implementations.
|
* on the heap and can be overridden with platform-specific implementations.
|
||||||
* For example, when using FreeRTOS UNITY_FIXTURE_MALLOC becomes pvPortMalloc()
|
* For example, when using FreeRTOS UNITY_MALLOC becomes pvPortMalloc()
|
||||||
* and UNITY_FIXTURE_FREE becomes vPortFree(). */
|
* and UNITY_FREE becomes vPortFree(). */
|
||||||
#if !defined(UNITY_FIXTURE_MALLOC) || !defined(UNITY_FIXTURE_FREE)
|
#if !defined(UNITY_MALLOC) || !defined(UNITY_FREE)
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#define UNITY_FIXTURE_MALLOC(size) malloc(size)
|
#define UNITY_MALLOC(size) malloc(size)
|
||||||
#define UNITY_FIXTURE_FREE(ptr) free(ptr)
|
#define UNITY_FREE(ptr) free(ptr)
|
||||||
#else
|
#else
|
||||||
extern void* UNITY_FIXTURE_MALLOC(size_t size);
|
extern void* UNITY_MALLOC(size_t size);
|
||||||
extern void UNITY_FIXTURE_FREE(void* ptr);
|
extern void UNITY_FREE(void* ptr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define malloc unity_malloc
|
#define malloc unity_malloc
|
||||||
@@ -44,4 +48,13 @@ void* unity_calloc(size_t num, size_t size);
|
|||||||
void* unity_realloc(void * oldMem, size_t size);
|
void* unity_realloc(void * oldMem, size_t size);
|
||||||
void unity_free(void * mem);
|
void unity_free(void * mem);
|
||||||
|
|
||||||
#endif /* UNITY_FIXTURE_MALLOC_OVERRIDES_H_ */
|
/* You must compile with malloc replacement, as defined in unity_fixture_malloc_overrides.h */
|
||||||
|
void UnityMalloc_StartTest(void);
|
||||||
|
void UnityMalloc_EndTest(void);
|
||||||
|
void UnityMalloc_MakeMallocFailAfterCount(int countdown);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
78
extras/memory/test/Makefile
Normal file
78
extras/memory/test/Makefile
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
CC = gcc
|
||||||
|
ifeq ($(shell uname -s), Darwin)
|
||||||
|
CC = clang
|
||||||
|
endif
|
||||||
|
#DEBUG = -O0 -g
|
||||||
|
CFLAGS += -std=c99 -pedantic -Wall -Wextra -Werror
|
||||||
|
CFLAGS += $(DEBUG)
|
||||||
|
DEFINES = -D UNITY_OUTPUT_CHAR=UnityOutputCharSpy_OutputChar
|
||||||
|
ifeq ($(OS),Windows_NT)
|
||||||
|
DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=UnityOutputCharSpy_OutputChar(int)
|
||||||
|
else
|
||||||
|
DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=UnityOutputCharSpy_OutputChar\(int\)
|
||||||
|
endif
|
||||||
|
SRC = ../src/unity_memory.c \
|
||||||
|
../../../src/unity.c \
|
||||||
|
unity_memory_Test.c \
|
||||||
|
unity_memory_TestRunner.c \
|
||||||
|
unity_output_Spy.c \
|
||||||
|
|
||||||
|
INC_DIR = -I../src -I../../../src/
|
||||||
|
BUILD_DIR = ../build
|
||||||
|
TARGET = ../build/memory_tests.exe
|
||||||
|
|
||||||
|
all: default noStdlibMalloc 32bits
|
||||||
|
|
||||||
|
default: $(BUILD_DIR)
|
||||||
|
$(CC) $(CFLAGS) $(DEFINES) $(SRC) $(INC_DIR) -o $(TARGET) -D UNITY_SUPPORT_64
|
||||||
|
@ echo "default build"
|
||||||
|
./$(TARGET)
|
||||||
|
|
||||||
|
32bits: $(BUILD_DIR)
|
||||||
|
$(CC) $(CFLAGS) $(DEFINES) $(SRC) $(INC_DIR) -o $(TARGET) -m32
|
||||||
|
@ echo "32bits build"
|
||||||
|
./$(TARGET)
|
||||||
|
|
||||||
|
noStdlibMalloc: $(BUILD_DIR)
|
||||||
|
$(CC) $(CFLAGS) $(DEFINES) $(SRC) $(INC_DIR) -o $(TARGET) -D UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
@ echo "build with noStdlibMalloc"
|
||||||
|
./$(TARGET)
|
||||||
|
|
||||||
|
C89: CFLAGS += -D UNITY_EXCLUDE_STDINT_H # C89 did not have type 'long long', <stdint.h>
|
||||||
|
C89: $(BUILD_DIR)
|
||||||
|
$(CC) $(CFLAGS) $(DEFINES) $(SRC) $(INC_DIR) -o $(TARGET) -std=c89 && ./$(TARGET)
|
||||||
|
$(CC) $(CFLAGS) $(DEFINES) $(SRC) $(INC_DIR) -o $(TARGET) -D UNITY_EXCLUDE_STDLIB_MALLOC -std=c89
|
||||||
|
./$(TARGET)
|
||||||
|
|
||||||
|
$(BUILD_DIR):
|
||||||
|
mkdir -p $(BUILD_DIR)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f $(TARGET) $(BUILD_DIR)/*.gc*
|
||||||
|
|
||||||
|
cov: $(BUILD_DIR)
|
||||||
|
cd $(BUILD_DIR) && \
|
||||||
|
$(CC) $(DEFINES) $(foreach i, $(SRC), ../test/$(i)) $(INC_DIR) -o $(TARGET) -fprofile-arcs -ftest-coverage
|
||||||
|
rm -f $(BUILD_DIR)/*.gcda
|
||||||
|
./$(TARGET) > /dev/null ; ./$(TARGET) -v > /dev/null
|
||||||
|
cd $(BUILD_DIR) && \
|
||||||
|
gcov unity_memory.c | head -3
|
||||||
|
grep '###' $(BUILD_DIR)/unity_memory.c.gcov -C2 || true # Show uncovered lines
|
||||||
|
|
||||||
|
# These extended flags DO get included before any target build runs
|
||||||
|
CFLAGS += -Wbad-function-cast
|
||||||
|
CFLAGS += -Wcast-qual
|
||||||
|
CFLAGS += -Wconversion
|
||||||
|
CFLAGS += -Wformat=2
|
||||||
|
CFLAGS += -Wmissing-prototypes
|
||||||
|
CFLAGS += -Wold-style-definition
|
||||||
|
CFLAGS += -Wpointer-arith
|
||||||
|
CFLAGS += -Wshadow
|
||||||
|
CFLAGS += -Wstrict-overflow=5
|
||||||
|
CFLAGS += -Wstrict-prototypes
|
||||||
|
CFLAGS += -Wswitch-default
|
||||||
|
CFLAGS += -Wundef
|
||||||
|
CFLAGS += -Wno-error=undef # Warning only, this should not stop the build
|
||||||
|
CFLAGS += -Wunreachable-code
|
||||||
|
CFLAGS += -Wunused
|
||||||
|
CFLAGS += -fstrict-aliasing
|
||||||
325
extras/memory/test/unity_memory_Test.c
Normal file
325
extras/memory/test/unity_memory_Test.c
Normal file
@@ -0,0 +1,325 @@
|
|||||||
|
/* ==========================================
|
||||||
|
* 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"
|
||||||
|
#include "unity_memory.h"
|
||||||
|
#include "unity_output_Spy.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* This test module includes the following tests: */
|
||||||
|
|
||||||
|
void test_ForceMallocFail(void);
|
||||||
|
void test_ReallocSmallerIsUnchanged(void);
|
||||||
|
void test_ReallocSameIsUnchanged(void);
|
||||||
|
void test_ReallocLargerNeeded(void);
|
||||||
|
void test_ReallocNullPointerIsLikeMalloc(void);
|
||||||
|
void test_ReallocSizeZeroFreesMemAndReturnsNullPointer(void);
|
||||||
|
void test_CallocFillsWithZero(void);
|
||||||
|
void test_FreeNULLSafety(void);
|
||||||
|
void test_DetectsLeak(void);
|
||||||
|
void test_BufferOverrunFoundDuringFree(void);
|
||||||
|
void test_BufferOverrunFoundDuringRealloc(void);
|
||||||
|
void test_BufferGuardWriteFoundDuringFree(void);
|
||||||
|
void test_BufferGuardWriteFoundDuringRealloc(void);
|
||||||
|
void test_MallocPastBufferFails(void);
|
||||||
|
void test_CallocPastBufferFails(void);
|
||||||
|
void test_MallocThenReallocGrowsMemoryInPlace(void);
|
||||||
|
void test_ReallocFailDoesNotFreeMem(void);
|
||||||
|
|
||||||
|
/* It makes use of the following features */
|
||||||
|
void setUp(void);
|
||||||
|
void tearDown(void);
|
||||||
|
|
||||||
|
/* Let's Go! */
|
||||||
|
void setUp(void)
|
||||||
|
{
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
UnityOutputCharSpy_Create(200);
|
||||||
|
#else
|
||||||
|
UnityOutputCharSpy_Create(1000);
|
||||||
|
#endif
|
||||||
|
UnityMalloc_StartTest();
|
||||||
|
}
|
||||||
|
|
||||||
|
void tearDown(void)
|
||||||
|
{
|
||||||
|
UnityMalloc_EndTest();
|
||||||
|
UnityOutputCharSpy_Destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ForceMallocFail(void)
|
||||||
|
{
|
||||||
|
void* m;
|
||||||
|
void* mfails;
|
||||||
|
UnityMalloc_MakeMallocFailAfterCount(1);
|
||||||
|
m = malloc(10);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
mfails = malloc(10);
|
||||||
|
TEST_ASSERT_EQUAL_PTR(0, mfails);
|
||||||
|
free(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocSmallerIsUnchanged(void)
|
||||||
|
{
|
||||||
|
void* m1 = malloc(10);
|
||||||
|
void* m2 = realloc(m1, 5);
|
||||||
|
TEST_ASSERT_NOT_NULL(m1);
|
||||||
|
TEST_ASSERT_EQUAL_PTR(m1, m2);
|
||||||
|
free(m2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocSameIsUnchanged(void)
|
||||||
|
{
|
||||||
|
void* m1 = malloc(10);
|
||||||
|
void* m2 = realloc(m1, 10);
|
||||||
|
TEST_ASSERT_NOT_NULL(m1);
|
||||||
|
TEST_ASSERT_EQUAL_PTR(m1, m2);
|
||||||
|
free(m2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocLargerNeeded(void)
|
||||||
|
{
|
||||||
|
void* m2;
|
||||||
|
void* m1 = malloc(10);
|
||||||
|
TEST_ASSERT_NOT_NULL(m1);
|
||||||
|
strcpy((char*)m1, "123456789");
|
||||||
|
m2 = realloc(m1, 15);
|
||||||
|
TEST_ASSERT_EQUAL_STRING("123456789", m2);
|
||||||
|
free(m2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocNullPointerIsLikeMalloc(void)
|
||||||
|
{
|
||||||
|
void* m = realloc(0, 15);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
free(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocSizeZeroFreesMemAndReturnsNullPointer(void)
|
||||||
|
{
|
||||||
|
void* m1 = malloc(10);
|
||||||
|
void* m2 = realloc(m1, 0);
|
||||||
|
TEST_ASSERT_EQUAL_PTR(0, m2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_CallocFillsWithZero(void)
|
||||||
|
{
|
||||||
|
void* m = calloc(3, sizeof(char));
|
||||||
|
char* s = (char*)m;
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
TEST_ASSERT_EQUAL_HEX8(0, s[0]);
|
||||||
|
TEST_ASSERT_EQUAL_HEX8(0, s[1]);
|
||||||
|
TEST_ASSERT_EQUAL_HEX8(0, s[2]);
|
||||||
|
free(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_FreeNULLSafety(void)
|
||||||
|
{
|
||||||
|
free(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*------------------------------------------------------------ */
|
||||||
|
|
||||||
|
#define EXPECT_ABORT_BEGIN \
|
||||||
|
{ \
|
||||||
|
jmp_buf TestAbortFrame; \
|
||||||
|
memcpy(TestAbortFrame, Unity.AbortFrame, sizeof(jmp_buf)); \
|
||||||
|
if (TEST_PROTECT()) \
|
||||||
|
{
|
||||||
|
|
||||||
|
#define EXPECT_ABORT_END \
|
||||||
|
} \
|
||||||
|
memcpy(Unity.AbortFrame, TestAbortFrame, sizeof(jmp_buf)); \
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This tricky set of defines lets us see if we are using the Spy, returns 1 if true */
|
||||||
|
#ifdef __STDC_VERSION__
|
||||||
|
|
||||||
|
#ifdef UNITY_SUPPORT_VARIADIC_MACROS
|
||||||
|
#define USING_SPY_AS(a) EXPAND_AND_USE_2ND(ASSIGN_VALUE(a), 0)
|
||||||
|
#define ASSIGN_VALUE(a) VAL_##a
|
||||||
|
#define VAL_UnityOutputCharSpy_OutputChar 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 /* UNITY_OUTPUT_CHAR = UnityOutputCharSpy_OutputChar */
|
||||||
|
#endif
|
||||||
|
#endif /* UNITY_SUPPORT_VARIADIC_MACROS */
|
||||||
|
|
||||||
|
#else /* __STDC_VERSION__ else */
|
||||||
|
|
||||||
|
#define UnityOutputCharSpy_OutputChar 42
|
||||||
|
#if UNITY_OUTPUT_CHAR == UnityOutputCharSpy_OutputChar /* Works if no -Wundef -Werror */
|
||||||
|
#define USING_OUTPUT_SPY
|
||||||
|
#endif
|
||||||
|
#undef UnityOutputCharSpy_OutputChar
|
||||||
|
|
||||||
|
#endif /* __STDC_VERSION__ */
|
||||||
|
|
||||||
|
void test_DetectsLeak(void)
|
||||||
|
{
|
||||||
|
#ifdef USING_OUTPUT_SPY
|
||||||
|
void* m = malloc(10);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
UnityOutputCharSpy_Enable(1);
|
||||||
|
EXPECT_ABORT_BEGIN
|
||||||
|
UnityMalloc_EndTest();
|
||||||
|
EXPECT_ABORT_END
|
||||||
|
UnityOutputCharSpy_Enable(0);
|
||||||
|
Unity.CurrentTestFailed = 0;
|
||||||
|
TEST_ASSERT_NOT_NULL(strstr(UnityOutputCharSpy_Get(), "This test leaks!"));
|
||||||
|
free(m);
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable USING_OUTPUT_SPY To Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_BufferOverrunFoundDuringFree(void)
|
||||||
|
{
|
||||||
|
#ifdef USING_OUTPUT_SPY
|
||||||
|
void* m = malloc(10);
|
||||||
|
char* s = (char*)m;
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
s[10] = (char)0xFF;
|
||||||
|
UnityOutputCharSpy_Enable(1);
|
||||||
|
EXPECT_ABORT_BEGIN
|
||||||
|
free(m);
|
||||||
|
EXPECT_ABORT_END
|
||||||
|
UnityOutputCharSpy_Enable(0);
|
||||||
|
Unity.CurrentTestFailed = 0;
|
||||||
|
TEST_ASSERT_NOT_NULL(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during free()"));
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable USING_OUTPUT_SPY To Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_BufferOverrunFoundDuringRealloc(void)
|
||||||
|
{
|
||||||
|
#ifdef USING_OUTPUT_SPY
|
||||||
|
void* m = malloc(10);
|
||||||
|
char* s = (char*)m;
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
s[10] = (char)0xFF;
|
||||||
|
UnityOutputCharSpy_Enable(1);
|
||||||
|
EXPECT_ABORT_BEGIN
|
||||||
|
m = realloc(m, 100);
|
||||||
|
EXPECT_ABORT_END
|
||||||
|
UnityOutputCharSpy_Enable(0);
|
||||||
|
Unity.CurrentTestFailed = 0;
|
||||||
|
TEST_ASSERT_NOT_NULL(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during realloc()"));
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable USING_OUTPUT_SPY To Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_BufferGuardWriteFoundDuringFree(void)
|
||||||
|
{
|
||||||
|
#ifdef USING_OUTPUT_SPY
|
||||||
|
void* m = malloc(10);
|
||||||
|
char* s = (char*)m;
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
s[-1] = (char)0x00; /* Will not detect 0 */
|
||||||
|
s[-2] = (char)0x01;
|
||||||
|
UnityOutputCharSpy_Enable(1);
|
||||||
|
EXPECT_ABORT_BEGIN
|
||||||
|
free(m);
|
||||||
|
EXPECT_ABORT_END
|
||||||
|
UnityOutputCharSpy_Enable(0);
|
||||||
|
Unity.CurrentTestFailed = 0;
|
||||||
|
TEST_ASSERT_NOT_NULL(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during free()"));
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable USING_OUTPUT_SPY To Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_BufferGuardWriteFoundDuringRealloc(void)
|
||||||
|
{
|
||||||
|
#ifdef USING_OUTPUT_SPY
|
||||||
|
void* m = malloc(10);
|
||||||
|
char* s = (char*)m;
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
s[-1] = (char)0x0A;
|
||||||
|
UnityOutputCharSpy_Enable(1);
|
||||||
|
EXPECT_ABORT_BEGIN
|
||||||
|
m = realloc(m, 100);
|
||||||
|
EXPECT_ABORT_END
|
||||||
|
UnityOutputCharSpy_Enable(0);
|
||||||
|
Unity.CurrentTestFailed = 0;
|
||||||
|
TEST_ASSERT_NOT_NULL(strstr(UnityOutputCharSpy_Get(), "Buffer overrun detected during realloc()"));
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable USING_OUTPUT_SPY To Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*------------------------------------------------------------ */
|
||||||
|
|
||||||
|
#define TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(first_mem_ptr, ptr) \
|
||||||
|
ptr = malloc(10); free(ptr); \
|
||||||
|
TEST_ASSERT_EQUAL_PTR_MESSAGE(first_mem_ptr, ptr, "Memory was stranded, free in LIFO order");
|
||||||
|
|
||||||
|
void test_MallocPastBufferFails(void)
|
||||||
|
{
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
||||||
|
void* n = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
||||||
|
free(m);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
TEST_ASSERT_NULL(n);
|
||||||
|
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable UNITY_EXCLUDE_STDLIB_MALLOC to Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_CallocPastBufferFails(void)
|
||||||
|
{
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
void* m = calloc(1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
||||||
|
void* n = calloc(1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
||||||
|
free(m);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
TEST_ASSERT_NULL(n);
|
||||||
|
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable UNITY_EXCLUDE_STDLIB_MALLOC to Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_MallocThenReallocGrowsMemoryInPlace(void)
|
||||||
|
{
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
||||||
|
void* n = realloc(m, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 9);
|
||||||
|
free(n);
|
||||||
|
TEST_ASSERT_NOT_NULL(m);
|
||||||
|
TEST_ASSERT_EQUAL(m, n);
|
||||||
|
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n);
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable UNITY_EXCLUDE_STDLIB_MALLOC to Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_ReallocFailDoesNotFreeMem(void)
|
||||||
|
{
|
||||||
|
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
|
||||||
|
void* m = malloc(UNITY_INTERNAL_HEAP_SIZE_BYTES/2);
|
||||||
|
void* n1 = malloc(10);
|
||||||
|
void* out_of_mem = realloc(n1, UNITY_INTERNAL_HEAP_SIZE_BYTES/2 + 1);
|
||||||
|
void* n2 = malloc(10);
|
||||||
|
|
||||||
|
free(n2);
|
||||||
|
if (out_of_mem == NULL) free(n1);
|
||||||
|
free(m);
|
||||||
|
|
||||||
|
TEST_ASSERT_NOT_NULL(m); /* Got a real memory location */
|
||||||
|
TEST_ASSERT_NULL(out_of_mem); /* The realloc should have failed */
|
||||||
|
TEST_ASSERT_NOT_EQUAL(n2, n1); /* If n1 != n2 then realloc did not free n1 */
|
||||||
|
TEST_ASSERT_MEMORY_ALL_FREE_LIFO_ORDER(m, n2);
|
||||||
|
#else
|
||||||
|
TEST_IGNORE_MESSAGE("Enable UNITY_EXCLUDE_STDLIB_MALLOC to Run This Test");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
49
extras/memory/test/unity_memory_TestRunner.c
Normal file
49
extras/memory/test/unity_memory_TestRunner.c
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
/* ==========================================
|
||||||
|
* 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"
|
||||||
|
#include "unity_memory.h"
|
||||||
|
|
||||||
|
extern void test_ForceMallocFail(void);
|
||||||
|
extern void test_ReallocSmallerIsUnchanged(void);
|
||||||
|
extern void test_ReallocSameIsUnchanged(void);
|
||||||
|
extern void test_ReallocLargerNeeded(void);
|
||||||
|
extern void test_ReallocNullPointerIsLikeMalloc(void);
|
||||||
|
extern void test_ReallocSizeZeroFreesMemAndReturnsNullPointer(void);
|
||||||
|
extern void test_CallocFillsWithZero(void);
|
||||||
|
extern void test_FreeNULLSafety(void);
|
||||||
|
extern void test_DetectsLeak(void);
|
||||||
|
extern void test_BufferOverrunFoundDuringFree(void);
|
||||||
|
extern void test_BufferOverrunFoundDuringRealloc(void);
|
||||||
|
extern void test_BufferGuardWriteFoundDuringFree(void);
|
||||||
|
extern void test_BufferGuardWriteFoundDuringRealloc(void);
|
||||||
|
extern void test_MallocPastBufferFails(void);
|
||||||
|
extern void test_CallocPastBufferFails(void);
|
||||||
|
extern void test_MallocThenReallocGrowsMemoryInPlace(void);
|
||||||
|
extern void test_ReallocFailDoesNotFreeMem(void);
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
UnityBegin("unity_memory_Test.c");
|
||||||
|
RUN_TEST(test_ForceMallocFail);
|
||||||
|
RUN_TEST(test_ReallocSmallerIsUnchanged);
|
||||||
|
RUN_TEST(test_ReallocSameIsUnchanged);
|
||||||
|
RUN_TEST(test_ReallocLargerNeeded);
|
||||||
|
RUN_TEST(test_ReallocNullPointerIsLikeMalloc);
|
||||||
|
RUN_TEST(test_ReallocSizeZeroFreesMemAndReturnsNullPointer);
|
||||||
|
RUN_TEST(test_CallocFillsWithZero);
|
||||||
|
RUN_TEST(test_FreeNULLSafety);
|
||||||
|
RUN_TEST(test_DetectsLeak);
|
||||||
|
RUN_TEST(test_BufferOverrunFoundDuringFree);
|
||||||
|
RUN_TEST(test_BufferOverrunFoundDuringRealloc);
|
||||||
|
RUN_TEST(test_BufferGuardWriteFoundDuringFree);
|
||||||
|
RUN_TEST(test_BufferGuardWriteFoundDuringRealloc);
|
||||||
|
RUN_TEST(test_MallocPastBufferFails);
|
||||||
|
RUN_TEST(test_CallocPastBufferFails);
|
||||||
|
RUN_TEST(test_MallocThenReallocGrowsMemoryInPlace);
|
||||||
|
RUN_TEST(test_ReallocFailDoesNotFreeMem);
|
||||||
|
return UnityEnd();
|
||||||
|
}
|
||||||
@@ -1,16 +1,15 @@
|
|||||||
/* Copyright (c) 2010 James Grenning and Contributed to Unity Project
|
/* ==========================================
|
||||||
* ==========================================
|
|
||||||
* Unity Project - A Test Framework for C
|
* Unity Project - A Test Framework for C
|
||||||
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
* [Released under MIT License. Please refer to license.txt for details]
|
* [Released under MIT License. Please refer to license.txt for details]
|
||||||
* ========================================== */
|
* ========================================== */
|
||||||
|
|
||||||
|
#include "unity.h"
|
||||||
#include "unity_output_Spy.h"
|
#include "unity_output_Spy.h"
|
||||||
#include "unity_fixture.h"
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
static int size;
|
static int size;
|
||||||
static int count;
|
static int count;
|
||||||
@@ -1,12 +1,11 @@
|
|||||||
/* Copyright (c) 2010 James Grenning and Contributed to Unity Project
|
/* ==========================================
|
||||||
* ==========================================
|
|
||||||
* Unity Project - A Test Framework for C
|
* Unity Project - A Test Framework for C
|
||||||
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
* Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
* [Released under MIT License. Please refer to license.txt for details]
|
* [Released under MIT License. Please refer to license.txt for details]
|
||||||
* ========================================== */
|
* ========================================== */
|
||||||
|
|
||||||
#ifndef D_unity_output_Spy_H
|
#ifndef UNITY_OUTPUT_SPY_H
|
||||||
#define D_unity_output_Spy_H
|
#define UNITY_OUTPUT_SPY_H
|
||||||
|
|
||||||
void UnityOutputCharSpy_Create(int s);
|
void UnityOutputCharSpy_Create(int s);
|
||||||
void UnityOutputCharSpy_Destroy(void);
|
void UnityOutputCharSpy_Destroy(void);
|
||||||
14
meson.build
Normal file
14
meson.build
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
project('unity', 'c',
|
||||||
|
license: 'MIT',
|
||||||
|
meson_version: '>=0.53.0',
|
||||||
|
default_options: ['werror=true', 'c_std=c11']
|
||||||
|
)
|
||||||
|
|
||||||
|
subdir('src')
|
||||||
|
unity_dep = declare_dependency(link_with: unity_lib, include_directories: unity_dir)
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
121
|
|
||||||
|
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
2.4.2
|
|
||||||
|
|
||||||
11
src/meson.build
Normal file
11
src/meson.build
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
#
|
||||||
|
# build script written by : Michael Brockus.
|
||||||
|
# github repo author: Mike Karlesky, Mark VanderVoord, Greg Williams.
|
||||||
|
#
|
||||||
|
# license: MIT
|
||||||
|
#
|
||||||
|
unity_dir = include_directories('.')
|
||||||
|
|
||||||
|
unity_lib = static_library(meson.project_name(),
|
||||||
|
files('unity.c'),
|
||||||
|
include_directories: unity_dir)
|
||||||
879
src/unity.c
879
src/unity.c
File diff suppressed because it is too large
Load Diff
290
src/unity.h
290
src/unity.h
@@ -1,6 +1,6 @@
|
|||||||
/* ==========================================
|
/* ==========================================
|
||||||
Unity Project - A Test Framework for C
|
Unity Project - A Test Framework for C
|
||||||
Copyright (c) 2007-14 Mike Karlesky, Mark VanderVoord, Greg Williams
|
Copyright (c) 2007-21 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
[Released under MIT License. Please refer to license.txt for details]
|
[Released under MIT License. Please refer to license.txt for details]
|
||||||
========================================== */
|
========================================== */
|
||||||
|
|
||||||
@@ -8,6 +8,11 @@
|
|||||||
#define UNITY_FRAMEWORK_H
|
#define UNITY_FRAMEWORK_H
|
||||||
#define UNITY
|
#define UNITY
|
||||||
|
|
||||||
|
#define UNITY_VERSION_MAJOR 2
|
||||||
|
#define UNITY_VERSION_MINOR 5
|
||||||
|
#define UNITY_VERSION_BUILD 2
|
||||||
|
#define UNITY_VERSION ((UNITY_VERSION_MAJOR << 16) | (UNITY_VERSION_MINOR << 8) | UNITY_VERSION_BUILD)
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
@@ -15,9 +20,38 @@ extern "C"
|
|||||||
|
|
||||||
#include "unity_internals.h"
|
#include "unity_internals.h"
|
||||||
|
|
||||||
|
/*-------------------------------------------------------
|
||||||
|
* Test Setup / Teardown
|
||||||
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* These functions are intended to be called before and after each test.
|
||||||
|
* If using unity directly, these will need to be provided for each test
|
||||||
|
* executable built. If you are using the test runner generator and/or
|
||||||
|
* Ceedling, these are optional. */
|
||||||
void setUp(void);
|
void setUp(void);
|
||||||
void tearDown(void);
|
void tearDown(void);
|
||||||
|
|
||||||
|
/* These functions are intended to be called at the beginning and end of an
|
||||||
|
* entire test suite. suiteTearDown() is passed the number of tests that
|
||||||
|
* failed, and its return value becomes the exit code of main(). If using
|
||||||
|
* Unity directly, you're in charge of calling these if they are desired.
|
||||||
|
* If using Ceedling or the test runner generator, these will be called
|
||||||
|
* automatically if they exist. */
|
||||||
|
void suiteSetUp(void);
|
||||||
|
int suiteTearDown(int num_failures);
|
||||||
|
|
||||||
|
/*-------------------------------------------------------
|
||||||
|
* Test Reset and Verify
|
||||||
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* These functions are intended to be called before during tests in order
|
||||||
|
* to support complex test loops, etc. Both are NOT built into Unity. Instead
|
||||||
|
* the test runner generator will create them. resetTest will run teardown and
|
||||||
|
* setup again, verifying any end-of-test needs between. verifyTest will only
|
||||||
|
* run the verification. */
|
||||||
|
void resetTest(void);
|
||||||
|
void verifyTest(void);
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Configuration Options
|
* Configuration Options
|
||||||
*-------------------------------------------------------
|
*-------------------------------------------------------
|
||||||
@@ -68,11 +102,16 @@ void tearDown(void);
|
|||||||
#define TEST_FAIL() UNITY_TEST_FAIL(__LINE__, NULL)
|
#define TEST_FAIL() UNITY_TEST_FAIL(__LINE__, NULL)
|
||||||
#define TEST_IGNORE_MESSAGE(message) UNITY_TEST_IGNORE(__LINE__, (message))
|
#define TEST_IGNORE_MESSAGE(message) UNITY_TEST_IGNORE(__LINE__, (message))
|
||||||
#define TEST_IGNORE() UNITY_TEST_IGNORE(__LINE__, NULL)
|
#define TEST_IGNORE() UNITY_TEST_IGNORE(__LINE__, NULL)
|
||||||
|
#define TEST_MESSAGE(message) UnityMessage((message), __LINE__)
|
||||||
#define TEST_ONLY()
|
#define TEST_ONLY()
|
||||||
|
#ifdef UNITY_INCLUDE_PRINT_FORMATTED
|
||||||
|
#define TEST_PRINTF(message, ...) UnityPrintF(__LINE__, (message), __VA_ARGS__)
|
||||||
|
#endif
|
||||||
|
|
||||||
/* It is not necessary for you to call PASS. A PASS condition is assumed if nothing fails.
|
/* It is not necessary for you to call PASS. A PASS condition is assumed if nothing fails.
|
||||||
* This method allows you to abort a test immediately with a PASS state, ignoring the remainder of the test. */
|
* This method allows you to abort a test immediately with a PASS state, ignoring the remainder of the test. */
|
||||||
#define TEST_PASS() TEST_ABORT()
|
#define TEST_PASS() TEST_ABORT()
|
||||||
|
#define TEST_PASS_MESSAGE(message) do { UnityMessage((message), __LINE__); TEST_ABORT(); } while(0)
|
||||||
|
|
||||||
/* This macro does nothing, but it is useful for build tools (like Ceedling) to make use of this to figure out
|
/* This macro does nothing, but it is useful for build tools (like Ceedling) to make use of this to figure out
|
||||||
* which files should be linked to in order to perform a test. Use it like TEST_FILE("sandwiches.c") */
|
* which files should be linked to in order to perform a test. Use it like TEST_FILE("sandwiches.c") */
|
||||||
@@ -89,6 +128,8 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_FALSE(condition) UNITY_TEST_ASSERT( !(condition), __LINE__, " Expected FALSE Was TRUE")
|
#define TEST_ASSERT_FALSE(condition) UNITY_TEST_ASSERT( !(condition), __LINE__, " Expected FALSE Was TRUE")
|
||||||
#define TEST_ASSERT_NULL(pointer) UNITY_TEST_ASSERT_NULL( (pointer), __LINE__, " Expected NULL")
|
#define TEST_ASSERT_NULL(pointer) UNITY_TEST_ASSERT_NULL( (pointer), __LINE__, " Expected NULL")
|
||||||
#define TEST_ASSERT_NOT_NULL(pointer) UNITY_TEST_ASSERT_NOT_NULL((pointer), __LINE__, " Expected Non-NULL")
|
#define TEST_ASSERT_NOT_NULL(pointer) UNITY_TEST_ASSERT_NOT_NULL((pointer), __LINE__, " Expected Non-NULL")
|
||||||
|
#define TEST_ASSERT_EMPTY(pointer) UNITY_TEST_ASSERT_EMPTY( (pointer), __LINE__, " Expected Empty")
|
||||||
|
#define TEST_ASSERT_NOT_EMPTY(pointer) UNITY_TEST_ASSERT_NOT_EMPTY((pointer), __LINE__, " Expected Non-Empty")
|
||||||
|
|
||||||
/* Integers (of all sizes) */
|
/* Integers (of all sizes) */
|
||||||
#define TEST_ASSERT_EQUAL_INT(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_INT(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, NULL)
|
||||||
@@ -96,23 +137,41 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_INT16(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT16((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_INT16(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT16((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_INT32(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT32((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_INT32(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT32((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_INT64(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT64((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_INT64(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT64((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, NULL)
|
|
||||||
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, " Expected Not-Equal")
|
|
||||||
#define TEST_ASSERT_EQUAL_UINT(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT( (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT8(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT8( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT8(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT8( (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT16(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT16( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT16(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT16( (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT32(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT32( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT32(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT32( (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT64(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT64( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT64(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT64( (expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EQUAL_size_t(expected, actual) UNITY_TEST_ASSERT_EQUAL_UINT((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX8(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX8( (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX8(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX8( (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX16(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX16((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX16(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX16((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX32(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX32(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX64(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX64((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX64(expected, actual) UNITY_TEST_ASSERT_EQUAL_HEX64((expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EQUAL_CHAR(expected, actual) UNITY_TEST_ASSERT_EQUAL_CHAR((expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_BITS(mask, expected, actual) UNITY_TEST_ASSERT_BITS((mask), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_BITS(mask, expected, actual) UNITY_TEST_ASSERT_BITS((mask), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_BITS_HIGH(mask, actual) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT32)(-1), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_BITS_HIGH(mask, actual) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT)(-1), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_BITS_LOW(mask, actual) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT32)(0), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_BITS_LOW(mask, actual) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT)(0), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_BIT_HIGH(bit, actual) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(-1), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_BIT_HIGH(bit, actual) UNITY_TEST_ASSERT_BITS(((UNITY_UINT)1 << (bit)), (UNITY_UINT)(-1), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_BIT_LOW(bit, actual) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(0), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_BIT_LOW(bit, actual) UNITY_TEST_ASSERT_BITS(((UNITY_UINT)1 << (bit)), (UNITY_UINT)(0), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
|
/* Integer Not Equal To (of all sizes) */
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_INT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT8(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_INT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT16(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_INT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT32(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_INT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT64(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_INT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT8(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT16(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT32(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT64(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_size_t(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX8(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_HEX8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX16(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_HEX16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX32(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_HEX32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX64(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_HEX64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_CHAR(threshold, actual) UNITY_TEST_ASSERT_NOT_EQUAL_CHAR((threshold), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
/* Integer Greater Than/ Less Than (of all sizes) */
|
/* Integer Greater Than/ Less Than (of all sizes) */
|
||||||
#define TEST_ASSERT_GREATER_THAN(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
||||||
@@ -120,28 +179,72 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_GREATER_THAN_INT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_INT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_INT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_INT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_INT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_INT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_INT64(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_INT64((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_UINT(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_UINT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_UINT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_UINT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_UINT64(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_size_t(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_HEX8(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_HEX16(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_GREATER_THAN_HEX32(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_HEX64(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_HEX64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_CHAR(threshold, actual) UNITY_TEST_ASSERT_GREATER_THAN_CHAR((threshold), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
#define TEST_ASSERT_LESS_THAN(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_INT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_INT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_INT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_INT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_INT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_INT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_INT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_INT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_THAN_INT64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_INT64((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_UINT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_UINT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_UINT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_UINT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_THAN_UINT64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_THAN_size_t(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX8((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_HEX8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX8((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX16((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_HEX16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX16((threshold), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX32((threshold), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_LESS_THAN_HEX32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_THAN_HEX64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_HEX64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_THAN_CHAR(threshold, actual) UNITY_TEST_ASSERT_SMALLER_THAN_CHAR((threshold), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT64(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT8(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT16(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT32(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT64(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_size_t(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX8(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX16(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX32(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX64(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_CHAR(threshold, actual) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_CHAR((threshold), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_size_t(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX8(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX8((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX16(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX16((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX32(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX32((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX64(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX64((threshold), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_CHAR(threshold, actual) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_CHAR((threshold), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
/* Integer Ranges (of all sizes) */
|
/* Integer Ranges (of all sizes) */
|
||||||
#define TEST_ASSERT_INT_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_INT_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_INT_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_INT_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
@@ -154,11 +257,33 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_UINT16_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT16_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_UINT16_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT16_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_UINT32_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_UINT32_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_UINT64_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT64_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_UINT64_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT64_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_size_t_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_UINT_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_HEX_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_HEX_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_HEX8_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX8_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_HEX8_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX8_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_HEX16_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX16_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_HEX16_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX16_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_HEX32_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_HEX32_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_HEX64_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX64_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_HEX64_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_HEX64_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_CHAR_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_CHAR_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
|
|
||||||
|
/* Integer Array Ranges (of all sizes) */
|
||||||
|
#define TEST_ASSERT_INT_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_INT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_INT8_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_INT8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_INT16_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_INT16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_INT32_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_INT32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_INT64_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_INT64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_UINT_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_UINT8_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_UINT16_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_UINT32_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_UINT64_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_size_t_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_UINT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_HEX_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_HEX32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_HEX8_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_HEX8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_HEX16_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_HEX16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_HEX32_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_HEX32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_HEX64_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_HEX64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_CHAR_ARRAY_WITHIN(delta, expected, actual, num_elements) UNITY_TEST_ASSERT_CHAR_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, NULL)
|
||||||
|
|
||||||
|
|
||||||
/* Structs and Strings */
|
/* Structs and Strings */
|
||||||
#define TEST_ASSERT_EQUAL_PTR(expected, actual) UNITY_TEST_ASSERT_EQUAL_PTR((expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_PTR(expected, actual) UNITY_TEST_ASSERT_EQUAL_PTR((expected), (actual), __LINE__, NULL)
|
||||||
@@ -177,6 +302,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_UINT16_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT16_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT16_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT16_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT32_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT32_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT32_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT32_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_UINT64_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_UINT64_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EQUAL_size_t_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_UINT_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX32_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX32_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX8_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX8_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX8_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX8_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_HEX16_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX16_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_HEX16_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_HEX16_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
@@ -185,8 +311,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_PTR_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_PTR_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_STRING_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_STRING_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EQUAL_MEMORY_ARRAY(expected, actual, len, num_elements) UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY((expected), (actual), (len), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EQUAL_MEMORY_ARRAY(expected, actual, len, num_elements) UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY((expected), (actual), (len), (num_elements), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EQUAL_CHAR_ARRAY(expected, actual, num_elements) UNITY_TEST_ASSERT_EQUAL_CHAR_ARRAY((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
|
|
||||||
|
|
||||||
/* Arrays Compared To Single Value */
|
/* Arrays Compared To Single Value */
|
||||||
#define TEST_ASSERT_EACH_EQUAL_INT(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_INT((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_INT(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_INT((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
@@ -199,6 +324,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EACH_EQUAL_UINT16(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT16((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_UINT16(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT16((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_UINT32(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT32((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_UINT32(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT32((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_UINT64(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT64((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_UINT64(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT64((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EACH_EQUAL_size_t(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_UINT((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_HEX(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX8(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX8((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_HEX8(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX8((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX16(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX16((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_HEX16(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_HEX16((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
@@ -207,6 +333,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EACH_EQUAL_PTR(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_PTR((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_PTR(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_PTR((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_STRING(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_STRING((expected), (actual), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_STRING(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_STRING((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_EACH_EQUAL_MEMORY(expected, actual, len, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY((expected), (actual), (len), (num_elements), __LINE__, NULL)
|
#define TEST_ASSERT_EACH_EQUAL_MEMORY(expected, actual, len, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY((expected), (actual), (len), (num_elements), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_EACH_EQUAL_CHAR(expected, actual, num_elements) UNITY_TEST_ASSERT_EACH_EQUAL_CHAR((expected), (actual), (num_elements), __LINE__, NULL)
|
||||||
|
|
||||||
/* Floating Point (If Enabled) */
|
/* Floating Point (If Enabled) */
|
||||||
#define TEST_ASSERT_FLOAT_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_FLOAT_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
#define TEST_ASSERT_FLOAT_WITHIN(delta, expected, actual) UNITY_TEST_ASSERT_FLOAT_WITHIN((delta), (expected), (actual), __LINE__, NULL)
|
||||||
@@ -236,6 +363,28 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_DOUBLE_IS_NOT_NAN(actual) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN((actual), __LINE__, NULL)
|
#define TEST_ASSERT_DOUBLE_IS_NOT_NAN(actual) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN((actual), __LINE__, NULL)
|
||||||
#define TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(actual) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE((actual), __LINE__, NULL)
|
#define TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(actual) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE((actual), __LINE__, NULL)
|
||||||
|
|
||||||
|
/* Shorthand */
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_OLD
|
||||||
|
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, " Expected Not-Equal")
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_INT
|
||||||
|
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_MEM
|
||||||
|
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_ASSERT_EQUAL_MEMORY((&expected), (&actual), sizeof(expected), __LINE__, NULL)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_RAW
|
||||||
|
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_ASSERT(((expected) == (actual)), __LINE__, " Expected Equal")
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, " Expected Not-Equal")
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_NONE
|
||||||
|
#define TEST_ASSERT_EQUAL(expected, actual) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL(expected, actual) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Test Asserts (with additional messages)
|
* Test Asserts (with additional messages)
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
@@ -247,6 +396,8 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_FALSE_MESSAGE(condition, message) UNITY_TEST_ASSERT( !(condition), __LINE__, (message))
|
#define TEST_ASSERT_FALSE_MESSAGE(condition, message) UNITY_TEST_ASSERT( !(condition), __LINE__, (message))
|
||||||
#define TEST_ASSERT_NULL_MESSAGE(pointer, message) UNITY_TEST_ASSERT_NULL( (pointer), __LINE__, (message))
|
#define TEST_ASSERT_NULL_MESSAGE(pointer, message) UNITY_TEST_ASSERT_NULL( (pointer), __LINE__, (message))
|
||||||
#define TEST_ASSERT_NOT_NULL_MESSAGE(pointer, message) UNITY_TEST_ASSERT_NOT_NULL((pointer), __LINE__, (message))
|
#define TEST_ASSERT_NOT_NULL_MESSAGE(pointer, message) UNITY_TEST_ASSERT_NOT_NULL((pointer), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EMPTY_MESSAGE(pointer, message) UNITY_TEST_ASSERT_EMPTY( (pointer), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EMPTY_MESSAGE(pointer, message) UNITY_TEST_ASSERT_NOT_EMPTY((pointer), __LINE__, (message))
|
||||||
|
|
||||||
/* Integers (of all sizes) */
|
/* Integers (of all sizes) */
|
||||||
#define TEST_ASSERT_EQUAL_INT_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_INT_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, (message))
|
||||||
@@ -254,13 +405,12 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_INT16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT16((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_INT16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT16((expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_INT32_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT32((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_INT32_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT32((expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_INT64_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT64((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_INT64_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT64((expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, (message))
|
|
||||||
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, (message))
|
|
||||||
#define TEST_ASSERT_EQUAL_UINT_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT8_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT8( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT8_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT8( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT16( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT16( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT32_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT32( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT32_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT32( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT64_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT64( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT64_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT64( (expected), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EQUAL_size_t_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_UINT( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX32((expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX8_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX8( (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX8_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX8( (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX16((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX16_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_HEX16((expected), (actual), __LINE__, (message))
|
||||||
@@ -271,6 +421,26 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_BITS_LOW_MESSAGE(mask, actual, message) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT32)(0), (actual), __LINE__, (message))
|
#define TEST_ASSERT_BITS_LOW_MESSAGE(mask, actual, message) UNITY_TEST_ASSERT_BITS((mask), (UNITY_UINT32)(0), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_BIT_HIGH_MESSAGE(bit, actual, message) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(-1), (actual), __LINE__, (message))
|
#define TEST_ASSERT_BIT_HIGH_MESSAGE(bit, actual, message) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(-1), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_BIT_LOW_MESSAGE(bit, actual, message) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(0), (actual), __LINE__, (message))
|
#define TEST_ASSERT_BIT_LOW_MESSAGE(bit, actual, message) UNITY_TEST_ASSERT_BITS(((UNITY_UINT32)1 << (bit)), (UNITY_UINT32)(0), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EQUAL_CHAR_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_CHAR((expected), (actual), __LINE__, (message))
|
||||||
|
|
||||||
|
/* Integer Not Equal To (of all sizes) */
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_INT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_INT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_INT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_INT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_INT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_INT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_UINT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_size_t_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_HEX8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_HEX16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_HEX32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_HEX64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_HEX64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_CHAR_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_NOT_EQUAL_CHAR((threshold), (actual), __LINE__, (message))
|
||||||
|
|
||||||
|
|
||||||
/* Integer Greater Than/ Less Than (of all sizes) */
|
/* Integer Greater Than/ Less Than (of all sizes) */
|
||||||
#define TEST_ASSERT_GREATER_THAN_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT((threshold), (actual), __LINE__, (message))
|
||||||
@@ -278,28 +448,72 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_GREATER_THAN_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_INT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_INT64((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_UINT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_size_t_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_GREATER_THAN_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_GREATER_THAN_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_HEX64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_HEX64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_THAN_CHAR_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_THAN_CHAR((threshold), (actual), __LINE__, (message))
|
||||||
|
|
||||||
#define TEST_ASSERT_LESS_THAN_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_INT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_INT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_THAN_INT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_INT64((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_THAN_UINT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_THAN_size_t_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_UINT((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX8((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX8((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX16((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX16((threshold), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_LESS_THAN_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX32((threshold), (actual), __LINE__, (message))
|
#define TEST_ASSERT_LESS_THAN_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_THAN_HEX64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_HEX64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_THAN_CHAR_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_THAN_CHAR((threshold), (actual), __LINE__, (message))
|
||||||
|
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_INT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_UINT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_size_t_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_HEX64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_GREATER_OR_EQUAL_CHAR_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_GREATER_OR_EQUAL_CHAR((threshold), (actual), __LINE__, (message))
|
||||||
|
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_INT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_UINT64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_size_t_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX8_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX8((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX16_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX16((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX32_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX32((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_HEX64_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX64((threshold), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_LESS_OR_EQUAL_CHAR_MESSAGE(threshold, actual, message) UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_CHAR((threshold), (actual), __LINE__, (message))
|
||||||
|
|
||||||
/* Integer Ranges (of all sizes) */
|
/* Integer Ranges (of all sizes) */
|
||||||
#define TEST_ASSERT_INT_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_INT_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_INT_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_INT_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
@@ -312,11 +526,33 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_UINT16_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT16_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_UINT16_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT16_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_UINT32_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_UINT32_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_UINT64_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT64_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_UINT64_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT64_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_size_t_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_UINT_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_HEX_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_HEX_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_HEX8_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX8_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_HEX8_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX8_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_HEX16_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX16_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_HEX16_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX16_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_HEX32_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_HEX32_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX32_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_HEX64_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX64_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_HEX64_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_HEX64_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_CHAR_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_CHAR_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
|
|
||||||
|
/* Integer Array Ranges (of all sizes) */
|
||||||
|
#define TEST_ASSERT_INT_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_INT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_INT8_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_INT8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_INT16_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_INT16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_INT32_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_INT32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_INT64_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_INT64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_UINT_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_UINT8_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_UINT16_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_UINT32_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_UINT64_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_size_t_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_UINT_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_HEX_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_HEX32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_HEX8_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_HEX8_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_HEX16_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_HEX16_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_HEX32_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_HEX32_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_HEX64_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_HEX64_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_CHAR_ARRAY_WITHIN_MESSAGE(delta, expected, actual, num_elements, message) UNITY_TEST_ASSERT_CHAR_ARRAY_WITHIN((delta), (expected), (actual), num_elements, __LINE__, (message))
|
||||||
|
|
||||||
|
|
||||||
/* Structs and Strings */
|
/* Structs and Strings */
|
||||||
#define TEST_ASSERT_EQUAL_PTR_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_PTR((expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_PTR_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_PTR((expected), (actual), __LINE__, (message))
|
||||||
@@ -335,6 +571,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_UINT16_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT16_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT16_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT16_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT32_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT32_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT32_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT32_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_UINT64_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_UINT64_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EQUAL_size_t_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_UINT_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX32_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX32_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX8_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX8_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX8_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX8_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_HEX16_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX16_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_HEX16_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_HEX16_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
@@ -343,6 +580,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EQUAL_PTR_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_PTR_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_STRING_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_STRING_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EQUAL_MEMORY_ARRAY_MESSAGE(expected, actual, len, num_elements, message) UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY((expected), (actual), (len), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EQUAL_MEMORY_ARRAY_MESSAGE(expected, actual, len, num_elements, message) UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY((expected), (actual), (len), (num_elements), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EQUAL_CHAR_ARRAY_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EQUAL_CHAR_ARRAY((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
|
|
||||||
/* Arrays Compared To Single Value*/
|
/* Arrays Compared To Single Value*/
|
||||||
#define TEST_ASSERT_EACH_EQUAL_INT_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_INT((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_INT_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_INT((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
@@ -355,7 +593,8 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EACH_EQUAL_UINT16_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT16((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_UINT16_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT16((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_UINT32_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT32((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_UINT32_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT32((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_UINT64_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT64((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_UINT64_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT64((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX32_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_size_t_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_UINT((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EACH_EQUAL_HEX_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX8_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX8((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_HEX8_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX8((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX16_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX16((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_HEX16_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX16((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_HEX32_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_HEX32_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_HEX32((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
@@ -363,6 +602,7 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_EACH_EQUAL_PTR_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_PTR((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_PTR_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_PTR((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_STRING_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_STRING((expected), (actual), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_STRING_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_STRING((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
#define TEST_ASSERT_EACH_EQUAL_MEMORY_MESSAGE(expected, actual, len, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY((expected), (actual), (len), (num_elements), __LINE__, (message))
|
#define TEST_ASSERT_EACH_EQUAL_MEMORY_MESSAGE(expected, actual, len, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY((expected), (actual), (len), (num_elements), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_EACH_EQUAL_CHAR_MESSAGE(expected, actual, num_elements, message) UNITY_TEST_ASSERT_EACH_EQUAL_CHAR((expected), (actual), (num_elements), __LINE__, (message))
|
||||||
|
|
||||||
/* Floating Point (If Enabled) */
|
/* Floating Point (If Enabled) */
|
||||||
#define TEST_ASSERT_FLOAT_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_FLOAT_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
#define TEST_ASSERT_FLOAT_WITHIN_MESSAGE(delta, expected, actual, message) UNITY_TEST_ASSERT_FLOAT_WITHIN((delta), (expected), (actual), __LINE__, (message))
|
||||||
@@ -392,6 +632,28 @@ void tearDown(void);
|
|||||||
#define TEST_ASSERT_DOUBLE_IS_NOT_NAN_MESSAGE(actual, message) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN((actual), __LINE__, (message))
|
#define TEST_ASSERT_DOUBLE_IS_NOT_NAN_MESSAGE(actual, message) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN((actual), __LINE__, (message))
|
||||||
#define TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE_MESSAGE(actual, message) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE((actual), __LINE__, (message))
|
#define TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE_MESSAGE(actual, message) UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE((actual), __LINE__, (message))
|
||||||
|
|
||||||
|
/* Shorthand */
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_OLD
|
||||||
|
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, (message))
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, (message))
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_INT
|
||||||
|
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_INT((expected), (actual), __LINE__, message)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_MEM
|
||||||
|
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT_EQUAL_MEMORY((&expected), (&actual), sizeof(expected), __LINE__, message)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_RAW
|
||||||
|
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT(((expected) == (actual)), __LINE__, message)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_ASSERT(((expected) != (actual)), __LINE__, message)
|
||||||
|
#endif
|
||||||
|
#ifdef UNITY_SHORTHAND_AS_NONE
|
||||||
|
#define TEST_ASSERT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#define TEST_ASSERT_NOT_EQUAL_MESSAGE(expected, actual, message) UNITY_TEST_FAIL(__LINE__, UnityStrErrShorthand)
|
||||||
|
#endif
|
||||||
|
|
||||||
/* end of UNITY_FRAMEWORK_H */
|
/* end of UNITY_FRAMEWORK_H */
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
/* ==========================================
|
/* ==========================================
|
||||||
Unity Project - A Test Framework for C
|
Unity Project - A Test Framework for C
|
||||||
Copyright (c) 2007-14 Mike Karlesky, Mark VanderVoord, Greg Williams
|
Copyright (c) 2007-21 Mike Karlesky, Mark VanderVoord, Greg Williams
|
||||||
[Released under MIT License. Please refer to license.txt for details]
|
[Released under MIT License. Please refer to license.txt for details]
|
||||||
========================================== */
|
========================================== */
|
||||||
|
|
||||||
@@ -19,6 +19,14 @@
|
|||||||
#include <math.h>
|
#include <math.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_EXCLUDE_STDDEF_H
|
||||||
|
#include <stddef.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef UNITY_INCLUDE_PRINT_FORMATTED
|
||||||
|
#include <stdarg.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Unity Attempts to Auto-Detect Integer Types
|
/* Unity Attempts to Auto-Detect Integer Types
|
||||||
* Attempt 1: UINT_MAX, ULONG_MAX in <limits.h>, or default to 32 bits
|
* Attempt 1: UINT_MAX, ULONG_MAX in <limits.h>, or default to 32 bits
|
||||||
* Attempt 2: UINTPTR_MAX in <stdint.h>, or default to same size as long
|
* Attempt 2: UINTPTR_MAX in <stdint.h>, or default to same size as long
|
||||||
@@ -32,6 +40,12 @@
|
|||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined __GNUC__
|
||||||
|
# define UNITY_FUNCTION_ATTR(a) __attribute__((a))
|
||||||
|
#else
|
||||||
|
# define UNITY_FUNCTION_ATTR(a) /* ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Guess Widths If Not Specified
|
* Guess Widths If Not Specified
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
@@ -39,6 +53,8 @@
|
|||||||
/* Determine the size of an int, if not already specified.
|
/* Determine the size of an int, if not already specified.
|
||||||
* We cannot use sizeof(int), because it is not yet defined
|
* We cannot use sizeof(int), because it is not yet defined
|
||||||
* at this stage in the translation of the C program.
|
* at this stage in the translation of the C program.
|
||||||
|
* Also sizeof(int) does return the size in addressable units on all platforms,
|
||||||
|
* which may not necessarily be the size in bytes.
|
||||||
* Therefore, infer it from UINT_MAX if possible. */
|
* Therefore, infer it from UINT_MAX if possible. */
|
||||||
#ifndef UNITY_INT_WIDTH
|
#ifndef UNITY_INT_WIDTH
|
||||||
#ifdef UINT_MAX
|
#ifdef UINT_MAX
|
||||||
@@ -110,19 +126,21 @@
|
|||||||
* 64-bit Support
|
* 64-bit Support
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* Auto-detect 64 Bit Support */
|
||||||
#ifndef UNITY_SUPPORT_64
|
#ifndef UNITY_SUPPORT_64
|
||||||
#if UNITY_LONG_WIDTH == 64 || UNITY_POINTER_WIDTH == 64
|
#if UNITY_LONG_WIDTH == 64 || UNITY_POINTER_WIDTH == 64
|
||||||
#define UNITY_SUPPORT_64
|
#define UNITY_SUPPORT_64
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* 64-Bit Support Dependent Configuration */
|
||||||
#ifndef UNITY_SUPPORT_64
|
#ifndef UNITY_SUPPORT_64
|
||||||
/* No 64-bit Support */
|
/* No 64-bit Support */
|
||||||
typedef UNITY_UINT32 UNITY_UINT;
|
typedef UNITY_UINT32 UNITY_UINT;
|
||||||
typedef UNITY_INT32 UNITY_INT;
|
typedef UNITY_INT32 UNITY_INT;
|
||||||
|
#define UNITY_MAX_NIBBLES (8) /* Maximum number of nibbles in a UNITY_(U)INT */
|
||||||
#else
|
#else
|
||||||
|
/* 64-bit Support */
|
||||||
/* 64-bit Support */
|
|
||||||
#if (UNITY_LONG_WIDTH == 32)
|
#if (UNITY_LONG_WIDTH == 32)
|
||||||
typedef unsigned long long UNITY_UINT64;
|
typedef unsigned long long UNITY_UINT64;
|
||||||
typedef signed long long UNITY_INT64;
|
typedef signed long long UNITY_INT64;
|
||||||
@@ -133,8 +151,8 @@
|
|||||||
#error Invalid UNITY_LONG_WIDTH specified! (32 or 64 are supported)
|
#error Invalid UNITY_LONG_WIDTH specified! (32 or 64 are supported)
|
||||||
#endif
|
#endif
|
||||||
typedef UNITY_UINT64 UNITY_UINT;
|
typedef UNITY_UINT64 UNITY_UINT;
|
||||||
typedef UNITY_INT64 UNITY_INT;
|
typedef UNITY_INT64 UNITY_INT;
|
||||||
|
#define UNITY_MAX_NIBBLES (16) /* Maximum number of nibbles in a UNITY_(U)INT */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
@@ -142,24 +160,24 @@
|
|||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
#if (UNITY_POINTER_WIDTH == 32)
|
#if (UNITY_POINTER_WIDTH == 32)
|
||||||
#define UNITY_PTR_TO_INT UNITY_INT32
|
#define UNITY_PTR_TO_INT UNITY_INT32
|
||||||
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX32
|
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX32
|
||||||
#elif (UNITY_POINTER_WIDTH == 64)
|
#elif (UNITY_POINTER_WIDTH == 64)
|
||||||
#define UNITY_PTR_TO_INT UNITY_INT64
|
#define UNITY_PTR_TO_INT UNITY_INT64
|
||||||
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX64
|
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX64
|
||||||
#elif (UNITY_POINTER_WIDTH == 16)
|
#elif (UNITY_POINTER_WIDTH == 16)
|
||||||
#define UNITY_PTR_TO_INT UNITY_INT16
|
#define UNITY_PTR_TO_INT UNITY_INT16
|
||||||
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX16
|
#define UNITY_DISPLAY_STYLE_POINTER UNITY_DISPLAY_STYLE_HEX16
|
||||||
#else
|
#else
|
||||||
#error Invalid UNITY_POINTER_WIDTH specified! (16, 32 or 64 are supported)
|
#error Invalid UNITY_POINTER_WIDTH specified! (16, 32 or 64 are supported)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef UNITY_PTR_ATTRIBUTE
|
#ifndef UNITY_PTR_ATTRIBUTE
|
||||||
#define UNITY_PTR_ATTRIBUTE
|
#define UNITY_PTR_ATTRIBUTE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef UNITY_INTERNAL_PTR
|
#ifndef UNITY_INTERNAL_PTR
|
||||||
#define UNITY_INTERNAL_PTR UNITY_PTR_ATTRIBUTE const void*
|
#define UNITY_INTERNAL_PTR UNITY_PTR_ATTRIBUTE const void*
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
@@ -241,30 +259,30 @@ typedef UNITY_FLOAT_TYPE UNITY_FLOAT;
|
|||||||
* Output Method: stdout (DEFAULT)
|
* Output Method: stdout (DEFAULT)
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
#ifndef UNITY_OUTPUT_CHAR
|
#ifndef UNITY_OUTPUT_CHAR
|
||||||
/* Default to using putchar, which is defined in stdio.h */
|
/* Default to using putchar, which is defined in stdio.h */
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#define UNITY_OUTPUT_CHAR(a) (void)putchar(a)
|
#define UNITY_OUTPUT_CHAR(a) (void)putchar(a)
|
||||||
#else
|
#else
|
||||||
/* If defined as something else, make sure we declare it here so it's ready for use */
|
/* If defined as something else, make sure we declare it here so it's ready for use */
|
||||||
#ifdef UNITY_OUTPUT_CHAR_HEADER_DECLARATION
|
#ifdef UNITY_OUTPUT_CHAR_HEADER_DECLARATION
|
||||||
extern void UNITY_OUTPUT_CHAR_HEADER_DECLARATION;
|
extern void UNITY_OUTPUT_CHAR_HEADER_DECLARATION;
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef UNITY_OUTPUT_FLUSH
|
#ifndef UNITY_OUTPUT_FLUSH
|
||||||
#ifdef UNITY_USE_FLUSH_STDOUT
|
#ifdef UNITY_USE_FLUSH_STDOUT
|
||||||
/* We want to use the stdout flush utility */
|
/* We want to use the stdout flush utility */
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#define UNITY_OUTPUT_FLUSH() (void)fflush(stdout)
|
#define UNITY_OUTPUT_FLUSH() (void)fflush(stdout)
|
||||||
|
#else
|
||||||
|
/* We've specified nothing, therefore flush should just be ignored */
|
||||||
|
#define UNITY_OUTPUT_FLUSH()
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
/* We've specified nothing, therefore flush should just be ignored */
|
/* If defined as something else, make sure we declare it here so it's ready for use */
|
||||||
#define UNITY_OUTPUT_FLUSH()
|
#ifdef UNITY_OUTPUT_FLUSH_HEADER_DECLARATION
|
||||||
#endif
|
extern void UNITY_OUTPUT_FLUSH_HEADER_DECLARATION;
|
||||||
#else
|
#endif
|
||||||
/* We've defined flush as something else, so make sure we declare it here so it's ready for use */
|
|
||||||
#ifdef UNITY_OUTPUT_FLUSH_HEADER_DECLARATION
|
|
||||||
extern void UNITY_OMIT_OUTPUT_FLUSH_HEADER_DECLARATION;
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef UNITY_OUTPUT_FLUSH
|
#ifndef UNITY_OUTPUT_FLUSH
|
||||||
@@ -285,6 +303,69 @@ extern void UNITY_OMIT_OUTPUT_FLUSH_HEADER_DECLARATION;
|
|||||||
#define UNITY_OUTPUT_COMPLETE()
|
#define UNITY_OUTPUT_COMPLETE()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef UNITY_INCLUDE_EXEC_TIME
|
||||||
|
#if !defined(UNITY_EXEC_TIME_START) && \
|
||||||
|
!defined(UNITY_EXEC_TIME_STOP) && \
|
||||||
|
!defined(UNITY_PRINT_EXEC_TIME) && \
|
||||||
|
!defined(UNITY_TIME_TYPE)
|
||||||
|
/* If none any of these macros are defined then try to provide a default implementation */
|
||||||
|
|
||||||
|
#if defined(UNITY_CLOCK_MS)
|
||||||
|
/* This is a simple way to get a default implementation on platforms that support getting a millisecond counter */
|
||||||
|
#define UNITY_TIME_TYPE UNITY_UINT
|
||||||
|
#define UNITY_EXEC_TIME_START() Unity.CurrentTestStartTime = UNITY_CLOCK_MS()
|
||||||
|
#define UNITY_EXEC_TIME_STOP() Unity.CurrentTestStopTime = UNITY_CLOCK_MS()
|
||||||
|
#define UNITY_PRINT_EXEC_TIME() { \
|
||||||
|
UNITY_UINT execTimeMs = (Unity.CurrentTestStopTime - Unity.CurrentTestStartTime); \
|
||||||
|
UnityPrint(" ("); \
|
||||||
|
UnityPrintNumberUnsigned(execTimeMs); \
|
||||||
|
UnityPrint(" ms)"); \
|
||||||
|
}
|
||||||
|
#elif defined(_WIN32)
|
||||||
|
#include <time.h>
|
||||||
|
#define UNITY_TIME_TYPE clock_t
|
||||||
|
#define UNITY_GET_TIME(t) t = (clock_t)((clock() * 1000) / CLOCKS_PER_SEC)
|
||||||
|
#define UNITY_EXEC_TIME_START() UNITY_GET_TIME(Unity.CurrentTestStartTime)
|
||||||
|
#define UNITY_EXEC_TIME_STOP() UNITY_GET_TIME(Unity.CurrentTestStopTime)
|
||||||
|
#define UNITY_PRINT_EXEC_TIME() { \
|
||||||
|
UNITY_UINT execTimeMs = (Unity.CurrentTestStopTime - Unity.CurrentTestStartTime); \
|
||||||
|
UnityPrint(" ("); \
|
||||||
|
UnityPrintNumberUnsigned(execTimeMs); \
|
||||||
|
UnityPrint(" ms)"); \
|
||||||
|
}
|
||||||
|
#elif defined(__unix__)
|
||||||
|
#include <time.h>
|
||||||
|
#define UNITY_TIME_TYPE struct timespec
|
||||||
|
#define UNITY_GET_TIME(t) clock_gettime(CLOCK_MONOTONIC, &t)
|
||||||
|
#define UNITY_EXEC_TIME_START() UNITY_GET_TIME(Unity.CurrentTestStartTime)
|
||||||
|
#define UNITY_EXEC_TIME_STOP() UNITY_GET_TIME(Unity.CurrentTestStopTime)
|
||||||
|
#define UNITY_PRINT_EXEC_TIME() { \
|
||||||
|
UNITY_UINT execTimeMs = ((Unity.CurrentTestStopTime.tv_sec - Unity.CurrentTestStartTime.tv_sec) * 1000L); \
|
||||||
|
execTimeMs += ((Unity.CurrentTestStopTime.tv_nsec - Unity.CurrentTestStartTime.tv_nsec) / 1000000L); \
|
||||||
|
UnityPrint(" ("); \
|
||||||
|
UnityPrintNumberUnsigned(execTimeMs); \
|
||||||
|
UnityPrint(" ms)"); \
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_EXEC_TIME_START
|
||||||
|
#define UNITY_EXEC_TIME_START() do{}while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_EXEC_TIME_STOP
|
||||||
|
#define UNITY_EXEC_TIME_STOP() do{}while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_TIME_TYPE
|
||||||
|
#define UNITY_TIME_TYPE UNITY_UINT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_PRINT_EXEC_TIME
|
||||||
|
#define UNITY_PRINT_EXEC_TIME() do{}while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Footprint
|
* Footprint
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
@@ -297,23 +378,6 @@ extern void UNITY_OMIT_OUTPUT_FLUSH_HEADER_DECLARATION;
|
|||||||
#define UNITY_COUNTER_TYPE UNITY_UINT
|
#define UNITY_COUNTER_TYPE UNITY_UINT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
|
||||||
* Language Features Available
|
|
||||||
*-------------------------------------------------------*/
|
|
||||||
#if !defined(UNITY_WEAK_ATTRIBUTE) && !defined(UNITY_WEAK_PRAGMA)
|
|
||||||
# ifdef __GNUC__ /* includes clang */
|
|
||||||
# if !(defined(__WIN32__) && defined(__clang__)) && !defined(__TMS470__)
|
|
||||||
# define UNITY_WEAK_ATTRIBUTE __attribute__((weak))
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef UNITY_NO_WEAK
|
|
||||||
# undef UNITY_WEAK_ATTRIBUTE
|
|
||||||
# undef UNITY_WEAK_PRAGMA
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Internal Structs Needed
|
* Internal Structs Needed
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
@@ -323,10 +387,11 @@ typedef void (*UnityTestFunction)(void);
|
|||||||
#define UNITY_DISPLAY_RANGE_INT (0x10)
|
#define UNITY_DISPLAY_RANGE_INT (0x10)
|
||||||
#define UNITY_DISPLAY_RANGE_UINT (0x20)
|
#define UNITY_DISPLAY_RANGE_UINT (0x20)
|
||||||
#define UNITY_DISPLAY_RANGE_HEX (0x40)
|
#define UNITY_DISPLAY_RANGE_HEX (0x40)
|
||||||
|
#define UNITY_DISPLAY_RANGE_CHAR (0x80)
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
UNITY_DISPLAY_STYLE_INT = sizeof(int)+ UNITY_DISPLAY_RANGE_INT,
|
UNITY_DISPLAY_STYLE_INT = (UNITY_INT_WIDTH / 8) + UNITY_DISPLAY_RANGE_INT,
|
||||||
UNITY_DISPLAY_STYLE_INT8 = 1 + UNITY_DISPLAY_RANGE_INT,
|
UNITY_DISPLAY_STYLE_INT8 = 1 + UNITY_DISPLAY_RANGE_INT,
|
||||||
UNITY_DISPLAY_STYLE_INT16 = 2 + UNITY_DISPLAY_RANGE_INT,
|
UNITY_DISPLAY_STYLE_INT16 = 2 + UNITY_DISPLAY_RANGE_INT,
|
||||||
UNITY_DISPLAY_STYLE_INT32 = 4 + UNITY_DISPLAY_RANGE_INT,
|
UNITY_DISPLAY_STYLE_INT32 = 4 + UNITY_DISPLAY_RANGE_INT,
|
||||||
@@ -334,7 +399,7 @@ UNITY_DISPLAY_STYLE_INT = sizeof(int)+ UNITY_DISPLAY_RANGE_INT,
|
|||||||
UNITY_DISPLAY_STYLE_INT64 = 8 + UNITY_DISPLAY_RANGE_INT,
|
UNITY_DISPLAY_STYLE_INT64 = 8 + UNITY_DISPLAY_RANGE_INT,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
UNITY_DISPLAY_STYLE_UINT = sizeof(unsigned) + UNITY_DISPLAY_RANGE_UINT,
|
UNITY_DISPLAY_STYLE_UINT = (UNITY_INT_WIDTH / 8) + UNITY_DISPLAY_RANGE_UINT,
|
||||||
UNITY_DISPLAY_STYLE_UINT8 = 1 + UNITY_DISPLAY_RANGE_UINT,
|
UNITY_DISPLAY_STYLE_UINT8 = 1 + UNITY_DISPLAY_RANGE_UINT,
|
||||||
UNITY_DISPLAY_STYLE_UINT16 = 2 + UNITY_DISPLAY_RANGE_UINT,
|
UNITY_DISPLAY_STYLE_UINT16 = 2 + UNITY_DISPLAY_RANGE_UINT,
|
||||||
UNITY_DISPLAY_STYLE_UINT32 = 4 + UNITY_DISPLAY_RANGE_UINT,
|
UNITY_DISPLAY_STYLE_UINT32 = 4 + UNITY_DISPLAY_RANGE_UINT,
|
||||||
@@ -349,9 +414,23 @@ UNITY_DISPLAY_STYLE_UINT = sizeof(unsigned) + UNITY_DISPLAY_RANGE_UINT,
|
|||||||
UNITY_DISPLAY_STYLE_HEX64 = 8 + UNITY_DISPLAY_RANGE_HEX,
|
UNITY_DISPLAY_STYLE_HEX64 = 8 + UNITY_DISPLAY_RANGE_HEX,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
UNITY_DISPLAY_STYLE_CHAR = 1 + UNITY_DISPLAY_RANGE_CHAR + UNITY_DISPLAY_RANGE_INT,
|
||||||
|
|
||||||
UNITY_DISPLAY_STYLE_UNKNOWN
|
UNITY_DISPLAY_STYLE_UNKNOWN
|
||||||
} UNITY_DISPLAY_STYLE_T;
|
} UNITY_DISPLAY_STYLE_T;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
UNITY_WITHIN = 0x0,
|
||||||
|
UNITY_EQUAL_TO = 0x1,
|
||||||
|
UNITY_GREATER_THAN = 0x2,
|
||||||
|
UNITY_GREATER_OR_EQUAL = 0x2 + UNITY_EQUAL_TO,
|
||||||
|
UNITY_SMALLER_THAN = 0x4,
|
||||||
|
UNITY_SMALLER_OR_EQUAL = 0x4 + UNITY_EQUAL_TO,
|
||||||
|
UNITY_NOT_EQUAL = 0x0,
|
||||||
|
UNITY_UNKNOWN
|
||||||
|
} UNITY_COMPARISON_T;
|
||||||
|
|
||||||
#ifndef UNITY_EXCLUDE_FLOAT
|
#ifndef UNITY_EXCLUDE_FLOAT
|
||||||
typedef enum UNITY_FLOAT_TRAIT
|
typedef enum UNITY_FLOAT_TRAIT
|
||||||
{
|
{
|
||||||
@@ -370,7 +449,8 @@ typedef enum UNITY_FLOAT_TRAIT
|
|||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
UNITY_ARRAY_TO_VAL = 0,
|
UNITY_ARRAY_TO_VAL = 0,
|
||||||
UNITY_ARRAY_TO_ARRAY
|
UNITY_ARRAY_TO_ARRAY,
|
||||||
|
UNITY_ARRAY_UNKNOWN
|
||||||
} UNITY_FLAGS_T;
|
} UNITY_FLAGS_T;
|
||||||
|
|
||||||
struct UNITY_STORAGE_T
|
struct UNITY_STORAGE_T
|
||||||
@@ -387,6 +467,10 @@ struct UNITY_STORAGE_T
|
|||||||
UNITY_COUNTER_TYPE TestIgnores;
|
UNITY_COUNTER_TYPE TestIgnores;
|
||||||
UNITY_COUNTER_TYPE CurrentTestFailed;
|
UNITY_COUNTER_TYPE CurrentTestFailed;
|
||||||
UNITY_COUNTER_TYPE CurrentTestIgnored;
|
UNITY_COUNTER_TYPE CurrentTestIgnored;
|
||||||
|
#ifdef UNITY_INCLUDE_EXEC_TIME
|
||||||
|
UNITY_TIME_TYPE CurrentTestStartTime;
|
||||||
|
UNITY_TIME_TYPE CurrentTestStopTime;
|
||||||
|
#endif
|
||||||
#ifndef UNITY_EXCLUDE_SETJMP_H
|
#ifndef UNITY_EXCLUDE_SETJMP_H
|
||||||
jmp_buf AbortFrame;
|
jmp_buf AbortFrame;
|
||||||
#endif
|
#endif
|
||||||
@@ -400,8 +484,14 @@ extern struct UNITY_STORAGE_T Unity;
|
|||||||
|
|
||||||
void UnityBegin(const char* filename);
|
void UnityBegin(const char* filename);
|
||||||
int UnityEnd(void);
|
int UnityEnd(void);
|
||||||
|
void UnitySetTestFile(const char* filename);
|
||||||
void UnityConcludeTest(void);
|
void UnityConcludeTest(void);
|
||||||
|
|
||||||
|
#ifndef RUN_TEST
|
||||||
void UnityDefaultTestRun(UnityTestFunction Func, const char* FuncName, const int FuncLineNum);
|
void UnityDefaultTestRun(UnityTestFunction Func, const char* FuncName, const int FuncLineNum);
|
||||||
|
#else
|
||||||
|
#define UNITY_SKIP_DEFAULT_RUNNER
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Details Support
|
* Details Support
|
||||||
@@ -413,8 +503,8 @@ void UnityDefaultTestRun(UnityTestFunction Func, const char* FuncName, const int
|
|||||||
#define UNITY_SET_DETAILS(d1,d2)
|
#define UNITY_SET_DETAILS(d1,d2)
|
||||||
#else
|
#else
|
||||||
#define UNITY_CLR_DETAILS() { Unity.CurrentDetail1 = 0; Unity.CurrentDetail2 = 0; }
|
#define UNITY_CLR_DETAILS() { Unity.CurrentDetail1 = 0; Unity.CurrentDetail2 = 0; }
|
||||||
#define UNITY_SET_DETAIL(d1) { Unity.CurrentDetail1 = d1; Unity.CurrentDetail2 = 0; }
|
#define UNITY_SET_DETAIL(d1) { Unity.CurrentDetail1 = (d1); Unity.CurrentDetail2 = 0; }
|
||||||
#define UNITY_SET_DETAILS(d1,d2) { Unity.CurrentDetail1 = d1; Unity.CurrentDetail2 = d2; }
|
#define UNITY_SET_DETAILS(d1,d2) { Unity.CurrentDetail1 = (d1); Unity.CurrentDetail2 = (d2); }
|
||||||
|
|
||||||
#ifndef UNITY_DETAIL1_NAME
|
#ifndef UNITY_DETAIL1_NAME
|
||||||
#define UNITY_DETAIL1_NAME "Function"
|
#define UNITY_DETAIL1_NAME "Function"
|
||||||
@@ -425,17 +515,26 @@ void UnityDefaultTestRun(UnityTestFunction Func, const char* FuncName, const int
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef UNITY_PRINT_TEST_CONTEXT
|
||||||
|
void UNITY_PRINT_TEST_CONTEXT(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Test Output
|
* Test Output
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
void UnityPrint(const char* string);
|
void UnityPrint(const char* string);
|
||||||
|
|
||||||
|
#ifdef UNITY_INCLUDE_PRINT_FORMATTED
|
||||||
|
void UnityPrintF(const UNITY_LINE_TYPE line, const char* format, ...);
|
||||||
|
#endif
|
||||||
|
|
||||||
void UnityPrintLen(const char* string, const UNITY_UINT32 length);
|
void UnityPrintLen(const char* string, const UNITY_UINT32 length);
|
||||||
void UnityPrintMask(const UNITY_UINT mask, const UNITY_UINT number);
|
void UnityPrintMask(const UNITY_UINT mask, const UNITY_UINT number);
|
||||||
void UnityPrintNumberByStyle(const UNITY_INT number, const UNITY_DISPLAY_STYLE_T style);
|
void UnityPrintNumberByStyle(const UNITY_INT number, const UNITY_DISPLAY_STYLE_T style);
|
||||||
void UnityPrintNumber(const UNITY_INT number);
|
void UnityPrintNumber(const UNITY_INT number_to_print);
|
||||||
void UnityPrintNumberUnsigned(const UNITY_UINT number);
|
void UnityPrintNumberUnsigned(const UNITY_UINT number);
|
||||||
void UnityPrintNumberHex(const UNITY_UINT number, const char nibbles);
|
void UnityPrintNumberHex(const UNITY_UINT number, const char nibbles_to_print);
|
||||||
|
|
||||||
#ifndef UNITY_EXCLUDE_FLOAT_PRINT
|
#ifndef UNITY_EXCLUDE_FLOAT_PRINT
|
||||||
void UnityPrintFloat(const UNITY_DOUBLE input_number);
|
void UnityPrintFloat(const UNITY_DOUBLE input_number);
|
||||||
@@ -455,17 +554,12 @@ void UnityAssertEqualNumber(const UNITY_INT expected,
|
|||||||
const UNITY_LINE_TYPE lineNumber,
|
const UNITY_LINE_TYPE lineNumber,
|
||||||
const UNITY_DISPLAY_STYLE_T style);
|
const UNITY_DISPLAY_STYLE_T style);
|
||||||
|
|
||||||
void UnityAssertGreaterNumber(const UNITY_INT threshold,
|
void UnityAssertGreaterOrLessOrEqualNumber(const UNITY_INT threshold,
|
||||||
const UNITY_INT actual,
|
const UNITY_INT actual,
|
||||||
const char* msg,
|
const UNITY_COMPARISON_T compare,
|
||||||
const UNITY_LINE_TYPE lineNumber,
|
const char *msg,
|
||||||
const UNITY_DISPLAY_STYLE_T style);
|
const UNITY_LINE_TYPE lineNumber,
|
||||||
|
const UNITY_DISPLAY_STYLE_T style);
|
||||||
void UnityAssertSmallerNumber(const UNITY_INT threshold,
|
|
||||||
const UNITY_INT actual,
|
|
||||||
const char* msg,
|
|
||||||
const UNITY_LINE_TYPE lineNumber,
|
|
||||||
const UNITY_DISPLAY_STYLE_T style);
|
|
||||||
|
|
||||||
void UnityAssertEqualIntArray(UNITY_INTERNAL_PTR expected,
|
void UnityAssertEqualIntArray(UNITY_INTERNAL_PTR expected,
|
||||||
UNITY_INTERNAL_PTR actual,
|
UNITY_INTERNAL_PTR actual,
|
||||||
@@ -514,9 +608,24 @@ void UnityAssertNumbersWithin(const UNITY_UINT delta,
|
|||||||
const UNITY_LINE_TYPE lineNumber,
|
const UNITY_LINE_TYPE lineNumber,
|
||||||
const UNITY_DISPLAY_STYLE_T style);
|
const UNITY_DISPLAY_STYLE_T style);
|
||||||
|
|
||||||
void UnityFail(const char* message, const UNITY_LINE_TYPE line);
|
void UnityAssertNumbersArrayWithin(const UNITY_UINT delta,
|
||||||
|
UNITY_INTERNAL_PTR expected,
|
||||||
|
UNITY_INTERNAL_PTR actual,
|
||||||
|
const UNITY_UINT32 num_elements,
|
||||||
|
const char* msg,
|
||||||
|
const UNITY_LINE_TYPE lineNumber,
|
||||||
|
const UNITY_DISPLAY_STYLE_T style,
|
||||||
|
const UNITY_FLAGS_T flags);
|
||||||
|
|
||||||
|
#ifndef UNITY_EXCLUDE_SETJMP_H
|
||||||
|
void UnityFail(const char* message, const UNITY_LINE_TYPE line) UNITY_FUNCTION_ATTR(noreturn);
|
||||||
|
void UnityIgnore(const char* message, const UNITY_LINE_TYPE line) UNITY_FUNCTION_ATTR(noreturn);
|
||||||
|
#else
|
||||||
|
void UnityFail(const char* message, const UNITY_LINE_TYPE line);
|
||||||
void UnityIgnore(const char* message, const UNITY_LINE_TYPE line);
|
void UnityIgnore(const char* message, const UNITY_LINE_TYPE line);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void UnityMessage(const char* message, const UNITY_LINE_TYPE line);
|
||||||
|
|
||||||
#ifndef UNITY_EXCLUDE_FLOAT
|
#ifndef UNITY_EXCLUDE_FLOAT
|
||||||
void UnityAssertFloatsWithin(const UNITY_FLOAT delta,
|
void UnityAssertFloatsWithin(const UNITY_FLOAT delta,
|
||||||
@@ -574,9 +683,15 @@ UNITY_INTERNAL_PTR UnityDoubleToPtr(const double num);
|
|||||||
* Error Strings We Might Need
|
* Error Strings We Might Need
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
|
extern const char UnityStrOk[];
|
||||||
|
extern const char UnityStrPass[];
|
||||||
|
extern const char UnityStrFail[];
|
||||||
|
extern const char UnityStrIgnore[];
|
||||||
|
|
||||||
extern const char UnityStrErrFloat[];
|
extern const char UnityStrErrFloat[];
|
||||||
extern const char UnityStrErrDouble[];
|
extern const char UnityStrErrDouble[];
|
||||||
extern const char UnityStrErr64[];
|
extern const char UnityStrErr64[];
|
||||||
|
extern const char UnityStrErrShorthand[];
|
||||||
|
|
||||||
/*-------------------------------------------------------
|
/*-------------------------------------------------------
|
||||||
* Test Running Macros
|
* Test Running Macros
|
||||||
@@ -594,13 +709,13 @@ extern const char UnityStrErr64[];
|
|||||||
#ifndef RUN_TEST
|
#ifndef RUN_TEST
|
||||||
#ifdef __STDC_VERSION__
|
#ifdef __STDC_VERSION__
|
||||||
#if __STDC_VERSION__ >= 199901L
|
#if __STDC_VERSION__ >= 199901L
|
||||||
#define RUN_TEST(...) UnityDefaultTestRun(RUN_TEST_FIRST(__VA_ARGS__), RUN_TEST_SECOND(__VA_ARGS__))
|
#define UNITY_SUPPORT_VARIADIC_MACROS
|
||||||
#define RUN_TEST_FIRST(...) RUN_TEST_FIRST_HELPER(__VA_ARGS__, throwaway)
|
|
||||||
#define RUN_TEST_FIRST_HELPER(first, ...) (first), #first
|
|
||||||
#define RUN_TEST_SECOND(...) RUN_TEST_SECOND_HELPER(__VA_ARGS__, __LINE__, throwaway)
|
|
||||||
#define RUN_TEST_SECOND_HELPER(first, second, ...) (second)
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef UNITY_SUPPORT_VARIADIC_MACROS
|
||||||
|
#define RUN_TEST(...) RUN_TEST_AT_LINE(__VA_ARGS__, __LINE__, throwaway)
|
||||||
|
#define RUN_TEST_AT_LINE(func, line, ...) UnityDefaultTestRun(func, #func, line)
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If we can't do the tricky version, we'll just have to require them to always include the line number */
|
/* If we can't do the tricky version, we'll just have to require them to always include the line number */
|
||||||
@@ -627,6 +742,16 @@ extern const char UnityStrErr64[];
|
|||||||
#define UNITY_END() UnityEnd()
|
#define UNITY_END() UnityEnd()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef UNITY_SHORTHAND_AS_INT
|
||||||
|
#ifndef UNITY_SHORTHAND_AS_MEM
|
||||||
|
#ifndef UNITY_SHORTHAND_AS_NONE
|
||||||
|
#ifndef UNITY_SHORTHAND_AS_RAW
|
||||||
|
#define UNITY_SHORTHAND_AS_OLD
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/*-----------------------------------------------
|
/*-----------------------------------------------
|
||||||
* Command Line Argument Support
|
* Command Line Argument Support
|
||||||
*-----------------------------------------------*/
|
*-----------------------------------------------*/
|
||||||
@@ -647,9 +772,11 @@ int UnityTestMatches(void);
|
|||||||
* Test Asserts
|
* Test Asserts
|
||||||
*-------------------------------------------------------*/
|
*-------------------------------------------------------*/
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT(condition, line, message) if (condition) {} else {UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), (message));}
|
#define UNITY_TEST_ASSERT(condition, line, message) do {if (condition) {} else {UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), (message));}} while(0)
|
||||||
#define UNITY_TEST_ASSERT_NULL(pointer, line, message) UNITY_TEST_ASSERT(((pointer) == NULL), (UNITY_LINE_TYPE)(line), (message))
|
#define UNITY_TEST_ASSERT_NULL(pointer, line, message) UNITY_TEST_ASSERT(((pointer) == NULL), (UNITY_LINE_TYPE)(line), (message))
|
||||||
#define UNITY_TEST_ASSERT_NOT_NULL(pointer, line, message) UNITY_TEST_ASSERT(((pointer) != NULL), (UNITY_LINE_TYPE)(line), (message))
|
#define UNITY_TEST_ASSERT_NOT_NULL(pointer, line, message) UNITY_TEST_ASSERT(((pointer) != NULL), (UNITY_LINE_TYPE)(line), (message))
|
||||||
|
#define UNITY_TEST_ASSERT_EMPTY(pointer, line, message) UNITY_TEST_ASSERT(((pointer[0]) == 0), (UNITY_LINE_TYPE)(line), (message))
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EMPTY(pointer, line, message) UNITY_TEST_ASSERT(((pointer[0]) != 0), (UNITY_LINE_TYPE)(line), (message))
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_INT(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
#define UNITY_TEST_ASSERT_EQUAL_INT(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_INT8(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
#define UNITY_TEST_ASSERT_EQUAL_INT8(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
@@ -662,47 +789,100 @@ int UnityTestMatches(void);
|
|||||||
#define UNITY_TEST_ASSERT_EQUAL_HEX8(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
#define UNITY_TEST_ASSERT_EQUAL_HEX8(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_HEX16(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT16)(expected), (UNITY_INT)(UNITY_INT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
#define UNITY_TEST_ASSERT_EQUAL_HEX16(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT16)(expected), (UNITY_INT)(UNITY_INT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_HEX32(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT32)(expected), (UNITY_INT)(UNITY_INT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
#define UNITY_TEST_ASSERT_EQUAL_HEX32(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT32)(expected), (UNITY_INT)(UNITY_INT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_EQUAL_CHAR(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
#define UNITY_TEST_ASSERT_BITS(mask, expected, actual, line, message) UnityAssertBits((UNITY_INT)(mask), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line))
|
#define UNITY_TEST_ASSERT_BITS(mask, expected, actual, line, message) UnityAssertBits((UNITY_INT)(mask), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line))
|
||||||
|
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_INT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_INT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_INT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_INT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_UINT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_UINT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_UINT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_UINT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_HEX8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_HEX16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_HEX32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_CHAR(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_INT(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_INT8(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_INT16(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_INT32(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT8(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT16(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT32(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX8(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX16(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX32(threshold, actual, line, message) UnityAssertGreaterNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_CHAR(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_CHAR(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT) (threshold), (UNITY_INT) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT8(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 ) (threshold), (UNITY_INT)(UNITY_INT8 ) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT16(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT16) (threshold), (UNITY_INT)(UNITY_INT16) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT32(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT32) (threshold), (UNITY_INT)(UNITY_INT32) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT) (threshold), (UNITY_INT) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT8(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT16(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT32(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX8(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX16(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX32(threshold, actual, line, message) UnityAssertSmallerNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_CHAR(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 ) (threshold), (UNITY_INT)(UNITY_INT8 ) (actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT) (threshold), (UNITY_INT) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 ) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT16)(threshold), (UNITY_INT)(UNITY_INT16) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT32)(threshold), (UNITY_INT)(UNITY_INT32) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT) (threshold), (UNITY_INT) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX8(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT8 )(threshold), (UNITY_INT)(UNITY_UINT8 )(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX16(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT16)(threshold), (UNITY_INT)(UNITY_UINT16)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX32(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_UINT32)(threshold), (UNITY_INT)(UNITY_UINT32)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_CHAR(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(UNITY_INT8 )(threshold), (UNITY_INT)(UNITY_INT8 ) (actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
|
#define UNITY_TEST_ASSERT_INT_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin( (delta), (UNITY_INT) (expected), (UNITY_INT) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
||||||
#define UNITY_TEST_ASSERT_INT_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT)
|
#define UNITY_TEST_ASSERT_INT8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_INT8 ) (expected), (UNITY_INT)(UNITY_INT8 ) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
||||||
#define UNITY_TEST_ASSERT_INT8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_INT8 )(expected), (UNITY_INT)(UNITY_INT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8)
|
#define UNITY_TEST_ASSERT_INT16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_INT16) (expected), (UNITY_INT)(UNITY_INT16) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
||||||
#define UNITY_TEST_ASSERT_INT16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_INT16)(expected), (UNITY_INT)(UNITY_INT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16)
|
#define UNITY_TEST_ASSERT_INT32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_INT32) (expected), (UNITY_INT)(UNITY_INT32) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
||||||
#define UNITY_TEST_ASSERT_INT32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_INT32)(expected), (UNITY_INT)(UNITY_INT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32)
|
#define UNITY_TEST_ASSERT_UINT_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin( (delta), (UNITY_INT) (expected), (UNITY_INT) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
||||||
#define UNITY_TEST_ASSERT_UINT_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT)
|
|
||||||
#define UNITY_TEST_ASSERT_UINT8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
#define UNITY_TEST_ASSERT_UINT8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8)
|
||||||
#define UNITY_TEST_ASSERT_UINT16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
#define UNITY_TEST_ASSERT_UINT16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16)
|
||||||
#define UNITY_TEST_ASSERT_UINT32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
#define UNITY_TEST_ASSERT_UINT32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32)
|
||||||
#define UNITY_TEST_ASSERT_HEX8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
#define UNITY_TEST_ASSERT_HEX8_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT8 )(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8)
|
||||||
#define UNITY_TEST_ASSERT_HEX16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
#define UNITY_TEST_ASSERT_HEX16_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT16)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT16)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16)
|
||||||
#define UNITY_TEST_ASSERT_HEX32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
#define UNITY_TEST_ASSERT_HEX32_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT32)(delta), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(expected), (UNITY_INT)(UNITY_UINT)(UNITY_UINT32)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32)
|
||||||
|
#define UNITY_TEST_ASSERT_CHAR_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((UNITY_UINT8 )(delta), (UNITY_INT)(UNITY_INT8 ) (expected), (UNITY_INT)(UNITY_INT8 ) (actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR)
|
||||||
|
|
||||||
|
#define UNITY_TEST_ASSERT_INT_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin( (delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_INT8_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT8 )(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_INT16_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT16)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_INT32_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT32)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin( (delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT8_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin( (UNITY_UINT16)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT16_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT16)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT32_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT32)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_HEX8_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT8 )(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_HEX16_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT16)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_HEX32_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT32)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_CHAR_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT8 )(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), ((UNITY_UINT32)(num_elements)), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_PTR(expected, actual, line, message) UnityAssertEqualNumber((UNITY_PTR_TO_INT)(expected), (UNITY_PTR_TO_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER)
|
#define UNITY_TEST_ASSERT_EQUAL_PTR(expected, actual, line, message) UnityAssertEqualNumber((UNITY_PTR_TO_INT)(expected), (UNITY_PTR_TO_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_STRING(expected, actual, line, message) UnityAssertEqualString((const char*)(expected), (const char*)(actual), (message), (UNITY_LINE_TYPE)(line))
|
#define UNITY_TEST_ASSERT_EQUAL_STRING(expected, actual, line, message) UnityAssertEqualString((const char*)(expected), (const char*)(actual), (message), (UNITY_LINE_TYPE)(line))
|
||||||
@@ -723,21 +903,23 @@ int UnityTestMatches(void);
|
|||||||
#define UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER, UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_PTR_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER, UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualStringArray((UNITY_INTERNAL_PTR)(expected), (const char**)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_STRING_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualStringArray((UNITY_INTERNAL_PTR)(expected), (const char**)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY(expected, actual, len, num_elements, line, message) UnityAssertEqualMemory((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(len), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_MEMORY_ARRAY(expected, actual, len, num_elements, line, message) UnityAssertEqualMemory((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(len), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_EQUAL_CHAR_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT) expected, sizeof(int)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT) (expected), (UNITY_INT_WIDTH / 8)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT8 )expected, 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT8 )(expected), 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT8, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT16 )expected, 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT16 )(expected), 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT16, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT32 )expected, 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT32 )(expected), 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT32, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT) expected, sizeof(unsigned int)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT) (expected), (UNITY_INT_WIDTH / 8)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT8 )expected, 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT8 )(expected), 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT8, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT16)expected, 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT16)(expected), 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT16, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT32)expected, 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT32)(expected), 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT32, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT8 )expected, 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX8(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT8 )(expected), 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX8, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT16 )expected, 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX16(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT16 )(expected), 2), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX16, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT32 )expected, 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX32(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT32 )(expected), 4), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX32, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_PTR(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_PTR_TO_INT) expected, sizeof(int*)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_PTR(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_PTR_TO_INT) (expected), (UNITY_POINTER_WIDTH / 8)), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_POINTER, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_STRING(expected, actual, num_elements, line, message) UnityAssertEqualStringArray((UNITY_INTERNAL_PTR)(expected), (const char**)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_STRING(expected, actual, num_elements, line, message) UnityAssertEqualStringArray((UNITY_INTERNAL_PTR)(expected), (const char**)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY(expected, actual, len, num_elements, line, message) UnityAssertEqualMemory((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(len), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_MEMORY(expected, actual, len, num_elements, line, message) UnityAssertEqualMemory((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(len), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_VAL)
|
||||||
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_CHAR(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT8 )(expected), 1), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_CHAR, UNITY_ARRAY_TO_VAL)
|
||||||
|
|
||||||
#ifdef UNITY_SUPPORT_64
|
#ifdef UNITY_SUPPORT_64
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_INT64(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
#define UNITY_TEST_ASSERT_EQUAL_INT64(expected, actual, line, message) UnityAssertEqualNumber((UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
@@ -746,12 +928,30 @@ int UnityTestMatches(void);
|
|||||||
#define UNITY_TEST_ASSERT_EQUAL_INT64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64, UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_INT64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64, UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64, UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_UINT64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64, UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_HEX64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64, UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_HEX64_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualIntArray((UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64, UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT64)expected, 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_INT64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT64)(expected), 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT64)expected, 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_UINT64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_UINT64)(expected), 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT64)expected, 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_HEX64(expected, actual, num_elements, line, message) UnityAssertEqualIntArray(UnityNumToPtr((UNITY_INT)(UNITY_INT64)(expected), 8), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64, UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_INT64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
#define UNITY_TEST_ASSERT_INT64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
#define UNITY_TEST_ASSERT_UINT64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
#define UNITY_TEST_ASSERT_UINT64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
#define UNITY_TEST_ASSERT_HEX64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
#define UNITY_TEST_ASSERT_HEX64_WITHIN(delta, expected, actual, line, message) UnityAssertNumbersWithin((delta), (UNITY_INT)(expected), (UNITY_INT)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_INT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_UINT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
|
#define UNITY_TEST_ASSERT_NOT_EQUAL_HEX64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_NOT_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_GREATER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_THAN, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX64(threshold, actual, line, message) UnityAssertGreaterOrLessOrEqualNumber((UNITY_INT)(threshold), (UNITY_INT)(actual), UNITY_SMALLER_OR_EQUAL, (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64)
|
||||||
|
#define UNITY_TEST_ASSERT_INT64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT64)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_INT64, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT64)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_UINT64, UNITY_ARRAY_TO_ARRAY)
|
||||||
|
#define UNITY_TEST_ASSERT_HEX64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UnityAssertNumbersArrayWithin((UNITY_UINT64)(delta), (UNITY_INTERNAL_PTR)(expected), (UNITY_INTERNAL_PTR)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_DISPLAY_STYLE_HEX64, UNITY_ARRAY_TO_ARRAY)
|
||||||
#else
|
#else
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_INT64(expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
#define UNITY_TEST_ASSERT_EQUAL_INT64(expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_UINT64(expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
#define UNITY_TEST_ASSERT_EQUAL_UINT64(expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
@@ -762,6 +962,21 @@ int UnityTestMatches(void);
|
|||||||
#define UNITY_TEST_ASSERT_INT64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
#define UNITY_TEST_ASSERT_INT64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
#define UNITY_TEST_ASSERT_UINT64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
#define UNITY_TEST_ASSERT_UINT64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
#define UNITY_TEST_ASSERT_HEX64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
#define UNITY_TEST_ASSERT_HEX64_WITHIN(delta, expected, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_INT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_UINT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_THAN_HEX64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_INT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_UINT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_GREATER_OR_EQUAL_HEX64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_INT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_UINT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_THAN_HEX64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_INT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_UINT64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_SMALLER_OR_EQUAL_HEX64(threshold, actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_INT64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_UINT64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
|
#define UNITY_TEST_ASSERT_HEX64_ARRAY_WITHIN(delta, expected, actual, num_elements, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErr64)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef UNITY_EXCLUDE_FLOAT
|
#ifdef UNITY_EXCLUDE_FLOAT
|
||||||
@@ -806,10 +1021,10 @@ int UnityTestMatches(void);
|
|||||||
#define UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN(actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErrDouble)
|
#define UNITY_TEST_ASSERT_DOUBLE_IS_NOT_NAN(actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErrDouble)
|
||||||
#define UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErrDouble)
|
#define UNITY_TEST_ASSERT_DOUBLE_IS_NOT_DETERMINATE(actual, line, message) UNITY_TEST_FAIL((UNITY_LINE_TYPE)(line), UnityStrErrDouble)
|
||||||
#else
|
#else
|
||||||
#define UNITY_TEST_ASSERT_DOUBLE_WITHIN(delta, expected, actual, line, message) UnityAssertDoublesWithin((UNITY_DOUBLE)(delta), (UNITY_DOUBLE)(expected), (UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)line)
|
#define UNITY_TEST_ASSERT_DOUBLE_WITHIN(delta, expected, actual, line, message) UnityAssertDoublesWithin((UNITY_DOUBLE)(delta), (UNITY_DOUBLE)(expected), (UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line))
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_DOUBLE(expected, actual, line, message) UNITY_TEST_ASSERT_DOUBLE_WITHIN((UNITY_DOUBLE)(expected) * (UNITY_DOUBLE)UNITY_DOUBLE_PRECISION, (UNITY_DOUBLE)expected, (UNITY_DOUBLE)actual, (UNITY_LINE_TYPE)(line), message)
|
#define UNITY_TEST_ASSERT_EQUAL_DOUBLE(expected, actual, line, message) UNITY_TEST_ASSERT_DOUBLE_WITHIN((UNITY_DOUBLE)(expected) * (UNITY_DOUBLE)UNITY_DOUBLE_PRECISION, (UNITY_DOUBLE)(expected), (UNITY_DOUBLE)(actual), (UNITY_LINE_TYPE)(line), (message))
|
||||||
#define UNITY_TEST_ASSERT_EQUAL_DOUBLE_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualDoubleArray((UNITY_DOUBLE*)(expected), (UNITY_DOUBLE*)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)line, UNITY_ARRAY_TO_ARRAY)
|
#define UNITY_TEST_ASSERT_EQUAL_DOUBLE_ARRAY(expected, actual, num_elements, line, message) UnityAssertEqualDoubleArray((UNITY_DOUBLE*)(expected), (UNITY_DOUBLE*)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_ARRAY)
|
||||||
#define UNITY_TEST_ASSERT_EACH_EQUAL_DOUBLE(expected, actual, num_elements, line, message) UnityAssertEqualDoubleArray(UnityDoubleToPtr(expected), (UNITY_DOUBLE*)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)line, UNITY_ARRAY_TO_VAL)
|
#define UNITY_TEST_ASSERT_EACH_EQUAL_DOUBLE(expected, actual, num_elements, line, message) UnityAssertEqualDoubleArray(UnityDoubleToPtr(expected), (UNITY_DOUBLE*)(actual), (UNITY_UINT32)(num_elements), (message), (UNITY_LINE_TYPE)(line), UNITY_ARRAY_TO_VAL)
|
||||||
#define UNITY_TEST_ASSERT_DOUBLE_IS_INF(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_INF)
|
#define UNITY_TEST_ASSERT_DOUBLE_IS_INF(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_INF)
|
||||||
#define UNITY_TEST_ASSERT_DOUBLE_IS_NEG_INF(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_NEG_INF)
|
#define UNITY_TEST_ASSERT_DOUBLE_IS_NEG_INF(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_NEG_INF)
|
||||||
#define UNITY_TEST_ASSERT_DOUBLE_IS_NAN(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_NAN)
|
#define UNITY_TEST_ASSERT_DOUBLE_IS_NAN(actual, line, message) UnityAssertDoubleSpecial((UNITY_DOUBLE)(actual), (message), (UNITY_LINE_TYPE)(line), UNITY_FLOAT_IS_NAN)
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
#inherit_from: .rubocop_todo.yml
|
#inherit_from: .rubocop_todo.yml
|
||||||
|
|
||||||
AllCops:
|
AllCops:
|
||||||
TargetRubyVersion: 2.1
|
TargetRubyVersion: 2.3
|
||||||
|
|
||||||
# These are areas where ThrowTheSwitch's coding style diverges from the Ruby standard
|
# These are areas where ThrowTheSwitch's coding style diverges from the Ruby standard
|
||||||
Style/SpecialGlobalVars:
|
Style/SpecialGlobalVars:
|
||||||
@@ -12,13 +12,31 @@ Style/FormatString:
|
|||||||
Enabled: false
|
Enabled: false
|
||||||
Style/GlobalVars:
|
Style/GlobalVars:
|
||||||
Enabled: false
|
Enabled: false
|
||||||
|
Style/FrozenStringLiteralComment:
|
||||||
|
Enabled: false
|
||||||
Style/RegexpLiteral:
|
Style/RegexpLiteral:
|
||||||
AllowInnerSlashes: true
|
AllowInnerSlashes: true
|
||||||
Style/HashSyntax:
|
Style/HashSyntax:
|
||||||
EnforcedStyle: no_mixed_keys
|
EnforcedStyle: no_mixed_keys
|
||||||
|
Style/NumericPredicate:
|
||||||
|
Enabled: false
|
||||||
|
Style/MultilineBlockChain:
|
||||||
|
Enabled: false
|
||||||
|
Style/Alias:
|
||||||
|
Enabled: false
|
||||||
|
Style/EvalWithLocation:
|
||||||
|
Enabled: false
|
||||||
|
Style/MixinUsage:
|
||||||
|
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
|
# This is disabled because it seems to get confused over nested hashes
|
||||||
Style/AlignHash:
|
Layout/AlignHash:
|
||||||
Enabled: false
|
Enabled: false
|
||||||
EnforcedHashRocketStyle: table
|
EnforcedHashRocketStyle: table
|
||||||
EnforcedColonStyle: table
|
EnforcedColonStyle: table
|
||||||
|
|||||||
118
test/Makefile
118
test/Makefile
@@ -7,16 +7,29 @@ E = -Weverything
|
|||||||
CFLAGS += $E -Wno-unknown-warning-option -Wno-missing-prototypes
|
CFLAGS += $E -Wno-unknown-warning-option -Wno-missing-prototypes
|
||||||
CFLAGS += -Wno-unused-macros -Wno-padded -Wno-missing-noreturn
|
CFLAGS += -Wno-unused-macros -Wno-padded -Wno-missing-noreturn
|
||||||
endif
|
endif
|
||||||
CFLAGS += -std=c99 -pedantic -Wall -Wextra -Wconversion -Werror
|
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-switch-enum -Wno-double-promotion
|
||||||
|
CFLAGS += -Wno-poison-system-directories
|
||||||
CFLAGS += -Wbad-function-cast -Wcast-qual -Wold-style-definition -Wshadow -Wstrict-overflow \
|
CFLAGS += -Wbad-function-cast -Wcast-qual -Wold-style-definition -Wshadow -Wstrict-overflow \
|
||||||
-Wstrict-prototypes -Wswitch-default -Wundef
|
-Wstrict-prototypes -Wswitch-default -Wundef
|
||||||
#DEBUG = -O0 -g
|
#DEBUG = -O0 -g
|
||||||
CFLAGS += $(DEBUG)
|
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=putcharSpy
|
||||||
DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=putcharSpy\(int\)
|
DEFINES += -D UNITY_OUTPUT_CHAR_HEADER_DECLARATION=putcharSpy\(int\)
|
||||||
DEFINES += -D UNITY_SUPPORT_64 -D UNITY_INCLUDE_DOUBLE
|
DEFINES += -D UNITY_OUTPUT_FLUSH=flushSpy
|
||||||
SRC = ../src/unity.c tests/testunity.c build/testunityRunner.c
|
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
|
INC_DIR = -I ../src
|
||||||
COV_FLAGS = -fprofile-arcs -ftest-coverage -I ../../src
|
COV_FLAGS = -fprofile-arcs -ftest-coverage -I ../../src
|
||||||
BUILD_DIR = build
|
BUILD_DIR = build
|
||||||
@@ -26,18 +39,80 @@ TARGET = build/testunity-cov.exe
|
|||||||
# For verbose output of all the tests, run 'make test'.
|
# For verbose output of all the tests, run 'make test'.
|
||||||
default: coverage
|
default: coverage
|
||||||
.PHONY: default coverage test clean
|
.PHONY: default coverage test clean
|
||||||
coverage: DEFINES += -D UNITY_NO_WEAK
|
coverage: $(SRC1) $(SRC2) $(SRC3) $(SRC4) $(SRC5) $(SRC6) $(SRC7) $(SRC8)
|
||||||
coverage: $(BUILD_DIR)/testunityRunner.c
|
|
||||||
cd $(BUILD_DIR) && \
|
cd $(BUILD_DIR) && \
|
||||||
$(CC) $(CFLAGS) $(DEFINES) $(foreach i,$(SRC), ../$i) $(COV_FLAGS) -o ../$(TARGET)
|
$(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
|
rm -f $(BUILD_DIR)/*.gcda
|
||||||
./$(TARGET) | grep 'Tests\|]]]' -A1
|
./$(TARGET) | grep 'Tests\|]]]' -A1
|
||||||
cd $(BUILD_DIR) && \
|
cd $(BUILD_DIR) && \
|
||||||
gcov unity.c | head -3
|
gcov unity.c | head -3
|
||||||
grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
|
grep '###' $(BUILD_DIR)/unity.c.gcov -C2 || true
|
||||||
|
|
||||||
test: $(BUILD_DIR)/testunityRunner.c
|
test: $(SRC1) $(SRC2) $(SRC3) $(SRC4) $(SRC5) $(SRC6) $(SRC7) $(SRC8)
|
||||||
$(CC) $(CFLAGS) $(DEFINES) $(INC_DIR) $(SRC) -o $(TARGET)
|
$(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)
|
./$(TARGET)
|
||||||
|
|
||||||
# Compile only, for testing that preprocessor detection works
|
# Compile only, for testing that preprocessor detection works
|
||||||
@@ -46,8 +121,29 @@ intDetection:
|
|||||||
$(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_STDINT_H
|
$(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_STDINT_H
|
||||||
$(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_LIMITS_H
|
$(CC) $(CFLAGS) $(INC_DIR) $(UNITY_C_ONLY) -D UNITY_EXCLUDE_LIMITS_H
|
||||||
|
|
||||||
$(BUILD_DIR)/testunityRunner.c: tests/testunity.c | $(BUILD_DIR)
|
$(BUILD_DIR)/test_unity_arraysRunner.c: tests/test_unity_arrays.c | $(BUILD_DIR)
|
||||||
awk $(AWK_SCRIPT) tests/testunity.c > $@
|
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=\
|
AWK_SCRIPT=\
|
||||||
'/^void test/{ declarations[d++]=$$0; gsub(/\(?void\)? ?/,""); tests[t++]=$$0; line[u++]=NR } \
|
'/^void test/{ declarations[d++]=$$0; gsub(/\(?void\)? ?/,""); tests[t++]=$$0; line[u++]=NR } \
|
||||||
@@ -61,4 +157,4 @@ $(BUILD_DIR):
|
|||||||
mkdir -p $(BUILD_DIR)
|
mkdir -p $(BUILD_DIR)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(TARGET) $(BUILD_DIR)/*.gc* $(BUILD_DIR)/testunityRunner.c
|
rm -f $(TARGET) $(BUILD_DIR)/*.gc* $(BUILD_DIR)/test_unity_*Runner.c
|
||||||
|
|||||||
@@ -4,17 +4,17 @@
|
|||||||
# [Released under MIT License. Please refer to license.txt for details]
|
# [Released under MIT License. Please refer to license.txt for details]
|
||||||
# ==========================================
|
# ==========================================
|
||||||
|
|
||||||
UNITY_ROOT = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
||||||
$verbose = false
|
$verbose = false
|
||||||
|
$extra_paths = []
|
||||||
|
|
||||||
require 'rake'
|
require 'rake'
|
||||||
require 'rake/clean'
|
require 'rake/clean'
|
||||||
require UNITY_ROOT + 'rakefile_helper'
|
require_relative 'rakefile_helper'
|
||||||
require 'rspec/core/rake_task'
|
require 'rspec/core/rake_task'
|
||||||
|
|
||||||
TEMP_DIRS = [
|
TEMP_DIRS = [
|
||||||
File.join(UNITY_ROOT, 'build'),
|
File.join(__dir__, 'build'),
|
||||||
File.join(UNITY_ROOT, 'sandbox')
|
File.join(__dir__, 'sandbox')
|
||||||
]
|
]
|
||||||
|
|
||||||
TEMP_DIRS.each do |dir|
|
TEMP_DIRS.each do |dir|
|
||||||
@@ -30,33 +30,70 @@ include RakefileHelpers
|
|||||||
DEFAULT_CONFIG_FILE = 'gcc_auto_stdint.yml'
|
DEFAULT_CONFIG_FILE = 'gcc_auto_stdint.yml'
|
||||||
configure_toolchain(DEFAULT_CONFIG_FILE)
|
configure_toolchain(DEFAULT_CONFIG_FILE)
|
||||||
|
|
||||||
desc "Test unity with its own unit tests"
|
############# ALL THE SELF-TESTS WE CAN PERFORM
|
||||||
task :unit => [:prepare_for_tests] do
|
namespace :test do
|
||||||
run_tests unit_test_files
|
desc "Build and test Unity"
|
||||||
end
|
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's helper scripts"
|
desc "Test unity with its own unit tests"
|
||||||
task :scripts => [:prepare_for_tests] do
|
task :unit => [:prepare_for_tests] do
|
||||||
Dir['tests/test_*.rb'].each do |scriptfile|
|
run_tests unit_test_files
|
||||||
require "./"+scriptfile
|
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
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Run all rspecs"
|
###################### Shorthand for many common tasks
|
||||||
RSpec::Core::RakeTask.new(:spec) do |t|
|
task :ci => ['test:ci']
|
||||||
t.pattern = 'spec/**/*_spec.rb'
|
task :all => ['test:all']
|
||||||
end
|
|
||||||
|
|
||||||
desc "Generate test summary"
|
|
||||||
task :summary do
|
|
||||||
report_summary
|
|
||||||
end
|
|
||||||
|
|
||||||
desc "Build and test Unity"
|
|
||||||
task :all => [:clean, :prepare_for_tests, :scripts, :unit, :style, :summary]
|
|
||||||
task :default => [:clobber, :all]
|
task :default => [:clobber, :all]
|
||||||
task :ci => [:no_color, :default]
|
|
||||||
task :cruise => [:no_color, :default]
|
|
||||||
|
|
||||||
desc "Load configuration"
|
desc "Load configuration"
|
||||||
task :config, :config_file do |t, args|
|
task :config, :config_file do |t, args|
|
||||||
@@ -71,6 +108,7 @@ task :verbose do
|
|||||||
$verbose = true
|
$verbose = true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
################### CODING STYLE VALIDATION
|
||||||
namespace :style do
|
namespace :style do
|
||||||
desc "Check style"
|
desc "Check style"
|
||||||
task :check do
|
task :check do
|
||||||
@@ -82,7 +120,7 @@ namespace :style do
|
|||||||
namespace :check do
|
namespace :check do
|
||||||
Dir['../**/*.rb'].each do |f|
|
Dir['../**/*.rb'].each do |f|
|
||||||
filename = File.basename(f, '.rb')
|
filename = File.basename(f, '.rb')
|
||||||
desc "Check Style of #{filename}"
|
#desc "Check Style of #{filename}"
|
||||||
task filename.to_sym => ['style:clean'] do
|
task filename.to_sym => ['style:clean'] do
|
||||||
report execute("rubocop #{f} --color --config .rubocop.yml", true)
|
report execute("rubocop #{f} --color --config .rubocop.yml", true)
|
||||||
report "Style Checked for #{f}"
|
report "Style Checked for #{f}"
|
||||||
@@ -98,7 +136,7 @@ namespace :style do
|
|||||||
namespace :c do
|
namespace :c do
|
||||||
Dir['../{src,extras/**}/*.{c,h}'].each do |f|
|
Dir['../{src,extras/**}/*.{c,h}'].each do |f|
|
||||||
filename = File.basename(f)[0..-3]
|
filename = File.basename(f)[0..-3]
|
||||||
desc "Check Style of #{filename}"
|
#desc "Check Style of #{filename}"
|
||||||
task filename.to_sym do
|
task filename.to_sym do
|
||||||
run_astyle f
|
run_astyle f
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -6,9 +6,9 @@
|
|||||||
|
|
||||||
require 'yaml'
|
require 'yaml'
|
||||||
require 'fileutils'
|
require 'fileutils'
|
||||||
require UNITY_ROOT + '../auto/unity_test_summary'
|
require_relative '../auto/unity_test_summary'
|
||||||
require UNITY_ROOT + '../auto/generate_test_runner'
|
require_relative '../auto/generate_test_runner'
|
||||||
require UNITY_ROOT + '../auto/colour_reporter'
|
require_relative '../auto/colour_reporter'
|
||||||
|
|
||||||
module RakefileHelpers
|
module RakefileHelpers
|
||||||
C_EXTENSION = '.c'.freeze
|
C_EXTENSION = '.c'.freeze
|
||||||
@@ -22,7 +22,7 @@ module RakefileHelpers
|
|||||||
end
|
end
|
||||||
|
|
||||||
def configure_clean
|
def configure_clean
|
||||||
CLEAN.include($cfg['compiler']['build_path'] + '*.*') unless $cfg['compiler']['build_path'].nil?
|
CLEAN.include('build/*.*')
|
||||||
end
|
end
|
||||||
|
|
||||||
def configure_toolchain(config_file = DEFAULT_CONFIG_FILE)
|
def configure_toolchain(config_file = DEFAULT_CONFIG_FILE)
|
||||||
@@ -33,13 +33,16 @@ module RakefileHelpers
|
|||||||
end
|
end
|
||||||
|
|
||||||
def unit_test_files
|
def unit_test_files
|
||||||
path = $cfg['compiler']['unit_tests_path'] + 'test*' + C_EXTENSION
|
path = 'tests/test*' + C_EXTENSION
|
||||||
path.tr!('\\', '/')
|
path.tr!('\\', '/')
|
||||||
FileList.new(path)
|
FileList.new(path)
|
||||||
end
|
end
|
||||||
|
|
||||||
def local_include_dirs
|
def local_include_dirs
|
||||||
include_dirs = $cfg['compiler']['includes']['items'].dup
|
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.delete_if { |dir| dir.is_a?(Array) }
|
||||||
include_dirs
|
include_dirs
|
||||||
end
|
end
|
||||||
@@ -86,75 +89,73 @@ module RakefileHelpers
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def build_compiler_fields(inject_defines)
|
def build_command_string(hash, values, defines = nil)
|
||||||
command = tackit($cfg['compiler']['path'])
|
|
||||||
defines = if $cfg['compiler']['defines']['items'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash($cfg['compiler']['defines']['prefix'], $cfg['compiler']['defines']['items'] + ['UNITY_OUTPUT_CHAR=putcharSpy'] + ['UNITY_OUTPUT_CHAR_HEADER_DECLARATION=putcharSpy\(int\)'] + inject_defines)
|
|
||||||
end
|
|
||||||
options = squash('', $cfg['compiler']['options'])
|
|
||||||
includes = squash($cfg['compiler']['includes']['prefix'], $cfg['compiler']['includes']['items'])
|
|
||||||
includes = includes.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ :command => command, :defines => defines, :options => options, :includes => includes }
|
# 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
|
end
|
||||||
|
|
||||||
def compile(file, defines = [])
|
def compile(file, defines = [])
|
||||||
compiler = build_compiler_fields(defines)
|
out_file = File.join('build', File.basename(file, C_EXTENSION)) + $cfg[:extension][:object]
|
||||||
cmd_str = "#{compiler[:command]}#{compiler[:defines]}#{compiler[:options]}#{compiler[:includes]} #{file} " \
|
cmd_str = build_command_string( $cfg[:tools][:test_compiler], [ file, out_file ], defines )
|
||||||
"#{$cfg['compiler']['object_files']['prefix']}#{$cfg['compiler']['object_files']['destination']}"
|
execute(cmd_str)
|
||||||
obj_file = "#{File.basename(file, C_EXTENSION)}#{$cfg['compiler']['object_files']['extension']}"
|
out_file
|
||||||
execute(cmd_str + obj_file)
|
|
||||||
|
|
||||||
obj_file
|
|
||||||
end
|
|
||||||
|
|
||||||
def build_linker_fields
|
|
||||||
command = tackit($cfg['linker']['path'])
|
|
||||||
options = if $cfg['linker']['options'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['linker']['options'])
|
|
||||||
end
|
|
||||||
includes = if $cfg['linker']['includes'].nil? || $cfg['linker']['includes']['items'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash($cfg['linker']['includes']['prefix'], $cfg['linker']['includes']['items'])
|
|
||||||
end.gsub(/\\ /, ' ').gsub(/\\\"/, '"').gsub(/\\$/, '') # Remove trailing slashes (for IAR)
|
|
||||||
|
|
||||||
{ :command => command, :options => options, :includes => includes }
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def link_it(exe_name, obj_list)
|
def link_it(exe_name, obj_list)
|
||||||
linker = build_linker_fields
|
exe_name = File.join('build', File.basename(exe_name))
|
||||||
cmd_str = "#{linker[:command]}#{linker[:options]}#{linker[:includes]} " +
|
cmd_str = build_command_string( $cfg[:tools][:test_linker], [ obj_list, exe_name ] )
|
||||||
(obj_list.map { |obj| "#{$cfg['linker']['object_files']['path']}#{obj} " }).join +
|
|
||||||
$cfg['linker']['bin_files']['prefix'] + ' ' +
|
|
||||||
$cfg['linker']['bin_files']['destination'] +
|
|
||||||
exe_name + $cfg['linker']['bin_files']['extension']
|
|
||||||
execute(cmd_str)
|
execute(cmd_str)
|
||||||
end
|
end
|
||||||
|
|
||||||
def build_simulator_fields
|
def runtest(bin_name, ok_to_fail = false, extra_args = nil)
|
||||||
return nil if $cfg['simulator'].nil?
|
bin_name = File.join('build', File.basename(bin_name))
|
||||||
command = if $cfg['simulator']['path'].nil?
|
extra_args = extra_args.nil? ? "" : " " + extra_args
|
||||||
''
|
if $cfg[:tools][:test_fixture]
|
||||||
else
|
cmd_str = build_command_string( $cfg[:tools][:test_fixture], [ bin_name, extra_args ] )
|
||||||
(tackit($cfg['simulator']['path']) + ' ')
|
else
|
||||||
end
|
cmd_str = bin_name + extra_args
|
||||||
pre_support = if $cfg['simulator']['pre_support'].nil?
|
end
|
||||||
''
|
execute(cmd_str, ok_to_fail)
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['pre_support'])
|
|
||||||
end
|
|
||||||
post_support = if $cfg['simulator']['post_support'].nil?
|
|
||||||
''
|
|
||||||
else
|
|
||||||
squash('', $cfg['simulator']['post_support'])
|
|
||||||
end
|
|
||||||
|
|
||||||
{ :command => command, :pre_support => pre_support, :post_support => post_support }
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def run_astyle(style_what)
|
def run_astyle(style_what)
|
||||||
@@ -173,41 +174,100 @@ module RakefileHelpers
|
|||||||
report command_string if $verbose
|
report command_string if $verbose
|
||||||
output = `#{command_string}`.chomp
|
output = `#{command_string}`.chomp
|
||||||
report(output) if $verbose && !output.nil? && !output.empty?
|
report(output) if $verbose && !output.nil? && !output.empty?
|
||||||
raise "Command failed. (Returned #{$?.exitstatus})" if !$?.exitstatus.zero? && !ok_to_fail
|
raise "Command failed. (Returned #{$?.exitstatus})" if !$?.nil? && !$?.exitstatus.zero? && !ok_to_fail
|
||||||
output
|
output
|
||||||
end
|
end
|
||||||
|
|
||||||
def report_summary
|
def report_summary
|
||||||
summary = UnityTestSummary.new
|
summary = UnityTestSummary.new
|
||||||
summary.root = UNITY_ROOT
|
summary.root = __dir__
|
||||||
results_glob = "#{$cfg['compiler']['build_path']}*.test*"
|
results_glob = File.join('build','*.test*')
|
||||||
results_glob.tr!('\\', '/')
|
results_glob.tr!('\\', '/')
|
||||||
results = Dir[results_glob]
|
results = Dir[results_glob]
|
||||||
summary.targets = results
|
summary.targets = results
|
||||||
report summary.run
|
report summary.run
|
||||||
end
|
end
|
||||||
|
|
||||||
def run_tests(test_files)
|
def save_test_results(test_base, output)
|
||||||
report 'Running Unity system tests...'
|
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
|
||||||
|
|
||||||
# Tack on TEST define for compiling unit tests
|
def test_fixtures()
|
||||||
load_configuration($cfg_file)
|
report "\nRunning Fixture Addon"
|
||||||
test_defines = ['TEST']
|
|
||||||
$cfg['compiler']['defines']['items'] ||= []
|
# Get a list of all source files needed
|
||||||
$cfg['compiler']['defines']['items'] << 'TEST'
|
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
|
include_dirs = local_include_dirs
|
||||||
|
|
||||||
# Build and execute each unit test
|
# Build and execute each unit test
|
||||||
test_files.each do |test|
|
test_files.each do |test|
|
||||||
obj_list = []
|
|
||||||
|
|
||||||
unless $cfg['compiler']['aux_sources'].nil?
|
# Drop Out if we're skipping this type of test
|
||||||
$cfg['compiler']['aux_sources'].each do |aux|
|
if $cfg[:skip_tests]
|
||||||
obj_list << compile(aux, test_defines)
|
if $cfg[:skip_tests].include?(:parameterized) && test.match(/parameterized/)
|
||||||
|
report("Skipping Parameterized Tests for this Target:IGNORE")
|
||||||
|
next
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
report "\nRunning Tests in #{test}"
|
||||||
|
obj_list = []
|
||||||
|
test_defines = []
|
||||||
|
|
||||||
# Detect dependencies and build required modules
|
# Detect dependencies and build required modules
|
||||||
extract_headers(test).each do |header|
|
extract_headers(test).each do |header|
|
||||||
# Compile corresponding source file if it exists
|
# Compile corresponding source file if it exists
|
||||||
@@ -218,14 +278,8 @@ module RakefileHelpers
|
|||||||
|
|
||||||
# Build the test runner (generate if configured to do so)
|
# Build the test runner (generate if configured to do so)
|
||||||
test_base = File.basename(test, C_EXTENSION)
|
test_base = File.basename(test, C_EXTENSION)
|
||||||
|
|
||||||
runner_name = test_base + '_Runner.c'
|
runner_name = test_base + '_Runner.c'
|
||||||
|
runner_path = File.join('build',runner_name)
|
||||||
runner_path = if $cfg['compiler']['runner_path'].nil?
|
|
||||||
$cfg['compiler']['build_path'] + runner_name
|
|
||||||
else
|
|
||||||
$cfg['compiler']['runner_path'] + runner_name
|
|
||||||
end
|
|
||||||
|
|
||||||
options = $cfg[:unity]
|
options = $cfg[:unity]
|
||||||
options[:use_param_tests] = test =~ /parameterized/ ? true : false
|
options[:use_param_tests] = test =~ /parameterized/ ? true : false
|
||||||
@@ -239,22 +293,23 @@ module RakefileHelpers
|
|||||||
link_it(test_base, obj_list)
|
link_it(test_base, obj_list)
|
||||||
|
|
||||||
# Execute unit test and generate results file
|
# Execute unit test and generate results file
|
||||||
simulator = build_simulator_fields
|
output = runtest(test_base)
|
||||||
executable = $cfg['linker']['bin_files']['destination'] + test_base + $cfg['linker']['bin_files']['extension']
|
save_test_results(test_base, output)
|
||||||
cmd_str = if simulator.nil?
|
end
|
||||||
executable
|
end
|
||||||
else
|
|
||||||
"#{simulator[:command]} #{simulator[:pre_support]} #{executable} #{simulator[:post_support]}"
|
def run_make_tests()
|
||||||
end
|
[ "make -s", # test with all defaults
|
||||||
output = execute(cmd_str)
|
#"make -s DEBUG=-m32", # test 32-bit architecture with 64-bit support
|
||||||
test_results = $cfg['compiler']['build_path'] + test_base
|
#"make -s DEBUG=-m32 UNITY_SUPPORT_64=", # test 32-bit build without 64-bit types
|
||||||
if output.match(/OK$/m).nil?
|
"make -s UNITY_INCLUDE_DOUBLE= ", # test without double
|
||||||
test_results += '.testfail'
|
"cd #{File.join("..","extras","fixture",'test')} && make -s default noStdlibMalloc",
|
||||||
else
|
"cd #{File.join("..","extras","fixture",'test')} && make -s C89",
|
||||||
report output unless $verbose # Verbose already prints this line, as does a failure
|
"cd #{File.join("..","extras","memory",'test')} && make -s default noStdlibMalloc",
|
||||||
test_results += '.testpass'
|
"cd #{File.join("..","extras","memory",'test')} && make -s C89",
|
||||||
end
|
].each do |cmd|
|
||||||
File.open(test_results, 'w') { |f| f.print output }
|
report "Testing '#{cmd}'"
|
||||||
|
execute(cmd, false)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
44
test/targets/ansi.yml
Normal file
44
test/targets/ansi.yml
Normal file
@@ -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
|
||||||
@@ -1,78 +1,72 @@
|
|||||||
---
|
---
|
||||||
compiler:
|
|
||||||
path: clang
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-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'
|
|
||||||
# - '-Wunreachable-code'
|
|
||||||
- '-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'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
- UNITY_OUTPUT_RESULTS_FILE
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: clang
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,78 +1,71 @@
|
|||||||
---
|
---
|
||||||
compiler:
|
|
||||||
path: clang
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-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'
|
|
||||||
# - '-Wunreachable-code'
|
|
||||||
- '-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'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: clang
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,49 +1,45 @@
|
|||||||
compiler:
|
---
|
||||||
path: gcc
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-c'
|
|
||||||
- '-m32'
|
|
||||||
- '-Wall'
|
|
||||||
- '-Wno-address'
|
|
||||||
- '-std=c99'
|
|
||||||
- '-pedantic'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_EXCLUDE_STDINT_H
|
|
||||||
- UNITY_EXCLUDE_LIMITS_H
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- UNITY_INT_WIDTH=32
|
|
||||||
- UNITY_LONG_WIDTH=32
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: gcc
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m32'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,50 +1,46 @@
|
|||||||
compiler:
|
---
|
||||||
path: gcc
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-c'
|
|
||||||
- '-m64'
|
|
||||||
- '-Wall'
|
|
||||||
- '-Wno-address'
|
|
||||||
- '-std=c99'
|
|
||||||
- '-pedantic'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- 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
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: gcc
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,47 +1,43 @@
|
|||||||
compiler:
|
---
|
||||||
path: gcc
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-c'
|
|
||||||
- '-m64'
|
|
||||||
- '-Wall'
|
|
||||||
- '-Wno-address'
|
|
||||||
- '-std=c99'
|
|
||||||
- '-pedantic'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_EXCLUDE_STDINT_H
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: gcc
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,59 +1,55 @@
|
|||||||
compiler:
|
---
|
||||||
path: gcc
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-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'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: gcc
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,47 +1,43 @@
|
|||||||
compiler:
|
---
|
||||||
path: gcc
|
|
||||||
source_path: '../src/'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests/'
|
|
||||||
build_path: &build_path 'build/'
|
|
||||||
options:
|
|
||||||
- '-c'
|
|
||||||
- '-m64'
|
|
||||||
- '-Wall'
|
|
||||||
- '-Wno-address'
|
|
||||||
- '-std=c99'
|
|
||||||
- '-pedantic'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- 'src/'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_EXCLUDE_MATH_H
|
|
||||||
- UNITY_INCLUDE_DOUBLE
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: gcc
|
|
||||||
options:
|
|
||||||
- -lm
|
|
||||||
- '-m64'
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.exe'
|
|
||||||
destination: *build_path
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,101 +1,91 @@
|
|||||||
# rumor has it that this yaml file works for the standard edition of the
|
---
|
||||||
# hitech PICC18 compiler, but not the pro version.
|
|
||||||
#
|
|
||||||
compiler:
|
|
||||||
path: cd build && picc18
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --chip=18F87J10
|
|
||||||
- --ide=hitide
|
|
||||||
- --q #quiet please
|
|
||||||
- --asmlist
|
|
||||||
- --codeoffset=0
|
|
||||||
- --emi=wordwrite # External memory interface protocol
|
|
||||||
- --warn=0 # allow all normal warning messages
|
|
||||||
- --errors=10 # Number of errors before aborting compile
|
|
||||||
- --char=unsigned
|
|
||||||
- -Bl # Large memory model
|
|
||||||
- -G # generate symbol file
|
|
||||||
- --cp=16 # 16-bit pointers
|
|
||||||
- --double=24
|
|
||||||
- -N255 # 255-char symbol names
|
|
||||||
- --opt=none # Do not use any compiler optimziations
|
|
||||||
- -c # compile only
|
|
||||||
- -M
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- '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/'
|
|
||||||
- *unit_tests_path
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_INT_WIDTH=16
|
|
||||||
- UNITY_POINTER_WIDTH=16
|
|
||||||
- CMOCK_MEM_STATIC
|
|
||||||
- CMOCK_MEM_SIZE=3000
|
|
||||||
- UNITY_SUPPORT_TEST_CASES
|
|
||||||
- _PICC18
|
|
||||||
object_files:
|
|
||||||
# prefix: '-O' # Hi-Tech doesn't want a prefix. They key off of filename .extensions, instead
|
|
||||||
extension: '.obj'
|
|
||||||
destination: *build_path
|
|
||||||
|
|
||||||
linker:
|
|
||||||
path: cd build && picc18
|
|
||||||
options:
|
|
||||||
- --chip=18F87J10
|
|
||||||
- --ide=hitide
|
|
||||||
- --cp=24 # 24-bit pointers. Is this needed for linker??
|
|
||||||
- --double=24 # Is this needed for linker??
|
|
||||||
- -Lw # Scan the pic87*w.lib in the lib/ of the compiler installation directory
|
|
||||||
- --summary=mem,file # info listing
|
|
||||||
- --summary=+psect
|
|
||||||
- --summary=+hex
|
|
||||||
- --output=+intel
|
|
||||||
- --output=+mcof
|
|
||||||
- --runtime=+init # Directs startup code to copy idata, ibigdata and ifardata psects from ROM to RAM.
|
|
||||||
- --runtime=+clear # Directs startup code to clear bss, bigbss, rbss and farbss psects
|
|
||||||
- --runtime=+clib # link in the c-runtime
|
|
||||||
- --runtime=+keep # Keep the generated startup src after its obj is linked
|
|
||||||
- -G # Generate src-level symbol file
|
|
||||||
- -MIWasTheLastToBuild.map
|
|
||||||
- --warn=0 # allow all normal warning messages
|
|
||||||
- -Bl # Large memory model (probably not needed for linking)
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.obj'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-O'
|
|
||||||
extension: '.hex'
|
|
||||||
destination: *build_path
|
|
||||||
|
|
||||||
simulator:
|
|
||||||
path:
|
|
||||||
pre_support:
|
|
||||||
- 'java -client -jar ' # note space
|
|
||||||
- ['C:\Program Files\HI-TECH Software\HI-TIDE\3.15\lib\', 'simpic18.jar']
|
|
||||||
- 18F87J10
|
|
||||||
post_support:
|
|
||||||
|
|
||||||
:cmock:
|
:cmock:
|
||||||
:plugins: []
|
:plugins: []
|
||||||
:includes:
|
:includes:
|
||||||
- Types.h
|
- Types.h
|
||||||
:suite_teardown: |
|
:suite_teardown: |
|
||||||
if (num_failures)
|
if (num_failures)
|
||||||
_FAILED_TEST();
|
_FAILED_TEST();
|
||||||
else
|
else
|
||||||
_PASSED_TESTS();
|
_PASSED_TESTS();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
colour: true
|
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
|
||||||
|
|||||||
@@ -1,90 +1,98 @@
|
|||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\'
|
---
|
||||||
compiler:
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 4.0 Kickstart\
|
||||||
path: [*tools_root, 'arm\bin\iccarm.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, '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
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\inc\']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r79'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'common\bin\xlink.exe']
|
|
||||||
options:
|
|
||||||
- -rt
|
|
||||||
- [*tools_root, '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
|
|
||||||
- [*tools_root, '\arm\config\lnkarm.xcl']
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\config\']
|
|
||||||
- [*tools_root, 'arm\lib\']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.r79'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.d79'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*tools_root, 'arm\bin\armproc.dll']
|
|
||||||
- [*tools_root, 'arm\bin\armsim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'arm\bin\armbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'arm\config\ioat91sam7X256.ddf']
|
|
||||||
- -d
|
|
||||||
- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,80 +1,92 @@
|
|||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 5.3\'
|
---
|
||||||
compiler:
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3\
|
||||||
path: [*tools_root, 'arm\bin\iccarm.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, '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
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\inc\']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
- 'iar\iar_v5\incIAR\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r79'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'arm\bin\ilinkarm.exe']
|
|
||||||
options:
|
|
||||||
- --redirect _Printf=_PrintfLarge
|
|
||||||
- --redirect _Scanf=_ScanfSmall
|
|
||||||
- --semihosting
|
|
||||||
- --entry __iar_program_start
|
|
||||||
- --config
|
|
||||||
- [*tools_root, 'arm\config\generic.icf']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.out'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*tools_root, 'arm\bin\armproc.dll']
|
|
||||||
- [*tools_root, 'arm\bin\armsim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'arm\bin\armbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'arm\config\debugger\atmel\ioat91sam7X256.ddf']
|
|
||||||
- -d
|
|
||||||
- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,80 +1,92 @@
|
|||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 5.3\'
|
---
|
||||||
compiler:
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3\
|
||||||
path: [*tools_root, 'arm\bin\iccarm.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, '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
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\inc\']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
- 'iar\iar_v5\incIAR\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r79'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'arm\bin\ilinkarm.exe']
|
|
||||||
options:
|
|
||||||
- --redirect _Printf=_PrintfLarge
|
|
||||||
- --redirect _Scanf=_ScanfSmall
|
|
||||||
- --semihosting
|
|
||||||
- --entry __iar_program_start
|
|
||||||
- --config
|
|
||||||
- [*tools_root, 'arm\config\generic.icf']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.out'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*tools_root, 'arm\bin\armproc.dll']
|
|
||||||
- [*tools_root, 'arm\bin\armsim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'arm\bin\armbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'arm\config\debugger\atmel\ioat91sam7X256.ddf']
|
|
||||||
- -d
|
|
||||||
- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,94 +1,90 @@
|
|||||||
#Default tool path for IAR 5.4 on Windows XP 64bit
|
---
|
||||||
tools_root: &tools_root 'C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\'
|
tools_root: C:\Program Files (x86)\IAR Systems\Embedded Workbench 5.4 Kickstart\
|
||||||
compiler:
|
|
||||||
path: [*tools_root, 'arm\bin\iccarm.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --diag_suppress=Pa050
|
|
||||||
#- --diag_suppress=Pe111
|
|
||||||
- --debug
|
|
||||||
- --endian=little
|
|
||||||
- --cpu=Cortex-M3
|
|
||||||
- --no_path_in_file_macros
|
|
||||||
- -e
|
|
||||||
- --fpu=None
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, 'arm\inc\DLib_Config_Normal.h']
|
|
||||||
#- --preinclude --preinclude C:\Vss\T2 Working\common\system.h
|
|
||||||
- --interwork
|
|
||||||
- --warnings_are_errors
|
|
||||||
# - Ohz
|
|
||||||
- -Oh
|
|
||||||
# - --no_cse
|
|
||||||
# - --no_unroll
|
|
||||||
# - --no_inline
|
|
||||||
# - --no_code_motion
|
|
||||||
# - --no_tbaa
|
|
||||||
# - --no_clustering
|
|
||||||
# - --no_scheduling
|
|
||||||
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\inc\']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
- 'iar\iar_v5\incIAR\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- ewarm
|
|
||||||
- PART_LM3S9B92
|
|
||||||
- TARGET_IS_TEMPEST_RB1
|
|
||||||
- USE_ROM_DRIVERS
|
|
||||||
- UART_BUFFERED
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r79'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'arm\bin\ilinkarm.exe']
|
|
||||||
options:
|
|
||||||
- --redirect _Printf=_PrintfLarge
|
|
||||||
- --redirect _Scanf=_ScanfSmall
|
|
||||||
- --semihosting
|
|
||||||
- --entry __iar_program_start
|
|
||||||
- --config
|
|
||||||
- [*tools_root, 'arm\config\generic.icf']
|
|
||||||
# - ['C:\Temp\lm3s9b92.icf']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.out'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
#- --silent
|
|
||||||
- [*tools_root, 'arm\bin\armproc.dll']
|
|
||||||
- [*tools_root, 'arm\bin\armsim2.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'arm\bin\armbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- --endian=little
|
|
||||||
- --cpu=Cortex-M3
|
|
||||||
- --fpu=None
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'arm\config\debugger\TexasInstruments\iolm3sxxxx.ddf']
|
|
||||||
- --semihosting
|
|
||||||
- --device=LM3SxBxx
|
|
||||||
#- -d
|
|
||||||
#- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,84 +1,94 @@
|
|||||||
# unit testing under iar compiler / simulator for STM32 Cortex-M3
|
---
|
||||||
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.4\
|
||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 5.4\'
|
|
||||||
compiler:
|
|
||||||
path: [*tools_root, 'arm\bin\iccarm.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, '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
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'arm\inc\']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
- 'iar\iar_v5\incIAR\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- 'IAR'
|
|
||||||
- 'UNITY_SUPPORT_64'
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r79'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'arm\bin\ilinkarm.exe']
|
|
||||||
options:
|
|
||||||
- --redirect _Printf=_PrintfLarge
|
|
||||||
- --redirect _Scanf=_ScanfSmall
|
|
||||||
- --semihosting
|
|
||||||
- --entry __iar_program_start
|
|
||||||
- --config
|
|
||||||
- [*tools_root, 'arm\config\generic_cortex.icf']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.out'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*tools_root, 'arm\bin\armproc.dll']
|
|
||||||
- [*tools_root, 'arm\bin\armsim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'arm\bin\armbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'arm\config\debugger\ST\iostm32f107xx.ddf']
|
|
||||||
- --cpu=Cortex-M3
|
|
||||||
- -d
|
|
||||||
- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,95 +1,112 @@
|
|||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\'
|
---
|
||||||
core_root: &core_root [*tools_root, '430\']
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\
|
||||||
core_bin: &core_bin [*core_root, 'bin\']
|
core_root: &1
|
||||||
core_config: &core_config [*core_root, 'config\']
|
- C:\Program Files\IAR Systems\Embedded Workbench 5.3 MSP430\
|
||||||
core_lib: &core_lib [*core_root, 'lib\']
|
- 430\
|
||||||
core_inc: &core_inc [*core_root, 'inc\']
|
core_bin: &2
|
||||||
core_config: &core_config [*core_root, 'config\']
|
- *1
|
||||||
|
- bin\
|
||||||
compiler:
|
core_config: &4
|
||||||
path: [*core_bin, 'icc430.exe']
|
- *1
|
||||||
source_path: '..\src\'
|
- config\
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
core_lib: &3
|
||||||
build_path: &build_path 'build\'
|
- *1
|
||||||
options:
|
- lib\
|
||||||
- --dlib_config
|
core_inc: &5
|
||||||
- [*core_lib, 'dlib\dl430fn.h']
|
- *1
|
||||||
- --no_cse
|
- inc\
|
||||||
- --no_unroll
|
|
||||||
- --no_inline
|
|
||||||
- --no_code_motion
|
|
||||||
- --no_tbaa
|
|
||||||
- --debug
|
|
||||||
- -e
|
|
||||||
- -Ol
|
|
||||||
- --multiplier=16
|
|
||||||
- --double=32
|
|
||||||
- --diag_suppress Pa050
|
|
||||||
- --diag_suppress Pe111
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- *core_inc
|
|
||||||
- [*core_inc, 'dlib']
|
|
||||||
- [*core_lib, 'dlib']
|
|
||||||
- 'src\'
|
|
||||||
- '../src/'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- '__MSP430F149__'
|
|
||||||
- 'INT_WIDTH=16'
|
|
||||||
- 'UNITY_EXCLUDE_FLOAT'
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.r43'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*core_bin, 'xlink.exe']
|
|
||||||
options:
|
|
||||||
- -rt
|
|
||||||
- [*core_lib, '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
|
|
||||||
- [*core_config, 'lnk430f5438.xcl']
|
|
||||||
- -f
|
|
||||||
- [*core_config, 'multiplier.xcl']
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- *core_config
|
|
||||||
- *core_lib
|
|
||||||
- [*core_lib, 'dlib']
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.r79'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.d79'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*core_bin, '430proc.dll']
|
|
||||||
- [*core_bin, '430sim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*core_bin, '430bat.dll']
|
|
||||||
- --backend -B
|
|
||||||
- --cpu MSP430F5438
|
|
||||||
- -p
|
|
||||||
- [*core_config, 'MSP430F5438.ddf']
|
|
||||||
- -d sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
@@ -1,86 +1,99 @@
|
|||||||
tools_root: &tools_root 'C:\Program Files\IAR Systems\Embedded Workbench 6.0\'
|
---
|
||||||
compiler:
|
tools_root: C:\Program Files\IAR Systems\Embedded Workbench 6.0\
|
||||||
path: [*tools_root, 'sh\bin\iccsh.exe']
|
|
||||||
source_path: '..\src\'
|
|
||||||
unit_tests_path: &unit_tests_path 'tests\'
|
|
||||||
build_path: &build_path 'build\'
|
|
||||||
options:
|
|
||||||
- -e
|
|
||||||
- --char_is_signed
|
|
||||||
- -Ol
|
|
||||||
- --no_cse
|
|
||||||
- --no_unroll
|
|
||||||
- --no_inline
|
|
||||||
- --no_code_motion
|
|
||||||
- --no_tbaa
|
|
||||||
- --no_scheduling
|
|
||||||
- --no_clustering
|
|
||||||
- --debug
|
|
||||||
- --dlib_config
|
|
||||||
- [*tools_root, '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
|
|
||||||
includes:
|
|
||||||
prefix: '-I'
|
|
||||||
items:
|
|
||||||
- [*tools_root, 'sh\inc\']
|
|
||||||
- [*tools_root, 'sh\inc\c']
|
|
||||||
- 'src\'
|
|
||||||
- '..\src\'
|
|
||||||
- 'testdata/'
|
|
||||||
- *unit_tests_path
|
|
||||||
- 'vendor\unity\src\'
|
|
||||||
defines:
|
|
||||||
prefix: '-D'
|
|
||||||
items:
|
|
||||||
- UNITY_SUPPORT_64
|
|
||||||
- 'UNITY_SUPPORT_TEST_CASES'
|
|
||||||
object_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.o'
|
|
||||||
destination: *build_path
|
|
||||||
linker:
|
|
||||||
path: [*tools_root, 'sh\bin\ilinksh.exe']
|
|
||||||
options:
|
|
||||||
- --redirect __Printf=__PrintfSmall
|
|
||||||
- --redirect __Scanf=__ScanfSmall
|
|
||||||
- --config
|
|
||||||
- [*tools_root, '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
|
|
||||||
object_files:
|
|
||||||
path: *build_path
|
|
||||||
extension: '.o'
|
|
||||||
bin_files:
|
|
||||||
prefix: '-o'
|
|
||||||
extension: '.out'
|
|
||||||
destination: *build_path
|
|
||||||
simulator:
|
|
||||||
path: [*tools_root, 'common\bin\CSpyBat.exe']
|
|
||||||
pre_support:
|
|
||||||
- --silent
|
|
||||||
- [*tools_root, 'sh\bin\shproc.dll']
|
|
||||||
- [*tools_root, 'sh\bin\shsim.dll']
|
|
||||||
post_support:
|
|
||||||
- --plugin
|
|
||||||
- [*tools_root, 'sh\bin\shbat.dll']
|
|
||||||
- --backend
|
|
||||||
- -B
|
|
||||||
- --core sh2afpu
|
|
||||||
- -p
|
|
||||||
- [*tools_root, 'sh\config\debugger\io7264.ddf']
|
|
||||||
- -d
|
|
||||||
- sim
|
|
||||||
colour: true
|
colour: true
|
||||||
:unity:
|
:unity:
|
||||||
:plugins: []
|
: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
|
||||||
|
|||||||
2
test/testdata/CException.h
vendored
2
test/testdata/CException.h
vendored
@@ -8,4 +8,4 @@
|
|||||||
#define Try if (e)
|
#define Try if (e)
|
||||||
#define Catch(a) if (!a)
|
#define Catch(a) if (!a)
|
||||||
|
|
||||||
#endif //CEXCEPTION_H
|
#endif
|
||||||
|
|||||||
2
test/testdata/Defs.h
vendored
2
test/testdata/Defs.h
vendored
@@ -5,4 +5,4 @@
|
|||||||
|
|
||||||
extern int CounterSuiteSetup;
|
extern int CounterSuiteSetup;
|
||||||
|
|
||||||
#endif //DEF_H
|
#endif
|
||||||
|
|||||||
2
test/testdata/cmock.h
vendored
2
test/testdata/cmock.h
vendored
@@ -11,4 +11,4 @@ void mockMock_Init(void) { mockMock_Init_Counter++; }
|
|||||||
void mockMock_Verify(void) { mockMock_Verify_Counter++; }
|
void mockMock_Verify(void) { mockMock_Verify_Counter++; }
|
||||||
void mockMock_Destroy(void) { mockMock_Destroy_Counter++; }
|
void mockMock_Destroy(void) { mockMock_Destroy_Counter++; }
|
||||||
|
|
||||||
#endif //CMOCK_H
|
#endif
|
||||||
|
|||||||
2
test/testdata/mockMock.h
vendored
2
test/testdata/mockMock.h
vendored
@@ -10,4 +10,4 @@ void mockMock_Init(void);
|
|||||||
void mockMock_Verify(void);
|
void mockMock_Verify(void);
|
||||||
void mockMock_Destroy(void);
|
void mockMock_Destroy(void);
|
||||||
|
|
||||||
#endif //MOCK_MOCK_H
|
#endif
|
||||||
|
|||||||
12
test/testdata/testRunnerGenerator.c
vendored
12
test/testdata/testRunnerGenerator.c
vendored
@@ -21,7 +21,10 @@
|
|||||||
|
|
||||||
/* Support for Meta Test Rig */
|
/* Support for Meta Test Rig */
|
||||||
#define TEST_CASE(a)
|
#define TEST_CASE(a)
|
||||||
void putcharSpy(int c) { (void)putchar(c);} // include passthrough for linking tests
|
|
||||||
|
/* Include Passthroughs for Linking Tests */
|
||||||
|
void putcharSpy(int c) { (void)putchar(c);}
|
||||||
|
void flushSpy(void) {}
|
||||||
|
|
||||||
/* Global Variables Used During These Tests */
|
/* Global Variables Used During These Tests */
|
||||||
int CounterSetup = 0;
|
int CounterSetup = 0;
|
||||||
@@ -105,10 +108,12 @@ void custtest_ThisTestPassesWhenCustomTeardownRan(void)
|
|||||||
TEST_ASSERT_EQUAL_MESSAGE(2, CounterTeardown, "Custom Teardown Wasn't Run");
|
TEST_ASSERT_EQUAL_MESSAGE(2, CounterTeardown, "Custom Teardown Wasn't Run");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef UNITY_EXCLUDE_TESTING_NEW_COMMENTS
|
||||||
//void test_NewStyleCommentsShouldBeIgnored(void)
|
//void test_NewStyleCommentsShouldBeIgnored(void)
|
||||||
//{
|
//{
|
||||||
// TEST_ASSERT_FAIL("New Style Comments Should Be Ignored");
|
// TEST_ASSERT_FAIL("New Style Comments Should Be Ignored");
|
||||||
//}
|
//}
|
||||||
|
#endif
|
||||||
|
|
||||||
void test_NotBeConfusedByLongComplicatedStrings(void)
|
void test_NotBeConfusedByLongComplicatedStrings(void)
|
||||||
{
|
{
|
||||||
@@ -117,10 +122,13 @@ void test_NotBeConfusedByLongComplicatedStrings(void)
|
|||||||
TEST_ASSERT_EQUAL_STRING_MESSAGE(crazyString, crazyString, "These Strings Are The Same");
|
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)
|
void test_NotDisappearJustBecauseTheTestBeforeAndAfterHaveCrazyStrings(void)
|
||||||
{
|
{
|
||||||
TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
|
TEST_ASSERT_TRUE_MESSAGE(1, "1 Should be True");
|
||||||
|
/* still should not break anything */
|
||||||
}
|
}
|
||||||
|
/* nor should this */
|
||||||
|
|
||||||
void test_StillNotBeConfusedByLongComplicatedStrings(void)
|
void test_StillNotBeConfusedByLongComplicatedStrings(void)
|
||||||
{
|
{
|
||||||
@@ -179,5 +187,3 @@ void suitetest_ThisTestPassesWhenCustomSuiteSetupAndTeardownRan(void)
|
|||||||
{
|
{
|
||||||
TEST_ASSERT_EQUAL_MESSAGE(1, CounterSuiteSetup, "Suite Setup Should Have Run");
|
TEST_ASSERT_EQUAL_MESSAGE(1, CounterSuiteSetup, "Suite Setup Should Have Run");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
5
test/testdata/testRunnerGeneratorSmall.c
vendored
5
test/testdata/testRunnerGeneratorSmall.c
vendored
@@ -13,7 +13,10 @@ TEST_FILE("some_file.c")
|
|||||||
|
|
||||||
/* Support for Meta Test Rig */
|
/* Support for Meta Test Rig */
|
||||||
#define TEST_CASE(a)
|
#define TEST_CASE(a)
|
||||||
void putcharSpy(int c) { (void)putchar(c);} // include passthrough for linking tests
|
|
||||||
|
/* Include Passthroughs for Linking Tests */
|
||||||
|
void putcharSpy(int c) { (void)putchar(c);}
|
||||||
|
void flushSpy(void) {}
|
||||||
|
|
||||||
/* Global Variables Used During These Tests */
|
/* Global Variables Used During These Tests */
|
||||||
int CounterSetup = 0;
|
int CounterSetup = 0;
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user