#requirements #coverage #testing #tracing #docker #id #tool

bin+lib mantra

mantra offers a lightweight approach for requirement tracing and coverage

11 releases (6 breaking)

new 0.7.5 Jan 7, 2025
0.7.3 Dec 22, 2024
0.6.2 Sep 3, 2024
0.6.1 Jul 4, 2024
0.2.14 Sep 21, 2023

#202 in Database interfaces

Download history 13/week @ 2024-09-21 8/week @ 2024-09-28 1/week @ 2024-10-05 2/week @ 2024-10-12 29/week @ 2024-12-07 278/week @ 2024-12-14 125/week @ 2024-12-21 37/week @ 2024-12-28 167/week @ 2025-01-04

607 downloads per month

MIT license

210KB
5K SLoC

Rust 4.5K SLoC // 0.0% comments SQL 503 SLoC // 0.1% comments

mantra

build-test docker

Manuels ANforderungs-TRAcing (or MANaged TRAcing)

mantra is a tool for easier tracing between requirements, implementation, and tests.

Checkout the usage example folder to see how requirement tracing with mantra works.

Core Concepts

IDs are used to identify requirements, and reference them in the implementation and/or tests. These requirement IDs must be set manually on the implementation and test side. mantra then adds available requirements and found traces into a SQL database for further analysis.

Using the trace information, test code coverage may be passed to mantra to get requirement coverage information.

Requirement ID

Every requirement must have a unique requirement ID. A requirement hierarchy may be created by using the parent ID as prefix followed by ..

Example:

req_id

req_id.sub_req_id

Requirement tracing

To get requirement traces, IDs may be referenced in the implementation and/or tests of your system/project. How requirement IDs are referenced may vary between programming languages. If no special syntax is defined for a file type, the default is to search for references having the form [req(<requirement id(s)>)].

Language specific tracing:

  • Rust: Uses mantra-rust-trace to collect requirement traces

    Add mantra-rust-macros to your dependencies to create requirement traces using the attribute macro req or the fn-like macro reqcov.

    Example:

    use mantra_rust_macros::{req, reqcov};
    
    #[req(req_id)]
    fn some_fn() {
      reqcov!(function_like_trace);
    }
    

Usage

Prerequisites

mantra uses the tree-sitter crate to find traces in source code. This crate requires access to a native C compiler.

Ensure cc is available on Path when installing mantra via cargo install.

Per CLI

mantra may be installed using cargo install mantra.

All information is stored in a SQL database and the connection may be set before any command using url. By default, the URL is sqlite://mantra.db?mode=rwc.

Note: Only SQLite is supported for now, because some SQL queries contain SQLite specific syntax.

  • Collect all data at once

    mantra collect [<filepath>]

    This will look for a TOML file at the given path. By default, the path is set to mantra.toml.

    File structure:

    # Project information that will be used by `mantra report`.
    # The CLI arguments overwrite these settings.
    #
    # All fields are optional.
    [project]
    name = "project-name"
    version = "0.1.0"
    repository = "<link to the project repository>"
    homepage = "<link to the project homepage>"
    
    # Template paths that will be used by `mantra report`.
    # The CLI arguments overwrite these settings.
    #
    # All fields are optional.
    [report-template]
    # The base template to use.
    # Mantra uses the integrated report template if no base template is set.
    base = "base-template.html"
    # The template used to render the custom `data` field for requirements.
    req-data = "data-template.html"
    # The template used to render the custom `data` field for test runs.
    test-run-data = "test-run-template.html"
    
    # Collect requirements from local Markdown files.
    [[requirements]]
    # Root path to start looking for requirements.
    # Empty means current directory.
    root = ""
    # Base URL for all requirements
    origin = "https://github.com/mhatzl/mantra-wiki/tree/main/5-Requirements/"
    
    # Collect requirements from JSON files adhering to the `RequirementSchema`.
    [[requirements]]
    # The path to JSON files containing requirements.
    files = ["requirements.json"]
    
    # Collect traces from local files
    [[traces]]
    # Root path to start looking for traces.
    # Empty means current directory.
    root = ""
    # If 'false', the filepath will be stored relativ to the root path.
    keep-path-absolute = false
    
    # Collect traces from JSON files adhering to the `TraceSchema`.
    [[traces]]
    # The path to JSON files containing traces.
    files = ["traces.json"]
    
    # Collect coverage from JSON files adhering to the `CoverageSchema`.
    [coverage]
    # Path to JSON files containing coverage.
    files = ["coverage.json"]
    
    # Collect reviews from TOML files adhering to the `ReviewSchema`.
    [review]
    # List of review files to add.
    files = ["first_review.toml"]
    
  • Generate a report

    mantra report --formats=html,json <file path>

    This will create an HTML and JSON report at the given file path. Optionally, a template file may be given via --template. Templates may use the Tera template language. The JSON form is passed to the template. If no template is given, the report_default_template is used.

    To render custom data like requirement and test-run data, the arguments --req-template and --test-run-template may be set to template files. These templates are then pre-rendered using Tera, and the rendered content is made available as rendered_data next to the regular data fields.

    Project name, version, repository, and homepage may be set using the arguments --project-name, --project-version, --project-repository, and --project-homepage. A tag name and link may also be set using the arguments --tag-name and --tag-link. Tags should be used to indicate the requirements-snapshot/tag the report was generated with.

    The template and project arguments may be set in the mantra.toml file, because these settings are assumed to not change much.

Manual Reviews

Requirements may be manually verified in reviews following the structure below:

name = "<review name>"
date = "<yyyy-mm-dd HH:MM[optional [:SS.fraction]]>"
reviewer = "<reviewer of this review>"
comment = "<optional: general comment for this review>"

[[requirement]]
id = "<verified requirement ID>"
comment = "<optional: comment for this specific ID>"

[[requirement]]
id = "<verified requirement ID>"
comment = "<optional: comment for this specific ID>"

License

MIT Licensed

Dependencies

~55–74MB
~1.5M SLoC