Skip to content

refactor: use Schema.from_dict in task transforms

d510d08
Select commit
Loading
Failed to load commit list.
Draft

Convert msgspec schemas to Schema.from_dict format #929

refactor: use Schema.from_dict in task transforms
d510d08
Select commit
Loading
Failed to load commit list.
firefoxci-taskcluster / test-unit-multithread-py314t succeeded Apr 29, 2026 in 5m 29s

FirefoxCI (pull_request)

Run unit tests with py314t on Linux with multithreading enabled (Treeherder push)

Details

View task in Taskcluster | View logs in Taskcluster | View task group in Taskcluster

Task Status

Started: 2026-04-29T17:44:58.765Z
Resolved: 2026-04-29T17:48:24.984Z
Task Execution Time: 3 minutes, 26 seconds, 219 milliseconds
Task Status: completed
Reason Resolved: completed
TaskId: K69jB-2wSZScD_uNNis5BA
RunId: 0

Artifacts

- public/coverage.py314t
- public/logs/live_backing.log
- public/logs/live.log


[taskcluster 2026-04-29T17:44:58.804Z] Worker Type (taskgraph-t/linux-docker) settings:
[taskcluster 2026-04-29T17:44:58.804Z]   {
[taskcluster 2026-04-29T17:44:58.804Z]     "generic-worker": {
[taskcluster 2026-04-29T17:44:58.804Z]       "config": {
[taskcluster 2026-04-29T17:44:58.804Z]         "headlessTasks": true
[taskcluster 2026-04-29T17:44:58.804Z]       },
[taskcluster 2026-04-29T17:44:58.804Z]       "engine": "multiuser",
[taskcluster 2026-04-29T17:44:58.804Z]       "go-arch": "amd64",
[taskcluster 2026-04-29T17:44:58.804Z]       "go-os": "linux",
[taskcluster 2026-04-29T17:44:58.804Z]       "go-version": "go1.26.0",
[taskcluster 2026-04-29T17:44:58.804Z]       "release": "https://github.com/taskcluster/taskcluster/releases/tag/v97.0.1",
[taskcluster 2026-04-29T17:44:58.804Z]       "revision": "6519c127aad40a47b1412136d9a5797a76eca200",
[taskcluster 2026-04-29T17:44:58.804Z]       "source": "https://github.com/taskcluster/taskcluster/commits/6519c127aad40a47b1412136d9a5797a76eca200",
[taskcluster 2026-04-29T17:44:58.804Z]       "version": "97.0.1"
[taskcluster 2026-04-29T17:44:58.804Z]     },
[taskcluster 2026-04-29T17:44:58.804Z]     "image": "projects/taskcluster-imaging/global/images/gw-fxci-gcp-l1-2404-amd64-headless-googlecompute-2026-03-05",
[taskcluster 2026-04-29T17:44:58.804Z]     "instance-id": "3275076775761149381",
[taskcluster 2026-04-29T17:44:58.804Z]     "instance-type": "projects/887720501152/machineTypes/c2-standard-4",
[taskcluster 2026-04-29T17:44:58.804Z]     "local-ipv4": "10.138.0.54",
[taskcluster 2026-04-29T17:44:58.804Z]     "project-id": "fxci-production-level1-workers",

...(544 lines hidden)...

[task 2026-04-29T17:47:50.601+00:00] test/test_util_readonlydict.py::test_copy PASSED                         [ 71%]
[task 2026-04-29T17:47:50.602+00:00] test/test_util_readonlydict.py::test_pickle PASSED                       [ 71%]
[task 2026-04-29T17:47:50.616+00:00] test/test_util_schema.py::TestValidateSchema::test_invalid PASSED        [ 71%]
[task 2026-04-29T17:47:50.618+00:00] test/test_util_schema.py::TestValidateSchema::test_valid PASSED          [ 72%]
[task 2026-04-29T17:47:50.621+00:00] test/test_util_schema.py::TestSchemaFeatures::test_allow_unknown_fields PASSED [ 72%]
[task 2026-04-29T17:47:50.623+00:00] test/test_util_schema.py::TestSchemaFeatures::test_forbid_unknown_fields PASSED [ 72%]
[task 2026-04-29T17:47:50.626+00:00] test/test_util_schema.py::TestSchemaFeatures::test_kebab_rename PASSED   [ 72%]
[task 2026-04-29T17:47:50.628+00:00] test/test_util_schema.py::test_validation_skipped PASSED                 [ 72%]
[task 2026-04-29T17:47:50.629+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_list PASSED           [ 72%]
[task 2026-04-29T17:47:50.630+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_default PASSED  [ 73%]
[task 2026-04-29T17:47:50.631+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_extra_value PASSED [ 73%]
[task 2026-04-29T17:47:50.632+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_nested_exact PASSED [ 73%]
[task 2026-04-29T17:47:50.633+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_partial_regexp PASSED [ 73%]
[task 2026-04-29T17:47:50.634+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_regexp PASSED   [ 73%]
[task 2026-04-29T17:47:50.635+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_multiple_matches PASSED [ 73%]
[task 2026-04-29T17:47:50.636+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_nested PASSED         [ 74%]
[task 2026-04-29T17:47:50.637+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by PASSED          [ 74%]
[task 2026-04-29T17:47:50.638+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_dotted PASSED   [ 74%]
[task 2026-04-29T17:47:50.639+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_empty_dict PASSED [ 74%]
[task 2026-04-29T17:47:50.640+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_by PASSED   [ 74%]
[task 2026-04-29T17:47:50.641+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_dict PASSED [ 74%]
[task 2026-04-29T17:47:50.642+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_only_by PASSED [ 75%]
[task 2026-04-29T17:47:50.643+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_key PASSED         [ 75%]
[task 2026-04-29T17:47:50.644+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_key_no_default PASSED [ 75%]
[task 2026-04-29T17:47:50.645+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_match PASSED       [ 75%]
[task 2026-04-29T17:47:50.646+00:00] test/test_util_schema.py::TestNestedStructFieldsOptional::test_index_schema_accepts_all_fields PASSED [ 75%]
[task 2026-04-29T17:47:50.647+00:00] test/test_util_schema.py::TestNestedStructFieldsOptional::test_index_schema_accepts_partial_fields PASSED [ 75%]
[task 2026-04-29T17:47:50.649+00:00] test/test_util_schema.py::TestValidateSchemaDictHandler::test_dict_schema_invalid PASSED [ 76%]
[task 2026-04-29T17:47:50.650+00:00] test/test_util_schema.py::TestValidateSchemaDictHandler::test_dict_schema_valid PASSED [ 76%]
[task 2026-04-29T17:47:50.655+00:00] test/test_util_schema.py::test_optionally_keyed_by PASSED                [ 76%]
[task 2026-04-29T17:47:50.659+00:00] test/test_util_schema.py::test_optionally_keyed_by_multiple_keys PASSED  [ 76%]
[task 2026-04-29T17:47:50.672+00:00] test/test_util_schema.py::test_optionally_keyed_by_object_passthrough PASSED [ 76%]
[task 2026-04-29T17:47:50.676+00:00] test/test_util_schema.py::test_optionally_keyed_by_dict PASSED           [ 76%]
[task 2026-04-29T17:47:50.682+00:00] test/test_util_schema.py::test_from_dict_valid[fields_dict0-data0-name-foo] PASSED [ 76%]
[task 2026-04-29T17:47:50.685+00:00] test/test_util_schema.py::test_from_dict_valid[fields_dict1-data1-count-None] PASSED [ 77%]
[task 2026-04-29T17:47:50.688+00:00] test/test_util_schema.py::test_from_dict_valid[fields_dict2-data2-tags-expected2] PASSED [ 77%]
[task 2026-04-29T17:47:50.690+00:00] test/test_util_schema.py::test_from_dict_valid[fields_dict3-data3-my_field-bar] PASSED [ 77%]
[task 2026-04-29T17:47:50.694+00:00] test/test_util_schema.py::test_from_dict_invalid[fields_dict0-data0] PASSED [ 77%]
[task 2026-04-29T17:47:50.696+00:00] test/test_util_schema.py::test_from_dict_invalid[fields_dict1-data1] PASSED [ 77%]
[task 2026-04-29T17:47:50.701+00:00] test/test_util_schema.py::test_exclusive[data0-True] PASSED              [ 77%]
[task 2026-04-29T17:47:50.703+00:00] test/test_util_schema.py::test_exclusive[data1-False] PASSED             [ 78%]
[task 2026-04-29T17:47:50.706+00:00] test/test_util_schema.py::test_exclusive[data2-False] PASSED             [ 78%]
[task 2026-04-29T17:47:50.737+00:00] test/test_util_taskcluster.py::test_get_root_url PASSED                  [ 78%]
[task 2026-04-29T17:47:50.755+00:00] test/test_util_taskcluster.py::test_get_artifact_url PASSED              [ 78%]
[task 2026-04-29T17:47:50.784+00:00] test/test_util_taskcluster.py::test_get_artifact PASSED                  [ 78%]
[task 2026-04-29T17:47:50.789+00:00] test/test_util_taskcluster.py::test_list_artifact PASSED                 [ 78%]
[task 2026-04-29T17:47:50.804+00:00] test/test_util_taskcluster.py::test_get_artifact_path PASSED             [ 79%]
[task 2026-04-29T17:47:50.811+00:00] test/test_util_taskcluster.py::test_get_index_url PASSED                 [ 79%]
[task 2026-04-29T17:47:50.816+00:00] test/test_util_taskcluster.py::test_find_task_id PASSED                  [ 79%]
[task 2026-04-29T17:47:50.822+00:00] test/test_util_taskcluster.py::test_find_task_id_batched PASSED          [ 79%]
[task 2026-04-29T17:47:50.829+00:00] test/test_util_taskcluster.py::test_get_artifact_from_index PASSED       [ 79%]
[task 2026-04-29T17:47:50.835+00:00] test/test_util_taskcluster.py::test_get_artifact_from_index_uses_artifact_path_for_parsing PASSED [ 79%]
[task 2026-04-29T17:47:50.841+00:00] test/test_util_taskcluster.py::test_list_tasks PASSED                    [ 80%]
[task 2026-04-29T17:47:50.845+00:00] test/test_util_taskcluster.py::test_parse_time PASSED                    [ 80%]
[task 2026-04-29T17:47:50.850+00:00] test/test_util_taskcluster.py::test_get_task_url PASSED                  [ 80%]
[task 2026-04-29T17:47:50.855+00:00] test/test_util_taskcluster.py::test_get_task_definition PASSED           [ 80%]
[task 2026-04-29T17:47:50.864+00:00] test/test_util_taskcluster.py::test_get_task_definitions PASSED          [ 80%]
[task 2026-04-29T17:47:50.867+00:00] test/test_util_taskcluster.py::test_cancel_task PASSED                   [ 80%]
[task 2026-04-29T17:47:50.872+00:00] test/test_util_taskcluster.py::test_status_task PASSED                   [ 81%]
[task 2026-04-29T17:47:50.879+00:00] test/test_util_taskcluster.py::test_status_task_batched PASSED           [ 81%]
[task 2026-04-29T17:47:50.884+00:00] test/test_util_taskcluster.py::test_state_task PASSED                    [ 81%]
[task 2026-04-29T17:47:50.887+00:00] test/test_util_taskcluster.py::test_rerun_task PASSED                    [ 81%]
[task 2026-04-29T17:47:50.892+00:00] test/test_util_taskcluster.py::test_get_current_scopes PASSED            [ 81%]
[task 2026-04-29T17:47:50.895+00:00] test/test_util_taskcluster.py::test_purge_cache PASSED                   [ 81%]
[task 2026-04-29T17:47:50.897+00:00] test/test_util_taskcluster.py::test_send_email PASSED                    [ 82%]
[task 2026-04-29T17:47:50.905+00:00] test/test_util_taskcluster.py::test_list_task_group_incomplete_tasks PASSED [ 82%]
[task 2026-04-29T17:47:50.916+00:00] test/test_util_taskcluster.py::test_get_ancestors PASSED                 [ 82%]
[task 2026-04-29T17:47:50.925+00:00] test/test_util_taskcluster.py::test_get_ancestors_string PASSED          [ 82%]
[task 2026-04-29T17:47:50.930+00:00] test/test_util_taskcluster.py::test_get_taskcluster_client PASSED        [ 82%]
[task 2026-04-29T17:47:50.932+00:00] test/test_util_templates.py::MergeTest::test_merge PASSED                [ 82%]
[task 2026-04-29T17:47:50.933+00:00] test/test_util_templates.py::MergeTest::test_merge_by PASSED             [ 83%]
[task 2026-04-29T17:47:50.934+00:00] test/test_util_templates.py::MergeTest::test_merge_diff_types PASSED     [ 83%]
[task 2026-04-29T17:47:50.935+00:00] test/test_util_templates.py::MergeTest::test_merge_multiple_by PASSED    [ 83%]
[task 2026-04-29T17:47:50.936+00:00] test/test_util_templates.py::MergeTest::test_merge_to_dicts PASSED       [ 83%]
[task 2026-04-29T17:47:50.937+00:00] test/test_util_templates.py::MergeTest::test_merge_to_lists PASSED       [ 83%]
[task 2026-04-29T17:47:50.947+00:00] test/test_util_time.py::FromNowTest::test_current_json_time PASSED       [ 83%]
[task 2026-04-29T17:47:50.949+00:00] test/test_util_time.py::FromNowTest::test_invalid_str PASSED             [ 84%]
[task 2026-04-29T17:47:50.950+00:00] test/test_util_time.py::FromNowTest::test_json_from_now PASSED           [ 84%]
[task 2026-04-29T17:47:50.952+00:00] test/test_util_time.py::FromNowTest::test_json_from_now_tzinfo PASSED    [ 84%]
[task 2026-04-29T17:47:50.953+00:00] test/test_util_time.py::FromNowTest::test_json_from_now_utc_now PASSED   [ 84%]
[task 2026-04-29T17:47:50.954+00:00] test/test_util_time.py::FromNowTest::test_missing_unit PASSED            [ 84%]
[task 2026-04-29T17:47:50.956+00:00] test/test_util_time.py::FromNowTest::test_missing_unknown_unit PASSED    [ 84%]
[task 2026-04-29T17:47:50.960+00:00] test/test_util_time.py::FromNowTest::test_value_of PASSED                [ 84%]
[task 2026-04-29T17:47:50.961+00:00] test/test_util_treeherder.py::TestSymbols::test_add_suffix_no_group PASSED [ 85%]
[task 2026-04-29T17:47:50.962+00:00] test/test_util_treeherder.py::TestSymbols::test_add_suffix_with_group PASSED [ 85%]
[task 2026-04-29T17:47:50.963+00:00] test/test_util_treeherder.py::TestSymbols::test_join_no_group PASSED     [ 85%]
[task 2026-04-29T17:47:50.964+00:00] test/test_util_treeherder.py::TestSymbols::test_join_with_group PASSED   [ 85%]
[task 2026-04-29T17:47:50.965+00:00] test/test_util_treeherder.py::TestSymbols::test_split_no_group PASSED    [ 85%]
[task 2026-04-29T17:47:50.966+00:00] test/test_util_treeherder.py::TestSymbols::test_split_with_group PASSED  [ 85%]
[task 2026-04-29T17:47:51.003+00:00] test/test_util_vcs.py::test_get_repository[git] PASSED                   [ 86%]
[task 2026-04-29T17:47:51.008+00:00] test/test_util_vcs.py::test_get_repository[hg] PASSED                    [ 86%]
[task 2026-04-29T17:47:51.018+00:00] test/test_util_vcs.py::test_get_repository_type[git] PASSED              [ 86%]
[task 2026-04-29T17:47:51.023+00:00] test/test_util_vcs.py::test_get_repository_type[hg] PASSED               [ 86%]
[task 2026-04-29T17:47:51.025+00:00] test/test_util_vcs.py::test_get_repository_type_failure PASSED           [ 86%]
[task 2026-04-29T17:47:51.029+00:00] test/test_util_vcs.py::test_hgplain PASSED                               [ 86%]
[task 2026-04-29T17:47:51.050+00:00] test/test_util_vcs.py::test_get_commit_message[git-commit message in\u2026 pure utf8] PASSED [ 87%]
[task 2026-04-29T17:47:51.066+00:00] test/test_util_vcs.py::test_get_commit_message[git-commit message in... ascii] PASSED [ 87%]
[task 2026-04-29T17:47:51.672+00:00] test/test_util_vcs.py::test_get_commit_message[hg-commit message in\u2026 pure utf8] PASSED [ 87%]
[task 2026-04-29T17:47:52.294+00:00] test/test_util_vcs.py::test_get_commit_message[hg-commit message in... ascii] PASSED [ 87%]
[task 2026-04-29T17:47:52.305+00:00] test/test_util_vcs.py::test_calculate_head_rev[git] PASSED               [ 87%]
[task 2026-04-29T17:47:52.513+00:00] test/test_util_vcs.py::test_calculate_head_rev[hg] PASSED                [ 87%]
[task 2026-04-29T17:47:52.531+00:00] test/test_util_vcs.py::test_get_repo_path[git] PASSED                    [ 88%]
[task 2026-04-29T17:47:52.913+00:00] test/test_util_vcs.py::test_get_repo_path[hg] PASSED                     [ 88%]
[task 2026-04-29T17:47:52.945+00:00] test/test_util_vcs.py::test_update[git] PASSED                           [ 88%]
[task 2026-04-29T17:47:54.574+00:00] test/test_util_vcs.py::test_update[hg] PASSED                            [ 88%]
[task 2026-04-29T17:47:54.709+00:00] test/test_util_vcs.py::test_branch[git] PASSED                           [ 88%]
[task 2026-04-29T17:47:55.931+00:00] test/test_util_vcs.py::test_branch[hg] PASSED                            [ 88%]
[task 2026-04-29T17:47:55.947+00:00] test/test_util_vcs.py::test_remote_name_no_remote[git] PASSED            [ 89%]
[task 2026-04-29T17:47:56.122+00:00] test/test_util_vcs.py::test_remote_name_no_remote[hg] PASSED             [ 89%]
[task 2026-04-29T17:47:56.168+00:00] test/test_util_vcs.py::test_remote_name[git] PASSED                      [ 89%]
[task 2026-04-29T17:47:56.542+00:00] test/test_util_vcs.py::test_remote_name[hg] PASSED                       [ 89%]
[task 2026-04-29T17:47:56.589+00:00] test/test_util_vcs.py::test_all_remote_names[git] PASSED                 [ 89%]
[task 2026-04-29T17:47:57.335+00:00] test/test_util_vcs.py::test_all_remote_names[hg] PASSED                  [ 89%]
[task 2026-04-29T17:47:57.385+00:00] test/test_util_vcs.py::test_remote_name_many_remotes[git] PASSED         [ 90%]
[task 2026-04-29T17:47:57.982+00:00] test/test_util_vcs.py::test_remote_name_many_remotes[hg] PASSED          [ 90%]
[task 2026-04-29T17:47:58.031+00:00] test/test_util_vcs.py::test_remote_name_default_and_origin[git] PASSED   [ 90%]
[task 2026-04-29T17:47:58.641+00:00] test/test_util_vcs.py::test_remote_name_default_and_origin[hg] PASSED    [ 90%]
[task 2026-04-29T17:47:58.670+00:00] test/test_util_vcs.py::test_default_branch_guess[git] PASSED             [ 90%]
[task 2026-04-29T17:47:58.678+00:00] test/test_util_vcs.py::test_default_branch_guess[hg] PASSED              [ 90%]
[task 2026-04-29T17:47:58.722+00:00] test/test_util_vcs.py::test_default_branch_remote_query[git] PASSED      [ 91%]
[task 2026-04-29T17:47:58.937+00:00] test/test_util_vcs.py::test_default_branch_remote_query[hg] PASSED       [ 91%]
[task 2026-04-29T17:47:58.959+00:00] test/test_util_vcs.py::test_default_branch_cloned_metadata[git] PASSED   [ 91%]
[task 2026-04-29T17:47:58.966+00:00] test/test_util_vcs.py::test_default_branch_cloned_metadata[hg] PASSED    [ 91%]
[task 2026-04-29T17:47:59.003+00:00] test/test_util_vcs.py::test_get_tracked_files[git] PASSED                [ 91%]
[task 2026-04-29T17:48:00.886+00:00] test/test_util_vcs.py::test_get_tracked_files[hg] PASSED                 [ 91%]
[task 2026-04-29T17:48:00.907+00:00] test/test_util_vcs.py::test_get_changed_files_no_changes[git] PASSED     [ 92%]
[task 2026-04-29T17:48:01.699+00:00] test/test_util_vcs.py::test_get_changed_files_no_changes[hg] PASSED      [ 92%]
[task 2026-04-29T17:48:01.735+00:00] test/test_util_vcs.py::test_get_changed_files_one_modified_file[git] PASSED [ 92%]
[task 2026-04-29T17:48:03.142+00:00] test/test_util_vcs.py::test_get_changed_files_one_modified_file[hg] PASSED [ 92%]
[task 2026-04-29T17:48:03.165+00:00] test/test_util_vcs.py::test_get_changed_files_one_deleted_file[git] PASSED [ 92%]
[task 2026-04-29T17:48:04.558+00:00] test/test_util_vcs.py::test_get_changed_files_one_deleted_file[hg] PASSED [ 92%]
[task 2026-04-29T17:48:04.591+00:00] test/test_util_vcs.py::test_get_changed_files_one_added_file[git] PASSED [ 92%]
[task 2026-04-29T17:48:06.180+00:00] test/test_util_vcs.py::test_get_changed_files_one_added_file[hg] PASSED  [ 93%]
[task 2026-04-29T17:48:06.245+00:00] test/test_util_vcs.py::test_get_changed_files_two_revisions[git] PASSED  [ 93%]
[task 2026-04-29T17:48:09.778+00:00] test/test_util_vcs.py::test_get_changed_files_two_revisions[hg] PASSED   [ 93%]
[task 2026-04-29T17:48:09.864+00:00] test/test_util_vcs.py::test_workdir_outgoing[git] PASSED                 [ 93%]
[task 2026-04-29T17:48:15.028+00:00] test/test_util_vcs.py::test_workdir_outgoing[hg] PASSED                  [ 93%]
[task 2026-04-29T17:48:15.090+00:00] test/test_util_vcs.py::test_working_directory_clean[git] PASSED          [ 93%]
[task 2026-04-29T17:48:17.512+00:00] test/test_util_vcs.py::test_working_directory_clean[hg] PASSED           [ 94%]
[task 2026-04-29T17:48:17.581+00:00] test/test_util_vcs.py::test_find_latest_common_revision[git] PASSED      [ 94%]
[task 2026-04-29T17:48:20.085+00:00] test/test_util_vcs.py::test_find_latest_common_revision[hg] PASSED       [ 94%]
[task 2026-04-29T17:48:20.111+00:00] test/test_util_vcs.py::test_does_revision_exist_locally[git] PASSED      [ 94%]
[task 2026-04-29T17:48:21.582+00:00] test/test_util_vcs.py::test_does_revision_exist_locally[hg] PASSED       [ 94%]
[task 2026-04-29T17:48:21.699+00:00] test/test_util_vcs.py::test_get_changed_files_shallow_clone PASSED       [ 94%]
[task 2026-04-29T17:48:21.725+00:00] test/test_util_vcs.py::test_get_changed_files_with_null_base_revision[git] PASSED [ 95%]
[task 2026-04-29T17:48:22.582+00:00] test/test_util_vcs.py::test_get_changed_files_with_null_base_revision[hg] PASSED [ 95%]
[task 2026-04-29T17:48:22.627+00:00] test/test_util_vcs.py::test_get_changed_files_with_null_base_revision_shallow_clone PASSED [ 95%]
[task 2026-04-29T17:48:22.705+00:00] test/test_util_vcs.py::test_get_note_git PASSED                          [ 95%]
[task 2026-04-29T17:48:22.732+00:00] test/test_util_verify.py::test_verification_types[GraphVerification] PASSED [ 95%]
[task 2026-04-29T17:48:22.733+00:00] test/test_util_verify.py::test_verification_types[InitialVerification] PASSED [ 95%]
[task 2026-04-29T17:48:22.736+00:00] test/test_util_verify.py::test_verification_types[KindsVerification] PASSED [ 96%]
[task 2026-04-29T17:48:22.737+00:00] test/test_util_verify.py::test_verification_types[ParametersVerification] PASSED [ 96%]
[task 2026-04-29T17:48:22.739+00:00] test/test_util_verify.py::test_verification_types[GraphConfigVerification] PASSED [ 96%]
[task 2026-04-29T17:48:22.743+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: valid] PASSED [ 96%]
[task 2026-04-29T17:48:22.745+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: conflicting symbol] PASSED [ 96%]
[task 2026-04-29T17:48:22.746+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: too many collections] PASSED [ 96%]
[task 2026-04-29T17:48:22.747+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: valid] PASSED [ 97%]
[task 2026-04-29T17:48:22.749+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: invalid] PASSED [ 97%]
[task 2026-04-29T17:48:22.750+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: deprecated] PASSED [ 97%]
[task 2026-04-29T17:48:22.751+00:00] test/test_util_verify.py::test_verification[verify_index_route: valid route] PASSED [ 97%]
[task 2026-04-29T17:48:22.753+00:00] test/test_util_verify.py::test_verification[verify_index_route: invalid slash in route] PASSED [ 97%]
[task 2026-04-29T17:48:22.754+00:00] test/test_util_verify.py::test_verification[verify_index_route: invalid plus in route] PASSED [ 97%]
[task 2026-04-29T17:48:22.755+00:00] test/test_util_verify.py::test_verification[verify_index_route: invalid space in route] PASSED [ 98%]
[task 2026-04-29T17:48:22.757+00:00] test/test_util_verify.py::test_verification[dependencies under limit] PASSED [ 98%]
[task 2026-04-29T17:48:22.758+00:00] test/test_util_verify.py::test_verification[dependencies at limit] PASSED [ 98%]
[task 2026-04-29T17:48:22.759+00:00] test/test_util_verify.py::test_verification[dependencies over limit] PASSED [ 98%]
[task 2026-04-29T17:48:22.761+00:00] test/test_util_verify.py::test_verification[using cache with wrong trust-domain] PASSED [ 98%]
[task 2026-04-29T17:48:22.762+00:00] test/test_util_verify.py::test_verification[using reserved cache] PASSED [ 98%]
[task 2026-04-29T17:48:22.763+00:00] test/test_util_verify.py::test_verification[using run-task without cache suffix] PASSED [ 99%]
[task 2026-04-29T17:48:22.765+00:00] test/test_util_verify.py::test_verification[using run-task-hg without cache suffix] PASSED [ 99%]
[task 2026-04-29T17:48:22.771+00:00] test/test_util_workertypes.py::test_get_worker_type[linux-1-Exception] PASSED [ 99%]
[task 2026-04-29T17:48:22.772+00:00] test/test_util_workertypes.py::test_get_worker_type[b-linux-3-test-domain-3/b-linux-gcp] PASSED [ 99%]
[task 2026-04-29T17:48:22.773+00:00] test/test_util_workertypes.py::test_get_worker_type[t-linux-1-test-domain-1/t-linux-gcp] PASSED [ 99%]
[task 2026-04-29T17:48:22.778+00:00] test/test_util_yaml.py::test_load PASSED                                 [ 99%]
[task 2026-04-29T17:48:23.132+00:00] test/test_util_yaml.py::test_key_order PASSED                            [100%]
[task 2026-04-29T17:48:23.132+00:00] 
[task 2026-04-29T17:48:23.132+00:00] =============================== warnings summary ===============================
[task 2026-04-29T17:48:23.132+00:00] test/test_config.py::test_vcs_root_fallback
[task 2026-04-29T17:48:23.132+00:00]   /builds/worker/checkouts/vcs/test/test_config.py:60: PytestMockWarning: Mocks returned by pytest-mock do not need to be used as context managers. The mocker fixture automatically undoes mocking at the end of a test. This warning can be ignored if it was triggered by mocking a context manager. https://pytest-mock.readthedocs.io/en/latest/usage.html#usage-as-context-manager
[task 2026-04-29T17:48:23.132+00:00]     with mocker.patch("taskgraph.config.get_repository", side_effect=RuntimeError):
[task 2026-04-29T17:48:23.132+00:00] 
[task 2026-04-29T17:48:23.132+00:00] test/test_config.py::test_vcs_root_fallback
[task 2026-04-29T17:48:23.132+00:00]   /builds/worker/checkouts/vcs/test/test_config.py:63: PytestMockWarning: Mocks returned by pytest-mock do not need to be used as context managers. The mocker fixture automatically undoes mocking at the end of a test. This warning can be ignored if it was triggered by mocking a context manager. https://pytest-mock.readthedocs.io/en/latest/usage.html#usage-as-context-manager
[task 2026-04-29T17:48:23.133+00:00]     with mocker.patch("taskgraph.config.get_repository", side_effect=RuntimeError):
[task 2026-04-29T17:48:23.133+00:00] 
[task 2026-04-29T17:48:23.133+00:00] -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
[task 2026-04-29T17:48:23.133+00:00] ============ 604 passed, 7 skipped, 2 xfailed, 2 warnings in 56.95s ============
[taskcluster 2026-04-29T17:48:23.955Z]                        Exit Code: 0
[taskcluster 2026-04-29T17:48:23.955Z]                        User Time: 36.639ms
[taskcluster 2026-04-29T17:48:23.955Z]                      Kernel Time: 53.186ms
[taskcluster 2026-04-29T17:48:23.955Z]                        Wall Time: 2m46.949263821s
[taskcluster 2026-04-29T17:48:23.955Z]  Average Available System Memory: 14.01 GiB
[taskcluster 2026-04-29T17:48:23.955Z]       Average System Memory Used: 1.60 GiB
[taskcluster 2026-04-29T17:48:23.955Z]          Peak System Memory Used: 1.86 GiB
[taskcluster 2026-04-29T17:48:23.955Z]              Total System Memory: 15.61 GiB
[taskcluster 2026-04-29T17:48:23.955Z]                           Result: SUCCEEDED
[taskcluster 2026-04-29T17:48:23.955Z] === Task Finished ===
[taskcluster 2026-04-29T17:48:23.955Z] Task Duration: 2m46.950130321s
[taskcluster 2026-04-29T17:48:24.491Z] [mounts] Preserving cache: Moving "/home/task_177748469787039/cache0" to "/home/generic-worker/caches/STDqyP_QRKutIJkdNi5xZA"
[taskcluster 2026-04-29T17:48:24.491Z] [mounts] Preserving cache: Moving "/home/task_177748469787039/cache1" to "/home/generic-worker/caches/HmF6OIGWRKyRbp4ZTngBvA"