Customized tool to run Maestro tests, parse Maestro report file, and push reports to Lark.
Project description
py-maestro-reporter
py-maestro-reporter is a lightweight tool that helps you:
- Run Maestro test seamlessly
- Parse Maestro JUnit reports
- Send summarized test results to a Lark respective group (for now)
It can be used either as a CLI tool or a python package into your own test pipelines
Prerequisites
- Python 3.10 or above
- Maestro framework installed on your system (version 2.0.0 or above)
- Device/emulator with the app under test installed
- Lark webhook URL
Installation
For the installation, you can either install the package from PyPI or from source. If you'd like to install from PyPI, you can install it with:
pip install maestro-reporter
Or, using uv:
uv pip install maestro-reporter
Or, if you'd prefer to install from source, you'll need to clone this repository and install it in editable mode:
pip install -e .
Usage
Using as a CLI argument
This package expose a CLI via the reporter module
All you need to do is, ensure you have Maestro installed on your device, example flows which is going to be tested, physical device / emulator and Webhook URL from Lark. Once you have all of these, you can run with :
python -m reporter \
-c "maestro test examples/facebook-sign-up-flow.yaml --format junit --output tests/report.xml" \
-r "tests/report.xml" \
-w "https://webhook.url.com"
Parsing an existing report
Or, if you only want to run and parse the report without testing, you can use --no-run flag
python -m reporter \
--no-run \
-r "tests/report.xml" \
-w "https://webhook.url.com"
You can also overrides the Webhook URL by setting the
LARK_URLorSLACK_URLenvironment variable in your.envfile, depending on the provider you choose.
Using the reporter package
Otherwise, if you'd like to run the tests without using the CLI arguments and you need to run the tests with the reporter package, you can follow the example below (this will test the Facebook sign up flow):
import os
from dotenv import load_dotenv
from reporter import parse_xml_report, send_report_to_lark, run_maestro_command
load_dotenv()
command = "maestro test examples/facebook-sign-up-flow.yaml --format junit --output tests/report.xml"
run_maestro_command(command=command, cwd="tests")
parsed_result = parse_xml_report(file_path="report.xml")
report = send_report_to_lark(
summary=parsed_result,
title="Maestro Reporter Test",
color_template="Green",
webhook_url=os.getenv("LARK_URL"),
)
The parameters of
color_templateandtitleare mandatory, if you don't provide them, the default values will be used
All successful tests (from execute the Maestro command -> parse the report -> send the report to Lark) will be displayed in the log stream handler, for example:
27-11-2025 : 10:51:46 : main : [WARNING] : No color template provided, using default color template or you can set it with `--color` flag
27-11-2025 : 10:51:46 : main : [WARNING] : No title provided, using default title or you can set it with `--title` flag
27-11-2025 : 10:51:46 : main : [INFO] : --no-run flag is set, skipping Maestro tests
27-11-2025 : 10:51:46 : main : [INFO] : Parsing Maestro report file: tests/report.xml
27-11-2025 : 10:51:46 : main : [INFO] : Sending Maestro report to Lark...
27-11-2025 : 10:51:46 : reporter.sender : [INFO] : Lark message sent successfully
27-11-2025 : 10:51:46 : main : [INFO] : Maestro report sent successfully
Once the report is sent successfully, you should be able to see the interactive card message in your Lark group like the following image
Otherwise, if you want to use Slack as a reporting platform, the card message will be displayed as follows
CLI arguments
List of available CLI arguments that you can use with this package:
| arguments | description |
|---|---|
-h / --help |
show this help message and exit |
-c / --command |
Maestro command to run |
-r / --report |
Path to Maestro report, by default it's report.xml but you can configure it by yourself |
-w / --webhook |
Specify a webhook URL to send the report to Lark |
-n / --no-run |
No need to run Maestro tests, just parse the report and send the result to Lark |
-t / --title |
Set a custom title for the interactive card Lark message |
-ct / --color |
Set a custom color template for the interactive card Lark message |
-p / --provider |
Specify the reporting platform (lark or slack). Default is lark |
Notes
- At the moment, this package only supports the parsing of the
junitformat as follows for the Maestro report - In addition, the webhook integration currently supports Lark and Slack
- The interactive card message is built using the
msg_actioncardmessage type for Lark andBlock Kitfor Slack
Further references
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
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 maestro_reporter-0.6.0.tar.gz.
File metadata
- Download URL: maestro_reporter-0.6.0.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
832874534756ced2fd7ea5701ded052bacd556b4e6f26cfbd9c9b37fd14ea151
|
|
| MD5 |
dfbee9f5c9784120403ae29d76ea5b20
|
|
| BLAKE2b-256 |
13a48ce40c41133fe16814e8d387ec4d6f6be1ce5cdf836b41d64d77ad698c36
|
File details
Details for the file maestro_reporter-0.6.0-py3-none-any.whl.
File metadata
- Download URL: maestro_reporter-0.6.0-py3-none-any.whl
- Upload date:
- Size: 15.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c71274a60b3d502d7743b63a00e6a6b2590618b9fa0746ddade96fc8b8c33a20
|
|
| MD5 |
7bdd88d2c7c32c401e53a7854754a3a5
|
|
| BLAKE2b-256 |
57967831b12d28773d193d1dd2474509e10729d0ea38f05fcd39b96d663e6a93
|