teams-ctrf
v0.0.5
Published
Send test results messages to Microsoft Teams
Downloads
15,421
Readme
Teams Test Results Notification
Send Microsoft Teams message with test result from popular testing frameworks
⭐⭐ If you find this project useful, consider giving it a GitHub star ⭐⭐
You can help us grow
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! 💙
Features
- 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.
Setup
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
Create a Teams Incoming Webhook
Setup an incoming webhook by following instructions on Teams documentation
Set the Environment Variable
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.
Usage
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
Send Only on Failures
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
Options
--onFailOnly, -f
: Send notification only if there are failed tests.
Merge reports
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.
What is CTRF?
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.
Support Us
If you find this project useful, consider giving it a GitHub star ⭐ It means a lot to us.