Host your Allure test reports on the web with history, retries, and Slack integration—no server required.
Example report: https://gatedaccessdev.web.app
This package can be used three different ways:
-
🤖 A GitHub Action to deploy reports to GitHub pages or Firebase
-
🐳 A Docker image to deploy reports to Firebase
-
🖥 A CLI to deploy reports to Firebase
-
Firebase/GCP Credentials:
- Create a Firebase/GCP service account.
- Download the
service-account-file.json
JSON file.
-
Firebase/Google Cloud Storage Bucket:
- Create a bucket to store test results and reports. You can use the default.
1. Add the Allure Deployer GitHub Action to your workflow.
jobs:
firebase:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4.1.5
- name: Run test
run: #Run test and create allure results
- name: Deploy Reports to Firebase with History and Retries
uses: cybersokari/allure-deployer-action@v1.4.2
with:
target: 'firebase'
allure_results_path: 'allure-results'
google_credentials_json: ${{ secrets.GOOGLE_APPLICATION_CREDENTIALS }}
storage_bucket: ${{vars.STORAGE_BUCKET}}
show_history: 'true'
retries: 5
See configurations for complete options and environment variables
Pull request comment example
📊 Your Test Report is ready
Test Report: https://your-example-url.web.app
File Storage: https://console.firebase.google.com/project/${project-id}/storage/${storage-bucket}/files
| ✅ Passed | ⚠️ Broken |
|----------|-----------|
| 15 | 2 |
Add the docker image to your Gitlab workflow and run it.
sokari/allure-deployer:latest
stages:
- test
- deploy
variables:
DOCKER_IMAGE: sokari/allure-deployer:latest
STORAGE_BUCKET: my-test-results-bucket
PREFIX: project-123
REPORT_NAME: Notification module Q2
before_script:
- mkdir -p ./allure-results
test:
stage: test
script:
- echo "Running tests..."
# Simulate test execution and output results
- mkdir -p allure-results
# Add real test commands here
artifacts:
paths:
- allure-results/
expire_in: 1 day
deploy:
stage: deploy
image: docker:latest
services:
- docker:dind
before_script:
- echo "Logging in to Docker Hub"
- docker login -u "$DOCKERHUB_USERNAME" -p "$DOCKERHUB_TOKEN"
script:
- echo "Deploying Allure Reports..."
- docker run --rm \
-e STORAGE_BUCKET=$STORAGE_BUCKET \
-e PREFIX=$PREFIX \
-e REPORT_NAME=$REPORT_NAME \
-e SHOW_HISTORY=true \
-e RETRIES=5 \
-v ${CI_PROJECT_DIR}/allure-results:/allure-results \
-v ${GCP_CREDENTIALS_FILE_PATH}:/credentials/key.json \
sokari/allure-deployer:latest
only:
- main
dependencies:
- test
See the Docker configuration section for more info
Use the CLI in your Codemagic workflow.
workflows:
android-allure:
name: Android Allure Report
max_build_duration: 30
instance_type: linux_x2
scripts:
- name: Build Android apk # 1. Build apk
script:
- name: Git clone Appium project # 2. Clone Appium project if required
script: |
git clone https://github.com/my-appium-project
- name: Install Appium Deps # 3. Install Appium dependencies
script: |
cd appium && npm install --force
- name: Launch Android Emulator # 4. Start Codemagic Android Emulator
script: |
FIRST_AVD=$(emulator -list-avds | head -n 1) \
&& emulator -avd "$FIRST_AVD" & adb wait-for-device
- name: Run Appium test # 5. Run test and generate Allure results
script: |
cd appium && npm run android
- name: Run Allure Report Deployer # 6. Generate and deploy reports
script: |
npm i -g allure-deployer
cd appium && echo $ALLURE_GOOGLE_KEY >> service-key.json
allure-deployer deploy path/to/allure-results my-report-name \
--gcp-json /credentials/key.json \
--show-history \
--retries 6 \
--slack-token $SLACK_TOKEN \
--slack-channel $SLACK_CHANNEL
artifacts:
- android/app/build/outputs/**/*.apk
npm install -g allure-deployer
allure-deployer gcp-json:set ./gcp-key.json
allure-deployer bucket:set <my-bucket-name>
allure-deployer slack:set <channel> <token>
allure-deployer deploy path/to/allure-results my-report-name \
--show-history \
--retries 10
https://github.com/marketplace/actions/allure-deployer-action
Input | Description | Required | Default |
---|---|---|---|
google_credentials_json |
Firebase (Google Cloud) credentials JSON | Yes | None |
allure_results_path |
Path to the directory containing Allure results files. | Yes | allure-results |
report_name |
The name/title of your report. | No | Allure Report |
target |
Set where to deploy test Report. firebase or github . github requires github_token |
No | firebase |
storage_bucket |
Name of the Google Cloud Storage bucket for backup and history storage. | No | None |
prefix |
Path prefix in the Cloud Storage bucket for archiving files. | No | None |
show_history |
Display history from previous test runs. | No | true |
retries |
Number of previous test runs to show as retries in the upcoming report when Storage storage_bucket is provided |
No | 0 |
output |
A directory to generate Allure report into. Setting this value disables report hosting and Slack notification | No | None |
slack_channel |
ID of the Slack channel to send notifications about report links. | No | None |
slack_token |
Token for Slack App to send notifications with report URLs. | No | None |
github_token |
A generated GITHUB_TOKEN for when github_pages_branch is provide or when pr_comment is set to true |
No | None |
pr_comment |
Post test report information as pull request comment. Requires github_token to be set with permission |
No | false |
github_pages_branch |
Set target branch for Deploying test report to GitHub Pages. Requires github_token to be set with permission |
No | None |
Key | Description |
---|---|
report_url |
URL of the test report. |
docker pull sokari/allure-deployer:latest
Variable | Description | Example | Default |
---|---|---|---|
STORAGE_BUCKET |
Google Cloud Storage bucket name | project-id.firebasestorage.app | None |
PREFIX |
A path in your Storage bucket. Optional. | project-123 | None |
REPORT_NAME |
The name/title of your report | Space ship report | Alure Report |
SHOW_HISTORY |
Show history in the current report by pulling the history from the last Cloud Storage backup | true | true |
RETRIES |
Number of previous test runs to show as retries in the upcoming report when Storage STORAGE_BUCKET is provided |
5 | 0 |
SLACK_TOKEN |
Your Slack App token | xoxb-XXXXXXXXXX-XXXXXXXX | None |
SLACK_CHANNEL |
The Slack channel ID or conversation to notify with Allure report details | DC56JYGT8 | None |
Host | Container | Description |
---|---|---|
/path/to/allure-results |
/allure-results |
Allure test results directory. |
/path/to/credentials.json |
/credentials/key.json |
Google Cloud service account JSON file. |
Notes: |
- Ensure that the directories and files exist on your local machine or CI environment.
- Use absolute paths to avoid errors with relative paths in Docker commands.
Allure Report Deployer hosts your Reports on Firebase Hosting and saves your history and
results files in Firebase/GCP storage.
A secure URL will be generated and displayed in the console logs.
If configured, the URL will also appear in GitHub Summary and Slack notifications.
For more information, check the Configuration section.
Your files are backed up as .zip
archives when you set SHOW_HISTORY
or RETRIES
.
RETRIES
adds all the files in your/allure-results
directory tp an archiveSHOW_HISTORY
adds thehistory
subdirectory of your latest report to an archive namedlast-history.zip
Example of an archive when both RETRIES
and RETRIES
are set
last-history.zip/
├── categories-trend.json
├── duration-trend.json
├── history-trend.json
├── history.json
└── retry-trend.json
1784839939391.zip/
├── 01f49176-82b1-462d-aa15-bd0369600617-result.json
├── 2f10bad1-2f73-46ab-b2ef-28fc010f4473-container.json
├── 3abc8f5d-8292-45fa-9c0c-d0e1bfc8d173-container.json
├── 4cb007b9-e103-4518-a3b0-5ef98e178367-attachment.webm
├── 4dd05185-1dd4-4981-a860-9db6cd66532a-attachment.webm
├── 4f4d3f28-f6a2-4e0b-8f72-cf37763a4cd0-attachment.webm
├── 7a71a49f-4b80-4cde-a3d2-37813e6a51f3-attachment.webm
├── 7b1f36ef-ce18-4cfe-af8d-17af3a42995d-result.json
├── 7fbde46e-3030-4836-8399-7d537d568b6a-result.json
├── 07febc1-46d1-4fc6-8175-9e167e2ad760-attachment.webm
├── 8d25f178-46dc-4779-87c5-3f82e44e3630-container.json
├── 8fde3b8a-7632-4c87-9c28-4c66b1b99383-attachment.webm
├── 9a6c98c8-3773-4a1e-b1d7-267fc2b7887b-result.json
├── 9c0689aa-3a6c-4580-9f00-427f941ba2ac-container.json
├── 21f27bd5-d1c6-40e1-bc79-9747b3dbe93f-result.json
└── 39aea642-05b4-4b01-8944-d8e02f184e30-container.json
Zipped archives examples in the Firebase Developer console
This feature uses history and result files saved in Cloud Storage and requires a STORAGE_BUCKET
.
Set SHOW_HISTORY
to true
to enable history in your incoming test report.
This is enabled by default when STORAGE_BUCKET
is provided.
See how Allure History works
Set RETRIES
to the number to previous test runs you want to show as retries in the new test report.
This feature combines all the result files from previous test run saved in Cloud Storage before generating the new report.
See how Allure Retries work
To notify stakeholders with secure test report links after each test run,
create a simple Slack app and set SLACK_TOKEN
and SLACK_CHANNEL
environment variable when you run the Docker image.
- Problem: Issues with Google Cloud credentials or permissions.
- Solution:
- Verify the path to your Google credentials is mounted to
/credentials/key.json
on the docker container. - Ensure the credential file belongs to a service account with the required permissions for Firebase Hosting and Cloud Storage.
- Run the following commands to test credentials:
- Verify the path to your Google credentials is mounted to
gcloud auth activate-service-account --key-file=/path/to/credentials.json
gcloud firebase hosting:list
- Problem: Misconfigured
STORAGE_BUCKET
. - Solution:
- Verify the
STORAGE_BUCKET
environment variable matches the name of your Google Cloud Storage bucket. - Confirm the Google credential file has write access to the bucket.
- Verify the
- A: Yes, you can generate and share reports without using cloud storage. However, enabling
STORAGE_BUCKET
allows you to enable test report History and Retries.
- A: 36, due to Firebase limitation:
- A: Yes, each deployment creates a new report site. This allows you to manage separate URLs for different test runs or environments.
- A: No, the free Firebase plan is sufficient to host your reports. However, you will need to enable billing to use cloud storage for History and Retries. Firebase Storage is free for the first 5GB of storage
- A: If
REPORT_NAME
is not set,Allure Report
will be used as your report id.
- A: Set the following environment variables:
SLACK_TOKEN
: Your Slack Bot's token.SLACK_CHANNEL
: The ID of the channel where you want to send notifications.- Test the bot by sending a manual message before integrating with the container.
- A: Not directly. You will need to merge allure-results directories manually before generating a report.
This project is licensed under the BSD-3 License. See the LICENSE file for details.
Contributions are welcome! Feel free to open issues or submit pull requests for bug fixes or new features.