Skip to main content

NTFC for NuttX

Project description

NTFC

NuttX Test Framework for Community.

What is NTFC?

NTFC is a Python-based testing framework designed to automate the testing of NuttX RTOS on various platforms. It provides a structured way to develop, discover, and execute test cases against NuttX configurations.

Purpose

NTFC enables developers to:

  • Validate NuttX functionality across different configurations and hardware targets

  • Automate test execution on NuttX devices for real hardware and host-based target

  • Detect system failures including OS crashes and busy loop conditions

  • Dynamically discover applicable tests based on the NuttX image configuration

  • Standardize testing workflows using pytest, a widely-adopted Python testing framework

How It Works

NTFC acts as a bridge between pytest and NuttX devices/simulators:

  1. Loads a NuttX YAML configuration specifying the target device and build parameters

  2. Builds or prepares the NuttX image (optionally flashing to hardware)

  3. Discovers which test cases are applicable based on the NuttX configuration and ELF symbols

  4. Executes tests by sending NSH commands to the running NuttX instance

  5. Validates command output and monitors for system failures

This tool requires at least Python 3.10. Not tested with earlier versions of Python.

Features

  • NuttX simulator, QEMU and devices with serial port are supported

  • Run the command from NSH and compare with the expected output

  • OS crash detection and busy loop detection

  • Detection of supported test cases for a given NuttX image based on the configuration and image ELF file

Installation

NTFC can be installed from source using pip. PyPI package release is planned for future versions.

git clone <PATH_TO_NTFC_REPO>
cd ntfc
pip install -e .

NTFC requires Python 3.10 or later (not tested with older Python).

Optional dependencies

  • pytest-html - for HTML test reports
  • pytest-json - for JSON test reports

Documentation

Documentation is available in the Documentation/ directory. You can build the HTML documentation using Sphinx:

pip install -r Documentation/requirements.txt
cd Documentation
make html

The generated HTML will be available in Documentation/_build/html/index.html.

See Documentation/quickstart for a quick start guide and Documentation/usage for detailed usage information.

Preparing the Image for Testing

  • CONFIG_DEBUG_SYMBOLS is required for automatic command detection
  • CONFIG_DEBUG_FEATURES=y and CONFIG_DEBUG_ASSERTIONS=y are recommended for better error detection

Test Cases

Currently available test case repositories:

For guidance on writing your own test cases, see Documentation/writing-test-cases.

Contributing

To get started with developing NTFC, see CONTRIBUTING.md.

The roadmpa for the project can be found in ROADMAP.

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

ntfc-0.0.2.tar.gz (105.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ntfc-0.0.2-py3-none-any.whl (132.9 kB view details)

Uploaded Python 3

File details

Details for the file ntfc-0.0.2.tar.gz.

File metadata

  • Download URL: ntfc-0.0.2.tar.gz
  • Upload date:
  • Size: 105.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for ntfc-0.0.2.tar.gz
Algorithm Hash digest
SHA256 1b16901b80ffaed7590ae3255c91abbe4260fc2358e05e3f4c266dcf44bddf53
MD5 7688fda68b8e267abea32bf66e33ee0a
BLAKE2b-256 f3885ead21804f192f54925213729634408865cb0599901aeb6e9eafc982058a

See more details on using hashes here.

File details

Details for the file ntfc-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: ntfc-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 132.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for ntfc-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e33c179959b459cbe0340ce760d2cce6d4c134baadf3ef0f9e8c5036b562909e
MD5 77f8a8eb540a31abc96547524f88b9e9
BLAKE2b-256 5d8ec4a2153367ad10d27f04875369e279884a0265f0db0c96873d7a248ca7f1

See more details on using hashes here.

Supported by

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