image: registry.gitlab.com/satoshilabs/trezor/trezor-firmware/trezor-firmware-env.nix # Caching .gitlab_caching: &gitlab_caching cache: key: "$CI_COMMIT_REF_SLUG" paths: - .venv/ # Core core unit test: stage: test <<: *gitlab_caching needs: - core unix regular build script: - nix-shell --run "poetry run make -C core test | ts -s" - nix-shell --run "poetry run make -C core test_rust | ts -s" - nix-shell --run "poetry run make -C core clippy | ts -s" core unit test t1: stage: test needs: - core unix frozen btconly debug t1 build variables: BITCOIN_ONLY: "1" TREZOR_MODEL: "1" script: - nix-shell --run "poetry run make -C core test_rust | ts -s" core device ui test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build script: - nix-shell --run "poetry run make -C core test_emu_ui | ts -s" after_script: - mv tests/ui_tests/reporting/reports/test/ test_ui_report - nix-shell --run "poetry run python ci/prepare_ui_artifacts.py | ts -s" - diff tests/ui_tests/fixtures.json tests/ui_tests/fixtures.suggestion.json artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - ci/ui_test_records/ - test_ui_report - tests/ui_tests/screens/ - tests/ui_tests/fixtures.suggestion.json - tests/junit.xml - tests/trezor.log when: always expire_in: 1 week reports: junit: tests/junit.xml core device test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build variables: TREZOR_PROFILING: 1 script: - nix-shell --run "poetry run make -C core test_emu | ts -s" - mv core/src/.coverage core/.coverage.test_emu artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - tests/junit.xml - core/.coverage.* expire_in: 1 week when: always reports: junit: tests/junit.xml core btconly device test: stage: test <<: *gitlab_caching needs: - core unix frozen btconly debug build variables: MICROPYTHON: "build/unix/trezor-emu-core-bitcoinonly" TREZOR_PYTEST_SKIP_ALTCOINS: 1 script: - nix-shell --run "poetry run make -C core test_emu | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - tests/junit.xml expire_in: 1 week when: always reports: junit: tests/junit.xml core monero test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build variables: TREZOR_PROFILING: 1 script: - nix-shell --arg fullDeps true --run "poetry run make -C core test_emu_monero | ts -s" - mv core/src/.coverage core/.coverage.test_emu_monero artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - core/tests/trezor_monero_tests.log - core/.coverage.* expire_in: 1 week when: always core u2f test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build variables: TREZOR_PROFILING: 1 script: - nix-shell --run "poetry run make -C tests/fido_tests/u2f-tests-hid | ts -s" - nix-shell --run "poetry run make -C core test_emu_u2f | ts -s" - mv core/src/.coverage core/.coverage.test_emu_u2f artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - core/.coverage.* expire_in: 1 week when: always core fido2 test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build variables: TREZOR_PROFILING: 1 script: - pgrep trezor-emu-core || true - nix-shell --run "poetry run make -C core test_emu_fido2 | ts -s" - pgrep trezor-emu-core || true - mv core/src/.coverage core/.coverage.test_emu_fido2 artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - tests/junit.xml - core/.coverage.* expire_in: 1 week reports: junit: tests/junit.xml when: always core click test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build script: - nix-shell --run "poetry run make -C core test_emu_click | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always core upgrade test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build variables: TREZOR_UPGRADE_TEST: "core" script: - nix-shell --run "tests/download_emulators.sh" - nix-shell --run "poetry run pytest --junitxml=tests/junit.xml tests/upgrade_tests | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always core persistence test: stage: test <<: *gitlab_caching needs: - core unix frozen debug build script: - nix-shell --run "poetry run pytest --junitxml=tests/junit.xml tests/persistence_tests | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always # Crypto crypto test: stage: test only: changes: - .gitlab-ci.yml - ci/**/* - crypto/**/* <<: *gitlab_caching needs: - crypto build script: - ./crypto/tests/aestst - ./crypto/tests/test_check - ./crypto/tests/test_openssl 1000 - nix-shell --run "cd crypto && ITERS=10 poetry run pytest --junitxml=tests/junit.xml tests | ts -s" - nix-shell --run "CK_TIMEOUT_MULTIPLIER=20 valgrind -q --error-exitcode=1 ./crypto/tests/test_check | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always # Legacy legacy test: stage: test <<: *gitlab_caching needs: - legacy emu regular debug build variables: EMULATOR: "1" script: - nix-shell --run "poetry run legacy/script/test | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always legacy btconly test: stage: test <<: *gitlab_caching needs: - legacy emu btconly debug build variables: EMULATOR: "1" EMULATOR_BINARY: "firmware/trezor-bitcoinonly.elf" TREZOR_PYTEST_SKIP_ALTCOINS: 1 script: - nix-shell --run "poetry run legacy/script/test | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always legacy upgrade test: stage: test <<: *gitlab_caching needs: - legacy emu regular debug build variables: TREZOR_UPGRADE_TEST: "legacy" script: - nix-shell --run "tests/download_emulators.sh" - nix-shell --run "poetry run pytest --junitxml=tests/junit.xml tests/upgrade_tests | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always # Python python test: stage: test <<: *gitlab_caching needs: [] variables: LC_ALL: "C.UTF-8" LANG: "C.UTF-8" only: changes: - poetry.lock - .gitlab-ci.yml - ci/**/* - common/**/* - python/**/* script: # Workaround for nixpkgs+tox integration failure which results in: # ModuleNotFoundError: No module named '_sysconfigdata__linux_x86_64-linux-gnu' # The value of _PYTHON_SYSCONFIGDATA_NAME has changed between python 3.7 and 3.8 and with # multiple versions in your environment the older pythons don't seem to work under tox. # When the variable is unset the interpreter seems to do the right thing. Can be removed in # july 2023 when python 3.7 is EOLed. # See also: # https://github.com/NixOS/nixpkgs/blob/b00c7c2d1d905eb63c81a0917f1a94b763a7843b/pkgs/development/interpreters/python/cpython/default.nix#L103 # https://github.com/NixOS/nixpkgs/pull/98915 - nix-shell --arg fullDeps true --run "unset _PYTHON_SYSCONFIGDATA_NAME && cd python && poetry run tox | ts -s" # Storage storage test: stage: test only: changes: - .gitlab-ci.yml - ci/**/* - storage/**/* <<: *gitlab_caching needs: [] script: - nix-shell --run "poetry run make -C storage/tests build | ts -s" - nix-shell --run "poetry run make -C storage/tests tests_all | ts -s" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/junit.xml reports: junit: tests/junit.xml expire_in: 1 week when: always # Memory profiling core unix memory profiler: stage: test when: manual <<: *gitlab_caching needs: [] variables: PYOPT: "0" TREZOR_MEMPERF: "1" PYTEST_TIMEOUT: "900" script: - nix-shell --run "poetry run make -C core build_unix_frozen | ts -s" - nix-shell --run "poetry run make -C core test_emu | ts -s" - nix-shell --run "mkdir core/prof/memperf-html" - nix-shell --run "poetry run core/tools/alloc.py --alloc-data=core/src/alloc_data.txt html core/prof/memperf-html" artifacts: name: "$CI_JOB_NAME-$CI_COMMIT_SHORT_SHA" paths: - tests/trezor.log - core/prof/memperf-html expire_in: 1 week when: always