1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-17 20:08:12 +00:00

feat(tests): update_fixtures.py: github actions support

This commit is contained in:
Martin Milata 2024-03-22 17:45:26 +01:00
parent 4e5cf5e795
commit 60e01ce0e8
2 changed files with 82 additions and 5 deletions

66
tests/github.py Normal file
View File

@ -0,0 +1,66 @@
"""
Helper functions for communication with GitHub.
Allowing for interaction with the test results, e.g. with UI tests.
"""
from __future__ import annotations
from pathlib import Path
from typing import Any, Iterable, Iterator
import requests
AnyDict = dict[Any, Any]
HERE = Path(__file__).parent
LIST_RUNS_TEMPLATE = "https://api.github.com/repos/trezor/trezor-firmware/actions/workflows/{workflow}/runs?branch={branch}"
FIXTURES_TEMPLATE = "https://data.trezor.io/dev/firmware/ui_report/{run}/{model}-{lang}-{job}/fixtures.results.json"
MODELS = ["T2T1", "T2B1", "T3T1"]
LANGUAGES = ["en", "cs", "de", "es", "fr"]
JOBS = ["core_device_test", "core_click_test", "core_persistence_test"]
def get_branch_ui_fixtures_results(
branch_name: str,
only_jobs: Iterable[str] | None,
exclude_jobs: Iterable[str] | None,
) -> dict[str, AnyDict]:
print(f"Checking branch {branch_name}")
response = requests.get(
LIST_RUNS_TEMPLATE.format(branch=branch_name, workflow="core.yml")
)
response.raise_for_status()
run_id = response.json()["workflow_runs"][0]["id"]
def yield_key_value() -> Iterator[tuple[str, AnyDict]]:
for model in MODELS:
for lang in LANGUAGES:
for job in JOBS:
job_instance = f"{model}-{lang}-{job}"
if only_jobs and all(
(job not in job_instance) for job in only_jobs
):
continue
if exclude_jobs and any(
(job in job_instance) for job in exclude_jobs
):
continue
response = requests.get(
FIXTURES_TEMPLATE.format(
run=run_id, model=model, lang=lang, job=job
)
)
if response.status_code != 200:
print(
f"Failed to get fixtures for {job_instance}: {response.status_code}"
)
continue
yield job_instance, response.json()
return dict(yield_key_value())

View File

@ -8,7 +8,6 @@ from typing import Iterable
import click import click
from gitlab import UI_JOB_NAMES, get_branch_ui_fixtures_results, get_jobs_of_interest
from ui_tests import update_fixtures from ui_tests import update_fixtures
from ui_tests.common import FIXTURES_FILE, get_current_fixtures from ui_tests.common import FIXTURES_FILE, get_current_fixtures
@ -36,23 +35,28 @@ def _get_current_git_branch() -> str:
@cli.command() @cli.command()
@click.option(
"-g",
"--github",
is_flag=True,
help="Fetch from GitHub Actions instead of GitLab CI",
)
@click.option("-b", "--branch", help="Branch name") @click.option("-b", "--branch", help="Branch name")
@click.option( @click.option(
"-o", "-o",
"--only-jobs", "--only-jobs",
type=click.Choice(UI_JOB_NAMES),
help="Job names which to process", help="Job names which to process",
multiple=True, multiple=True,
) )
@click.option( @click.option(
"-e", "-e",
"--exclude-jobs", "--exclude-jobs",
type=click.Choice(UI_JOB_NAMES),
help="Not take these jobs", help="Not take these jobs",
multiple=True, multiple=True,
) )
@click.option("-r", "--remove-missing", is_flag=True, help="Remove missing tests") @click.option("-r", "--remove-missing", is_flag=True, help="Remove missing tests")
def ci( def ci(
github: bool,
branch: str | None, branch: str | None,
only_jobs: Iterable[str] | None, only_jobs: Iterable[str] | None,
exclude_jobs: Iterable[str] | None, exclude_jobs: Iterable[str] | None,
@ -73,8 +77,15 @@ def ci(
if exclude_jobs: if exclude_jobs:
print(f"Exclude jobs: {exclude_jobs}") print(f"Exclude jobs: {exclude_jobs}")
jobs_of_interest = get_jobs_of_interest(only_jobs, exclude_jobs) if github:
ui_results = get_branch_ui_fixtures_results(branch, jobs_of_interest) from github import get_branch_ui_fixtures_results
ui_results = get_branch_ui_fixtures_results(branch, only_jobs, exclude_jobs)
else:
from gitlab import get_branch_ui_fixtures_results, get_jobs_of_interest
jobs_of_interest = get_jobs_of_interest(only_jobs, exclude_jobs)
ui_results = get_branch_ui_fixtures_results(branch, jobs_of_interest)
current_fixtures = get_current_fixtures() current_fixtures = get_current_fixtures()