mantra 0.7.0

`mantra` offers a lightweight approach for requirement tracing and coverage.
# mantra


![build-test](https://github.com/mhatzl/mantra/actions/workflows/rust.yml/badge.svg?branch=main)
[![docker](https://github.com/mhatzl/mantra/actions/workflows/docker.yml/badge.svg?branch=main)](https://hub.docker.com/r/manuelhatzl/mantra)

**M**anuels **AN**forderungs-**TRA**cing (or **MAN**aged **TRA**cing)

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

Checkout the [usage example](/mantra/examples/) 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`]/langs/rust/mantra-rust-trace/README.md to collect requirement traces

  Add [`mantra-rust-macros`]/langs/rust/mantra-rust-macros/README.md to your dependencies to create requirement traces using
  the attribute macro `req` or the fn-like macro `reqcov`.

  **Example:**

  ```rust
  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](https://docs.rs/cc/latest/cc/#compile-time-requirements).

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:**

  ```toml
  # 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]https://keats.github.io/tera/docs/ template language.
  The JSON form is passed to the template.
  If no template is given, the [report_default_template]/mantra/src/cmd/report_default_template.html 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]https://keats.github.io/tera/docs/,
  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:

```toml
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