Skip to main content

Framework for automating tests involving hardware test fixtures.

Project description

Documentation Status Build status MIT license Supported Python Versions Pypi Release Version Sonarcloud Quality Gate Sonarcloud coverage Sonarcloud bugs

A delicious Nanaimo bar

A delicious Python treat that makes on-target testing sweet and satisfying.

Nanaimo is a set of utilities and plugins designed to enable integration of hardware test apparatuses with pytest. This can allow on-target tests to run as part of continuous integration pipelines like Buildkite, Bamboo, or Jenkins.

S32K evaluation boards attached to Raspberry PIs.

Example of S32K dev boards attached to Raspberry PI CI workers running the Buildkite agent and using Nanaimo.

Nanaimo is designed to enable testing of software-defined, physical components in isolation to provide pre-integration verification of software interfaces and behavioral contracts. It adapts asynchronous control and monitoring of these components to fit familiar testing idioms (e.g. x-unit testing) using the popular python test framework, pytest.

Block diagram of Nanaimo's relationship to other components of a typical software build and test pipeline.

Block diagram of Nanaimo’s relationship to other components of a typical software build and test pipeline.

Nanaimo is not a simulation framework and is not designed to support the complexity of a full hardware-in-the-loop platform. Instead it’s focused on testing small integrations with a few hardware components and instruments using concepts, syntax, and frameworks familiar to software engineers. Examples of these small integrations might include verifying a SPI driver for a microcontroller or ensuring the upload time for a serial bootloader meets expected Key-Performance-Indicators (KPIs). To do this Nanaimo abstractions provide async interfaces to hardware either directly using available communication protocols (e.g. serial or IP networks) or by invoking a CLI provided by the instrument vendor. Because of this latter use case some instruments will require additional programs be available in a test environment.

Example scenario using Nanaimo to test an I2C driver for a microcontroller.

Example scenario using Nanaimo to test an I2C driver for a microcontroller.

This design is an amalgam of the TLYF (Test Like You Fly) methodology and the Swiss cheese model of failure analysis. Specifically; Nanaimo facilitates testing on actual or representative hardware for the first integration of software into a part or subassembly. Traditionally software engineers were responsible only for unit-testing and Software-In-the-Loop (SIL) simulation of their code. Nanaimo encourages software engineers to also provide hardware integration tests by enabling Hardware-In-the-Loop continuous-integration (HIL-CI, perhaps?).

Hierarchy of system testing.

Hierarchy of system testing. Nanaimo focuses on part and subassembly testing.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nanaimo-0.2.5.tar.gz (56.0 kB view details)

Uploaded Source

Built Distribution

nanaimo-0.2.5-66-py3-none-any.whl (62.8 kB view details)

Uploaded Python 3

File details

Details for the file nanaimo-0.2.5.tar.gz.

File metadata

  • Download URL: nanaimo-0.2.5.tar.gz
  • Upload date:
  • Size: 56.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.4

File hashes

Hashes for nanaimo-0.2.5.tar.gz
Algorithm Hash digest
SHA256 1f0a7a8d9a64978f0206b958dbe4e76eff569b3c97949db856eb7d569ffca319
MD5 bc108c004ec886db71310e24310928b9
BLAKE2b-256 c544f491f669c60fa70025d2a3d72f53425cbaf4b95970190bf299321aa7029d

See more details on using hashes here.

File details

Details for the file nanaimo-0.2.5-66-py3-none-any.whl.

File metadata

  • Download URL: nanaimo-0.2.5-66-py3-none-any.whl
  • Upload date:
  • Size: 62.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.4

File hashes

Hashes for nanaimo-0.2.5-66-py3-none-any.whl
Algorithm Hash digest
SHA256 9aef267a3301a5473352455e03149c7dbfdf87c0e1a00a802eda6378d5ed7fe6
MD5 f809b530b60b7e90bbe1811b5563d0e0
BLAKE2b-256 2f8227a60ed7a62f242d88381276a62ce3796942e391e8490da46120d566290c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page