Skip to main content

A modern, readable, CI/CD-friendly Markdown report formatter for Behave.

Project description

Behave Markdown Report

PyPI Python CI License

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.

Table of Contents

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.
  • 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

  1. Create or update behave.ini in your Behave project root:
[behave]
format = markdown
outfiles = report.md

[behave.formatters]
markdown = behave_modern_md_report.formatter:BehaveMarkdownFormatter
  1. Run Behave:
behave
  1. Open report.md in 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

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

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 two examples:

  • examples/behave_project/ — a complete Behave project that exercises all report sections.
  • examples/demo_generator/ — a script that generates a synthetic demo-report.md without running Behave.

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.

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.
Attach API attach.py Convenience helpers for environment.py.

See docs/architecture.md for the full architecture and data flow.

Documentation

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

behave_modern_md_report-1.1.0.tar.gz (43.7 kB view details)

Uploaded Source

Built Distribution

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

behave_modern_md_report-1.1.0-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file behave_modern_md_report-1.1.0.tar.gz.

File metadata

  • Download URL: behave_modern_md_report-1.1.0.tar.gz
  • Upload date:
  • Size: 43.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for behave_modern_md_report-1.1.0.tar.gz
Algorithm Hash digest
SHA256 d62b8df70eb95937b5c5e959d10dd6b5ce5be2523baff09de80fa4bc4e6ef1d4
MD5 9b86df04d80d8a8b86738a99602a9102
BLAKE2b-256 ffd4a082170e32a8bb6904b42141f88fcd2aa071422da92d299d36d6a661878c

See more details on using hashes here.

Provenance

The following attestation bundles were made for behave_modern_md_report-1.1.0.tar.gz:

Publisher: release.yml on MathiasPaulenko/behave-modern-md-report

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file behave_modern_md_report-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for behave_modern_md_report-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 12370f70020885ed16a7c7a0b435242ba556d472b2e524c455500879048635cc
MD5 772bd2253dc2c3b562be36cd22cdb5ce
BLAKE2b-256 86d91fc667847455da3ba39437a47c4183ca87299cb81ae09901af86ce1fdeb1

See more details on using hashes here.

Provenance

The following attestation bundles were made for behave_modern_md_report-1.1.0-py3-none-any.whl:

Publisher: release.yml on MathiasPaulenko/behave-modern-md-report

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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