The Mozilla Mobile TestOps Dashboard is data pump that collects data from diverse APIs (datasources) and aggregates it in a Cloud SQL database for display in Looker graphs.
The following is an overview of the test-dashboard.
The code is in this repository provides the backend which enables us to publish graphs in Looker.
It is constructed to function as follows
__main__.py
script invoked via github workflow cron to initiate a data extraction- Data 'pumped' from source API indicated
- Data temporarily packaged into a payload
- Payload used to update Cloud SQL database
Once the updated data is available in the database, it is made available to our Looker graphs via BigQuery views.
-
Main menu
Usage: __main__.py [-h] --project {fenix,focus-android,reference-browser,firefox-ios,focus-ios,ALL} --report-type {test-case-coverage,test-run-counts,issue-regression} [--num-days NUM_DAYS] Retrieve and update mobile project test data optional arguments: -h, --help show this help message and exit --project {fenix,focus-android,reference-browser,firefox-ios,focus-ios,ALL} Indicate project --report-type {test-case-coverage,test-run-counts,issue-regression} Indicate report type --num-days NUM_DAYS Indicate number of historic days of records to include
-
API Requests
Queries data from a given data source (see: Source APIs below).
-
Data Payload
Repackage desired data points (usually JSON) from source API into a pandas dataframe. This allows for easy updates to database.
-
Database Update
Uses SQLAlchemy to update database with pandas dataframe data payload. Data reports are generated using github workflows set to specified cron periods:
- Daily
- Weekly
- Fortnightly
- Monthly
-
Data Retrieval
Database is connected to a BigQuery instance. Corresponding views are created in BigQuery that can be directly accessed for generating report in Looker.
Data Sources
- Testrail
- Bugzilla
- Github - TBD
- Taskcluster - TBD
- Bitrise.io - TBD
Data is aggregated / cached in a Cloud SQL database. Data queries are constructed using BigQuery views.