Optimize graph traversal by using a more appropriate algorithm #823
firefoxci-taskcluster / test-unit-py312
succeeded
Oct 17, 2025 in 3m 6s
FirefoxCI (pull_request)
Run unit tests with py312 (Treeherder push)
Details
View task in Taskcluster | View logs in Taskcluster | View task group in Taskcluster
Task Status
Started: 2025-10-17T13:34:03.443Z
Resolved: 2025-10-17T13:34:50.319Z
Task Execution Time: 46 seconds, 876 milliseconds
Task Status: completed
Reason Resolved: completed
RunId: 0
Artifacts
- public/coverage.py312
- public/logs/live_backing.log
- public/logs/live.log
[taskcluster 2025-10-17 13:34:03.565Z] Task ID: MQITASS4QRCZ_69aqZpTfQ
[taskcluster 2025-10-17 13:34:03.565Z] Worker ID: 5262635392332463030
[taskcluster 2025-10-17 13:34:03.565Z] Worker Group: us-west1-c
[taskcluster 2025-10-17 13:34:03.565Z] Worker Node Type: projects/887720501152/machineTypes/c2-standard-4
[taskcluster 2025-10-17 13:34:03.565Z] Worker Pool: taskgraph-t/linux-gcp
[taskcluster 2025-10-17 13:34:03.565Z] Worker Version: 38.0.5
[taskcluster 2025-10-17 13:34:03.565Z] Public IP: 104.199.113.74
[taskcluster 2025-10-17 13:34:03.565Z] Hostname: taskgraph-t-linux-gcp-do1ib-b5sp-k2hy99betwq
[taskcluster 2025-10-17 13:34:03.565Z] using cache "taskgraph-level-1-uv-v3-26529e177a382bde07b2-VDYT3xlFRRWEiuuxW6__jw" -> /builds/worker/.task-cache/uv
[taskcluster 2025-10-17 13:34:03.565Z] using cache "taskgraph-level-1-checkouts-v3-26529e177a382bde07b2-VDYT3xlFRRWEiuuxW6__jw" -> /builds/worker/checkouts
[taskcluster 2025-10-17 13:34:04.281Z] Image 'public/image.tar.zst' from task 'VDYT3xlFRRWEiuuxW6__jw' loaded. Using image ID sha256:a4917f5b7fcd8e5242f16f8b0d33554ed25b3d8e5f5290c5c5f36e1e612cee5e.
[taskcluster 2025-10-17 13:34:04.366Z] === Task Starting ===
[setup 2025-10-17T13:34:04.982+00:00] run-task started in /
[setup 2025-10-17T13:34:04.982+00:00] Invoked by command: --ci-checkout=/builds/worker/checkouts/vcs/ --task-cwd /builds/worker/checkouts/vcs -- bash -cx uv run coverage run --data-file /builds/worker/artifacts/coverage --context=py312 -m pytest -vv
[setup 2025-10-17T13:34:04.982+00:00] Python version: 3.11.2
[setup 2025-10-17T13:34:04.982+00:00] Subprocess python version:
cpython-3.13.2-linux-x86_64-gnu /builds/worker/.local/share/uv/python/cpython-3.13.2-linux-x86_64-gnu/bin/python3.13
cpython-3.12.9-linux-x86_64-gnu /builds/worker/.local/share/uv/python/cpython-3.12.9-linux-x86_64-gnu/bin/python3.12
cpython-3.11.11-linux-x86_64-gnu /builds/worker/.local/share/uv/python/cpython-3.11.11-linux-x86_64-gnu/bin/python3.11
...(407 lines hidden)...
[task 2025-10-17T13:34:26.950+00:00] 'orjson': No module named 'orjson') [ 66%]
[task 2025-10-17T13:34:26.952+00:00] test/test_util_keyed_by.py::test_iter_dot_paths[simple case] PASSED [ 66%]
[task 2025-10-17T13:34:26.954+00:00] test/test_util_keyed_by.py::test_iter_dot_paths[list case] PASSED [ 66%]
[task 2025-10-17T13:34:26.956+00:00] test/test_util_keyed_by.py::test_iter_dot_paths[list partial match case] PASSED [ 66%]
[task 2025-10-17T13:34:26.958+00:00] test/test_util_keyed_by.py::test_iter_dot_paths[deep list case] PASSED [ 66%]
[task 2025-10-17T13:34:26.959+00:00] test/test_util_parameterization.py::test_timestamps_no_change PASSED [ 67%]
[task 2025-10-17T13:34:26.961+00:00] test/test_util_parameterization.py::test_timestamps_buried_replacement PASSED [ 67%]
[task 2025-10-17T13:34:26.962+00:00] test/test_util_parameterization.py::test_timestamps_appears_with_other_keys PASSED [ 67%]
[task 2025-10-17T13:34:26.964+00:00] test/test_util_parameterization.py::test_task_refs_no_change PASSED [ 67%]
[task 2025-10-17T13:34:26.966+00:00] test/test_util_parameterization.py::test_task_refs_in_list PASSED [ 67%]
[task 2025-10-17T13:34:26.967+00:00] test/test_util_parameterization.py::test_task_refs_in_dict PASSED [ 67%]
[task 2025-10-17T13:34:26.969+00:00] test/test_util_parameterization.py::test_task_refs_multiple PASSED [ 68%]
[task 2025-10-17T13:34:26.971+00:00] test/test_util_parameterization.py::test_task_refs_embedded PASSED [ 68%]
[task 2025-10-17T13:34:26.972+00:00] test/test_util_parameterization.py::test_task_refs_escaping PASSED [ 68%]
[task 2025-10-17T13:34:26.974+00:00] test/test_util_parameterization.py::test_task_refs_multikey PASSED [ 68%]
[task 2025-10-17T13:34:26.976+00:00] test/test_util_parameterization.py::test_task_refs_self PASSED [ 68%]
[task 2025-10-17T13:34:26.977+00:00] test/test_util_parameterization.py::test_task_refs_decision PASSED [ 69%]
[task 2025-10-17T13:34:26.979+00:00] test/test_util_parameterization.py::test_task_refs_key PASSED [ 69%]
[task 2025-10-17T13:34:26.980+00:00] test/test_util_parameterization.py::test_task_refs_invalid PASSED [ 69%]
[task 2025-10-17T13:34:26.982+00:00] test/test_util_parameterization.py::test_artifact_refs_in_list PASSED [ 69%]
[task 2025-10-17T13:34:26.984+00:00] test/test_util_parameterization.py::test_artifact_refs_in_dict PASSED [ 69%]
[task 2025-10-17T13:34:26.986+00:00] test/test_util_parameterization.py::test_artifact_refs_in_string PASSED [ 69%]
[task 2025-10-17T13:34:26.988+00:00] test/test_util_parameterization.py::test_artifact_refs_private PASSED [ 70%]
[task 2025-10-17T13:34:26.989+00:00] test/test_util_parameterization.py::test_artifact_refs_self PASSED [ 70%]
[task 2025-10-17T13:34:26.991+00:00] test/test_util_parameterization.py::test_artifact_refs_decision PASSED [ 70%]
[task 2025-10-17T13:34:26.993+00:00] test/test_util_parameterization.py::test_artifact_refs_invalid PASSED [ 70%]
[task 2025-10-17T13:34:26.994+00:00] test/test_util_parameterization.py::test_artifact_refs_badly_formed PASSED [ 70%]
[task 2025-10-17T13:34:26.996+00:00] test/test_util_path.py::TestPath::test_basedir PASSED [ 71%]
[task 2025-10-17T13:34:26.998+00:00] test/test_util_path.py::TestPath::test_basename PASSED [ 71%]
[task 2025-10-17T13:34:26.999+00:00] test/test_util_path.py::TestPath::test_commonprefix PASSED [ 71%]
[task 2025-10-17T13:34:27.001+00:00] test/test_util_path.py::TestPath::test_dirname PASSED [ 71%]
[task 2025-10-17T13:34:27.003+00:00] test/test_util_path.py::TestPath::test_join PASSED [ 71%]
[task 2025-10-17T13:34:27.034+00:00] test/test_util_path.py::TestPath::test_match PASSED [ 72%]
[task 2025-10-17T13:34:27.035+00:00] test/test_util_path.py::TestPath::test_normpath PASSED [ 72%]
[task 2025-10-17T13:34:27.037+00:00] test/test_util_path.py::TestPath::test_rebase PASSED [ 72%]
[task 2025-10-17T13:34:27.039+00:00] test/test_util_path.py::TestPath::test_relpath PASSED [ 72%]
[task 2025-10-17T13:34:27.041+00:00] test/test_util_path.py::TestPath::test_split PASSED [ 72%]
[task 2025-10-17T13:34:27.042+00:00] test/test_util_path.py::TestPath::test_splitext PASSED [ 72%]
[task 2025-10-17T13:34:27.045+00:00] test/test_util_python_path.py::test_find_object_no_such_module PASSED [ 73%]
[task 2025-10-17T13:34:27.047+00:00] test/test_util_python_path.py::test_find_object_no_such_object PASSED [ 73%]
[task 2025-10-17T13:34:27.049+00:00] test/test_util_python_path.py::test_find_object_exists PASSED [ 73%]
[task 2025-10-17T13:34:27.051+00:00] test/test_util_readonlydict.py::test_basic PASSED [ 73%]
[task 2025-10-17T13:34:27.052+00:00] test/test_util_readonlydict.py::test_update PASSED [ 73%]
[task 2025-10-17T13:34:27.054+00:00] test/test_util_readonlydict.py::test_del PASSED [ 74%]
[task 2025-10-17T13:34:27.055+00:00] test/test_util_readonlydict.py::test_copy PASSED [ 74%]
[task 2025-10-17T13:34:27.057+00:00] test/test_util_readonlydict.py::test_pickle PASSED [ 74%]
[task 2025-10-17T13:34:27.059+00:00] test/test_util_schema.py::TestValidateSchema::test_invalid PASSED [ 74%]
[task 2025-10-17T13:34:27.060+00:00] test/test_util_schema.py::TestValidateSchema::test_valid PASSED [ 74%]
[task 2025-10-17T13:34:27.062+00:00] test/test_util_schema.py::TestCheckSchema::test_extend_schema PASSED [ 74%]
[task 2025-10-17T13:34:27.064+00:00] test/test_util_schema.py::TestCheckSchema::test_extend_schema_twice PASSED [ 75%]
[task 2025-10-17T13:34:27.066+00:00] test/test_util_schema.py::TestCheckSchema::test_schema PASSED [ 75%]
[task 2025-10-17T13:34:27.068+00:00] test/test_util_schema.py::test_check_skipped PASSED [ 75%]
[task 2025-10-17T13:34:27.070+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_list PASSED [ 75%]
[task 2025-10-17T13:34:27.072+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_default PASSED [ 75%]
[task 2025-10-17T13:34:27.073+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_extra_value PASSED [ 76%]
[task 2025-10-17T13:34:27.075+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_nested_exact PASSED [ 76%]
[task 2025-10-17T13:34:27.077+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_partial_regexp PASSED [ 76%]
[task 2025-10-17T13:34:27.079+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_match_regexp PASSED [ 76%]
[task 2025-10-17T13:34:27.082+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_multiple_matches PASSED [ 76%]
[task 2025-10-17T13:34:27.084+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_nested PASSED [ 76%]
[task 2025-10-17T13:34:27.085+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by PASSED [ 77%]
[task 2025-10-17T13:34:27.087+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_dotted PASSED [ 77%]
[task 2025-10-17T13:34:27.088+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_empty_dict PASSED [ 77%]
[task 2025-10-17T13:34:27.090+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_by PASSED [ 77%]
[task 2025-10-17T13:34:27.092+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_dict PASSED [ 77%]
[task 2025-10-17T13:34:27.093+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_by_not_only_by PASSED [ 78%]
[task 2025-10-17T13:34:27.095+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_key PASSED [ 78%]
[task 2025-10-17T13:34:27.096+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_key_no_default PASSED [ 78%]
[task 2025-10-17T13:34:27.098+00:00] test/test_util_schema.py::TestResolveKeyedBy::test_no_match PASSED [ 78%]
[task 2025-10-17T13:34:27.099+00:00] test/test_util_schema.py::test_optionally_keyed_by PASSED [ 78%]
[task 2025-10-17T13:34:27.102+00:00] test/test_util_schema.py::test_optionally_keyed_by_mulitple_keys PASSED [ 79%]
[task 2025-10-17T13:34:27.104+00:00] test/test_util_taskcluster.py::test_get_root_url PASSED [ 79%]
[task 2025-10-17T13:34:27.106+00:00] test/test_util_taskcluster.py::test_get_artifact_url PASSED [ 79%]
[task 2025-10-17T13:34:27.117+00:00] test/test_util_taskcluster.py::test_get_artifact PASSED [ 79%]
[task 2025-10-17T13:34:27.121+00:00] test/test_util_taskcluster.py::test_list_artifact PASSED [ 79%]
[task 2025-10-17T13:34:27.123+00:00] test/test_util_taskcluster.py::test_get_artifact_path PASSED [ 79%]
[task 2025-10-17T13:34:27.125+00:00] test/test_util_taskcluster.py::test_get_index_url PASSED [ 80%]
[task 2025-10-17T13:34:27.128+00:00] test/test_util_taskcluster.py::test_find_task_id PASSED [ 80%]
[task 2025-10-17T13:34:27.133+00:00] test/test_util_taskcluster.py::test_find_task_id_batched PASSED [ 80%]
[task 2025-10-17T13:34:27.137+00:00] test/test_util_taskcluster.py::test_get_artifact_from_index PASSED [ 80%]
[task 2025-10-17T13:34:27.142+00:00] test/test_util_taskcluster.py::test_list_tasks PASSED [ 80%]
[task 2025-10-17T13:34:27.144+00:00] test/test_util_taskcluster.py::test_parse_time PASSED [ 81%]
[task 2025-10-17T13:34:27.145+00:00] test/test_util_taskcluster.py::test_get_task_url PASSED [ 81%]
[task 2025-10-17T13:34:27.149+00:00] test/test_util_taskcluster.py::test_get_task_definition PASSED [ 81%]
[task 2025-10-17T13:34:27.152+00:00] test/test_util_taskcluster.py::test_cancel_task PASSED [ 81%]
[task 2025-10-17T13:34:27.156+00:00] test/test_util_taskcluster.py::test_status_task PASSED [ 81%]
[task 2025-10-17T13:34:27.160+00:00] test/test_util_taskcluster.py::test_status_task_batched PASSED [ 81%]
[task 2025-10-17T13:34:27.164+00:00] test/test_util_taskcluster.py::test_state_task PASSED [ 82%]
[task 2025-10-17T13:34:27.167+00:00] test/test_util_taskcluster.py::test_rerun_task PASSED [ 82%]
[task 2025-10-17T13:34:27.170+00:00] test/test_util_taskcluster.py::test_get_current_scopes PASSED [ 82%]
[task 2025-10-17T13:34:27.174+00:00] test/test_util_taskcluster.py::test_purge_cache PASSED [ 82%]
[task 2025-10-17T13:34:27.177+00:00] test/test_util_taskcluster.py::test_send_email PASSED [ 82%]
[task 2025-10-17T13:34:27.183+00:00] test/test_util_taskcluster.py::test_list_task_group_incomplete_tasks PASSED [ 83%]
[task 2025-10-17T13:34:27.195+00:00] test/test_util_taskcluster.py::test_get_ancestors PASSED [ 83%]
[task 2025-10-17T13:34:27.207+00:00] test/test_util_taskcluster.py::test_get_ancestors_string PASSED [ 83%]
[task 2025-10-17T13:34:27.209+00:00] test/test_util_templates.py::MergeTest::test_merge PASSED [ 83%]
[task 2025-10-17T13:34:27.210+00:00] test/test_util_templates.py::MergeTest::test_merge_by PASSED [ 83%]
[task 2025-10-17T13:34:27.212+00:00] test/test_util_templates.py::MergeTest::test_merge_diff_types PASSED [ 83%]
[task 2025-10-17T13:34:27.213+00:00] test/test_util_templates.py::MergeTest::test_merge_multiple_by PASSED [ 84%]
[task 2025-10-17T13:34:27.215+00:00] test/test_util_templates.py::MergeTest::test_merge_to_dicts PASSED [ 84%]
[task 2025-10-17T13:34:27.217+00:00] test/test_util_templates.py::MergeTest::test_merge_to_lists PASSED [ 84%]
[task 2025-10-17T13:34:27.219+00:00] test/test_util_time.py::FromNowTest::test_current_json_time PASSED [ 84%]
[task 2025-10-17T13:34:27.221+00:00] test/test_util_time.py::FromNowTest::test_invalid_str PASSED [ 84%]
[task 2025-10-17T13:34:27.222+00:00] test/test_util_time.py::FromNowTest::test_json_from_now PASSED [ 85%]
[task 2025-10-17T13:34:27.224+00:00] test/test_util_time.py::FromNowTest::test_json_from_now_tzinfo PASSED [ 85%]
[task 2025-10-17T13:34:27.226+00:00] test/test_util_time.py::FromNowTest::test_json_from_now_utc_now PASSED [ 85%]
[task 2025-10-17T13:34:27.227+00:00] test/test_util_time.py::FromNowTest::test_missing_unit PASSED [ 85%]
[task 2025-10-17T13:34:27.229+00:00] test/test_util_time.py::FromNowTest::test_missing_unknown_unit PASSED [ 85%]
[task 2025-10-17T13:34:27.231+00:00] test/test_util_time.py::FromNowTest::test_value_of PASSED [ 86%]
[task 2025-10-17T13:34:27.232+00:00] test/test_util_treeherder.py::TestSymbols::test_add_suffix_no_group PASSED [ 86%]
[task 2025-10-17T13:34:27.234+00:00] test/test_util_treeherder.py::TestSymbols::test_add_suffix_with_group PASSED [ 86%]
[task 2025-10-17T13:34:27.236+00:00] test/test_util_treeherder.py::TestSymbols::test_join_no_group PASSED [ 86%]
[task 2025-10-17T13:34:27.237+00:00] test/test_util_treeherder.py::TestSymbols::test_join_with_group PASSED [ 86%]
[task 2025-10-17T13:34:27.239+00:00] test/test_util_treeherder.py::TestSymbols::test_split_no_group PASSED [ 86%]
[task 2025-10-17T13:34:27.241+00:00] test/test_util_treeherder.py::TestSymbols::test_split_with_group PASSED [ 87%]
[task 2025-10-17T13:34:27.248+00:00] test/test_util_vcs.py::test_get_repository[git] PASSED [ 87%]
[task 2025-10-17T13:34:27.254+00:00] test/test_util_vcs.py::test_get_repository[hg] PASSED [ 87%]
[task 2025-10-17T13:34:27.261+00:00] test/test_util_vcs.py::test_get_repository_type[git] PASSED [ 87%]
[task 2025-10-17T13:34:27.266+00:00] test/test_util_vcs.py::test_get_repository_type[hg] PASSED [ 87%]
[task 2025-10-17T13:34:27.269+00:00] test/test_util_vcs.py::test_get_repository_type_failure PASSED [ 88%]
[task 2025-10-17T13:34:27.271+00:00] test/test_util_vcs.py::test_hgplain PASSED [ 88%]
[task 2025-10-17T13:34:27.285+00:00] test/test_util_vcs.py::test_get_commit_message[git-commit message in\u2026 pure utf8] PASSED [ 88%]
[task 2025-10-17T13:34:27.300+00:00] test/test_util_vcs.py::test_get_commit_message[git-commit message in... ascii] PASSED [ 88%]
[task 2025-10-17T13:34:27.720+00:00] test/test_util_vcs.py::test_get_commit_message[hg-commit message in\u2026 pure utf8] PASSED [ 88%]
[task 2025-10-17T13:34:28.141+00:00] test/test_util_vcs.py::test_get_commit_message[hg-commit message in... ascii] PASSED [ 88%]
[task 2025-10-17T13:34:28.150+00:00] test/test_util_vcs.py::test_calculate_head_rev[git] PASSED [ 89%]
[task 2025-10-17T13:34:28.287+00:00] test/test_util_vcs.py::test_calculate_head_rev[hg] PASSED [ 89%]
[task 2025-10-17T13:34:28.300+00:00] test/test_util_vcs.py::test_get_repo_path[git] PASSED [ 89%]
[task 2025-10-17T13:34:28.543+00:00] test/test_util_vcs.py::test_get_repo_path[hg] PASSED [ 89%]
[task 2025-10-17T13:34:28.566+00:00] test/test_util_vcs.py::test_update[git] PASSED [ 89%]
[task 2025-10-17T13:34:29.729+00:00] test/test_util_vcs.py::test_update[hg] PASSED [ 90%]
[task 2025-10-17T13:34:29.757+00:00] test/test_util_vcs.py::test_branch[git] PASSED [ 90%]
[task 2025-10-17T13:34:30.602+00:00] test/test_util_vcs.py::test_branch[hg] PASSED [ 90%]
[task 2025-10-17T13:34:30.612+00:00] test/test_util_vcs.py::test_remote_name_no_remote[git] PASSED [ 90%]
[task 2025-10-17T13:34:30.730+00:00] test/test_util_vcs.py::test_remote_name_no_remote[hg] PASSED [ 90%]
[task 2025-10-17T13:34:30.758+00:00] test/test_util_vcs.py::test_remote_name[git] PASSED [ 90%]
[task 2025-10-17T13:34:31.017+00:00] test/test_util_vcs.py::test_remote_name[hg] PASSED [ 91%]
[task 2025-10-17T13:34:31.056+00:00] test/test_util_vcs.py::test_all_remote_names[git] PASSED [ 91%]
[task 2025-10-17T13:34:31.573+00:00] test/test_util_vcs.py::test_all_remote_names[hg] PASSED [ 91%]
[task 2025-10-17T13:34:31.615+00:00] test/test_util_vcs.py::test_remote_name_many_remotes[git] PASSED [ 91%]
[task 2025-10-17T13:34:32.007+00:00] test/test_util_vcs.py::test_remote_name_many_remotes[hg] PASSED [ 91%]
[task 2025-10-17T13:34:32.047+00:00] test/test_util_vcs.py::test_remote_name_default_and_origin[git] PASSED [ 92%]
[task 2025-10-17T13:34:32.450+00:00] test/test_util_vcs.py::test_remote_name_default_and_origin[hg] PASSED [ 92%]
[task 2025-10-17T13:34:32.464+00:00] test/test_util_vcs.py::test_default_branch_guess[git] PASSED [ 92%]
[task 2025-10-17T13:34:32.470+00:00] test/test_util_vcs.py::test_default_branch_guess[hg] PASSED [ 92%]
[task 2025-10-17T13:34:32.498+00:00] test/test_util_vcs.py::test_default_branch_remote_query[git] PASSED [ 92%]
[task 2025-10-17T13:34:32.644+00:00] test/test_util_vcs.py::test_default_branch_remote_query[hg] PASSED [ 93%]
[task 2025-10-17T13:34:32.662+00:00] test/test_util_vcs.py::test_default_branch_cloned_metadata[git] PASSED [ 93%]
[task 2025-10-17T13:34:32.668+00:00] test/test_util_vcs.py::test_default_branch_cloned_metadata[hg] PASSED [ 93%]
[task 2025-10-17T13:34:32.691+00:00] test/test_util_vcs.py::test_get_tracked_files[git] PASSED [ 93%]
[task 2025-10-17T13:34:33.933+00:00] test/test_util_vcs.py::test_get_tracked_files[hg] PASSED [ 93%]
[task 2025-10-17T13:34:33.947+00:00] test/test_util_vcs.py::test_get_changed_files_no_changes[git] PASSED [ 93%]
[task 2025-10-17T13:34:34.459+00:00] test/test_util_vcs.py::test_get_changed_files_no_changes[hg] PASSED [ 94%]
[task 2025-10-17T13:34:34.486+00:00] test/test_util_vcs.py::test_get_changed_files_one_modified_file[git] PASSED [ 94%]
[task 2025-10-17T13:34:35.446+00:00] test/test_util_vcs.py::test_get_changed_files_one_modified_file[hg] PASSED [ 94%]
[task 2025-10-17T13:34:35.467+00:00] test/test_util_vcs.py::test_get_changed_files_one_deleted_file[git] PASSED [ 94%]
[task 2025-10-17T13:34:36.436+00:00] test/test_util_vcs.py::test_get_changed_files_one_deleted_file[hg] PASSED [ 94%]
[task 2025-10-17T13:34:36.461+00:00] test/test_util_vcs.py::test_get_changed_files_one_added_file[git] PASSED [ 95%]
[task 2025-10-17T13:34:37.545+00:00] test/test_util_vcs.py::test_get_changed_files_one_added_file[hg] PASSED [ 95%]
[task 2025-10-17T13:34:37.586+00:00] test/test_util_vcs.py::test_get_changed_files_two_revisions[git] PASSED [ 95%]
[task 2025-10-17T13:34:40.142+00:00] test/test_util_vcs.py::test_get_changed_files_two_revisions[hg] PASSED [ 95%]
[task 2025-10-17T13:34:40.209+00:00] test/test_util_vcs.py::test_workdir_outgoing[git] PASSED [ 95%]
[task 2025-10-17T13:34:43.840+00:00] test/test_util_vcs.py::test_workdir_outgoing[hg] PASSED [ 95%]
[task 2025-10-17T13:34:43.871+00:00] test/test_util_vcs.py::test_working_directory_clean[git] PASSED [ 96%]
[task 2025-10-17T13:34:45.508+00:00] test/test_util_vcs.py::test_working_directory_clean[hg] PASSED [ 96%]
[task 2025-10-17T13:34:45.555+00:00] test/test_util_vcs.py::test_find_latest_common_revision[git] PASSED [ 96%]
[task 2025-10-17T13:34:47.274+00:00] test/test_util_vcs.py::test_find_latest_common_revision[hg] PASSED [ 96%]
[task 2025-10-17T13:34:47.294+00:00] test/test_util_vcs.py::test_does_revision_exist_locally[git] PASSED [ 96%]
[task 2025-10-17T13:34:48.295+00:00] test/test_util_vcs.py::test_does_revision_exist_locally[hg] PASSED [ 97%]
[task 2025-10-17T13:34:48.298+00:00] test/test_util_verify.py::test_verification_types[GraphVerification] PASSED [ 97%]
[task 2025-10-17T13:34:48.300+00:00] test/test_util_verify.py::test_verification_types[InitialVerification] PASSED [ 97%]
[task 2025-10-17T13:34:48.302+00:00] test/test_util_verify.py::test_verification_types[KindsVerification] PASSED [ 97%]
[task 2025-10-17T13:34:48.303+00:00] test/test_util_verify.py::test_verification_types[ParametersVerification] PASSED [ 97%]
[task 2025-10-17T13:34:48.306+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: valid] PASSED [ 97%]
[task 2025-10-17T13:34:48.308+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: conflicting symbol] PASSED [ 98%]
[task 2025-10-17T13:34:48.310+00:00] test/test_util_verify.py::test_verification[task_graph_symbol: too many collections] PASSED [ 98%]
[task 2025-10-17T13:34:48.312+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: valid] PASSED [ 98%]
[task 2025-10-17T13:34:48.314+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: invalid] PASSED [ 98%]
[task 2025-10-17T13:34:48.317+00:00] test/test_util_verify.py::test_verification[routes_notfication_filter: deprecated] PASSED [ 98%]
[task 2025-10-17T13:34:48.319+00:00] test/test_util_verify.py::test_verification[verify_index_route: invalid slash in route] PASSED [ 99%]
[task 2025-10-17T13:34:48.322+00:00] test/test_util_workertypes.py::test_get_worker_type[linux-1-Exception] PASSED [ 99%]
[task 2025-10-17T13:34:48.324+00:00] test/test_util_workertypes.py::test_get_worker_type[b-linux-3-test-domain-3/b-linux-gcp] PASSED [ 99%]
[task 2025-10-17T13:34:48.326+00:00] test/test_util_workertypes.py::test_get_worker_type[t-linux-1-test-domain-1/t-linux-gcp] PASSED [ 99%]
[task 2025-10-17T13:34:48.328+00:00] test/test_util_yaml.py::test_load PASSED [ 99%]
[task 2025-10-17T13:34:48.562+00:00] test/test_util_yaml.py::test_key_order PASSED [100%]
[task 2025-10-17T13:34:48.562+00:00]
[task 2025-10-17T13:34:48.562+00:00] =============================== warnings summary ===============================
[task 2025-10-17T13:34:48.562+00:00] test/test_config.py::test_vcs_root_fallback
[task 2025-10-17T13:34:48.562+00:00] /builds/worker/checkouts/vcs/test/test_config.py:57: 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 2025-10-17T13:34:48.562+00:00] with mocker.patch("taskgraph.config.get_repository", side_effect=RuntimeError):
[task 2025-10-17T13:34:48.562+00:00]
[task 2025-10-17T13:34:48.562+00:00] test/test_config.py::test_vcs_root_fallback
[task 2025-10-17T13:34:48.562+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 2025-10-17T13:34:48.563+00:00] with mocker.patch("taskgraph.config.get_repository", side_effect=RuntimeError):
[task 2025-10-17T13:34:48.563+00:00]
[task 2025-10-17T13:34:48.563+00:00] -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
[task 2025-10-17T13:34:48.563+00:00] ============ 535 passed, 6 skipped, 2 xfailed, 2 warnings in 33.53s ============
[taskcluster 2025-10-17 13:34:49.422Z] === Task Finished ===
[taskcluster 2025-10-17 13:34:49.714Z] Successful task run with exit code: 0 completed in 46.15 seconds
Loading