A modern, readable, CI/CD-friendly Markdown report formatter for Behave.
Project description
Behave Markdown Report
A modern, readable, CI/CD-friendly Markdown report formatter for the Behave BDD framework.
It generates a single report.md that you can publish directly to GitHub, GitHub Actions Summaries, GitLab, Azure DevOps, Jenkins, Bitbucket, wikis, or any Markdown viewer.
See a generated example report at examples/report.md.
See a generated step catalog at examples/step_catalog.md.
Table of Contents
- Why Markdown?
- Features
- Installation
- Quick start
- Configuration
- Attachments
- Examples
- Report layout
- Architecture
- Documentation
- Development
- Changelog
- License
Why Markdown?
- Works everywhere — no JavaScript, no external assets, no HTML sanitization issues.
- CI-native — GitHub Actions, GitLab, and Azure DevOps render Markdown summaries out of the box.
- Diff-friendly — line-based changes make PR reviews easier.
- Portable — one file, easy to archive, email, or paste into an issue.
Features
- Single-file Markdown output with a table of contents and internal links.
- Executive summary showing passed, failed, and skipped counts with status icons.
- Feature summary table with links and durations.
- Tag statistics table with pass rate per tag.
- Failed scenarios section with error messages and tracebacks.
- Slowest scenarios top-10 list.
- Scenario details with collapsible sections, Gherkin backgrounds, data tables, and doc strings.
- Environment section with Python, Behave, OS, Git, and CI environment details.
- Step catalog formatter that statically analyses
features/steps/and produces a Markdown catalog with patterns, parameters, docstrings, source code, and statistics. - Attachments rendered inline: images, JSON, XML, HTML, logs, and plain text.
- No heavy dependencies — only the Python standard library and
behave.
Installation
Install from PyPI:
pip install behave-modern-md-report
Or install from source:
git clone https://github.com/MathiasPaulenko/behave-modern-md-report.git
cd behave-modern-md-report
pip install -e .
For development, install with the extra dependencies:
pip install -e ".[dev]"
Quick start
Markdown report
- Create or update
behave.iniin your Behave project root:
[behave]
format = markdown
outfiles = report.md
[behave.formatters]
markdown = behave_modern_md_report.formatter:BehaveMarkdownFormatter
- Run Behave:
behave
- Open
report.mdin any Markdown viewer.
If you prefer not to register the short name, use the full formatter path:
behave -f behave_modern_md_report.formatter:BehaveMarkdownFormatter -o report.md
Step catalog
- Register the formatter in
behave.ini:
[behave.formatters]
stepcatalog = behave_modern_md_report.step_catalog_formatter:StepCatalogMarkdownFormatter
- Run Behave with the
stepcatalogformatter:
behave -f stepcatalog -o step_catalog.md --no-skipped
- Open
step_catalog.md— it contains a table of all step definitions, their patterns, parameters, docstrings, source code, and aggregate statistics.
You can also combine both formatters in a single run:
[behave]
format = markdown
stepcatalog
outfiles = report.md
step_catalog.md
Configuration
All options are passed through Behave's userdata mechanism. Add a [behave.userdata] section to behave.ini:
[behave.userdata]
bmr.title = My Report
bmr.project_name = My Project
bmr.company = My Company
bmr.include_passed = true
bmr.include_skipped = true
bmr.include_traceback = true
bmr.include_environment = true
bmr.sort_failed_first = true
bmr.max_traceback_lines = 0
bmr.steps_dir = features/steps
You can also override options from the command line:
behave -D bmr.title="Nightly Report" -D bmr.include_environment=false
See docs/configuration.md for the full reference and troubleshooting.
Attachments
Capture screenshots, logs, JSON, or files directly from your features/environment.py hooks:
from behave_modern_md_report import attach_screenshot, log
def after_step(context, step):
if step.status == "failed":
log(context, f"URL at failure: {getattr(context, 'url', 'unknown')}")
attach_screenshot(context, getattr(context, "driver", None), name="failure.png")
See docs/attachments.md for the full attachment API and supported MIME types.
Examples
The repository includes three examples:
examples/behave_project/— a complete Behave project that exercises all report sections.examples/demo_generator/— a script that generates a syntheticdemo-report.mdwithout running Behave.examples/step_catalog.md— a generated step catalog showing all step definitions, patterns, parameters, and source code.
Run the example project:
cd examples/behave_project
behave
Generate the demo report:
python examples/demo_generator/generate_demo.py
Report layout
A generated report contains the following sections in order:
# My Report
## Table of Contents
## Executive Summary
## Statistics
## Feature Summary
## Tags
## Failed Scenarios
## Slowest Scenarios
## Scenario Details
## Environment
Each section is linked from the table of contents. Scenario details are wrapped in collapsible <details> blocks so the report stays readable even for large suites.
Step catalog layout
The step catalog (stepcatalog formatter) produces:
# 📋 Step Catalog
## Statistics
## Steps by Keyword
## Steps by File
## Step Definitions
Each step definition is wrapped in a collapsible <details> block showing its keyword, pattern, function name, location, parameters, docstring, and source code.
Architecture
Behave Markdown Report uses a clean, layered architecture:
| Layer | File | Responsibility |
|---|---|---|
| Formatter | formatter.py |
Adapts Behave events to the collector. |
| Collector | collector.py |
Builds the Execution model from Behave objects. |
| Models | models.py |
Pure dataclasses representing the test tree. |
| Statistics | statistics.py |
Computes aggregates and derived metrics. |
| Renderer | renderer.py |
Turns the Execution model into Markdown. |
| Markdown | markdown.py |
Low-level Markdown document helpers. |
| Step Scanner | step_scanner.py |
AST-based static analysis of step definitions. |
| Step Catalog | step_catalog_formatter.py |
Renders step catalog Markdown from scanned definitions. |
| Attach API | attach.py |
Convenience helpers for environment.py. |
See docs/architecture.md for the full architecture and data flow.
Documentation
- docs/configuration.md — all
bmr.*options and troubleshooting. - docs/attachments.md — attaching screenshots, JSON, files, and logs.
- docs/ci-cd.md — GitHub Actions, GitLab CI, Azure DevOps, and Jenkins examples.
- docs/customizing.md — subclassing the renderer and building custom themes.
- docs/architecture.md — project structure and data flow.
Development
Install the development dependencies:
pip install -e ".[dev]"
Run the test suite:
pytest
Run the linter:
ruff check behave_modern_md_report tests
Run the type checker:
mypy behave_modern_md_report
Build the package:
python -m build
Changelog
See CHANGELOG.md for the release history.
License
This project is licensed under the MIT License. See LICENSE for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file behave_modern_md_report-1.2.0.tar.gz.
File metadata
- Download URL: behave_modern_md_report-1.2.0.tar.gz
- Upload date:
- Size: 50.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d18a9446b2bb151ed2601760f82b010e1f4b2ce91d113fd4132f4b0ba9ae101e
|
|
| MD5 |
7f4577d1ead94532b57af49dfd050e0a
|
|
| BLAKE2b-256 |
9dbf4108e09ae016629cdd3724156d66f9832ff6ecb3925f64a2b8b15a50be7c
|
Provenance
The following attestation bundles were made for behave_modern_md_report-1.2.0.tar.gz:
Publisher:
release.yml on MathiasPaulenko/behave-modern-md-report
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
behave_modern_md_report-1.2.0.tar.gz -
Subject digest:
d18a9446b2bb151ed2601760f82b010e1f4b2ce91d113fd4132f4b0ba9ae101e - Sigstore transparency entry: 2031163331
- Sigstore integration time:
-
Permalink:
MathiasPaulenko/behave-modern-md-report@74acfbbde1e744998eddb2f9ae4b7296d25370ec -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MathiasPaulenko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@74acfbbde1e744998eddb2f9ae4b7296d25370ec -
Trigger Event:
push
-
Statement type:
File details
Details for the file behave_modern_md_report-1.2.0-py3-none-any.whl.
File metadata
- Download URL: behave_modern_md_report-1.2.0-py3-none-any.whl
- Upload date:
- Size: 32.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7aaa94fc2aa1740aed66da68c836238bdbe6eeec00e626aaf76997296fba868a
|
|
| MD5 |
2598a6cd4d05deda04aef6cbfa1c73b1
|
|
| BLAKE2b-256 |
e723eac274e3f87e0507d1c91388c0ae7c6337341689b60811cef368f26f2162
|
Provenance
The following attestation bundles were made for behave_modern_md_report-1.2.0-py3-none-any.whl:
Publisher:
release.yml on MathiasPaulenko/behave-modern-md-report
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
behave_modern_md_report-1.2.0-py3-none-any.whl -
Subject digest:
7aaa94fc2aa1740aed66da68c836238bdbe6eeec00e626aaf76997296fba868a - Sigstore transparency entry: 2031163641
- Sigstore integration time:
-
Permalink:
MathiasPaulenko/behave-modern-md-report@74acfbbde1e744998eddb2f9ae4b7296d25370ec -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MathiasPaulenko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@74acfbbde1e744998eddb2f9ae4b7296d25370ec -
Trigger Event:
push
-
Statement type: