Skip to main content

Pytest Plugin for communicating test results and information to a FixturFab Test Runner GUI

Project description

pytest-f3ts

Use your pytest test plans with the FixturFab Test Executor!

Manage, Execute, and Support your Hardware Test Plan Deployments

Leverage the amazingness that is pytest and all of the community support to implement hardware tests for circuit boards, sub-assemblies and more!

Simply add the pytest-f3ts plugin and a config.yml test plan to your project and start executing your tests using the FixturFab Test Executor.

Installation

Install from PyPI with pip:

pip install pytest-f3ts

Or add it to a project managed with poetry:

poetry add pytest-f3ts

Documentation

See the docs for more information.

Development

Environment Setup

poetry is used for dependency management and pre-commit is used to identify simple issues before submission for code review. Once installed, run the following commands to setup your development environment:

poetry install
pre-commit install

Making changes

Use the following process when making changes to the module:

  1. Create new test cases
  2. Write new feature code and/or bugfixes
  3. Write documentation for new features
  4. Run pre-commit checks and tests prior to committing

To run the pre-commit checks, simply run the following:

poetry run pre-commit run --all-files

Git Commit Message Format

We use Conventional Commits for our commit messages. This allows us to automatically generate changelogs and version numbers.

Brief Overview:

  • fix: - Fixes a bug
  • feat: - Adds a new feature
  • docs: - Updates documentation
  • style: - Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
  • refactor: - A code change that neither fixes a bug nor adds a feature
  • perf: - A code change that improves performance
  • test: - Adding missing tests or correcting existing tests
  • chore: - Changes to the build process or auxiliary tools and libraries such as documentation generation
  • ci: - Changes to our CI configuration files and scripts
  • BREAKING CHANGE: - A commit that has a footer BREAKING CHANGE:, or appends a ! after the type/scope, introduces a breaking API change (correlating with MAJOR in semantic versioning).

Code Quality Tools

black

black is used for code formatting, this is configured within pyproject.toml

To run black manually, run:

poetry run black .

flake8

flake8 is used to enforce additional style guidelines.

To run flake8 manually, run:

poetry run flake8 ./pytest_f3ts

isort

isort is used to automatically reformat python module import statements.

To run isort manually, run:

poetry run isort .

pre-commit

To automatically check if code is ready to be committed and pushed to Gitlab pre-commit is used. This is configured via the .pre-commit-config.yml file.

To run pre-commit manually, run:

poetry run pre-commit run --all-files

Documentation Generation

mkdocs is utilized along with mkdocs-material to generate documentation for this project.

The docs directory contains the general structure for the documentation in the form of markdown files. To autogenerate additional documentation from docstrings, the mkdocstrings module is used.

Developing documentation with the live server

When creating additional documentation it's useful to run the mkdocs server which will live-reload the webpages as you make changes. To start this server, run the following in a terminal:

poetry run mkdocs serve

Adding a new file for autodocumentation

To add a new python file to the autodocumentation, open the docs/reference.md file. Add a new header to the file, and then add the line ::: pytest_f3ts.{new_file_name}, this will signal to mkdocstrings to process the new file when building the documentation

Manually building and uploading a wheel

poetry config repositories.pytest-f3ts https://us-west1-python.pkg.dev/test-runner-404519/pytest-f3ts/

# On windows you will need to run the following command as two separate commands
# and paste the token into the password prompt for the second command.
gcloud auth print-access-token | poetry config http-basic.pytest-f3ts oauth2accesstoken

poetry publish --repository pytest-f3ts --build

Pipeline Setup

The pipeline is configured via the .gitlab-ci.yml file. The pipeline is configured to run the following stages:

  • linting: Runs the black and isort checks (flake8 runs locally via pre-commit)
    • Occurs on all merge requests and is required to pass before a merge request can be merged
  • version: Runs the gen-semver.py command to update the version number
    • Occurs on the main branch after a merge request is accepted, and creates a new tag
  • build: Builds the wheel and publishes it to both the Google Cloud Artifact Registry and PyPI
    • Triggered by new tags, which are created by the version stage

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

pytest_f3ts-1.1.7.tar.gz (30.7 kB view details)

Uploaded Source

Built Distribution

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

pytest_f3ts-1.1.7-py3-none-any.whl (35.7 kB view details)

Uploaded Python 3

File details

Details for the file pytest_f3ts-1.1.7.tar.gz.

File metadata

  • Download URL: pytest_f3ts-1.1.7.tar.gz
  • Upload date:
  • Size: 30.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.10.20 Linux/5.15.154+

File hashes

Hashes for pytest_f3ts-1.1.7.tar.gz
Algorithm Hash digest
SHA256 cb5d63809845e7ab9ddaba87b98a386748e3dbe378ebec97bc9d1fc32ff15846
MD5 8b15119fb4e5c1dbeef769476e58acb2
BLAKE2b-256 808cedd5ac1a5f3a9d62b5f253bb5ab0348d3ed5f683e33753ea45ebce02e706

See more details on using hashes here.

File details

Details for the file pytest_f3ts-1.1.7-py3-none-any.whl.

File metadata

  • Download URL: pytest_f3ts-1.1.7-py3-none-any.whl
  • Upload date:
  • Size: 35.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.10.20 Linux/5.15.154+

File hashes

Hashes for pytest_f3ts-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 63dbe8aaf4fdf1770017cdb66e04fc0f4cff7b513fe0617da05af24dfb5e5ebf
MD5 07a35e4d97a063bfc1abde0aa8bc30ac
BLAKE2b-256 a0fdce9da03621a360d5dd703fbe0d47aa82d795ec57a1af540880b1aa263872

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