This format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
This changelog is complemented by two other documents:
- 🔊 Release Notes for announcements, education, acknowledgements, and known issues.
- 💔 Breaking Changes for a list of impacts to existing Ceedling projects.
As was explained in the Highlights, Ceedling can now run its internal tasks in parallel and take full advantage of your build system’s resources. Even lacking various optimizations (see Known Issues) builds are now often quite speedy.
Enabling this speedup requires either or both of two simple configuration settings. See Ceedling’s documentation for :project
↳ :compile_threads
and :project
↳ :test_threads
.
Ceedling now offers a full command line interface with rich help, useful order-independent option flags, and more.
The existing new
, upgrade
, example
, and exampples
commands remain but have been improved. For those commands that support it, you may now specify the project file to load (see new, related mixins feature discussed elsewhere), log file to write to, exit code handling behavior, and more from the command line.
Try ceedling help
and then ceedling help <command>
to get started.
See the Release Notes and CeedlingPacket for more on the new and improved command line.
Issue #743
Using what we are calling test build directive macros, you can now provide Ceedling certain configuration details from inside a test file.
See the documentation discussion on include paths, Ceedling conventions, and these macros to understand all the details.
Notes:
- Ceedling can preserves these test build directive macros through preprocessing of test files. However, wrapping
TEST_INCLUDE_PATH()
in conditional compilation C preprocessing statements (e.g.#ifdef
) can produce unexpected resutls (see documentation for more). - Both
TEST_INCLUDE_PATH()
&TEST_SOURCE_FILE()
can be disabled with standard C comments. - However, preprocessing of mockable header files can now be enabled separately (see
:project
↳:use_test_preprocessor
).
In short, TEST_INCLUDE_PATH()
allows you to add a header file search path to the build of the test executable in which it is found. This can mean much shorter compilation command lines and good flexibility for complicated projects. Unlike , TEST_SOURCE_FILE()
this should not be wrapped in conditional compilation preprocessing statements (see documentation for more).
In short, TEST_SOURCE_FILE()
allows you to be explicit as to which source C files should be compiled and linked into a test executable. Sometimes Ceedling’s convention for matching source files with test files by way of #include
d header files does not meet the need. This solves the problems of those scenarios. Unlike TEST_INCLUDE_PATH()
, this test build directive can be wrapped in in conditional compilation preprocessing statements (see documentation for more).
Thorough documentation on Mixins can be found in CeedlingPacket.
Once upon a time, you could load a project configuration in just two simple ways — project.yml in your working directory and an environment variable pointing to a different file. Those days are over.
You may now:
- Load your project configuration from a filepath provided at the command line.
- Load your project configuration from an environment variable hoding a filepath.
- Load your project configuration from the default project.yml in your working directory.
- Modify your configuration with Mixins loaded from your project file, environment variables, and/or from the command line.
All the options for loading and modifying a project configuration are thoroughly documented in CeedlingPacket).
Ceedling’s validation of your configuration has been significantly expanded to cover more sections and with more helpful error messages.
Previously Ceedling had a limited ability to detect and report segmentation faults and primarily only on Unix-like platforms. This has been expanded and improved to crash detection more broadly. Invalid memory accesses, stack overflows, heap errors, and branching problems can all lead to crashed test executables. Ceedling is now able to detect these across platforms and report on them appropriately.
Ceedling defaults to executing this new behavior. Optionally, it can be disabled or its reporting enhanced further by enabling the use of gdb
.
See CeedlingPacket) for the new :project
↳ :use_backtrace
feature to control how much detail is extracted from a crashed test executable to help you find the cause.
Issue #43
Each test executable is now built as a mini project. Using improved :flags
handling and an updated section format within Ceedling’s project configuration, you have much better options for specifying flags presented to the various tools within your build, particulary within test builds.
Each test executable is now built as a mini project. Using improved :defines
handling and an updated section format within Ceedling’s project configuration, you have much better options for specifying symbols used in your builds' compilation steps, particulary within test builds.
One powerful new feature is the ability to test the same source file built differently for different tests. Imagine a source file has three different conditional compilation sections. You can now write unit tests for each of those sections without complicated gymnastics to cause your test suite to build and run properly.
Inline Ruby string expansion has been, well, expanded for use in :flags
and :defines
entries to complement existing such functionality in :environment
, :paths
, :tools
, etc.
The previously distributed documentation for inline Ruby string expansion has been collected into a single subsection within the project file documentation and improved.
Previous versions of Ceedling had limited support for enabling builds of Unity’s parameterized test cases. Multiple configuration settings were needed to enable test builds with these test case features. Now, setting this single configuration value in the :unity
section of your Ceedling project configuration automatically assembles the correct compilation and test runner generation options.
This new plugin consolidates a handful of previously discrete report gernation plugins into a single plugin that also enables low-code, custom, end-user created reports.
The abilities of these previously independent plugins are now supersededed by configuration options for the single, new report_tests_log_factory
plugin:
junit_tests_report
json_tests_report
xml_tests_report
This new plugin also includes the option to generate an HTML report (see next section).
A community member submitted an HTML report generation plugin that was not officially released before 1.0. It has been absorbed into the new report_tests_log_factory
plugin (see previous section).
Segmentation faults are now reported as failures with as much details as possible instead of as build errors. If gdb
is available, Ceedling can now even automatically highlight the source of the segfault (see section above on crash detection).
Previous versions of Ceedling included support for including assembly code in release builds. Now Ceedling can include assembly code in test builds as well.
The default assembler is the GNU tool as
. Like all other tools it may be overridden in the :tools
section.
To enable this feature, use the following in your project configuration:
:test_build:
:use_assembly: TRUE
In order to inject assembly code files into the build of a test executable after enabling test build assembly code, two conditions must be true:
- The assembly files must be visible to Ceedling by way of
:paths
and:extension
settings for assembly files — just like C code files. - Ceedling must be told into which test executable build to insert a given assembly file. The easiest way to do so is with the new
TEST_SOURCE_FILE()
build directive macro — described elsewhere in this Changelog and documented in CeedlingPacket.
When either :test_build
↳ :use_assembly
or :release_build
↳ :use_assembly
are enabled, Ceedling’s command line files:
tasks will list assembly files among the files it discovers from your project configuration. That is, you can confirm your settings for assembly code with those tasks. See CeedlingPacket’s documentation for the command line.
Ceedling logging now optionally includes emoji and nice Unicode characters. Ceedling will attempt to determine if your platform supports it. You can use the environment variable CEEDLING_DECORATORS
to force the feature on or off. See the documentation for logging decorators in CeedlingPacket.
The application commands ceedling new
and ceedling upgrade
at the command line provide project creation and management functions. Optionally, these commands can vendor tools and libraries locally alongside your project. These vendoring options now include license files along with the source of the vendored tools and libraries.
ceedling version
output now includes the Git Commit short SHA in Ceedling’s build identifier and Ceedling’s path of origin.
🌱 Welcome to Ceedling!
Ceedling => #.#.#-<Short SHA>
----------------------
<Ceedling install path>
Build Frameworks
----------------------
CMock => #.#.#
Unity => #.#.#
CException => #.#.#
If the short SHA information is unavailable such as in local development, the SHA is omitted. The source for this string is generated and captured in the Gem at the time of Ceedling’s automated build in CI.
A shortcut for adding arguments to an existing tool defition already existed. The handling for this shortcut has been expanded to allow :executable
to be redefined.
:tools_test_compiler:
:executable: foo # Shell out for `foo` instead of `gcc`
:arguments: # Existing functionality
- --flag1 # Add the following at the end of existing list of command line arguments
- --flag2
Starting with gcovr
v6.0 (now at v7.2), report generation can encounters a fatal error if multiple coverage results exist for the same function. This is a very possible scenario with Ceedling 1.0.0 now being able to build and run the same same test executable multiple ways.
Support for this option, enacted based on gcovr
’s reported version, has been added to the Gcov plugin with a reasonable default setting.
Most project configurations are relatively simple, and Ceedling’s features for collecting paths worked fine enough. However, bugs and ambiguities lurked. Further, insufficient validation left users resorting to old fashioned trial-and-error troubleshooting.
Much glorious filepath and pathfile handling now abounds:
- The purpose and use of
:paths
and:files
has been clarified in both code and documentation.:paths
are directory-oriented while:files
are filepath-oriented. - Documentation is now accurate and complete.
- Path handling edge cases have been properly resolved (
./foo/bar
is the same asfoo/bar
but was not always processed as such). - Matching globs were advertised in the documentation (erroneously, incidentally) but lacked full programmatic support.
- Ceedling now tells you if your matching patterns don't work. Unfortunately, all Ceedling can determine is if a particular pattern yielded 0 results.
This fix addresses the problem detailed in PR #728 and related issues.
CMock can optionally mock inline functions. This requires ingesting, modifying, and rewriting a source hearder file along with then mocking it. Sophisticated header files with complex macros can require that the source header file be preprocessed before CMock then processes it a second time. In previous versions of Ceedling the preprocessing steps and handoff to CMock were not working as intended. This has been fixed.
Issue #621
For certain advanced testing scenarios test runners generated by Ceedling + Unity must have the same #include
list as that of the test file itself from which a runner is gnerated. Previous versions of Ceedling did not provide the proper list of #include
directives to runner generation. This has been fixed.
Longstanding bugs produced duplicate and sometimes incorrect lists of header files. Similarly, support file lists were not properly expanded from globs. Both of these problems have been fixed. The files:header
command line task has replaced the files:include
task.
Issue #780
In certain combinations of Ceedling features, a dash in a C filename could cause Ceedling to exit with an exception. This has been fixed.
Issue #110
Ceedling has long had the ability to configure a source filename extension other than .c
(:extension
↳ :source
). However, in most circumstances this ability would lead to broken builds. Regardless of user-provided source files and filename extenion settings, Ceedling’s supporting frameworks — Unity, CMock, and CException — all have .c
file components. Ceedling also generates mocks and test runners with .c
filename extensions regardless of any filename extension setting. Changing the source filename extension would cause Ceedling to miss its own core source files. This has been fixed.
The most commonly reported bugs have been fixed:
nil
references- Exit code issues with recent releases of
gcov
- Empty coverage results and related build failures
A handful of small bugs in using shell echo
with the ASCII bell character have been fixed.
A previously semi-documented feature allowed you to point to a version of Ceedling on disk to run from within your project file, :project
↳ :which_ceedling
.
This feature is primarily of use to Ceedling developers but can be useful in other specialized scenarios. See the documentation in CeedlingPacket) for full deatils as this is an advanced feature.
The existing feature has been improved with logging and validation as well as proper documentation. An environment variable WHICH_CEEDLING
is now also supported. If set, this variable supersedes any other settings. In the case of ceedling new
and ceedling upgrade
, it is the only way to change which Ceedling is in use as a project file either does not exist for the former or is not loaded for the latter.
Previous versions of Ceedling made assumptions about file naming conventions — specifically that the only place a period occurred was in a filename extension. In reality, C supports the same basic filenames as any file system does. Filenames can include periods throughout their name.
As an example, some legacy code includes a versioning scheme in the name itself — foo.12.h. Such names would previously break builds. This has been fixed.
Preprocessing refers to expanding macros and other related code text manipulations often needed in sophisticated projects before key test suite generation steps. Without (optional) preprocessing in complicated code bases, generating test runners from test files and generating mocks from header files lead to all manner of build shenanigans.
The preprocessing needed by Ceedling for sophisticated projects has always been a difficult feature to implement. The most significant reason is simply that there is no readily available cross-platform C code preprocessing tool that provides Ceedling everything it needs to accomplish this task. Even gcc’s cpp
preprocessor tool comes up short. Over time Ceedling’s attempt at preprocessing grew more brittle and complicated as community contribturs attempted to fix it or cause it to work properly with other new features.
This release of Ceedling stripped the feature back to basics and largely rewrote it. Complicated regular expressions and Ruby-generated temporary files have been eliminated. Instead, Ceedling now blends two reports from gcc’s cpp
tool and complements this with additional context. In addition, preprocessing now occurs at the right moments in the build pipeline.
While this new approach is not 100% foolproof, it is far more robust and far simpler than previous attempts. Other new Ceedling features should be able to address shortcomings in edge cases.
Options and support for loading a project configuration have expanded significantly, mostly notably with the addition of Mixins.
The environment variable option for pointing Ceedling to a project file other than project.yml in your working directory has been renamed CEEDLING_MAIN_PROJECT_FILE
➡️ CEEDLING_PROJECT_FILE
.
Documentation on Mixins and the new options for loading a project configuration are thoroughly documented in CeedlingPacket).
Ceedling’s previous handling of defaults and configuration processing order certainly worked, but it was not as proper as it could be. To oversimplify, default values were applied in an ordering that caused complications for advanced plugins and advanced users. This has been rectified. Default settings are now processed after all user configurations and plugins.
:project
↳ :use_test_preprocessor
is no longer a binary setting (true/false). What is preprocessed can be chosen with the options :none
, :tests
, :mocks
, :all
.
:none
maps to the previous false option (preprocessing disabled).:all
maps to the previous true option running preprpocessing for all mockable header files and test C files.:mocks
enables only preprocessing of header files that are to be mocked.:tests
enables only preprocessing of your test files.
- The plugin subsystem has incorporated logging to trace plugin activities at high verbosity levels.
- Additional events have been added for test preprocessing steps (the popular and useful
command_hooks
plugin has been updated accordingly). - Built-in plugins have been updated for thread-safety as Ceedling is now able to execute builds with multiple threads.
Logging messages are more useful. A variety of logging messages have been added throughout Ceedling builds. Message labels (e.g. ERROR:
) are now applied automatically). Exception handling is now centralized and significantly cleans up exception messages (backtraces are available with debug verbosity).
Be default Ceedling terminates with an exit code of 1
when a build succeeds but unit tests fail.
A previously undocumented project configuration option :graceful_fail
could force a Ceedling exit code of 0
upon test failures.
This configuration option has moved but is now documented. It is also available as a new command line argument (--graceful-fail
).
:test_build:
:graceful_fail: TRUE
Segmentation faults are now reported as failures instead of an error with as much detail as possible. See the project configuration file documentation discussing the :project
↳ :use_backtrace
option for more!
The application commands ceedling new
and ceedling upgrade
at the command line provide options for local copies of documentation when creating or upgrading a project. Previous versions of Ceedling used a flat file structure for the docs/ directory. Ceedling now uses subdirectories to organize plugin and tool documentation within the docs/ directory for clearer organization and preserving original filenames.
The three previously discrete plugins listed below have been consolidated into a single new plugin, report_tests_log_factory
:
junit_tests_report
json_tests_report
xml_tests_report
report_tests_log_factory
is able to generate all 3 reports of the plugins it replaces, a new HTML report, and custom report formats with a small amount of user-written Ruby code (i.e. not an entire Ceedling plugun). See its documentation for more.
The report format of the previously independent xml_tests_report
plugin has been renamed from XML in all instances to CppUnit as this is the specific test reporting format the former plugin and new report_tests_log_factory
plugin outputs.
In some circumstances, JUnit report generation would yield an exception in its routines for reorganizing test results (Issues #829 & #833). The true source of the nil test results entries has likely been fixed but protections have also been added in JUnit report generation as well.
- Documentation has been significantly updated including a Troubleshooting for common issues.
- Compilation with coverage now only occurs for the source files under test and no longer for all C files (i.e. coverage for unity.c, mocks, and test files that is meaningless noise has been eliminated).
- Coverage summaries printed to the console after
gcov:
test task runs now only concern the source files exercised instead of all source files. A final coverage tally has been restored. - Coverage summaries can now be disabled.
- Coverage reports are now automatically generated after
gcov:
test tasks are executed. This behvaior can be disabled with a new configuration option. When enabled, a separate task is made available to trigger report generation. - To maintain consistency, repports generated by
gcovr
andreportgenerator
are written to subdirectories named for the respective tools benath thegcov/
artifacts path.
See the gcov plugin’s documentation.
- The plugin creates a compilation database that distinguishes the same code file compiled multiple times with different configurations as part of the new test suite build structure. It has been updated to work with other Ceedling changes.
- Documentation has been greatly revised.
- Additional sound tools —
:tput
,:beep
, and:say
— have been added for more platform sound output options and fun. - Documentation has been greatly revised.
- The plugin more properly uses looging and system shell calls.
In previous versions of Ceedling, the Command Hooks plugin associated tools and hooks by a naming convention within the top-level :tools
section of your project configuration. This required some semi-ugly tool names and could lead to a rather unwieldy :tools
list. Further, this convention also limited a hook to an association with only a single tool.
Hooks are now enabled within a top-level :command_hooks
section in your project configuration. Each hook key in this configuration block can now support one or more tools organized beneath it. As such, each hook can execute one or more tools.
Reaching back to the earliest days of Ceedling, tool definitions supported two slightly different string replacement options that executed at different points in a build’s lifetime. Yeah. It was maybe not great. This has been simplfied.
Only support for #{...}
Ruby string expansion in tool definitions remains. Any such expansions are now evaluated each time a tool is executed during a build.
These command line features were implemented using Rake. That is, they were Rake tasks, not command line switches, and they were subject to the peculiarities of Rake tasks. Specifically, order mattered — these tasks had to precede build tasks they were to affect — and verbosity
required a non-standard parameter convention for numeric values.
These command line tasks no longer exist. They are now proper command line flags. These are most useful (and, in the case of logging, only availble) with Ceedling’s new build
command line argument. The build
command takes a list of build & plugin tasks to run. It is now complmented by --verbosity
, --log
, and --logfile
flags. See the detailed help at ceedling help build
for these.
The build
keyword is optional. That is, omitting it is allowed and operates largely equivalent to the historical Ceedling command line.
The previous command line of ceedling verbosity[4] test:all release
or ceedling verbosity:obnoxious test:all release
can now be any of the following:
ceedling test:all release --verbosity=obnoxious
ceedling test:all release -v 4
ceedling --verbosity=obnoxious test:all release
ceedling -v 4 test:all release
Note: In the above list Ceedling is actually executing as though ceedling build <args>
were entered at the command line. It is entirely acceptable to use the full form. The above list is provided as its form is the simplest to enter and consistent with the command line conventions of previous Ceedling versions.
Options files were a simple but limited way to merge configuration with your base configuration from the command line. This feature has been superseded by Ceedling Mixins.
The :import
project configuration section was a simple but limited way to merge configuration with your base configuration. This feature has been superseded by all new and more powerful Ceedling Mixins.
All “smart” test suite rebuild features built around Rake no longer exist. That is, incremental test suite builds for only changed files are no longer possible. Any test build is a full rebuild of its components (the speed increase due to parallel build tasks more than makes up for this).
These project configuration options related to smart builds are no longer recognized and likely will not return in this form:
:use_deep_dependencies
:generate_deep_dependencies
:auto_link_deep_dependencies
In future revisions of Ceedling, smart rebuilds will be brought back (without relying on Rake) and without a list of possibly conflicting configuation options to control related features.
Note: Release builds do retain a fair amount of smart rebuild capabilities. Release builds continue to rely on Rake (for now).
Temporarily removed preprocessor support for Unity’s parameterized test case macros TEST_CASE()
and TEST_RANGE()
Unity’s TEST_CASE()
and TEST_RANGE()
continue to work but only when :project
↳ :use_test_preprocessor
is not enabled for test files. The previous project configuration option :use_preprocessor_directives
that preserved these and other directive macros when preprocessing is enabled is no longer recognized.
TEST_CASE()
and TEST_RANGE()
are macros that disappear when the GNU preprocessor digests a test file. After preprocessing, these macros no longer exist in the test file that is compiled. They and some other macros are largely used as markers for advanced abilities discovered by parsing a test file rather than compiling it.
In future revisions of Ceedling, support for TEST_CASE()
and TEST_RANGE()
when test file preprocessing is enabled will be brought back (very likely without a dedicated configuration option — hopefully, we’ll get it to just work).
Note: :project
↳ :use_test_preprocessor
is no longer a binary setting (true
/false
). Mockable header file preprocessing can now be enabled with a :mocks
setting while test files are left untouched by preprocessing. This should support the majority of advanced use cases for preprocessing.
Note: :project
↳ :use_deep_preprocessor
is an additional setting which can be used to specify if the entire header include chain should be listed in generated mock and test files. Like the option above, it has options of :none
, :mocks
, :tests
and :all
. It is very likely :none
or :mocks
are the right choice for you.
Background task execution for tool configurations (:background_exec
) has been deprecated. This option was one of Ceedling’s earliest features attempting to speed up builds within the constraints of relying on Rake. This feature has rarely, if ever, been used in practice, and other, better options exist to manage any scenario that might motivate a background task.
Colored build output and test results in your terminal is glorious. Long ago the colour_report
plugin provided this. It was a simple plugin that hooked into Ceedling in a somewhat messy way. Its approach to coloring output was also fairly brittle. It long ago stopped coloring build output as intended. It has been removed.
Ceedling’s logging will eventually be updated to rely on a proper logging library. This will provide a number of important features along with greater speed and stability for the tool as a whole. This will also be the opportunity to add robust terminal text coloring support.
The Gcov plugin has been updated and improved, but its proprietary counterpart, the Bullseye plugin, is not presently functional. The needed fixes and updates require a software license that we do not (yet) have.
The configuration format for the gcovr
utility changed when support for the reportgenerator
utility was added. A format that accomodated a more uniform and common layout was adopted. However, support for the older, deprecated gcovr
-only configuration was maintained. This support for the deprecated gcovr
configuration format has been removed.
Please consult the gcov plugin’s documentation to update any old-style gcovr
configurations.
Like Ceedling’s preprocessing features, the Gcov plugin had grown in features and complexity over time. The plugin had become difficult to maintain and some of its features had become user unfriendly at best and misleading at worst.
The Gcov plugin’s :abort_on_uncovered
option plus the related :uncovered_ignore_list
option were not preserved in this release. They will be brought back after some noodling on how to make these features user friendly again.
A previously undocumented feature for merging a second configuration via environment variable CEEDLING_USER_PROJECT_FILE
has been removed. This feature has been superseded by the new Mixins functionality.
Reaching back to the earliest days of Ceedling, tool definitions supported two slightly different string replacement options that executed at different points in a build’s lifetime. Yeah. It was maybe not great.
Support for {...}
Ruby evaluation in tool definitions has been removed. Support for #{...}
Ruby string expansion in tool definitions remains.
Ceedling’s internal default tool definitions no longer incorporate (undocumented) environment variable lookups.
When Ceedling was very young and tool definitions were relatively simple, Ceedling’s defaults were configured to incorporate commonly used environment variables (e.g. CC_FLAGS
). This made sense at the time. As Ceedling’s tool processing grew in sophistication, this convention no longer made sense for a variety of reasons. All such references have been removed.
If you want to incorporate environment variables into your tool definitions, you may still do so. See the documentation for inline Ruby string exapnsion and the various options for defining or modifying a tool definition. In short, you may incorporate "#{ENV['<VAR>']}"
strings into your tooling.
This project setting existed from Ceedling’s earliest days and was a crude stand-in for command line debug verbosity handling.
It has been removed as it was rarely if ever utilized and needlessly complicated internal mechanisms for verbosity handling and project validation.