Send Microsoft Teams message with test result from popular testing frameworks
Support our mission to enhance test reporting in Microsoft Teams by:
- ⭐ Starring this repository to show your support. ⭐
- 🙌 Following our GitHub page here to stay updated. 🙌
Thank you! Your support is invaluable to us! 💙
- Send Test Results to Teams: Automatically send test results to a Teams channel.
- Send Flaky Test Details to Teams: Automatically send flaky test details to a Teams channel.
- Send AI generated Failed Test Summary to Teams: Automatically send AI summary to a Teams channel.
- Conditional Notifications: Use the
--onFailOnly
option to send notifications only if tests fail.
You'll need a CTRF report generated by your testing framework. CTRF reporters are available for most testing frameworks and easy to install.
No CTRF reporter? No problem!
Use junit-to-ctrf to convert a JUnit report to CTRF
Setup an incoming webhook by following instructions on Teams documentation
Set the webhook URL as an environment variable in your shell or CI environment:
export TEAMS_WEBHOOK_URL='https://hooks.teams.com/services/your/webhook/url'
Make sure to replace 'https://hooks.teams.com/services/your/webhook/url'
with your actual webhook URL.
You might want to store the webhook URL as a secret.
To send the test results summary to Teams:
npx teams-ctrf results /path/to/ctrf-report.json
To send flaky test report to Teams:
npx teams-ctrf flaky /path/to/ctrf-report.json
To send ai test summary for failed tests to Teams:
npx teams-ctrf ai /path/to/ctrf-report.json
To send the test results summary to Teams only if there are failed tests, use the --onFailOnly
option:
npx teams-ctrf results /path/to/ctrf-file.json --onFailOnly
or using the alias:
npx teams-ctrf results /path/to/ctrf-file.json -f
--onFailOnly, -f
: Send notification only if there are failed tests.
You can merge reports if your chosen reporter generates multiple reports through design, parallelisation or otherwise.
The ctrf-cli package provides a method to merge multiple ctrf json files into a single file.
After executing your tests, use the following command:
npx ctrf merge <directory>
Replace directory with the path to the directory containing the CTRF reports you want to merge.
CTRF is a universal JSON test report schema that addresses the lack of a standardized format for JSON test reports.
Consistency Across Tools: Different testing tools and frameworks often produce reports in varied formats. CTRF ensures a uniform structure, making it easier to understand and compare reports, regardless of the testing tool used.
Language and Framework Agnostic: It provides a universal reporting schema that works seamlessly with any programming language and testing framework.
Facilitates Better Analysis: With a standardized format, programatically analyzing test outcomes across multiple platforms becomes more straightforward.
If you find this project useful, consider giving it a GitHub star ⭐ It means a lot to us.