Assert statements are a great tool for programming defensively. This is especially true in embedded systems where we don't typically have a lot of user interface to help our users figure out an error. Often it's better to crash or reset the application programmatically than risk executing the code in and undefined state. But how do you write unit tests for code that can assert?Read More
Including mocks in your tests means that those tests know a lot about the internal implementation of the unit under test. Make a change in the interface of any mocked module, and you not only drive changes in every caller of that interface, you create a cascading series of changes in the tests for each of those callers as well.
Because tests that rely on mocks are prone to breakage, or brittle, they're an active disincentive for making changes to existing code. You're forced to either update the tests with every change you make, allow the tests to break and lose the benefits of unit testing, or just avoid making changes to the code.Read More
It's super useful to write and test embedded software... but hardware interfaces can be tough.
How do we write code that needs to access hardware, without it?Read More
For most of my time as an embedded software developer, I almost exclusively wrote code that was going to be run on some microcontroller. I'd fire up the IDE, crank out some code, download (this often took a couple minutes) an run. Then I'd somehow try to figure out if what I had written was correct.Read More
Unit testing is great for verifying the behavior of individual modules, but how do you put those modules together in a way that makes things testable?
One of the most useful ways I've found to do this is to think about the system in terms of events.Read More
This is the third of a three video series to show how to quickly get started with Ceedling for test driven development in C -- by test driving a simple "FizzBuzz" example.
In the previous video we test drove a simple example -- writing the tests along with the code.
In this video we look at how to use Ceedling to build a release binary (it's pretty easy!).
In this example we used native GCC to compile for our host platform, but you can could the
release_compiler setting in the project.yml file to compile for whatever target you want.
I hope you enjoyed this quick intoduction to test-driving embedded software with Ceedling. If you're new to unit testing or test driven developement, Ceedling is a really great way to get started. In just a few minutes we were able to create a new project and develop a high quality, well-tested FizzBuzz implementation.
This is the second of a three video series to show you how to quickly get started with Ceedling, by test driving a simple "FizzBuzz" example.
In this video we test drive a simple FizzBuzz example in C -- writing the tests as we go -- and using Ceedling to run the tests.Read More
This is the first of a three video series to show how to quickly get started with Ceedling, by test driving a simple "FizzBuzz" example.
In this video we introduce our example problem, create Ceedling project, create a source code module (easily using Ceedling!) and look at how to run the tests.Read More
Have you tried to use Ceedling recently, but got this error when you tried to run rake?
No Rakefile found (looking for: rakefile, Rakefile, rakefile.rb, Rakefile.rb)Read More
Do your embedded applications ever save any data to flash memory (aka EEPROM)? This where you typically store non-volatile information that needs to preserved if the device is powered down.
This sort of thing is tough to test in the traditional way -- by loading code onto the target and running it -- because it's hard to set and _re-set_ the data in flash for testing. It can also be harder to inspect the data when it's in flash memory.Read More
I don't know about you, but a very natural way for me to think about designing embedded software is from the "outside in". I've been thinking about this a bit recently, and I'm not so sure that's the best approach.Read More
So you write embedded software in C and you think that unit testing might help you do it better. You already know about creating well-defined software modules and how this makes it easier to write unit tests. But what else can you do to make these modules easier to test? What are some more coding patterns that make unit testing easier?Read More
So you write embedded software in C and you've read about unit testing. You think unit tests will help you write better software, but how do you actually write code that's testable? What are some coding patterns that make unit testing easier?Read More
You want to try unit testing your embedded software but there's a problem -- you've got an existing project and a whole lot of code already written. Maybe it's even embedded legacy code.Read More
If you want to do embedded test-driven development (TDD), running your automated unit tests on the target is too slow. When you're test-driving, you're running the tests very frequently. You will not want to wait for the tests to download to the target. It will disrupt your flow and you'll get more easily distracted.Read More
I've created a plug-in for Ceedling which lets you use the Fake Function Framework (instead of CMock) to automatically create the mock interfaces used in your unit tests. You can find the plug-in (along with complete instructions for how to use it) in the GitHub repository.Read More
Do you write embedded software? Looking for an introduction to unit testing?
I've written a bit of an introduction to unit testing, especially for embedded systems developers.Read More
Catch is a unit testing framework that has some interesting (better!) ways to write tests for C and C++.
Instead of naming your tests with function calls, you can write your tests as a nested series of Given-When-Then statements.Read More
Did you know you have options when it comes to creating mocks for your C-language unit tests?
I've been spending a lot of time working with CMock -- since it's used by Ceedling -- but I've just been checking out FFF (the "fake function framework"). It's well done and I think it deserves a closer look.Read More
How can you unit test your embedded software? What about your hardware dependencies?
The secret is mocking.
We can mock the interfaces to our hardware so that we don't need the actual hardware to test.Read More