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. See a generated step catalog at examples/step_catalog.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.
  • 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

  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

Step catalog

  1. Register the formatter in behave.ini:
[behave.formatters]
stepcatalog = behave_modern_md_report.step_catalog_formatter:StepCatalogMarkdownFormatter
  1. Run Behave with the stepcatalog formatter:
behave -f stepcatalog -o step_catalog.md --no-skipped
  1. 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 synthetic demo-report.md without 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

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.2.0.tar.gz (50.5 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.2.0-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

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

Hashes for behave_modern_md_report-1.2.0.tar.gz
Algorithm Hash digest
SHA256 d18a9446b2bb151ed2601760f82b010e1f4b2ce91d113fd4132f4b0ba9ae101e
MD5 7f4577d1ead94532b57af49dfd050e0a
BLAKE2b-256 9dbf4108e09ae016629cdd3724156d66f9832ff6ecb3925f64a2b8b15a50be7c

See more details on using hashes here.

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

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.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for behave_modern_md_report-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7aaa94fc2aa1740aed66da68c836238bdbe6eeec00e626aaf76997296fba868a
MD5 2598a6cd4d05deda04aef6cbfa1c73b1
BLAKE2b-256 e723eac274e3f87e0507d1c91388c0ae7c6337341689b60811cef368f26f2162

See more details on using hashes here.

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

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