all:
  children:
    zuul_unreachable:
      hosts: {}
  hosts:
    debian-trixie:
      ansible_connection: ssh
      ansible_host: 199.19.213.82
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      molecule_scenario: forget-package
      nodepool:
        az: nova
        cloud: public
        external_id: 615b3986-cb2a-444b-9313-41782f62aa50
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.19.213.82
        label: debian-trixie
        node_properties: {}
        private_ipv4: 199.19.213.82
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.213.82
        public_ipv6: 2604:e100:1:0:f816:3eff:fef2:79d1
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: 615b3986-cb2a-444b-9313-41782f62aa50
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.19.213.82
        label: debian-trixie
        node_properties: {}
        private_ipv4: 199.19.213.82
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.213.82
        public_ipv6: 2604:e100:1:0:f816:3eff:fef2:79d1
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    molecule_scenario: forget-package
    zuul:
      _inheritance_path:
      - '<Job base explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-config/zuul.d/jobs.yaml@main#1>'
      - '<Job molecule explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-jobs/zuul.d/ansible-jobs.yaml@main#1>'
      - '<Job ansible-collection-containers-molecule explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/ansible-collection-containers/.zuul.yaml@main#1>'
      - '<Job ansible-collection-containers-molecule-forget-package explicit: None
        implied: {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/ansible-collection-containers/.zuul.yaml@main#77>'
      - '<Job ansible-collection-containers-molecule-forget-package-debian-trixie
        explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/ansible-collection-containers/.zuul.yaml@main#84>'
      - '<Job ansible-collection-containers-molecule-forget-package-debian-trixie
        explicit: None implied: None source: vexxhost/ansible-collection-containers/.zuul.yaml@main#136>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: ddbdff2cd5784c228ba6986b1a446bde
      build_refs:
      - branch: main
        change: '110'
        change_message: "chore(deps): update dependency pytest to v9 [security]\n\nThis
          PR contains the following updates:\n\n| Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/)
          | [Confidence](https://docs.renovatebot.com/merge-confidence/) |\n|---|---|---|---|\n|
          [pytest](https://redirect.github.com/pytest-dev/pytest) ([changelog](https://docs.pytest.org/en/stable/changelog.html))
          | `8.4.1` \u2192 `9.0.3` | ![age](https://developer.mend.io/api/mc/badges/age/pypi/pytest/9.0.3?slim=true)
          | ![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/pytest/8.4.1/9.0.3?slim=true)
          |\n\n### GitHub Vulnerability Alerts\n\n#### [CVE-2025-71176](https://nvd.nist.gov/vuln/detail/CVE-2025-71176)\n\npytest
          through 9.0.2 on UNIX relies on directories with the `/tmp/pytest-of-{user}`
          name pattern, which allows local users to cause a denial of service or possibly
          gain privileges.\n\n---\n\n### Release Notes\n\n<details>\n<summary>pytest-dev/pytest
          (pytest)</summary>\n\n### [`v9.0.3`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.3)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.2...9.0.3)\n\n###
          pytest 9.0.3 (2026-04-07)\n\n#### Bug fixes\n\n- [#&#8203;12444](https://redirect.github.com/pytest-dev/pytest/issues/12444):
          Fixed `pytest.approx` which now correctly takes into account `~collections.abc.Mapping`
          keys order to compare them.\n\n- [#&#8203;13634](https://redirect.github.com/pytest-dev/pytest/issues/13634):
          Blocking a `conftest.py` file using the `-p no:` option is now explicitly
          disallowed.\n\n  Previously this resulted in an internal assertion failure
          during plugin loading.\n\n  Pytest now raises a clear `UsageError` explaining
          that conftest files are not plugins and cannot be disabled via `-p`.\n\n-
          [#&#8203;13734](https://redirect.github.com/pytest-dev/pytest/issues/13734):
          Fixed crash when a test raises an exceptiongroup with `__tracebackhide__
          = True`.\n\n- [#&#8203;14195](https://redirect.github.com/pytest-dev/pytest/issues/14195):
          Fixed an issue where non-string messages passed to <span class=\"title-ref\">unittest.TestCase.subTest()</span>
          were not printed.\n\n- [#&#8203;14343](https://redirect.github.com/pytest-dev/pytest/issues/14343):
          Fixed use of insecure temporary directory (CVE-2025-71176).\n\n#### Improved
          documentation\n\n- [#&#8203;13388](https://redirect.github.com/pytest-dev/pytest/issues/13388):
          Clarified documentation for `-p` vs `PYTEST_PLUGINS` plugin loading and
          fixed an incorrect `-p` example.\n- [#&#8203;13731](https://redirect.github.com/pytest-dev/pytest/issues/13731):
          Clarified that capture fixtures (e.g. `capsys` and `capfd`) take precedence
          over the `-s` / `--capture=no` command-line options in `Accessing captured
          output from a test function <accessing-captured-output>`.\n- [#&#8203;14088](https://redirect.github.com/pytest-dev/pytest/issues/14088):
          Clarified that the default `pytest_collection` hook sets `session.items`
          before it calls `pytest_collection_finish`, not after.\n- [#&#8203;14255](https://redirect.github.com/pytest-dev/pytest/issues/14255):
          TOML integer log levels must be quoted: Updating reference documentation.\n\n####
          Contributor-facing changes\n\n- [#&#8203;12689](https://redirect.github.com/pytest-dev/pytest/issues/12689):
          The test reports are now published to Codecov from GitHub Actions.\n  The
          test statistics is visible [on the web interface](https://app.codecov.io/gh/pytest-dev/pytest/tests).\n\n
          \ \\-- by `aleguy02`\n\n### [`v9.0.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.1...9.0.2)\n\n###
          pytest 9.0.2 (2025-12-06)\n\n#### Bug fixes\n\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress feature added in pytest 9.0.0 has been disabled by
          default, except on Windows, due to compatibility issues with some terminal
          emulators.\n\n  You may enable it again by passing `-p terminalprogress`.
          We may enable it by default again once compatibility improves in the future.\n\n
          \ Additionally, when the environment variable `TERM` is `dumb`, the escape
          codes are no longer emitted, even if the plugin is enabled.\n\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the `tmp_path_retention_count` settings in the API
          reference from number to string.\n\n- [#&#8203;13946](https://redirect.github.com/pytest-dev/pytest/issues/13946):
          The private `config.inicfg` attribute was changed in a breaking manner in
          pytest 9.0.0.\n  Due to its usage in the ecosystem, it is now restored to
          working order using a compatibility shim.\n  It will be deprecated in pytest
          9.1 and removed in pytest 10.\n\n- [#&#8203;13965](https://redirect.github.com/pytest-dev/pytest/issues/13965):
          Fixed quadratic-time behavior when handling `unittest` subtests in Python
          3.10.\n\n#### Improved documentation\n\n- [#&#8203;4492](https://redirect.github.com/pytest-dev/pytest/issues/4492):
          The API Reference now contains cross-reference-able documentation of `pytest's
          command-line flags <command-line-flags>`.\n\n### [`v9.0.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.1)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.0...9.0.1)\n\n###
          pytest 9.0.1 (2025-11-12)\n\n#### Bug fixes\n\n- [#&#8203;13895](https://redirect.github.com/pytest-dev/pytest/issues/13895):
          Restore support for skipping tests via `raise unittest.SkipTest`.\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress plugin added in pytest 9.0 is now automatically disabled
          when iTerm2 is detected, it generated desktop notifications instead of the
          desired functionality.\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the verbosity settings in the API reference from
          number to string.\n- [#&#8203;13910](https://redirect.github.com/pytest-dev/pytest/issues/13910):
          Fixed <span class=\"title-ref\">UserWarning: Do not expect file\\_or\\_dir</span>
          on some earlier Python 3.12 and 3.13 point versions.\n\n#### Packaging updates
          and notes for downstreams\n\n- [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n####
          Contributor-facing changes\n\n- [#&#8203;13891](https://redirect.github.com/pytest-dev/pytest/issues/13891),
          [#&#8203;13942](https://redirect.github.com/pytest-dev/pytest/issues/13942):
          The CI/CD part of the release automation is now capable of\n  creating GitHub
          Releases without having a Git checkout on\n  disk -- by `bluetech` and `webknjaz`.\n-
          [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n###
          [`v9.0.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.0)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.2...9.0.0)\n\n###
          pytest 9.0.0 (2025-11-05)\n\n#### New features\n\n- [#&#8203;1367](https://redirect.github.com/pytest-dev/pytest/issues/1367):
          **Support for subtests** has been added.\n\n  `subtests <subtests>` are
          an alternative to parametrization, useful in situations where the parametrization
          values are not all known at collection time.\n\n  Example:\n\n  ```python\n
          \ def contains_docstring(p: Path) -> bool:\n      \"\"\"Return True if the
          given Python file contains a top-level docstring.\"\"\"\n      ...\n\n  def
          test_py_files_contain_docstring(subtests: pytest.Subtests) -> None:\n      for
          path in Path.cwd().glob(\"*.py\"):\n          with subtests.test(path=str(path)):\n
          \             assert contains_docstring(path)\n  ```\n\n  Each assert failure
          or error is caught by the context manager and reported individually, giving
          a clear picture of all files that are missing a docstring.\n\n  In addition,
          `unittest.TestCase.subTest` is now also supported.\n\n  This feature was
          originally implemented as a separate plugin in [pytest-subtests](https://redirect.github.com/pytest-dev/pytest-subtests),
          but since then has been merged into the core.\n\n  > \\[!NOTE]\n  > This
          feature is experimental and will likely evolve in future releases. By that
          we mean that we might change how subtests are reported on failure, but the
          functionality and how to use it are stable.\n\n- [#&#8203;13743](https://redirect.github.com/pytest-dev/pytest/issues/13743):
          Added support for **native TOML configuration files**.\n\n  While pytest,
          since version 6, supports configuration in `pyproject.toml` files under
          `[tool.pytest.ini_options]`,\n  it does so in an \"INI compatibility mode\",
          where all configuration values are treated as strings or list of strings.\n
          \ Now, pytest supports the native TOML data model.\n\n  In `pyproject.toml`,
          the native TOML configuration is under the `[tool.pytest]` table.\n\n  ```toml\n
          \ # pyproject.toml\n  [tool.pytest]\n  minversion = \"9.0\"\n  addopts =
          [\"-ra\", \"-q\"]\n  testpaths = [\n      \"tests\",\n      \"integration\",\n
          \ ]\n  ```\n\n  The `[tool.pytest.ini_options]` table remains supported,
          but both tables cannot be used at the same time.\n\n  If you prefer to use
          a separate configuration file, or don't use `pyproject.toml`, you can use
          `pytest.toml` or `.pytest.toml`:\n\n  ```toml\n  # pytest.toml or .pytest.toml\n
          \ [pytest]\n  minversion = \"9.0\"\n  addopts = [\"-ra\", \"-q\"]\n  testpaths
          = [\n      \"tests\",\n      \"integration\",\n  ]\n  ```\n\n  The documentation
          now (sometimes) shows configuration snippets in both TOML and INI formats,
          in a tabbed interface.\n\n  See `config file formats` for full details.\n\n-
          [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added a **\"strict mode\"** enabled by the `strict` configuration option.\n\n
          \ When set to `true`, the `strict` option currently enables\n\n  - `strict_config`\n
          \ - `strict_markers`\n  - `strict_parametrization_ids`\n  - `strict_xfail`\n\n
          \ The individual strictness options can be explicitly set to override the
          global `strict` setting.\n\n  The previously-deprecated `--strict` command-line
          flag now enables strict mode.\n\n  If pytest adds new strictness options
          in the future, they will also be enabled in strict mode.\n  Therefore, you
          should only enable strict mode if you use a pinned/locked version of pytest,\n
          \ or if you want to proactively adopt new strictness options as they are
          added.\n\n  See `strict mode` for more details.\n\n- [#&#8203;13737](https://redirect.github.com/pytest-dev/pytest/issues/13737):
          Added the `strict_parametrization_ids` configuration option.\n\n  When set,
          pytest emits an error if it detects non-unique parameter set IDs,\n  rather
          than automatically making the IDs unique by adding <span class=\"title-ref\">0</span>,
          <span class=\"title-ref\">1</span>, ... to them.\n  This can be particularly
          useful for catching unintended duplicates.\n\n- [#&#8203;13072](https://redirect.github.com/pytest-dev/pytest/issues/13072):
          Added support for displaying test session **progress in the terminal tab**
          using the [OSC 9;4;](https://conemu.github.io/en/AnsiEscapeCodes.html#ConEmu_specific_OSC)
          ANSI sequence.\n  When pytest runs in a supported terminal emulator like
          ConEmu, Gnome Terminal, Ptyxis, Windows Terminal, Kitty or Ghostty,\n  you'll
          see the progress in the terminal tab or window,\n  allowing you to monitor
          pytest's progress at a glance.\n\n  This feature is automatically enabled
          when running in a TTY. It is implemented as an internal plugin. If needed,
          it can be disabled as follows:\n\n  - On a user level, using `-p no:terminalprogress`
          on the command line or via an environment variable `PYTEST_ADDOPTS='-p no:terminalprogress'`.\n
          \ - On a project configuration level, using `addopts = \"-p no:terminalprogress\"`.\n\n-
          [#&#8203;478](https://redirect.github.com/pytest-dev/pytest/issues/478):
          Support PEP420 (implicit namespace packages) as <span class=\"title-ref\">--pyargs</span>
          target when `consider_namespace_packages` is <span class=\"title-ref\">true</span>
          in the config.\n\n  Previously, this option only impacted package imports,
          now it also impacts tests discovery.\n\n- [#&#8203;13678](https://redirect.github.com/pytest-dev/pytest/issues/13678):
          Added a new `faulthandler_exit_on_timeout` configuration option set to \"false\"
          by default to let <span class=\"title-ref\">faulthandler</span> interrupt
          the <span class=\"title-ref\">pytest</span> process after a timeout in case
          of deadlock.\n\n  Previously, a <span class=\"title-ref\">faulthandler</span>
          timeout would only dump the traceback of all threads to stderr, but would
          not interrupt the <span class=\"title-ref\">pytest</span> process.\n\n  \\--
          by `ogrisel`.\n\n- [#&#8203;13829](https://redirect.github.com/pytest-dev/pytest/issues/13829):
          Added support for configuration option aliases via the `aliases` parameter
          in `Parser.addini() <pytest.Parser.addini>`.\n\n  Plugins can now register
          alternative names for configuration options,\n  allowing for more flexibility
          in configuration naming and supporting backward compatibility when renaming
          options.\n  The canonical name always takes precedence if both the canonical
          name and an alias are specified in the configuration file.\n\n#### Improvements
          in existing functionality\n\n- [#&#8203;13330](https://redirect.github.com/pytest-dev/pytest/issues/13330):
          Having pytest configuration spread over more than one file (for example
          having both a `pytest.ini` file and `pyproject.toml` with a `[tool.pytest.ini_options]`
          table) will now print a warning to make it clearer to the user that only
          one of them is actually used.\n\n  \\-- by `sgaist`\n\n- [#&#8203;13574](https://redirect.github.com/pytest-dev/pytest/issues/13574):
          The single argument `--version` no longer loads the entire plugin infrastructure,
          making it faster and more reliable when displaying only the pytest version.\n\n
          \ Passing `--version` twice (e.g., `pytest --version --version`) retains
          the original behavior, showing both the pytest version and plugin information.\n\n
          \ > \\[!NOTE]\n  > Since `--version` is now processed early, it only takes
          effect when passed directly via the command line. It will not work if set
          through other mechanisms, such as `PYTEST_ADDOPTS` or `addopts`.\n\n- [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added `strict_xfail` as an alias to the `xfail_strict` option,\n  `strict_config`
          as an alias to the `--strict-config` flag,\n  and `strict_markers` as an
          alias to the `--strict-markers` flag.\n  This makes all strictness options
          consistently have configuration options with the prefix `strict_`.\n\n-
          [#&#8203;13700](https://redirect.github.com/pytest-dev/pytest/issues/13700):
          <span class=\"title-ref\">--junitxml</span> no longer prints the <span class=\"title-ref\">generated
          xml file</span> summary at the end of the pytest session when <span class=\"title-ref\">--quiet</span>
          is given.\n\n- [#&#8203;13732](https://redirect.github.com/pytest-dev/pytest/issues/13732):
          Previously, when filtering warnings, pytest would fail if the filter referenced
          a class that could not be imported. Now, this only outputs a message indicating
          the problem.\n\n- [#&#8203;13859](https://redirect.github.com/pytest-dev/pytest/issues/13859):
          Clarify the error message for <span class=\"title-ref\">pytest.raises()</span>
          when a regex <span class=\"title-ref\">match</span> fails.\n\n- [#&#8203;13861](https://redirect.github.com/pytest-dev/pytest/issues/13861):
          Better sentence structure in a test's expected error message. Previously,
          the error message would be \"expected exception must be \\<expected>, but
          got \\<actual>\". Now, it is \"Expected \\<expected>, but got \\<actual>\".\n\n####
          Removals and backward incompatible breaking changes\n\n- [#&#8203;12083](https://redirect.github.com/pytest-dev/pytest/issues/12083):
          Fixed a bug where an invocation such as <span class=\"title-ref\">pytest
          a/ a/b</span> would cause only tests from <span class=\"title-ref\">a/b</span>
          to run, and not other tests under <span class=\"title-ref\">a/</span>.\n\n
          \ The fix entails a few breaking changes to how such overlapping arguments
          and duplicates are handled:\n\n  1. <span class=\"title-ref\">pytest a/b
          a/</span> or <span class=\"title-ref\">pytest a/ a/b</span> are equivalent
          to <span class=\"title-ref\">pytest a</span>; if an argument overlaps another
          arguments, only the prefix remains.\n  2. <span class=\"title-ref\">pytest
          x.py x.py</span> is equivalent to <span class=\"title-ref\">pytest x.py</span>;
          previously such an invocation was taken as an explicit request to run the
          tests from the file twice.\n\n  If you rely on these behaviors, consider
          using `--keep-duplicates <duplicate-paths>`, which retains its existing
          behavior (including the bug).\n\n- [#&#8203;13719](https://redirect.github.com/pytest-dev/pytest/issues/13719):
          Support for Python 3.9 is dropped following its end of life.\n\n- [#&#8203;13766](https://redirect.github.com/pytest-dev/pytest/issues/13766):
          Previously, pytest would assume it was running in a CI/CD environment if
          either of the environment variables <span class=\"title-ref\">$CI</span>
          or <span class=\"title-ref\">$BUILD\\_NUMBER</span> was defined;\n  now,
          CI mode is only activated if at least one of those variables is defined
          and set to a *non-empty* value.\n\n- [#&#8203;13779](https://redirect.github.com/pytest-dev/pytest/issues/13779):
          **PytestRemovedIn9Warning deprecation warnings are now errors by default.**\n\n
          \ Following our plan to remove deprecated features with as little disruption
          as\n  possible, all warnings of type `PytestRemovedIn9Warning` now generate
          errors\n  instead of warning messages by default.\n\n  **The affected features
          will be effectively removed in pytest 9.1**, so please consult the\n  `deprecations`
          section in the docs for directions on how to update existing code.\n\n  In
          the pytest `9.0.X` series, it is possible to change the errors back into
          warnings as a\n  stopgap measure by adding this to your `pytest.ini` file:\n\n
          \ ```ini\n  [pytest]\n  filterwarnings =\n      ignore::pytest.PytestRemovedIn9Warning\n
          \ ```\n\n  But this will stop working when pytest `9.1` is released.\n\n
          \ **If you have concerns** about the removal of a specific feature, please
          add a\n  comment to `13779`.\n\n#### Deprecations (removal in next major
          release)\n\n- [#&#8203;13807](https://redirect.github.com/pytest-dev/pytest/issues/13807):
          `monkeypatch.syspath_prepend() <pytest.MonkeyPatch.syspath_prepend>` now
          issues a deprecation warning when the prepended path contains legacy namespace
          packages (those using `pkg_resources.declare_namespace()`).\n  Users should
          migrate to native namespace packages (`420`).\n  See `monkeypatch-fixup-namespace-packages`
          for details.\n\n#### Bug fixes\n\n- [#&#8203;13445](https://redirect.github.com/pytest-dev/pytest/issues/13445):
          Made the type annotations of `pytest.skip` and friends more spec-complaint
          to have them work across more type checkers.\n\n- [#&#8203;13537](https://redirect.github.com/pytest-dev/pytest/issues/13537):
          Fixed a bug in which `ExceptionGroup` with only `Skipped` exceptions in
          teardown was not handled correctly and showed as error.\n\n- [#&#8203;13598](https://redirect.github.com/pytest-dev/pytest/issues/13598):
          Fixed possible collection confusion on Windows when short paths and symlinks
          are involved.\n\n- [#&#8203;13716](https://redirect.github.com/pytest-dev/pytest/issues/13716):
          Fixed a bug where a nonsensical invocation like `pytest x.py[a]` (a file
          cannot be parametrized) was silently treated as `pytest x.py`. This is now
          a usage error.\n\n- [#&#8203;13722](https://redirect.github.com/pytest-dev/pytest/issues/13722):
          Fixed a misleading assertion failure message when using `pytest.approx`
          on mappings with differing lengths.\n\n- [#&#8203;13773](https://redirect.github.com/pytest-dev/pytest/issues/13773):
          Fixed the static fixture closure calculation to properly consider transitive
          dependencies requested by overridden fixtures.\n\n- [#&#8203;13816](https://redirect.github.com/pytest-dev/pytest/issues/13816):
          Fixed `pytest.approx` which now returns a clearer error message when comparing
          mappings with different keys.\n\n- [#&#8203;13849](https://redirect.github.com/pytest-dev/pytest/issues/13849):
          Hidden `.pytest.ini` files are now picked up as the config file even if
          empty.\n  This was an inconsistency with non-hidden `pytest.ini`.\n\n- [#&#8203;13865](https://redirect.github.com/pytest-dev/pytest/issues/13865):
          Fixed <span class=\"title-ref\">--show-capture</span> with <span class=\"title-ref\">--tb=line</span>.\n\n-
          [#&#8203;13522](https://redirect.github.com/pytest-dev/pytest/issues/13522):
          Fixed `pytester` in subprocess mode ignored all :attr\\`pytester.plugins
          \\<pytest.Pytester.plugins>\\` except the first.\n\n  Fixed `pytester` in
          subprocess mode silently ignored non-str `pytester.plugins <pytest.Pytester.plugins>`.\n
          \ Now it errors instead.\n  If you are affected by this, specify the plugin
          by name, or switch the affected tests to use `pytester.runpytest_inprocess
          <pytest.Pytester.runpytest_inprocess>` explicitly instead.\n\n#### Packaging
          updates and notes for downstreams\n\n- [#&#8203;13791](https://redirect.github.com/pytest-dev/pytest/issues/13791):
          Minimum requirements on `iniconfig` and `packaging` were bumped to `1.0.1`
          and `22.0.0`, respectively.\n\n#### Contributor-facing changes\n\n- [#&#8203;12244](https://redirect.github.com/pytest-dev/pytest/issues/12244):
          Fixed self-test failures when <span class=\"title-ref\">TERM=dumb</span>.\n-
          [#&#8203;12474](https://redirect.github.com/pytest-dev/pytest/issues/12474):
          Added scheduled GitHub Action Workflow to run Sphinx linkchecks in repo
          documentation.\n- [#&#8203;13621](https://redirect.github.com/pytest-dev/pytest/issues/13621):
          pytest's own testsuite now handles the `lsof` command hanging (e.g. due
          to unreachable network filesystems), with the affected selftests being skipped
          after 10 seconds.\n- [#&#8203;13638](https://redirect.github.com/pytest-dev/pytest/issues/13638):
          Fixed deprecated `gh pr new` command in `scripts/prepare-release-pr.py`.\n
          \ The script now uses `gh pr create` which is compatible with GitHub CLI
          v2.0+.\n- [#&#8203;13695](https://redirect.github.com/pytest-dev/pytest/issues/13695):
          Flush <span class=\"title-ref\">stdout</span> and <span class=\"title-ref\">stderr</span>
          in <span class=\"title-ref\">Pytester.run</span> to avoid truncated outputs
          in <span class=\"title-ref\">test\\_faulthandler.py::test\\_timeout</span>
          on CI -- by `ogrisel`.\n- [#&#8203;13771](https://redirect.github.com/pytest-dev/pytest/issues/13771):
          Skip <span class=\"title-ref\">test\\_do\\_not\\_collect\\_symlink\\_siblings</span>
          on Windows environments without symlink support to avoid false negatives.\n-
          [#&#8203;13841](https://redirect.github.com/pytest-dev/pytest/issues/13841):
          `tox>=4` is now required when contributing to pytest.\n- [#&#8203;13625](https://redirect.github.com/pytest-dev/pytest/issues/13625):
          Added missing docstrings to `pytest_addoption()`, `pytest_configure()`,
          and `cacheshow()` functions in `cacheprovider.py`.\n\n#### Miscellaneous
          internal changes\n\n- [#&#8203;13830](https://redirect.github.com/pytest-dev/pytest/issues/13830):
          Configuration overrides (`-o`/`--override-ini`) are now processed during
          startup rather than during `config.getini() <pytest.Config.getini>`.\n\n###
          [`v8.4.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.4.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.1...8.4.2)\n\n###
          pytest 8.4.2 (2025-09-03)\n\n#### Bug fixes\n\n- [#&#8203;13478](https://redirect.github.com/pytest-dev/pytest/issues/13478):
          Fixed a crash when using `console_output_style`{.interpreted-text role=\"confval\"}
          with `times` and a module is skipped.\n\n- [#&#8203;13530](https://redirect.github.com/pytest-dev/pytest/issues/13530):
          Fixed a crash when using `pytest.approx`{.interpreted-text role=\"func\"}
          and `decimal.Decimal`{.interpreted-text role=\"class\"} instances with the
          `decimal.FloatOperation`{.interpreted-text role=\"class\"} trap set.\n\n-
          [#&#8203;13549](https://redirect.github.com/pytest-dev/pytest/issues/13549):
          No longer evaluate type annotations in Python `3.14` when inspecting function
          signatures.\n\n  This prevents crashes during module collection when modules
          do not explicitly use `from __future__ import annotations` and import types
          for annotations within a `if TYPE_CHECKING:` block.\n\n- [#&#8203;13559](https://redirect.github.com/pytest-dev/pytest/issues/13559):
          Added missing \\[int]{.title-ref} and \\[float]{.title-ref} variants to
          the \\[Literal]{.title-ref} type annotation of the \\[type]{.title-ref}
          parameter in `pytest.Parser.addini`{.interpreted-text role=\"meth\"}.\n\n-
          [#&#8203;13563](https://redirect.github.com/pytest-dev/pytest/issues/13563):
          `pytest.approx`{.interpreted-text role=\"func\"} now only imports `numpy`
          if NumPy is already in `sys.modules`. This fixes unconditional import behavior
          introduced in \\[8.4.0]{.title-ref}.\n\n#### Improved documentation\n\n-
          [#&#8203;13577](https://redirect.github.com/pytest-dev/pytest/issues/13577):
          Clarify that `pytest_generate_tests` is discovered in test modules/classes;
          other hooks must be in `conftest.py` or plugins.\n\n#### Contributor-facing
          changes\n\n- [#&#8203;13480](https://redirect.github.com/pytest-dev/pytest/issues/13480):
          Self-testing: fixed a few test failures when run with `-Wdefault` or a similar
          override.\n- [#&#8203;13547](https://redirect.github.com/pytest-dev/pytest/issues/13547):
          Self-testing: corrected expected message for `test_doctest_unexpected_exception`
          in Python `3.14`.\n- [#&#8203;13684](https://redirect.github.com/pytest-dev/pytest/issues/13684):
          Make pytest's own testsuite insensitive to the presence of the `CI` environment
          variable -- by `ogrisel`{.interpreted-text role=\"user\"}.\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: (UTC)\n\n- Branch creation\n  -
          \"\"\n- Automerge\n  - At any time (no schedule defined)\n\n\U0001F6A6 **Automerge**:
          Disabled by config. Please merge this manually once you are satisfied.\n\n\u267B
          **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry
          checkbox.\n\n\U0001F515 **Ignore**: Close this PR and you won't be reminded
          about this update again.\n\n---\n\n - [ ] <!-- rebase-check -->If you want
          to rebase/retry this PR, check this box\n\n---\n\nThis PR was generated
          by [Mend Renovate](https://mend.io/renovate/). View the [repository job
          log](https://developer.mend.io/github/vexxhost/ansible-collection-containers).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMTAuMiIsInVwZGF0ZWRJblZlciI6IjQzLjExMC4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->\n"
        change_url: https://github.com/vexxhost/ansible-collection-containers/pull/110
        commit_id: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        patchset: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-containers
          name: vexxhost/ansible-collection-containers
          short_name: ansible-collection-containers
          src_dir: src/github.com/vexxhost/ansible-collection-containers
        src_dir: src/github.com/vexxhost/ansible-collection-containers
        topic: null
      buildset: 326acb2130a548e4ab7e4ba94f2a7e85
      buildset_refs:
      - branch: main
        change: '110'
        change_message: "chore(deps): update dependency pytest to v9 [security]\n\nThis
          PR contains the following updates:\n\n| Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/)
          | [Confidence](https://docs.renovatebot.com/merge-confidence/) |\n|---|---|---|---|\n|
          [pytest](https://redirect.github.com/pytest-dev/pytest) ([changelog](https://docs.pytest.org/en/stable/changelog.html))
          | `8.4.1` \u2192 `9.0.3` | ![age](https://developer.mend.io/api/mc/badges/age/pypi/pytest/9.0.3?slim=true)
          | ![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/pytest/8.4.1/9.0.3?slim=true)
          |\n\n### GitHub Vulnerability Alerts\n\n#### [CVE-2025-71176](https://nvd.nist.gov/vuln/detail/CVE-2025-71176)\n\npytest
          through 9.0.2 on UNIX relies on directories with the `/tmp/pytest-of-{user}`
          name pattern, which allows local users to cause a denial of service or possibly
          gain privileges.\n\n---\n\n### Release Notes\n\n<details>\n<summary>pytest-dev/pytest
          (pytest)</summary>\n\n### [`v9.0.3`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.3)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.2...9.0.3)\n\n###
          pytest 9.0.3 (2026-04-07)\n\n#### Bug fixes\n\n- [#&#8203;12444](https://redirect.github.com/pytest-dev/pytest/issues/12444):
          Fixed `pytest.approx` which now correctly takes into account `~collections.abc.Mapping`
          keys order to compare them.\n\n- [#&#8203;13634](https://redirect.github.com/pytest-dev/pytest/issues/13634):
          Blocking a `conftest.py` file using the `-p no:` option is now explicitly
          disallowed.\n\n  Previously this resulted in an internal assertion failure
          during plugin loading.\n\n  Pytest now raises a clear `UsageError` explaining
          that conftest files are not plugins and cannot be disabled via `-p`.\n\n-
          [#&#8203;13734](https://redirect.github.com/pytest-dev/pytest/issues/13734):
          Fixed crash when a test raises an exceptiongroup with `__tracebackhide__
          = True`.\n\n- [#&#8203;14195](https://redirect.github.com/pytest-dev/pytest/issues/14195):
          Fixed an issue where non-string messages passed to <span class=\"title-ref\">unittest.TestCase.subTest()</span>
          were not printed.\n\n- [#&#8203;14343](https://redirect.github.com/pytest-dev/pytest/issues/14343):
          Fixed use of insecure temporary directory (CVE-2025-71176).\n\n#### Improved
          documentation\n\n- [#&#8203;13388](https://redirect.github.com/pytest-dev/pytest/issues/13388):
          Clarified documentation for `-p` vs `PYTEST_PLUGINS` plugin loading and
          fixed an incorrect `-p` example.\n- [#&#8203;13731](https://redirect.github.com/pytest-dev/pytest/issues/13731):
          Clarified that capture fixtures (e.g. `capsys` and `capfd`) take precedence
          over the `-s` / `--capture=no` command-line options in `Accessing captured
          output from a test function <accessing-captured-output>`.\n- [#&#8203;14088](https://redirect.github.com/pytest-dev/pytest/issues/14088):
          Clarified that the default `pytest_collection` hook sets `session.items`
          before it calls `pytest_collection_finish`, not after.\n- [#&#8203;14255](https://redirect.github.com/pytest-dev/pytest/issues/14255):
          TOML integer log levels must be quoted: Updating reference documentation.\n\n####
          Contributor-facing changes\n\n- [#&#8203;12689](https://redirect.github.com/pytest-dev/pytest/issues/12689):
          The test reports are now published to Codecov from GitHub Actions.\n  The
          test statistics is visible [on the web interface](https://app.codecov.io/gh/pytest-dev/pytest/tests).\n\n
          \ \\-- by `aleguy02`\n\n### [`v9.0.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.1...9.0.2)\n\n###
          pytest 9.0.2 (2025-12-06)\n\n#### Bug fixes\n\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress feature added in pytest 9.0.0 has been disabled by
          default, except on Windows, due to compatibility issues with some terminal
          emulators.\n\n  You may enable it again by passing `-p terminalprogress`.
          We may enable it by default again once compatibility improves in the future.\n\n
          \ Additionally, when the environment variable `TERM` is `dumb`, the escape
          codes are no longer emitted, even if the plugin is enabled.\n\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the `tmp_path_retention_count` settings in the API
          reference from number to string.\n\n- [#&#8203;13946](https://redirect.github.com/pytest-dev/pytest/issues/13946):
          The private `config.inicfg` attribute was changed in a breaking manner in
          pytest 9.0.0.\n  Due to its usage in the ecosystem, it is now restored to
          working order using a compatibility shim.\n  It will be deprecated in pytest
          9.1 and removed in pytest 10.\n\n- [#&#8203;13965](https://redirect.github.com/pytest-dev/pytest/issues/13965):
          Fixed quadratic-time behavior when handling `unittest` subtests in Python
          3.10.\n\n#### Improved documentation\n\n- [#&#8203;4492](https://redirect.github.com/pytest-dev/pytest/issues/4492):
          The API Reference now contains cross-reference-able documentation of `pytest's
          command-line flags <command-line-flags>`.\n\n### [`v9.0.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.1)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.0...9.0.1)\n\n###
          pytest 9.0.1 (2025-11-12)\n\n#### Bug fixes\n\n- [#&#8203;13895](https://redirect.github.com/pytest-dev/pytest/issues/13895):
          Restore support for skipping tests via `raise unittest.SkipTest`.\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress plugin added in pytest 9.0 is now automatically disabled
          when iTerm2 is detected, it generated desktop notifications instead of the
          desired functionality.\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the verbosity settings in the API reference from
          number to string.\n- [#&#8203;13910](https://redirect.github.com/pytest-dev/pytest/issues/13910):
          Fixed <span class=\"title-ref\">UserWarning: Do not expect file\\_or\\_dir</span>
          on some earlier Python 3.12 and 3.13 point versions.\n\n#### Packaging updates
          and notes for downstreams\n\n- [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n####
          Contributor-facing changes\n\n- [#&#8203;13891](https://redirect.github.com/pytest-dev/pytest/issues/13891),
          [#&#8203;13942](https://redirect.github.com/pytest-dev/pytest/issues/13942):
          The CI/CD part of the release automation is now capable of\n  creating GitHub
          Releases without having a Git checkout on\n  disk -- by `bluetech` and `webknjaz`.\n-
          [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n###
          [`v9.0.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.0)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.2...9.0.0)\n\n###
          pytest 9.0.0 (2025-11-05)\n\n#### New features\n\n- [#&#8203;1367](https://redirect.github.com/pytest-dev/pytest/issues/1367):
          **Support for subtests** has been added.\n\n  `subtests <subtests>` are
          an alternative to parametrization, useful in situations where the parametrization
          values are not all known at collection time.\n\n  Example:\n\n  ```python\n
          \ def contains_docstring(p: Path) -> bool:\n      \"\"\"Return True if the
          given Python file contains a top-level docstring.\"\"\"\n      ...\n\n  def
          test_py_files_contain_docstring(subtests: pytest.Subtests) -> None:\n      for
          path in Path.cwd().glob(\"*.py\"):\n          with subtests.test(path=str(path)):\n
          \             assert contains_docstring(path)\n  ```\n\n  Each assert failure
          or error is caught by the context manager and reported individually, giving
          a clear picture of all files that are missing a docstring.\n\n  In addition,
          `unittest.TestCase.subTest` is now also supported.\n\n  This feature was
          originally implemented as a separate plugin in [pytest-subtests](https://redirect.github.com/pytest-dev/pytest-subtests),
          but since then has been merged into the core.\n\n  > \\[!NOTE]\n  > This
          feature is experimental and will likely evolve in future releases. By that
          we mean that we might change how subtests are reported on failure, but the
          functionality and how to use it are stable.\n\n- [#&#8203;13743](https://redirect.github.com/pytest-dev/pytest/issues/13743):
          Added support for **native TOML configuration files**.\n\n  While pytest,
          since version 6, supports configuration in `pyproject.toml` files under
          `[tool.pytest.ini_options]`,\n  it does so in an \"INI compatibility mode\",
          where all configuration values are treated as strings or list of strings.\n
          \ Now, pytest supports the native TOML data model.\n\n  In `pyproject.toml`,
          the native TOML configuration is under the `[tool.pytest]` table.\n\n  ```toml\n
          \ # pyproject.toml\n  [tool.pytest]\n  minversion = \"9.0\"\n  addopts =
          [\"-ra\", \"-q\"]\n  testpaths = [\n      \"tests\",\n      \"integration\",\n
          \ ]\n  ```\n\n  The `[tool.pytest.ini_options]` table remains supported,
          but both tables cannot be used at the same time.\n\n  If you prefer to use
          a separate configuration file, or don't use `pyproject.toml`, you can use
          `pytest.toml` or `.pytest.toml`:\n\n  ```toml\n  # pytest.toml or .pytest.toml\n
          \ [pytest]\n  minversion = \"9.0\"\n  addopts = [\"-ra\", \"-q\"]\n  testpaths
          = [\n      \"tests\",\n      \"integration\",\n  ]\n  ```\n\n  The documentation
          now (sometimes) shows configuration snippets in both TOML and INI formats,
          in a tabbed interface.\n\n  See `config file formats` for full details.\n\n-
          [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added a **\"strict mode\"** enabled by the `strict` configuration option.\n\n
          \ When set to `true`, the `strict` option currently enables\n\n  - `strict_config`\n
          \ - `strict_markers`\n  - `strict_parametrization_ids`\n  - `strict_xfail`\n\n
          \ The individual strictness options can be explicitly set to override the
          global `strict` setting.\n\n  The previously-deprecated `--strict` command-line
          flag now enables strict mode.\n\n  If pytest adds new strictness options
          in the future, they will also be enabled in strict mode.\n  Therefore, you
          should only enable strict mode if you use a pinned/locked version of pytest,\n
          \ or if you want to proactively adopt new strictness options as they are
          added.\n\n  See `strict mode` for more details.\n\n- [#&#8203;13737](https://redirect.github.com/pytest-dev/pytest/issues/13737):
          Added the `strict_parametrization_ids` configuration option.\n\n  When set,
          pytest emits an error if it detects non-unique parameter set IDs,\n  rather
          than automatically making the IDs unique by adding <span class=\"title-ref\">0</span>,
          <span class=\"title-ref\">1</span>, ... to them.\n  This can be particularly
          useful for catching unintended duplicates.\n\n- [#&#8203;13072](https://redirect.github.com/pytest-dev/pytest/issues/13072):
          Added support for displaying test session **progress in the terminal tab**
          using the [OSC 9;4;](https://conemu.github.io/en/AnsiEscapeCodes.html#ConEmu_specific_OSC)
          ANSI sequence.\n  When pytest runs in a supported terminal emulator like
          ConEmu, Gnome Terminal, Ptyxis, Windows Terminal, Kitty or Ghostty,\n  you'll
          see the progress in the terminal tab or window,\n  allowing you to monitor
          pytest's progress at a glance.\n\n  This feature is automatically enabled
          when running in a TTY. It is implemented as an internal plugin. If needed,
          it can be disabled as follows:\n\n  - On a user level, using `-p no:terminalprogress`
          on the command line or via an environment variable `PYTEST_ADDOPTS='-p no:terminalprogress'`.\n
          \ - On a project configuration level, using `addopts = \"-p no:terminalprogress\"`.\n\n-
          [#&#8203;478](https://redirect.github.com/pytest-dev/pytest/issues/478):
          Support PEP420 (implicit namespace packages) as <span class=\"title-ref\">--pyargs</span>
          target when `consider_namespace_packages` is <span class=\"title-ref\">true</span>
          in the config.\n\n  Previously, this option only impacted package imports,
          now it also impacts tests discovery.\n\n- [#&#8203;13678](https://redirect.github.com/pytest-dev/pytest/issues/13678):
          Added a new `faulthandler_exit_on_timeout` configuration option set to \"false\"
          by default to let <span class=\"title-ref\">faulthandler</span> interrupt
          the <span class=\"title-ref\">pytest</span> process after a timeout in case
          of deadlock.\n\n  Previously, a <span class=\"title-ref\">faulthandler</span>
          timeout would only dump the traceback of all threads to stderr, but would
          not interrupt the <span class=\"title-ref\">pytest</span> process.\n\n  \\--
          by `ogrisel`.\n\n- [#&#8203;13829](https://redirect.github.com/pytest-dev/pytest/issues/13829):
          Added support for configuration option aliases via the `aliases` parameter
          in `Parser.addini() <pytest.Parser.addini>`.\n\n  Plugins can now register
          alternative names for configuration options,\n  allowing for more flexibility
          in configuration naming and supporting backward compatibility when renaming
          options.\n  The canonical name always takes precedence if both the canonical
          name and an alias are specified in the configuration file.\n\n#### Improvements
          in existing functionality\n\n- [#&#8203;13330](https://redirect.github.com/pytest-dev/pytest/issues/13330):
          Having pytest configuration spread over more than one file (for example
          having both a `pytest.ini` file and `pyproject.toml` with a `[tool.pytest.ini_options]`
          table) will now print a warning to make it clearer to the user that only
          one of them is actually used.\n\n  \\-- by `sgaist`\n\n- [#&#8203;13574](https://redirect.github.com/pytest-dev/pytest/issues/13574):
          The single argument `--version` no longer loads the entire plugin infrastructure,
          making it faster and more reliable when displaying only the pytest version.\n\n
          \ Passing `--version` twice (e.g., `pytest --version --version`) retains
          the original behavior, showing both the pytest version and plugin information.\n\n
          \ > \\[!NOTE]\n  > Since `--version` is now processed early, it only takes
          effect when passed directly via the command line. It will not work if set
          through other mechanisms, such as `PYTEST_ADDOPTS` or `addopts`.\n\n- [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added `strict_xfail` as an alias to the `xfail_strict` option,\n  `strict_config`
          as an alias to the `--strict-config` flag,\n  and `strict_markers` as an
          alias to the `--strict-markers` flag.\n  This makes all strictness options
          consistently have configuration options with the prefix `strict_`.\n\n-
          [#&#8203;13700](https://redirect.github.com/pytest-dev/pytest/issues/13700):
          <span class=\"title-ref\">--junitxml</span> no longer prints the <span class=\"title-ref\">generated
          xml file</span> summary at the end of the pytest session when <span class=\"title-ref\">--quiet</span>
          is given.\n\n- [#&#8203;13732](https://redirect.github.com/pytest-dev/pytest/issues/13732):
          Previously, when filtering warnings, pytest would fail if the filter referenced
          a class that could not be imported. Now, this only outputs a message indicating
          the problem.\n\n- [#&#8203;13859](https://redirect.github.com/pytest-dev/pytest/issues/13859):
          Clarify the error message for <span class=\"title-ref\">pytest.raises()</span>
          when a regex <span class=\"title-ref\">match</span> fails.\n\n- [#&#8203;13861](https://redirect.github.com/pytest-dev/pytest/issues/13861):
          Better sentence structure in a test's expected error message. Previously,
          the error message would be \"expected exception must be \\<expected>, but
          got \\<actual>\". Now, it is \"Expected \\<expected>, but got \\<actual>\".\n\n####
          Removals and backward incompatible breaking changes\n\n- [#&#8203;12083](https://redirect.github.com/pytest-dev/pytest/issues/12083):
          Fixed a bug where an invocation such as <span class=\"title-ref\">pytest
          a/ a/b</span> would cause only tests from <span class=\"title-ref\">a/b</span>
          to run, and not other tests under <span class=\"title-ref\">a/</span>.\n\n
          \ The fix entails a few breaking changes to how such overlapping arguments
          and duplicates are handled:\n\n  1. <span class=\"title-ref\">pytest a/b
          a/</span> or <span class=\"title-ref\">pytest a/ a/b</span> are equivalent
          to <span class=\"title-ref\">pytest a</span>; if an argument overlaps another
          arguments, only the prefix remains.\n  2. <span class=\"title-ref\">pytest
          x.py x.py</span> is equivalent to <span class=\"title-ref\">pytest x.py</span>;
          previously such an invocation was taken as an explicit request to run the
          tests from the file twice.\n\n  If you rely on these behaviors, consider
          using `--keep-duplicates <duplicate-paths>`, which retains its existing
          behavior (including the bug).\n\n- [#&#8203;13719](https://redirect.github.com/pytest-dev/pytest/issues/13719):
          Support for Python 3.9 is dropped following its end of life.\n\n- [#&#8203;13766](https://redirect.github.com/pytest-dev/pytest/issues/13766):
          Previously, pytest would assume it was running in a CI/CD environment if
          either of the environment variables <span class=\"title-ref\">$CI</span>
          or <span class=\"title-ref\">$BUILD\\_NUMBER</span> was defined;\n  now,
          CI mode is only activated if at least one of those variables is defined
          and set to a *non-empty* value.\n\n- [#&#8203;13779](https://redirect.github.com/pytest-dev/pytest/issues/13779):
          **PytestRemovedIn9Warning deprecation warnings are now errors by default.**\n\n
          \ Following our plan to remove deprecated features with as little disruption
          as\n  possible, all warnings of type `PytestRemovedIn9Warning` now generate
          errors\n  instead of warning messages by default.\n\n  **The affected features
          will be effectively removed in pytest 9.1**, so please consult the\n  `deprecations`
          section in the docs for directions on how to update existing code.\n\n  In
          the pytest `9.0.X` series, it is possible to change the errors back into
          warnings as a\n  stopgap measure by adding this to your `pytest.ini` file:\n\n
          \ ```ini\n  [pytest]\n  filterwarnings =\n      ignore::pytest.PytestRemovedIn9Warning\n
          \ ```\n\n  But this will stop working when pytest `9.1` is released.\n\n
          \ **If you have concerns** about the removal of a specific feature, please
          add a\n  comment to `13779`.\n\n#### Deprecations (removal in next major
          release)\n\n- [#&#8203;13807](https://redirect.github.com/pytest-dev/pytest/issues/13807):
          `monkeypatch.syspath_prepend() <pytest.MonkeyPatch.syspath_prepend>` now
          issues a deprecation warning when the prepended path contains legacy namespace
          packages (those using `pkg_resources.declare_namespace()`).\n  Users should
          migrate to native namespace packages (`420`).\n  See `monkeypatch-fixup-namespace-packages`
          for details.\n\n#### Bug fixes\n\n- [#&#8203;13445](https://redirect.github.com/pytest-dev/pytest/issues/13445):
          Made the type annotations of `pytest.skip` and friends more spec-complaint
          to have them work across more type checkers.\n\n- [#&#8203;13537](https://redirect.github.com/pytest-dev/pytest/issues/13537):
          Fixed a bug in which `ExceptionGroup` with only `Skipped` exceptions in
          teardown was not handled correctly and showed as error.\n\n- [#&#8203;13598](https://redirect.github.com/pytest-dev/pytest/issues/13598):
          Fixed possible collection confusion on Windows when short paths and symlinks
          are involved.\n\n- [#&#8203;13716](https://redirect.github.com/pytest-dev/pytest/issues/13716):
          Fixed a bug where a nonsensical invocation like `pytest x.py[a]` (a file
          cannot be parametrized) was silently treated as `pytest x.py`. This is now
          a usage error.\n\n- [#&#8203;13722](https://redirect.github.com/pytest-dev/pytest/issues/13722):
          Fixed a misleading assertion failure message when using `pytest.approx`
          on mappings with differing lengths.\n\n- [#&#8203;13773](https://redirect.github.com/pytest-dev/pytest/issues/13773):
          Fixed the static fixture closure calculation to properly consider transitive
          dependencies requested by overridden fixtures.\n\n- [#&#8203;13816](https://redirect.github.com/pytest-dev/pytest/issues/13816):
          Fixed `pytest.approx` which now returns a clearer error message when comparing
          mappings with different keys.\n\n- [#&#8203;13849](https://redirect.github.com/pytest-dev/pytest/issues/13849):
          Hidden `.pytest.ini` files are now picked up as the config file even if
          empty.\n  This was an inconsistency with non-hidden `pytest.ini`.\n\n- [#&#8203;13865](https://redirect.github.com/pytest-dev/pytest/issues/13865):
          Fixed <span class=\"title-ref\">--show-capture</span> with <span class=\"title-ref\">--tb=line</span>.\n\n-
          [#&#8203;13522](https://redirect.github.com/pytest-dev/pytest/issues/13522):
          Fixed `pytester` in subprocess mode ignored all :attr\\`pytester.plugins
          \\<pytest.Pytester.plugins>\\` except the first.\n\n  Fixed `pytester` in
          subprocess mode silently ignored non-str `pytester.plugins <pytest.Pytester.plugins>`.\n
          \ Now it errors instead.\n  If you are affected by this, specify the plugin
          by name, or switch the affected tests to use `pytester.runpytest_inprocess
          <pytest.Pytester.runpytest_inprocess>` explicitly instead.\n\n#### Packaging
          updates and notes for downstreams\n\n- [#&#8203;13791](https://redirect.github.com/pytest-dev/pytest/issues/13791):
          Minimum requirements on `iniconfig` and `packaging` were bumped to `1.0.1`
          and `22.0.0`, respectively.\n\n#### Contributor-facing changes\n\n- [#&#8203;12244](https://redirect.github.com/pytest-dev/pytest/issues/12244):
          Fixed self-test failures when <span class=\"title-ref\">TERM=dumb</span>.\n-
          [#&#8203;12474](https://redirect.github.com/pytest-dev/pytest/issues/12474):
          Added scheduled GitHub Action Workflow to run Sphinx linkchecks in repo
          documentation.\n- [#&#8203;13621](https://redirect.github.com/pytest-dev/pytest/issues/13621):
          pytest's own testsuite now handles the `lsof` command hanging (e.g. due
          to unreachable network filesystems), with the affected selftests being skipped
          after 10 seconds.\n- [#&#8203;13638](https://redirect.github.com/pytest-dev/pytest/issues/13638):
          Fixed deprecated `gh pr new` command in `scripts/prepare-release-pr.py`.\n
          \ The script now uses `gh pr create` which is compatible with GitHub CLI
          v2.0+.\n- [#&#8203;13695](https://redirect.github.com/pytest-dev/pytest/issues/13695):
          Flush <span class=\"title-ref\">stdout</span> and <span class=\"title-ref\">stderr</span>
          in <span class=\"title-ref\">Pytester.run</span> to avoid truncated outputs
          in <span class=\"title-ref\">test\\_faulthandler.py::test\\_timeout</span>
          on CI -- by `ogrisel`.\n- [#&#8203;13771](https://redirect.github.com/pytest-dev/pytest/issues/13771):
          Skip <span class=\"title-ref\">test\\_do\\_not\\_collect\\_symlink\\_siblings</span>
          on Windows environments without symlink support to avoid false negatives.\n-
          [#&#8203;13841](https://redirect.github.com/pytest-dev/pytest/issues/13841):
          `tox>=4` is now required when contributing to pytest.\n- [#&#8203;13625](https://redirect.github.com/pytest-dev/pytest/issues/13625):
          Added missing docstrings to `pytest_addoption()`, `pytest_configure()`,
          and `cacheshow()` functions in `cacheprovider.py`.\n\n#### Miscellaneous
          internal changes\n\n- [#&#8203;13830](https://redirect.github.com/pytest-dev/pytest/issues/13830):
          Configuration overrides (`-o`/`--override-ini`) are now processed during
          startup rather than during `config.getini() <pytest.Config.getini>`.\n\n###
          [`v8.4.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.4.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.1...8.4.2)\n\n###
          pytest 8.4.2 (2025-09-03)\n\n#### Bug fixes\n\n- [#&#8203;13478](https://redirect.github.com/pytest-dev/pytest/issues/13478):
          Fixed a crash when using `console_output_style`{.interpreted-text role=\"confval\"}
          with `times` and a module is skipped.\n\n- [#&#8203;13530](https://redirect.github.com/pytest-dev/pytest/issues/13530):
          Fixed a crash when using `pytest.approx`{.interpreted-text role=\"func\"}
          and `decimal.Decimal`{.interpreted-text role=\"class\"} instances with the
          `decimal.FloatOperation`{.interpreted-text role=\"class\"} trap set.\n\n-
          [#&#8203;13549](https://redirect.github.com/pytest-dev/pytest/issues/13549):
          No longer evaluate type annotations in Python `3.14` when inspecting function
          signatures.\n\n  This prevents crashes during module collection when modules
          do not explicitly use `from __future__ import annotations` and import types
          for annotations within a `if TYPE_CHECKING:` block.\n\n- [#&#8203;13559](https://redirect.github.com/pytest-dev/pytest/issues/13559):
          Added missing \\[int]{.title-ref} and \\[float]{.title-ref} variants to
          the \\[Literal]{.title-ref} type annotation of the \\[type]{.title-ref}
          parameter in `pytest.Parser.addini`{.interpreted-text role=\"meth\"}.\n\n-
          [#&#8203;13563](https://redirect.github.com/pytest-dev/pytest/issues/13563):
          `pytest.approx`{.interpreted-text role=\"func\"} now only imports `numpy`
          if NumPy is already in `sys.modules`. This fixes unconditional import behavior
          introduced in \\[8.4.0]{.title-ref}.\n\n#### Improved documentation\n\n-
          [#&#8203;13577](https://redirect.github.com/pytest-dev/pytest/issues/13577):
          Clarify that `pytest_generate_tests` is discovered in test modules/classes;
          other hooks must be in `conftest.py` or plugins.\n\n#### Contributor-facing
          changes\n\n- [#&#8203;13480](https://redirect.github.com/pytest-dev/pytest/issues/13480):
          Self-testing: fixed a few test failures when run with `-Wdefault` or a similar
          override.\n- [#&#8203;13547](https://redirect.github.com/pytest-dev/pytest/issues/13547):
          Self-testing: corrected expected message for `test_doctest_unexpected_exception`
          in Python `3.14`.\n- [#&#8203;13684](https://redirect.github.com/pytest-dev/pytest/issues/13684):
          Make pytest's own testsuite insensitive to the presence of the `CI` environment
          variable -- by `ogrisel`{.interpreted-text role=\"user\"}.\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: (UTC)\n\n- Branch creation\n  -
          \"\"\n- Automerge\n  - At any time (no schedule defined)\n\n\U0001F6A6 **Automerge**:
          Disabled by config. Please merge this manually once you are satisfied.\n\n\u267B
          **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry
          checkbox.\n\n\U0001F515 **Ignore**: Close this PR and you won't be reminded
          about this update again.\n\n---\n\n - [ ] <!-- rebase-check -->If you want
          to rebase/retry this PR, check this box\n\n---\n\nThis PR was generated
          by [Mend Renovate](https://mend.io/renovate/). View the [repository job
          log](https://developer.mend.io/github/vexxhost/ansible-collection-containers).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMTAuMiIsInVwZGF0ZWRJblZlciI6IjQzLjExMC4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->\n"
        change_url: https://github.com/vexxhost/ansible-collection-containers/pull/110
        commit_id: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        patchset: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-containers
          name: vexxhost/ansible-collection-containers
          short_name: ansible-collection-containers
          src_dir: src/github.com/vexxhost/ansible-collection-containers
        src_dir: src/github.com/vexxhost/ansible-collection-containers
        topic: null
      change: '110'
      change_message: "chore(deps): update dependency pytest to v9 [security]\n\nThis
        PR contains the following updates:\n\n| Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/)
        | [Confidence](https://docs.renovatebot.com/merge-confidence/) |\n|---|---|---|---|\n|
        [pytest](https://redirect.github.com/pytest-dev/pytest) ([changelog](https://docs.pytest.org/en/stable/changelog.html))
        | `8.4.1` \u2192 `9.0.3` | ![age](https://developer.mend.io/api/mc/badges/age/pypi/pytest/9.0.3?slim=true)
        | ![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/pytest/8.4.1/9.0.3?slim=true)
        |\n\n### GitHub Vulnerability Alerts\n\n#### [CVE-2025-71176](https://nvd.nist.gov/vuln/detail/CVE-2025-71176)\n\npytest
        through 9.0.2 on UNIX relies on directories with the `/tmp/pytest-of-{user}`
        name pattern, which allows local users to cause a denial of service or possibly
        gain privileges.\n\n---\n\n### Release Notes\n\n<details>\n<summary>pytest-dev/pytest
        (pytest)</summary>\n\n### [`v9.0.3`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.3)\n\n[Compare
        Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.2...9.0.3)\n\n###
        pytest 9.0.3 (2026-04-07)\n\n#### Bug fixes\n\n- [#&#8203;12444](https://redirect.github.com/pytest-dev/pytest/issues/12444):
        Fixed `pytest.approx` which now correctly takes into account `~collections.abc.Mapping`
        keys order to compare them.\n\n- [#&#8203;13634](https://redirect.github.com/pytest-dev/pytest/issues/13634):
        Blocking a `conftest.py` file using the `-p no:` option is now explicitly
        disallowed.\n\n  Previously this resulted in an internal assertion failure
        during plugin loading.\n\n  Pytest now raises a clear `UsageError` explaining
        that conftest files are not plugins and cannot be disabled via `-p`.\n\n-
        [#&#8203;13734](https://redirect.github.com/pytest-dev/pytest/issues/13734):
        Fixed crash when a test raises an exceptiongroup with `__tracebackhide__ =
        True`.\n\n- [#&#8203;14195](https://redirect.github.com/pytest-dev/pytest/issues/14195):
        Fixed an issue where non-string messages passed to <span class=\"title-ref\">unittest.TestCase.subTest()</span>
        were not printed.\n\n- [#&#8203;14343](https://redirect.github.com/pytest-dev/pytest/issues/14343):
        Fixed use of insecure temporary directory (CVE-2025-71176).\n\n#### Improved
        documentation\n\n- [#&#8203;13388](https://redirect.github.com/pytest-dev/pytest/issues/13388):
        Clarified documentation for `-p` vs `PYTEST_PLUGINS` plugin loading and fixed
        an incorrect `-p` example.\n- [#&#8203;13731](https://redirect.github.com/pytest-dev/pytest/issues/13731):
        Clarified that capture fixtures (e.g. `capsys` and `capfd`) take precedence
        over the `-s` / `--capture=no` command-line options in `Accessing captured
        output from a test function <accessing-captured-output>`.\n- [#&#8203;14088](https://redirect.github.com/pytest-dev/pytest/issues/14088):
        Clarified that the default `pytest_collection` hook sets `session.items` before
        it calls `pytest_collection_finish`, not after.\n- [#&#8203;14255](https://redirect.github.com/pytest-dev/pytest/issues/14255):
        TOML integer log levels must be quoted: Updating reference documentation.\n\n####
        Contributor-facing changes\n\n- [#&#8203;12689](https://redirect.github.com/pytest-dev/pytest/issues/12689):
        The test reports are now published to Codecov from GitHub Actions.\n  The
        test statistics is visible [on the web interface](https://app.codecov.io/gh/pytest-dev/pytest/tests).\n\n
        \ \\-- by `aleguy02`\n\n### [`v9.0.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.2)\n\n[Compare
        Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.1...9.0.2)\n\n###
        pytest 9.0.2 (2025-12-06)\n\n#### Bug fixes\n\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
        The terminal progress feature added in pytest 9.0.0 has been disabled by default,
        except on Windows, due to compatibility issues with some terminal emulators.\n\n
        \ You may enable it again by passing `-p terminalprogress`. We may enable
        it by default again once compatibility improves in the future.\n\n  Additionally,
        when the environment variable `TERM` is `dumb`, the escape codes are no longer
        emitted, even if the plugin is enabled.\n\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
        Fixed the TOML type of the `tmp_path_retention_count` settings in the API
        reference from number to string.\n\n- [#&#8203;13946](https://redirect.github.com/pytest-dev/pytest/issues/13946):
        The private `config.inicfg` attribute was changed in a breaking manner in
        pytest 9.0.0.\n  Due to its usage in the ecosystem, it is now restored to
        working order using a compatibility shim.\n  It will be deprecated in pytest
        9.1 and removed in pytest 10.\n\n- [#&#8203;13965](https://redirect.github.com/pytest-dev/pytest/issues/13965):
        Fixed quadratic-time behavior when handling `unittest` subtests in Python
        3.10.\n\n#### Improved documentation\n\n- [#&#8203;4492](https://redirect.github.com/pytest-dev/pytest/issues/4492):
        The API Reference now contains cross-reference-able documentation of `pytest's
        command-line flags <command-line-flags>`.\n\n### [`v9.0.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.1)\n\n[Compare
        Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.0...9.0.1)\n\n###
        pytest 9.0.1 (2025-11-12)\n\n#### Bug fixes\n\n- [#&#8203;13895](https://redirect.github.com/pytest-dev/pytest/issues/13895):
        Restore support for skipping tests via `raise unittest.SkipTest`.\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
        The terminal progress plugin added in pytest 9.0 is now automatically disabled
        when iTerm2 is detected, it generated desktop notifications instead of the
        desired functionality.\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
        Fixed the TOML type of the verbosity settings in the API reference from number
        to string.\n- [#&#8203;13910](https://redirect.github.com/pytest-dev/pytest/issues/13910):
        Fixed <span class=\"title-ref\">UserWarning: Do not expect file\\_or\\_dir</span>
        on some earlier Python 3.12 and 3.13 point versions.\n\n#### Packaging updates
        and notes for downstreams\n\n- [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
        The tox configuration has been adjusted to make sure the desired\n  version
        string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
        environment\n  variable as a part of the release process -- by `webknjaz`.\n\n####
        Contributor-facing changes\n\n- [#&#8203;13891](https://redirect.github.com/pytest-dev/pytest/issues/13891),
        [#&#8203;13942](https://redirect.github.com/pytest-dev/pytest/issues/13942):
        The CI/CD part of the release automation is now capable of\n  creating GitHub
        Releases without having a Git checkout on\n  disk -- by `bluetech` and `webknjaz`.\n-
        [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
        The tox configuration has been adjusted to make sure the desired\n  version
        string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
        environment\n  variable as a part of the release process -- by `webknjaz`.\n\n###
        [`v9.0.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.0)\n\n[Compare
        Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.2...9.0.0)\n\n###
        pytest 9.0.0 (2025-11-05)\n\n#### New features\n\n- [#&#8203;1367](https://redirect.github.com/pytest-dev/pytest/issues/1367):
        **Support for subtests** has been added.\n\n  `subtests <subtests>` are an
        alternative to parametrization, useful in situations where the parametrization
        values are not all known at collection time.\n\n  Example:\n\n  ```python\n
        \ def contains_docstring(p: Path) -> bool:\n      \"\"\"Return True if the
        given Python file contains a top-level docstring.\"\"\"\n      ...\n\n  def
        test_py_files_contain_docstring(subtests: pytest.Subtests) -> None:\n      for
        path in Path.cwd().glob(\"*.py\"):\n          with subtests.test(path=str(path)):\n
        \             assert contains_docstring(path)\n  ```\n\n  Each assert failure
        or error is caught by the context manager and reported individually, giving
        a clear picture of all files that are missing a docstring.\n\n  In addition,
        `unittest.TestCase.subTest` is now also supported.\n\n  This feature was originally
        implemented as a separate plugin in [pytest-subtests](https://redirect.github.com/pytest-dev/pytest-subtests),
        but since then has been merged into the core.\n\n  > \\[!NOTE]\n  > This feature
        is experimental and will likely evolve in future releases. By that we mean
        that we might change how subtests are reported on failure, but the functionality
        and how to use it are stable.\n\n- [#&#8203;13743](https://redirect.github.com/pytest-dev/pytest/issues/13743):
        Added support for **native TOML configuration files**.\n\n  While pytest,
        since version 6, supports configuration in `pyproject.toml` files under `[tool.pytest.ini_options]`,\n
        \ it does so in an \"INI compatibility mode\", where all configuration values
        are treated as strings or list of strings.\n  Now, pytest supports the native
        TOML data model.\n\n  In `pyproject.toml`, the native TOML configuration is
        under the `[tool.pytest]` table.\n\n  ```toml\n  # pyproject.toml\n  [tool.pytest]\n
        \ minversion = \"9.0\"\n  addopts = [\"-ra\", \"-q\"]\n  testpaths = [\n      \"tests\",\n
        \     \"integration\",\n  ]\n  ```\n\n  The `[tool.pytest.ini_options]` table
        remains supported, but both tables cannot be used at the same time.\n\n  If
        you prefer to use a separate configuration file, or don't use `pyproject.toml`,
        you can use `pytest.toml` or `.pytest.toml`:\n\n  ```toml\n  # pytest.toml
        or .pytest.toml\n  [pytest]\n  minversion = \"9.0\"\n  addopts = [\"-ra\",
        \"-q\"]\n  testpaths = [\n      \"tests\",\n      \"integration\",\n  ]\n
        \ ```\n\n  The documentation now (sometimes) shows configuration snippets
        in both TOML and INI formats, in a tabbed interface.\n\n  See `config file
        formats` for full details.\n\n- [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
        Added a **\"strict mode\"** enabled by the `strict` configuration option.\n\n
        \ When set to `true`, the `strict` option currently enables\n\n  - `strict_config`\n
        \ - `strict_markers`\n  - `strict_parametrization_ids`\n  - `strict_xfail`\n\n
        \ The individual strictness options can be explicitly set to override the
        global `strict` setting.\n\n  The previously-deprecated `--strict` command-line
        flag now enables strict mode.\n\n  If pytest adds new strictness options in
        the future, they will also be enabled in strict mode.\n  Therefore, you should
        only enable strict mode if you use a pinned/locked version of pytest,\n  or
        if you want to proactively adopt new strictness options as they are added.\n\n
        \ See `strict mode` for more details.\n\n- [#&#8203;13737](https://redirect.github.com/pytest-dev/pytest/issues/13737):
        Added the `strict_parametrization_ids` configuration option.\n\n  When set,
        pytest emits an error if it detects non-unique parameter set IDs,\n  rather
        than automatically making the IDs unique by adding <span class=\"title-ref\">0</span>,
        <span class=\"title-ref\">1</span>, ... to them.\n  This can be particularly
        useful for catching unintended duplicates.\n\n- [#&#8203;13072](https://redirect.github.com/pytest-dev/pytest/issues/13072):
        Added support for displaying test session **progress in the terminal tab**
        using the [OSC 9;4;](https://conemu.github.io/en/AnsiEscapeCodes.html#ConEmu_specific_OSC)
        ANSI sequence.\n  When pytest runs in a supported terminal emulator like ConEmu,
        Gnome Terminal, Ptyxis, Windows Terminal, Kitty or Ghostty,\n  you'll see
        the progress in the terminal tab or window,\n  allowing you to monitor pytest's
        progress at a glance.\n\n  This feature is automatically enabled when running
        in a TTY. It is implemented as an internal plugin. If needed, it can be disabled
        as follows:\n\n  - On a user level, using `-p no:terminalprogress` on the
        command line or via an environment variable `PYTEST_ADDOPTS='-p no:terminalprogress'`.\n
        \ - On a project configuration level, using `addopts = \"-p no:terminalprogress\"`.\n\n-
        [#&#8203;478](https://redirect.github.com/pytest-dev/pytest/issues/478): Support
        PEP420 (implicit namespace packages) as <span class=\"title-ref\">--pyargs</span>
        target when `consider_namespace_packages` is <span class=\"title-ref\">true</span>
        in the config.\n\n  Previously, this option only impacted package imports,
        now it also impacts tests discovery.\n\n- [#&#8203;13678](https://redirect.github.com/pytest-dev/pytest/issues/13678):
        Added a new `faulthandler_exit_on_timeout` configuration option set to \"false\"
        by default to let <span class=\"title-ref\">faulthandler</span> interrupt
        the <span class=\"title-ref\">pytest</span> process after a timeout in case
        of deadlock.\n\n  Previously, a <span class=\"title-ref\">faulthandler</span>
        timeout would only dump the traceback of all threads to stderr, but would
        not interrupt the <span class=\"title-ref\">pytest</span> process.\n\n  \\--
        by `ogrisel`.\n\n- [#&#8203;13829](https://redirect.github.com/pytest-dev/pytest/issues/13829):
        Added support for configuration option aliases via the `aliases` parameter
        in `Parser.addini() <pytest.Parser.addini>`.\n\n  Plugins can now register
        alternative names for configuration options,\n  allowing for more flexibility
        in configuration naming and supporting backward compatibility when renaming
        options.\n  The canonical name always takes precedence if both the canonical
        name and an alias are specified in the configuration file.\n\n#### Improvements
        in existing functionality\n\n- [#&#8203;13330](https://redirect.github.com/pytest-dev/pytest/issues/13330):
        Having pytest configuration spread over more than one file (for example having
        both a `pytest.ini` file and `pyproject.toml` with a `[tool.pytest.ini_options]`
        table) will now print a warning to make it clearer to the user that only one
        of them is actually used.\n\n  \\-- by `sgaist`\n\n- [#&#8203;13574](https://redirect.github.com/pytest-dev/pytest/issues/13574):
        The single argument `--version` no longer loads the entire plugin infrastructure,
        making it faster and more reliable when displaying only the pytest version.\n\n
        \ Passing `--version` twice (e.g., `pytest --version --version`) retains the
        original behavior, showing both the pytest version and plugin information.\n\n
        \ > \\[!NOTE]\n  > Since `--version` is now processed early, it only takes
        effect when passed directly via the command line. It will not work if set
        through other mechanisms, such as `PYTEST_ADDOPTS` or `addopts`.\n\n- [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
        Added `strict_xfail` as an alias to the `xfail_strict` option,\n  `strict_config`
        as an alias to the `--strict-config` flag,\n  and `strict_markers` as an alias
        to the `--strict-markers` flag.\n  This makes all strictness options consistently
        have configuration options with the prefix `strict_`.\n\n- [#&#8203;13700](https://redirect.github.com/pytest-dev/pytest/issues/13700):
        <span class=\"title-ref\">--junitxml</span> no longer prints the <span class=\"title-ref\">generated
        xml file</span> summary at the end of the pytest session when <span class=\"title-ref\">--quiet</span>
        is given.\n\n- [#&#8203;13732](https://redirect.github.com/pytest-dev/pytest/issues/13732):
        Previously, when filtering warnings, pytest would fail if the filter referenced
        a class that could not be imported. Now, this only outputs a message indicating
        the problem.\n\n- [#&#8203;13859](https://redirect.github.com/pytest-dev/pytest/issues/13859):
        Clarify the error message for <span class=\"title-ref\">pytest.raises()</span>
        when a regex <span class=\"title-ref\">match</span> fails.\n\n- [#&#8203;13861](https://redirect.github.com/pytest-dev/pytest/issues/13861):
        Better sentence structure in a test's expected error message. Previously,
        the error message would be \"expected exception must be \\<expected>, but
        got \\<actual>\". Now, it is \"Expected \\<expected>, but got \\<actual>\".\n\n####
        Removals and backward incompatible breaking changes\n\n- [#&#8203;12083](https://redirect.github.com/pytest-dev/pytest/issues/12083):
        Fixed a bug where an invocation such as <span class=\"title-ref\">pytest a/
        a/b</span> would cause only tests from <span class=\"title-ref\">a/b</span>
        to run, and not other tests under <span class=\"title-ref\">a/</span>.\n\n
        \ The fix entails a few breaking changes to how such overlapping arguments
        and duplicates are handled:\n\n  1. <span class=\"title-ref\">pytest a/b a/</span>
        or <span class=\"title-ref\">pytest a/ a/b</span> are equivalent to <span
        class=\"title-ref\">pytest a</span>; if an argument overlaps another arguments,
        only the prefix remains.\n  2. <span class=\"title-ref\">pytest x.py x.py</span>
        is equivalent to <span class=\"title-ref\">pytest x.py</span>; previously
        such an invocation was taken as an explicit request to run the tests from
        the file twice.\n\n  If you rely on these behaviors, consider using `--keep-duplicates
        <duplicate-paths>`, which retains its existing behavior (including the bug).\n\n-
        [#&#8203;13719](https://redirect.github.com/pytest-dev/pytest/issues/13719):
        Support for Python 3.9 is dropped following its end of life.\n\n- [#&#8203;13766](https://redirect.github.com/pytest-dev/pytest/issues/13766):
        Previously, pytest would assume it was running in a CI/CD environment if either
        of the environment variables <span class=\"title-ref\">$CI</span> or <span
        class=\"title-ref\">$BUILD\\_NUMBER</span> was defined;\n  now, CI mode is
        only activated if at least one of those variables is defined and set to a
        *non-empty* value.\n\n- [#&#8203;13779](https://redirect.github.com/pytest-dev/pytest/issues/13779):
        **PytestRemovedIn9Warning deprecation warnings are now errors by default.**\n\n
        \ Following our plan to remove deprecated features with as little disruption
        as\n  possible, all warnings of type `PytestRemovedIn9Warning` now generate
        errors\n  instead of warning messages by default.\n\n  **The affected features
        will be effectively removed in pytest 9.1**, so please consult the\n  `deprecations`
        section in the docs for directions on how to update existing code.\n\n  In
        the pytest `9.0.X` series, it is possible to change the errors back into warnings
        as a\n  stopgap measure by adding this to your `pytest.ini` file:\n\n  ```ini\n
        \ [pytest]\n  filterwarnings =\n      ignore::pytest.PytestRemovedIn9Warning\n
        \ ```\n\n  But this will stop working when pytest `9.1` is released.\n\n  **If
        you have concerns** about the removal of a specific feature, please add a\n
        \ comment to `13779`.\n\n#### Deprecations (removal in next major release)\n\n-
        [#&#8203;13807](https://redirect.github.com/pytest-dev/pytest/issues/13807):
        `monkeypatch.syspath_prepend() <pytest.MonkeyPatch.syspath_prepend>` now issues
        a deprecation warning when the prepended path contains legacy namespace packages
        (those using `pkg_resources.declare_namespace()`).\n  Users should migrate
        to native namespace packages (`420`).\n  See `monkeypatch-fixup-namespace-packages`
        for details.\n\n#### Bug fixes\n\n- [#&#8203;13445](https://redirect.github.com/pytest-dev/pytest/issues/13445):
        Made the type annotations of `pytest.skip` and friends more spec-complaint
        to have them work across more type checkers.\n\n- [#&#8203;13537](https://redirect.github.com/pytest-dev/pytest/issues/13537):
        Fixed a bug in which `ExceptionGroup` with only `Skipped` exceptions in teardown
        was not handled correctly and showed as error.\n\n- [#&#8203;13598](https://redirect.github.com/pytest-dev/pytest/issues/13598):
        Fixed possible collection confusion on Windows when short paths and symlinks
        are involved.\n\n- [#&#8203;13716](https://redirect.github.com/pytest-dev/pytest/issues/13716):
        Fixed a bug where a nonsensical invocation like `pytest x.py[a]` (a file cannot
        be parametrized) was silently treated as `pytest x.py`. This is now a usage
        error.\n\n- [#&#8203;13722](https://redirect.github.com/pytest-dev/pytest/issues/13722):
        Fixed a misleading assertion failure message when using `pytest.approx` on
        mappings with differing lengths.\n\n- [#&#8203;13773](https://redirect.github.com/pytest-dev/pytest/issues/13773):
        Fixed the static fixture closure calculation to properly consider transitive
        dependencies requested by overridden fixtures.\n\n- [#&#8203;13816](https://redirect.github.com/pytest-dev/pytest/issues/13816):
        Fixed `pytest.approx` which now returns a clearer error message when comparing
        mappings with different keys.\n\n- [#&#8203;13849](https://redirect.github.com/pytest-dev/pytest/issues/13849):
        Hidden `.pytest.ini` files are now picked up as the config file even if empty.\n
        \ This was an inconsistency with non-hidden `pytest.ini`.\n\n- [#&#8203;13865](https://redirect.github.com/pytest-dev/pytest/issues/13865):
        Fixed <span class=\"title-ref\">--show-capture</span> with <span class=\"title-ref\">--tb=line</span>.\n\n-
        [#&#8203;13522](https://redirect.github.com/pytest-dev/pytest/issues/13522):
        Fixed `pytester` in subprocess mode ignored all :attr\\`pytester.plugins \\<pytest.Pytester.plugins>\\`
        except the first.\n\n  Fixed `pytester` in subprocess mode silently ignored
        non-str `pytester.plugins <pytest.Pytester.plugins>`.\n  Now it errors instead.\n
        \ If you are affected by this, specify the plugin by name, or switch the affected
        tests to use `pytester.runpytest_inprocess <pytest.Pytester.runpytest_inprocess>`
        explicitly instead.\n\n#### Packaging updates and notes for downstreams\n\n-
        [#&#8203;13791](https://redirect.github.com/pytest-dev/pytest/issues/13791):
        Minimum requirements on `iniconfig` and `packaging` were bumped to `1.0.1`
        and `22.0.0`, respectively.\n\n#### Contributor-facing changes\n\n- [#&#8203;12244](https://redirect.github.com/pytest-dev/pytest/issues/12244):
        Fixed self-test failures when <span class=\"title-ref\">TERM=dumb</span>.\n-
        [#&#8203;12474](https://redirect.github.com/pytest-dev/pytest/issues/12474):
        Added scheduled GitHub Action Workflow to run Sphinx linkchecks in repo documentation.\n-
        [#&#8203;13621](https://redirect.github.com/pytest-dev/pytest/issues/13621):
        pytest's own testsuite now handles the `lsof` command hanging (e.g. due to
        unreachable network filesystems), with the affected selftests being skipped
        after 10 seconds.\n- [#&#8203;13638](https://redirect.github.com/pytest-dev/pytest/issues/13638):
        Fixed deprecated `gh pr new` command in `scripts/prepare-release-pr.py`.\n
        \ The script now uses `gh pr create` which is compatible with GitHub CLI v2.0+.\n-
        [#&#8203;13695](https://redirect.github.com/pytest-dev/pytest/issues/13695):
        Flush <span class=\"title-ref\">stdout</span> and <span class=\"title-ref\">stderr</span>
        in <span class=\"title-ref\">Pytester.run</span> to avoid truncated outputs
        in <span class=\"title-ref\">test\\_faulthandler.py::test\\_timeout</span>
        on CI -- by `ogrisel`.\n- [#&#8203;13771](https://redirect.github.com/pytest-dev/pytest/issues/13771):
        Skip <span class=\"title-ref\">test\\_do\\_not\\_collect\\_symlink\\_siblings</span>
        on Windows environments without symlink support to avoid false negatives.\n-
        [#&#8203;13841](https://redirect.github.com/pytest-dev/pytest/issues/13841):
        `tox>=4` is now required when contributing to pytest.\n- [#&#8203;13625](https://redirect.github.com/pytest-dev/pytest/issues/13625):
        Added missing docstrings to `pytest_addoption()`, `pytest_configure()`, and
        `cacheshow()` functions in `cacheprovider.py`.\n\n#### Miscellaneous internal
        changes\n\n- [#&#8203;13830](https://redirect.github.com/pytest-dev/pytest/issues/13830):
        Configuration overrides (`-o`/`--override-ini`) are now processed during startup
        rather than during `config.getini() <pytest.Config.getini>`.\n\n### [`v8.4.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.4.2)\n\n[Compare
        Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.1...8.4.2)\n\n###
        pytest 8.4.2 (2025-09-03)\n\n#### Bug fixes\n\n- [#&#8203;13478](https://redirect.github.com/pytest-dev/pytest/issues/13478):
        Fixed a crash when using `console_output_style`{.interpreted-text role=\"confval\"}
        with `times` and a module is skipped.\n\n- [#&#8203;13530](https://redirect.github.com/pytest-dev/pytest/issues/13530):
        Fixed a crash when using `pytest.approx`{.interpreted-text role=\"func\"}
        and `decimal.Decimal`{.interpreted-text role=\"class\"} instances with the
        `decimal.FloatOperation`{.interpreted-text role=\"class\"} trap set.\n\n-
        [#&#8203;13549](https://redirect.github.com/pytest-dev/pytest/issues/13549):
        No longer evaluate type annotations in Python `3.14` when inspecting function
        signatures.\n\n  This prevents crashes during module collection when modules
        do not explicitly use `from __future__ import annotations` and import types
        for annotations within a `if TYPE_CHECKING:` block.\n\n- [#&#8203;13559](https://redirect.github.com/pytest-dev/pytest/issues/13559):
        Added missing \\[int]{.title-ref} and \\[float]{.title-ref} variants to the
        \\[Literal]{.title-ref} type annotation of the \\[type]{.title-ref} parameter
        in `pytest.Parser.addini`{.interpreted-text role=\"meth\"}.\n\n- [#&#8203;13563](https://redirect.github.com/pytest-dev/pytest/issues/13563):
        `pytest.approx`{.interpreted-text role=\"func\"} now only imports `numpy`
        if NumPy is already in `sys.modules`. This fixes unconditional import behavior
        introduced in \\[8.4.0]{.title-ref}.\n\n#### Improved documentation\n\n- [#&#8203;13577](https://redirect.github.com/pytest-dev/pytest/issues/13577):
        Clarify that `pytest_generate_tests` is discovered in test modules/classes;
        other hooks must be in `conftest.py` or plugins.\n\n#### Contributor-facing
        changes\n\n- [#&#8203;13480](https://redirect.github.com/pytest-dev/pytest/issues/13480):
        Self-testing: fixed a few test failures when run with `-Wdefault` or a similar
        override.\n- [#&#8203;13547](https://redirect.github.com/pytest-dev/pytest/issues/13547):
        Self-testing: corrected expected message for `test_doctest_unexpected_exception`
        in Python `3.14`.\n- [#&#8203;13684](https://redirect.github.com/pytest-dev/pytest/issues/13684):
        Make pytest's own testsuite insensitive to the presence of the `CI` environment
        variable -- by `ogrisel`{.interpreted-text role=\"user\"}.\n\n</details>\n\n---\n\n###
        Configuration\n\n\U0001F4C5 **Schedule**: (UTC)\n\n- Branch creation\n  -
        \"\"\n- Automerge\n  - At any time (no schedule defined)\n\n\U0001F6A6 **Automerge**:
        Disabled by config. Please merge this manually once you are satisfied.\n\n\u267B
        **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry
        checkbox.\n\n\U0001F515 **Ignore**: Close this PR and you won't be reminded
        about this update again.\n\n---\n\n - [ ] <!-- rebase-check -->If you want
        to rebase/retry this PR, check this box\n\n---\n\nThis PR was generated by
        [Mend Renovate](https://mend.io/renovate/). View the [repository job log](https://developer.mend.io/github/vexxhost/ansible-collection-containers).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMTAuMiIsInVwZGF0ZWRJblZlciI6IjQzLjExMC4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->\n"
      change_url: https://github.com/vexxhost/ansible-collection-containers/pull/110
      child_jobs: []
      commit_id: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
      event_id: ca05b0c0-37a8-11f1-88dc-20bb82c8c755
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/ddbdff2cd5784c228ba6986b1a446bde/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/ddbdff2cd5784c228ba6986b1a446bde/work/logs
        result_data_file: /var/lib/zuul/builds/ddbdff2cd5784c228ba6986b1a446bde/work/results.json
        src_root: /var/lib/zuul/builds/ddbdff2cd5784c228ba6986b1a446bde/work/src
        work_root: /var/lib/zuul/builds/ddbdff2cd5784c228ba6986b1a446bde/work
      include_vars: []
      items:
      - branch: main
        change: '110'
        change_message: "chore(deps): update dependency pytest to v9 [security]\n\nThis
          PR contains the following updates:\n\n| Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/)
          | [Confidence](https://docs.renovatebot.com/merge-confidence/) |\n|---|---|---|---|\n|
          [pytest](https://redirect.github.com/pytest-dev/pytest) ([changelog](https://docs.pytest.org/en/stable/changelog.html))
          | `8.4.1` \u2192 `9.0.3` | ![age](https://developer.mend.io/api/mc/badges/age/pypi/pytest/9.0.3?slim=true)
          | ![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/pytest/8.4.1/9.0.3?slim=true)
          |\n\n### GitHub Vulnerability Alerts\n\n#### [CVE-2025-71176](https://nvd.nist.gov/vuln/detail/CVE-2025-71176)\n\npytest
          through 9.0.2 on UNIX relies on directories with the `/tmp/pytest-of-{user}`
          name pattern, which allows local users to cause a denial of service or possibly
          gain privileges.\n\n---\n\n### Release Notes\n\n<details>\n<summary>pytest-dev/pytest
          (pytest)</summary>\n\n### [`v9.0.3`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.3)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.2...9.0.3)\n\n###
          pytest 9.0.3 (2026-04-07)\n\n#### Bug fixes\n\n- [#&#8203;12444](https://redirect.github.com/pytest-dev/pytest/issues/12444):
          Fixed `pytest.approx` which now correctly takes into account `~collections.abc.Mapping`
          keys order to compare them.\n\n- [#&#8203;13634](https://redirect.github.com/pytest-dev/pytest/issues/13634):
          Blocking a `conftest.py` file using the `-p no:` option is now explicitly
          disallowed.\n\n  Previously this resulted in an internal assertion failure
          during plugin loading.\n\n  Pytest now raises a clear `UsageError` explaining
          that conftest files are not plugins and cannot be disabled via `-p`.\n\n-
          [#&#8203;13734](https://redirect.github.com/pytest-dev/pytest/issues/13734):
          Fixed crash when a test raises an exceptiongroup with `__tracebackhide__
          = True`.\n\n- [#&#8203;14195](https://redirect.github.com/pytest-dev/pytest/issues/14195):
          Fixed an issue where non-string messages passed to <span class=\"title-ref\">unittest.TestCase.subTest()</span>
          were not printed.\n\n- [#&#8203;14343](https://redirect.github.com/pytest-dev/pytest/issues/14343):
          Fixed use of insecure temporary directory (CVE-2025-71176).\n\n#### Improved
          documentation\n\n- [#&#8203;13388](https://redirect.github.com/pytest-dev/pytest/issues/13388):
          Clarified documentation for `-p` vs `PYTEST_PLUGINS` plugin loading and
          fixed an incorrect `-p` example.\n- [#&#8203;13731](https://redirect.github.com/pytest-dev/pytest/issues/13731):
          Clarified that capture fixtures (e.g. `capsys` and `capfd`) take precedence
          over the `-s` / `--capture=no` command-line options in `Accessing captured
          output from a test function <accessing-captured-output>`.\n- [#&#8203;14088](https://redirect.github.com/pytest-dev/pytest/issues/14088):
          Clarified that the default `pytest_collection` hook sets `session.items`
          before it calls `pytest_collection_finish`, not after.\n- [#&#8203;14255](https://redirect.github.com/pytest-dev/pytest/issues/14255):
          TOML integer log levels must be quoted: Updating reference documentation.\n\n####
          Contributor-facing changes\n\n- [#&#8203;12689](https://redirect.github.com/pytest-dev/pytest/issues/12689):
          The test reports are now published to Codecov from GitHub Actions.\n  The
          test statistics is visible [on the web interface](https://app.codecov.io/gh/pytest-dev/pytest/tests).\n\n
          \ \\-- by `aleguy02`\n\n### [`v9.0.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.1...9.0.2)\n\n###
          pytest 9.0.2 (2025-12-06)\n\n#### Bug fixes\n\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress feature added in pytest 9.0.0 has been disabled by
          default, except on Windows, due to compatibility issues with some terminal
          emulators.\n\n  You may enable it again by passing `-p terminalprogress`.
          We may enable it by default again once compatibility improves in the future.\n\n
          \ Additionally, when the environment variable `TERM` is `dumb`, the escape
          codes are no longer emitted, even if the plugin is enabled.\n\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the `tmp_path_retention_count` settings in the API
          reference from number to string.\n\n- [#&#8203;13946](https://redirect.github.com/pytest-dev/pytest/issues/13946):
          The private `config.inicfg` attribute was changed in a breaking manner in
          pytest 9.0.0.\n  Due to its usage in the ecosystem, it is now restored to
          working order using a compatibility shim.\n  It will be deprecated in pytest
          9.1 and removed in pytest 10.\n\n- [#&#8203;13965](https://redirect.github.com/pytest-dev/pytest/issues/13965):
          Fixed quadratic-time behavior when handling `unittest` subtests in Python
          3.10.\n\n#### Improved documentation\n\n- [#&#8203;4492](https://redirect.github.com/pytest-dev/pytest/issues/4492):
          The API Reference now contains cross-reference-able documentation of `pytest's
          command-line flags <command-line-flags>`.\n\n### [`v9.0.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.1)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/9.0.0...9.0.1)\n\n###
          pytest 9.0.1 (2025-11-12)\n\n#### Bug fixes\n\n- [#&#8203;13895](https://redirect.github.com/pytest-dev/pytest/issues/13895):
          Restore support for skipping tests via `raise unittest.SkipTest`.\n- [#&#8203;13896](https://redirect.github.com/pytest-dev/pytest/issues/13896):
          The terminal progress plugin added in pytest 9.0 is now automatically disabled
          when iTerm2 is detected, it generated desktop notifications instead of the
          desired functionality.\n- [#&#8203;13904](https://redirect.github.com/pytest-dev/pytest/issues/13904):
          Fixed the TOML type of the verbosity settings in the API reference from
          number to string.\n- [#&#8203;13910](https://redirect.github.com/pytest-dev/pytest/issues/13910):
          Fixed <span class=\"title-ref\">UserWarning: Do not expect file\\_or\\_dir</span>
          on some earlier Python 3.12 and 3.13 point versions.\n\n#### Packaging updates
          and notes for downstreams\n\n- [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n####
          Contributor-facing changes\n\n- [#&#8203;13891](https://redirect.github.com/pytest-dev/pytest/issues/13891),
          [#&#8203;13942](https://redirect.github.com/pytest-dev/pytest/issues/13942):
          The CI/CD part of the release automation is now capable of\n  creating GitHub
          Releases without having a Git checkout on\n  disk -- by `bluetech` and `webknjaz`.\n-
          [#&#8203;13933](https://redirect.github.com/pytest-dev/pytest/issues/13933):
          The tox configuration has been adjusted to make sure the desired\n  version
          string can be passed into its `package_env` through\n  the `SETUPTOOLS_SCM_PRETEND_VERSION_FOR_PYTEST`
          environment\n  variable as a part of the release process -- by `webknjaz`.\n\n###
          [`v9.0.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/9.0.0)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.2...9.0.0)\n\n###
          pytest 9.0.0 (2025-11-05)\n\n#### New features\n\n- [#&#8203;1367](https://redirect.github.com/pytest-dev/pytest/issues/1367):
          **Support for subtests** has been added.\n\n  `subtests <subtests>` are
          an alternative to parametrization, useful in situations where the parametrization
          values are not all known at collection time.\n\n  Example:\n\n  ```python\n
          \ def contains_docstring(p: Path) -> bool:\n      \"\"\"Return True if the
          given Python file contains a top-level docstring.\"\"\"\n      ...\n\n  def
          test_py_files_contain_docstring(subtests: pytest.Subtests) -> None:\n      for
          path in Path.cwd().glob(\"*.py\"):\n          with subtests.test(path=str(path)):\n
          \             assert contains_docstring(path)\n  ```\n\n  Each assert failure
          or error is caught by the context manager and reported individually, giving
          a clear picture of all files that are missing a docstring.\n\n  In addition,
          `unittest.TestCase.subTest` is now also supported.\n\n  This feature was
          originally implemented as a separate plugin in [pytest-subtests](https://redirect.github.com/pytest-dev/pytest-subtests),
          but since then has been merged into the core.\n\n  > \\[!NOTE]\n  > This
          feature is experimental and will likely evolve in future releases. By that
          we mean that we might change how subtests are reported on failure, but the
          functionality and how to use it are stable.\n\n- [#&#8203;13743](https://redirect.github.com/pytest-dev/pytest/issues/13743):
          Added support for **native TOML configuration files**.\n\n  While pytest,
          since version 6, supports configuration in `pyproject.toml` files under
          `[tool.pytest.ini_options]`,\n  it does so in an \"INI compatibility mode\",
          where all configuration values are treated as strings or list of strings.\n
          \ Now, pytest supports the native TOML data model.\n\n  In `pyproject.toml`,
          the native TOML configuration is under the `[tool.pytest]` table.\n\n  ```toml\n
          \ # pyproject.toml\n  [tool.pytest]\n  minversion = \"9.0\"\n  addopts =
          [\"-ra\", \"-q\"]\n  testpaths = [\n      \"tests\",\n      \"integration\",\n
          \ ]\n  ```\n\n  The `[tool.pytest.ini_options]` table remains supported,
          but both tables cannot be used at the same time.\n\n  If you prefer to use
          a separate configuration file, or don't use `pyproject.toml`, you can use
          `pytest.toml` or `.pytest.toml`:\n\n  ```toml\n  # pytest.toml or .pytest.toml\n
          \ [pytest]\n  minversion = \"9.0\"\n  addopts = [\"-ra\", \"-q\"]\n  testpaths
          = [\n      \"tests\",\n      \"integration\",\n  ]\n  ```\n\n  The documentation
          now (sometimes) shows configuration snippets in both TOML and INI formats,
          in a tabbed interface.\n\n  See `config file formats` for full details.\n\n-
          [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added a **\"strict mode\"** enabled by the `strict` configuration option.\n\n
          \ When set to `true`, the `strict` option currently enables\n\n  - `strict_config`\n
          \ - `strict_markers`\n  - `strict_parametrization_ids`\n  - `strict_xfail`\n\n
          \ The individual strictness options can be explicitly set to override the
          global `strict` setting.\n\n  The previously-deprecated `--strict` command-line
          flag now enables strict mode.\n\n  If pytest adds new strictness options
          in the future, they will also be enabled in strict mode.\n  Therefore, you
          should only enable strict mode if you use a pinned/locked version of pytest,\n
          \ or if you want to proactively adopt new strictness options as they are
          added.\n\n  See `strict mode` for more details.\n\n- [#&#8203;13737](https://redirect.github.com/pytest-dev/pytest/issues/13737):
          Added the `strict_parametrization_ids` configuration option.\n\n  When set,
          pytest emits an error if it detects non-unique parameter set IDs,\n  rather
          than automatically making the IDs unique by adding <span class=\"title-ref\">0</span>,
          <span class=\"title-ref\">1</span>, ... to them.\n  This can be particularly
          useful for catching unintended duplicates.\n\n- [#&#8203;13072](https://redirect.github.com/pytest-dev/pytest/issues/13072):
          Added support for displaying test session **progress in the terminal tab**
          using the [OSC 9;4;](https://conemu.github.io/en/AnsiEscapeCodes.html#ConEmu_specific_OSC)
          ANSI sequence.\n  When pytest runs in a supported terminal emulator like
          ConEmu, Gnome Terminal, Ptyxis, Windows Terminal, Kitty or Ghostty,\n  you'll
          see the progress in the terminal tab or window,\n  allowing you to monitor
          pytest's progress at a glance.\n\n  This feature is automatically enabled
          when running in a TTY. It is implemented as an internal plugin. If needed,
          it can be disabled as follows:\n\n  - On a user level, using `-p no:terminalprogress`
          on the command line or via an environment variable `PYTEST_ADDOPTS='-p no:terminalprogress'`.\n
          \ - On a project configuration level, using `addopts = \"-p no:terminalprogress\"`.\n\n-
          [#&#8203;478](https://redirect.github.com/pytest-dev/pytest/issues/478):
          Support PEP420 (implicit namespace packages) as <span class=\"title-ref\">--pyargs</span>
          target when `consider_namespace_packages` is <span class=\"title-ref\">true</span>
          in the config.\n\n  Previously, this option only impacted package imports,
          now it also impacts tests discovery.\n\n- [#&#8203;13678](https://redirect.github.com/pytest-dev/pytest/issues/13678):
          Added a new `faulthandler_exit_on_timeout` configuration option set to \"false\"
          by default to let <span class=\"title-ref\">faulthandler</span> interrupt
          the <span class=\"title-ref\">pytest</span> process after a timeout in case
          of deadlock.\n\n  Previously, a <span class=\"title-ref\">faulthandler</span>
          timeout would only dump the traceback of all threads to stderr, but would
          not interrupt the <span class=\"title-ref\">pytest</span> process.\n\n  \\--
          by `ogrisel`.\n\n- [#&#8203;13829](https://redirect.github.com/pytest-dev/pytest/issues/13829):
          Added support for configuration option aliases via the `aliases` parameter
          in `Parser.addini() <pytest.Parser.addini>`.\n\n  Plugins can now register
          alternative names for configuration options,\n  allowing for more flexibility
          in configuration naming and supporting backward compatibility when renaming
          options.\n  The canonical name always takes precedence if both the canonical
          name and an alias are specified in the configuration file.\n\n#### Improvements
          in existing functionality\n\n- [#&#8203;13330](https://redirect.github.com/pytest-dev/pytest/issues/13330):
          Having pytest configuration spread over more than one file (for example
          having both a `pytest.ini` file and `pyproject.toml` with a `[tool.pytest.ini_options]`
          table) will now print a warning to make it clearer to the user that only
          one of them is actually used.\n\n  \\-- by `sgaist`\n\n- [#&#8203;13574](https://redirect.github.com/pytest-dev/pytest/issues/13574):
          The single argument `--version` no longer loads the entire plugin infrastructure,
          making it faster and more reliable when displaying only the pytest version.\n\n
          \ Passing `--version` twice (e.g., `pytest --version --version`) retains
          the original behavior, showing both the pytest version and plugin information.\n\n
          \ > \\[!NOTE]\n  > Since `--version` is now processed early, it only takes
          effect when passed directly via the command line. It will not work if set
          through other mechanisms, such as `PYTEST_ADDOPTS` or `addopts`.\n\n- [#&#8203;13823](https://redirect.github.com/pytest-dev/pytest/issues/13823):
          Added `strict_xfail` as an alias to the `xfail_strict` option,\n  `strict_config`
          as an alias to the `--strict-config` flag,\n  and `strict_markers` as an
          alias to the `--strict-markers` flag.\n  This makes all strictness options
          consistently have configuration options with the prefix `strict_`.\n\n-
          [#&#8203;13700](https://redirect.github.com/pytest-dev/pytest/issues/13700):
          <span class=\"title-ref\">--junitxml</span> no longer prints the <span class=\"title-ref\">generated
          xml file</span> summary at the end of the pytest session when <span class=\"title-ref\">--quiet</span>
          is given.\n\n- [#&#8203;13732](https://redirect.github.com/pytest-dev/pytest/issues/13732):
          Previously, when filtering warnings, pytest would fail if the filter referenced
          a class that could not be imported. Now, this only outputs a message indicating
          the problem.\n\n- [#&#8203;13859](https://redirect.github.com/pytest-dev/pytest/issues/13859):
          Clarify the error message for <span class=\"title-ref\">pytest.raises()</span>
          when a regex <span class=\"title-ref\">match</span> fails.\n\n- [#&#8203;13861](https://redirect.github.com/pytest-dev/pytest/issues/13861):
          Better sentence structure in a test's expected error message. Previously,
          the error message would be \"expected exception must be \\<expected>, but
          got \\<actual>\". Now, it is \"Expected \\<expected>, but got \\<actual>\".\n\n####
          Removals and backward incompatible breaking changes\n\n- [#&#8203;12083](https://redirect.github.com/pytest-dev/pytest/issues/12083):
          Fixed a bug where an invocation such as <span class=\"title-ref\">pytest
          a/ a/b</span> would cause only tests from <span class=\"title-ref\">a/b</span>
          to run, and not other tests under <span class=\"title-ref\">a/</span>.\n\n
          \ The fix entails a few breaking changes to how such overlapping arguments
          and duplicates are handled:\n\n  1. <span class=\"title-ref\">pytest a/b
          a/</span> or <span class=\"title-ref\">pytest a/ a/b</span> are equivalent
          to <span class=\"title-ref\">pytest a</span>; if an argument overlaps another
          arguments, only the prefix remains.\n  2. <span class=\"title-ref\">pytest
          x.py x.py</span> is equivalent to <span class=\"title-ref\">pytest x.py</span>;
          previously such an invocation was taken as an explicit request to run the
          tests from the file twice.\n\n  If you rely on these behaviors, consider
          using `--keep-duplicates <duplicate-paths>`, which retains its existing
          behavior (including the bug).\n\n- [#&#8203;13719](https://redirect.github.com/pytest-dev/pytest/issues/13719):
          Support for Python 3.9 is dropped following its end of life.\n\n- [#&#8203;13766](https://redirect.github.com/pytest-dev/pytest/issues/13766):
          Previously, pytest would assume it was running in a CI/CD environment if
          either of the environment variables <span class=\"title-ref\">$CI</span>
          or <span class=\"title-ref\">$BUILD\\_NUMBER</span> was defined;\n  now,
          CI mode is only activated if at least one of those variables is defined
          and set to a *non-empty* value.\n\n- [#&#8203;13779](https://redirect.github.com/pytest-dev/pytest/issues/13779):
          **PytestRemovedIn9Warning deprecation warnings are now errors by default.**\n\n
          \ Following our plan to remove deprecated features with as little disruption
          as\n  possible, all warnings of type `PytestRemovedIn9Warning` now generate
          errors\n  instead of warning messages by default.\n\n  **The affected features
          will be effectively removed in pytest 9.1**, so please consult the\n  `deprecations`
          section in the docs for directions on how to update existing code.\n\n  In
          the pytest `9.0.X` series, it is possible to change the errors back into
          warnings as a\n  stopgap measure by adding this to your `pytest.ini` file:\n\n
          \ ```ini\n  [pytest]\n  filterwarnings =\n      ignore::pytest.PytestRemovedIn9Warning\n
          \ ```\n\n  But this will stop working when pytest `9.1` is released.\n\n
          \ **If you have concerns** about the removal of a specific feature, please
          add a\n  comment to `13779`.\n\n#### Deprecations (removal in next major
          release)\n\n- [#&#8203;13807](https://redirect.github.com/pytest-dev/pytest/issues/13807):
          `monkeypatch.syspath_prepend() <pytest.MonkeyPatch.syspath_prepend>` now
          issues a deprecation warning when the prepended path contains legacy namespace
          packages (those using `pkg_resources.declare_namespace()`).\n  Users should
          migrate to native namespace packages (`420`).\n  See `monkeypatch-fixup-namespace-packages`
          for details.\n\n#### Bug fixes\n\n- [#&#8203;13445](https://redirect.github.com/pytest-dev/pytest/issues/13445):
          Made the type annotations of `pytest.skip` and friends more spec-complaint
          to have them work across more type checkers.\n\n- [#&#8203;13537](https://redirect.github.com/pytest-dev/pytest/issues/13537):
          Fixed a bug in which `ExceptionGroup` with only `Skipped` exceptions in
          teardown was not handled correctly and showed as error.\n\n- [#&#8203;13598](https://redirect.github.com/pytest-dev/pytest/issues/13598):
          Fixed possible collection confusion on Windows when short paths and symlinks
          are involved.\n\n- [#&#8203;13716](https://redirect.github.com/pytest-dev/pytest/issues/13716):
          Fixed a bug where a nonsensical invocation like `pytest x.py[a]` (a file
          cannot be parametrized) was silently treated as `pytest x.py`. This is now
          a usage error.\n\n- [#&#8203;13722](https://redirect.github.com/pytest-dev/pytest/issues/13722):
          Fixed a misleading assertion failure message when using `pytest.approx`
          on mappings with differing lengths.\n\n- [#&#8203;13773](https://redirect.github.com/pytest-dev/pytest/issues/13773):
          Fixed the static fixture closure calculation to properly consider transitive
          dependencies requested by overridden fixtures.\n\n- [#&#8203;13816](https://redirect.github.com/pytest-dev/pytest/issues/13816):
          Fixed `pytest.approx` which now returns a clearer error message when comparing
          mappings with different keys.\n\n- [#&#8203;13849](https://redirect.github.com/pytest-dev/pytest/issues/13849):
          Hidden `.pytest.ini` files are now picked up as the config file even if
          empty.\n  This was an inconsistency with non-hidden `pytest.ini`.\n\n- [#&#8203;13865](https://redirect.github.com/pytest-dev/pytest/issues/13865):
          Fixed <span class=\"title-ref\">--show-capture</span> with <span class=\"title-ref\">--tb=line</span>.\n\n-
          [#&#8203;13522](https://redirect.github.com/pytest-dev/pytest/issues/13522):
          Fixed `pytester` in subprocess mode ignored all :attr\\`pytester.plugins
          \\<pytest.Pytester.plugins>\\` except the first.\n\n  Fixed `pytester` in
          subprocess mode silently ignored non-str `pytester.plugins <pytest.Pytester.plugins>`.\n
          \ Now it errors instead.\n  If you are affected by this, specify the plugin
          by name, or switch the affected tests to use `pytester.runpytest_inprocess
          <pytest.Pytester.runpytest_inprocess>` explicitly instead.\n\n#### Packaging
          updates and notes for downstreams\n\n- [#&#8203;13791](https://redirect.github.com/pytest-dev/pytest/issues/13791):
          Minimum requirements on `iniconfig` and `packaging` were bumped to `1.0.1`
          and `22.0.0`, respectively.\n\n#### Contributor-facing changes\n\n- [#&#8203;12244](https://redirect.github.com/pytest-dev/pytest/issues/12244):
          Fixed self-test failures when <span class=\"title-ref\">TERM=dumb</span>.\n-
          [#&#8203;12474](https://redirect.github.com/pytest-dev/pytest/issues/12474):
          Added scheduled GitHub Action Workflow to run Sphinx linkchecks in repo
          documentation.\n- [#&#8203;13621](https://redirect.github.com/pytest-dev/pytest/issues/13621):
          pytest's own testsuite now handles the `lsof` command hanging (e.g. due
          to unreachable network filesystems), with the affected selftests being skipped
          after 10 seconds.\n- [#&#8203;13638](https://redirect.github.com/pytest-dev/pytest/issues/13638):
          Fixed deprecated `gh pr new` command in `scripts/prepare-release-pr.py`.\n
          \ The script now uses `gh pr create` which is compatible with GitHub CLI
          v2.0+.\n- [#&#8203;13695](https://redirect.github.com/pytest-dev/pytest/issues/13695):
          Flush <span class=\"title-ref\">stdout</span> and <span class=\"title-ref\">stderr</span>
          in <span class=\"title-ref\">Pytester.run</span> to avoid truncated outputs
          in <span class=\"title-ref\">test\\_faulthandler.py::test\\_timeout</span>
          on CI -- by `ogrisel`.\n- [#&#8203;13771](https://redirect.github.com/pytest-dev/pytest/issues/13771):
          Skip <span class=\"title-ref\">test\\_do\\_not\\_collect\\_symlink\\_siblings</span>
          on Windows environments without symlink support to avoid false negatives.\n-
          [#&#8203;13841](https://redirect.github.com/pytest-dev/pytest/issues/13841):
          `tox>=4` is now required when contributing to pytest.\n- [#&#8203;13625](https://redirect.github.com/pytest-dev/pytest/issues/13625):
          Added missing docstrings to `pytest_addoption()`, `pytest_configure()`,
          and `cacheshow()` functions in `cacheprovider.py`.\n\n#### Miscellaneous
          internal changes\n\n- [#&#8203;13830](https://redirect.github.com/pytest-dev/pytest/issues/13830):
          Configuration overrides (`-o`/`--override-ini`) are now processed during
          startup rather than during `config.getini() <pytest.Config.getini>`.\n\n###
          [`v8.4.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.4.2)\n\n[Compare
          Source](https://redirect.github.com/pytest-dev/pytest/compare/8.4.1...8.4.2)\n\n###
          pytest 8.4.2 (2025-09-03)\n\n#### Bug fixes\n\n- [#&#8203;13478](https://redirect.github.com/pytest-dev/pytest/issues/13478):
          Fixed a crash when using `console_output_style`{.interpreted-text role=\"confval\"}
          with `times` and a module is skipped.\n\n- [#&#8203;13530](https://redirect.github.com/pytest-dev/pytest/issues/13530):
          Fixed a crash when using `pytest.approx`{.interpreted-text role=\"func\"}
          and `decimal.Decimal`{.interpreted-text role=\"class\"} instances with the
          `decimal.FloatOperation`{.interpreted-text role=\"class\"} trap set.\n\n-
          [#&#8203;13549](https://redirect.github.com/pytest-dev/pytest/issues/13549):
          No longer evaluate type annotations in Python `3.14` when inspecting function
          signatures.\n\n  This prevents crashes during module collection when modules
          do not explicitly use `from __future__ import annotations` and import types
          for annotations within a `if TYPE_CHECKING:` block.\n\n- [#&#8203;13559](https://redirect.github.com/pytest-dev/pytest/issues/13559):
          Added missing \\[int]{.title-ref} and \\[float]{.title-ref} variants to
          the \\[Literal]{.title-ref} type annotation of the \\[type]{.title-ref}
          parameter in `pytest.Parser.addini`{.interpreted-text role=\"meth\"}.\n\n-
          [#&#8203;13563](https://redirect.github.com/pytest-dev/pytest/issues/13563):
          `pytest.approx`{.interpreted-text role=\"func\"} now only imports `numpy`
          if NumPy is already in `sys.modules`. This fixes unconditional import behavior
          introduced in \\[8.4.0]{.title-ref}.\n\n#### Improved documentation\n\n-
          [#&#8203;13577](https://redirect.github.com/pytest-dev/pytest/issues/13577):
          Clarify that `pytest_generate_tests` is discovered in test modules/classes;
          other hooks must be in `conftest.py` or plugins.\n\n#### Contributor-facing
          changes\n\n- [#&#8203;13480](https://redirect.github.com/pytest-dev/pytest/issues/13480):
          Self-testing: fixed a few test failures when run with `-Wdefault` or a similar
          override.\n- [#&#8203;13547](https://redirect.github.com/pytest-dev/pytest/issues/13547):
          Self-testing: corrected expected message for `test_doctest_unexpected_exception`
          in Python `3.14`.\n- [#&#8203;13684](https://redirect.github.com/pytest-dev/pytest/issues/13684):
          Make pytest's own testsuite insensitive to the presence of the `CI` environment
          variable -- by `ogrisel`{.interpreted-text role=\"user\"}.\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: (UTC)\n\n- Branch creation\n  -
          \"\"\n- Automerge\n  - At any time (no schedule defined)\n\n\U0001F6A6 **Automerge**:
          Disabled by config. Please merge this manually once you are satisfied.\n\n\u267B
          **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry
          checkbox.\n\n\U0001F515 **Ignore**: Close this PR and you won't be reminded
          about this update again.\n\n---\n\n - [ ] <!-- rebase-check -->If you want
          to rebase/retry this PR, check this box\n\n---\n\nThis PR was generated
          by [Mend Renovate](https://mend.io/renovate/). View the [repository job
          log](https://developer.mend.io/github/vexxhost/ansible-collection-containers).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMTAuMiIsInVwZGF0ZWRJblZlciI6IjQzLjExMC4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->\n"
        change_url: https://github.com/vexxhost/ansible-collection-containers/pull/110
        commit_id: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        patchset: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-containers
          name: vexxhost/ansible-collection-containers
          short_name: ansible-collection-containers
          src_dir: src/github.com/vexxhost/ansible-collection-containers
        topic: null
      job: ansible-collection-containers-molecule-forget-package-debian-trixie
      jobtags: []
      max_attempts: 3
      message: Y2hvcmUoZGVwcyk6IHVwZGF0ZSBkZXBlbmRlbmN5IHB5dGVzdCB0byB2OSBbc2VjdXJpdHldCgpUaGlzIFBSIGNvbnRhaW5zIHRoZSBmb2xsb3dpbmcgdXBkYXRlczoKCnwgUGFja2FnZSB8IENoYW5nZSB8IFtBZ2VdKGh0dHBzOi8vZG9jcy5yZW5vdmF0ZWJvdC5jb20vbWVyZ2UtY29uZmlkZW5jZS8pIHwgW0NvbmZpZGVuY2VdKGh0dHBzOi8vZG9jcy5yZW5vdmF0ZWJvdC5jb20vbWVyZ2UtY29uZmlkZW5jZS8pIHwKfC0tLXwtLS18LS0tfC0tLXwKfCBbcHl0ZXN0XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QpIChbY2hhbmdlbG9nXShodHRwczovL2RvY3MucHl0ZXN0Lm9yZy9lbi9zdGFibGUvY2hhbmdlbG9nLmh0bWwpKSB8IGA4LjQuMWAg4oaSIGA5LjAuM2AgfCAhW2FnZV0oaHR0cHM6Ly9kZXZlbG9wZXIubWVuZC5pby9hcGkvbWMvYmFkZ2VzL2FnZS9weXBpL3B5dGVzdC85LjAuMz9zbGltPXRydWUpIHwgIVtjb25maWRlbmNlXShodHRwczovL2RldmVsb3Blci5tZW5kLmlvL2FwaS9tYy9iYWRnZXMvY29uZmlkZW5jZS9weXBpL3B5dGVzdC84LjQuMS85LjAuMz9zbGltPXRydWUpIHwKCiMjIyBHaXRIdWIgVnVsbmVyYWJpbGl0eSBBbGVydHMKCiMjIyMgW0NWRS0yMDI1LTcxMTc2XShodHRwczovL252ZC5uaXN0Lmdvdi92dWxuL2RldGFpbC9DVkUtMjAyNS03MTE3NikKCnB5dGVzdCB0aHJvdWdoIDkuMC4yIG9uIFVOSVggcmVsaWVzIG9uIGRpcmVjdG9yaWVzIHdpdGggdGhlIGAvdG1wL3B5dGVzdC1vZi17dXNlcn1gIG5hbWUgcGF0dGVybiwgd2hpY2ggYWxsb3dzIGxvY2FsIHVzZXJzIHRvIGNhdXNlIGEgZGVuaWFsIG9mIHNlcnZpY2Ugb3IgcG9zc2libHkgZ2FpbiBwcml2aWxlZ2VzLgoKLS0tCgojIyMgUmVsZWFzZSBOb3RlcwoKPGRldGFpbHM+CjxzdW1tYXJ5PnB5dGVzdC1kZXYvcHl0ZXN0IChweXRlc3QpPC9zdW1tYXJ5PgoKIyMjIFtgdjkuMC4zYF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L3JlbGVhc2VzL3RhZy85LjAuMykKCltDb21wYXJlIFNvdXJjZV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2NvbXBhcmUvOS4wLjIuLi45LjAuMykKCiMjIyBweXRlc3QgOS4wLjMgKDIwMjYtMDQtMDcpCgojIyMjIEJ1ZyBmaXhlcwoKLSBbIyYjODIwMzsxMjQ0NF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMjQ0NCk6IEZpeGVkIGBweXRlc3QuYXBwcm94YCB3aGljaCBub3cgY29ycmVjdGx5IHRha2VzIGludG8gYWNjb3VudCBgfmNvbGxlY3Rpb25zLmFiYy5NYXBwaW5nYCBrZXlzIG9yZGVyIHRvIGNvbXBhcmUgdGhlbS4KCi0gWyMmIzgyMDM7MTM2MzRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM2MzQpOiBCbG9ja2luZyBhIGBjb25mdGVzdC5weWAgZmlsZSB1c2luZyB0aGUgYC1wIG5vOmAgb3B0aW9uIGlzIG5vdyBleHBsaWNpdGx5IGRpc2FsbG93ZWQuCgogIFByZXZpb3VzbHkgdGhpcyByZXN1bHRlZCBpbiBhbiBpbnRlcm5hbCBhc3NlcnRpb24gZmFpbHVyZSBkdXJpbmcgcGx1Z2luIGxvYWRpbmcuCgogIFB5dGVzdCBub3cgcmFpc2VzIGEgY2xlYXIgYFVzYWdlRXJyb3JgIGV4cGxhaW5pbmcgdGhhdCBjb25mdGVzdCBmaWxlcyBhcmUgbm90IHBsdWdpbnMgYW5kIGNhbm5vdCBiZSBkaXNhYmxlZCB2aWEgYC1wYC4KCi0gWyMmIzgyMDM7MTM3MzRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3MzQpOiBGaXhlZCBjcmFzaCB3aGVuIGEgdGVzdCByYWlzZXMgYW4gZXhjZXB0aW9uZ3JvdXAgd2l0aCBgX190cmFjZWJhY2toaWRlX18gPSBUcnVlYC4KCi0gWyMmIzgyMDM7MTQxOTVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTQxOTUpOiBGaXhlZCBhbiBpc3N1ZSB3aGVyZSBub24tc3RyaW5nIG1lc3NhZ2VzIHBhc3NlZCB0byA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj51bml0dGVzdC5UZXN0Q2FzZS5zdWJUZXN0KCk8L3NwYW4+IHdlcmUgbm90IHByaW50ZWQuCgotIFsjJiM4MjAzOzE0MzQzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzE0MzQzKTogRml4ZWQgdXNlIG9mIGluc2VjdXJlIHRlbXBvcmFyeSBkaXJlY3RvcnkgKENWRS0yMDI1LTcxMTc2KS4KCiMjIyMgSW1wcm92ZWQgZG9jdW1lbnRhdGlvbgoKLSBbIyYjODIwMzsxMzM4OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzM4OCk6IENsYXJpZmllZCBkb2N1bWVudGF0aW9uIGZvciBgLXBgIHZzIGBQWVRFU1RfUExVR0lOU2AgcGx1Z2luIGxvYWRpbmcgYW5kIGZpeGVkIGFuIGluY29ycmVjdCBgLXBgIGV4YW1wbGUuCi0gWyMmIzgyMDM7MTM3MzFdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3MzEpOiBDbGFyaWZpZWQgdGhhdCBjYXB0dXJlIGZpeHR1cmVzIChlLmcuIGBjYXBzeXNgIGFuZCBgY2FwZmRgKSB0YWtlIHByZWNlZGVuY2Ugb3ZlciB0aGUgYC1zYCAvIGAtLWNhcHR1cmU9bm9gIGNvbW1hbmQtbGluZSBvcHRpb25zIGluIGBBY2Nlc3NpbmcgY2FwdHVyZWQgb3V0cHV0IGZyb20gYSB0ZXN0IGZ1bmN0aW9uIDxhY2Nlc3NpbmctY2FwdHVyZWQtb3V0cHV0PmAuCi0gWyMmIzgyMDM7MTQwODhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTQwODgpOiBDbGFyaWZpZWQgdGhhdCB0aGUgZGVmYXVsdCBgcHl0ZXN0X2NvbGxlY3Rpb25gIGhvb2sgc2V0cyBgc2Vzc2lvbi5pdGVtc2AgYmVmb3JlIGl0IGNhbGxzIGBweXRlc3RfY29sbGVjdGlvbl9maW5pc2hgLCBub3QgYWZ0ZXIuCi0gWyMmIzgyMDM7MTQyNTVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTQyNTUpOiBUT01MIGludGVnZXIgbG9nIGxldmVscyBtdXN0IGJlIHF1b3RlZDogVXBkYXRpbmcgcmVmZXJlbmNlIGRvY3VtZW50YXRpb24uCgojIyMjIENvbnRyaWJ1dG9yLWZhY2luZyBjaGFuZ2VzCgotIFsjJiM4MjAzOzEyNjg5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEyNjg5KTogVGhlIHRlc3QgcmVwb3J0cyBhcmUgbm93IHB1Ymxpc2hlZCB0byBDb2RlY292IGZyb20gR2l0SHViIEFjdGlvbnMuCiAgVGhlIHRlc3Qgc3RhdGlzdGljcyBpcyB2aXNpYmxlIFtvbiB0aGUgd2ViIGludGVyZmFjZV0oaHR0cHM6Ly9hcHAuY29kZWNvdi5pby9naC9weXRlc3QtZGV2L3B5dGVzdC90ZXN0cykuCgogIFwtLSBieSBgYWxlZ3V5MDJgCgojIyMgW2B2OS4wLjJgXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvcmVsZWFzZXMvdGFnLzkuMC4yKQoKW0NvbXBhcmUgU291cmNlXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvY29tcGFyZS85LjAuMS4uLjkuMC4yKQoKIyMjIHB5dGVzdCA5LjAuMiAoMjAyNS0xMi0wNikKCiMjIyMgQnVnIGZpeGVzCgotIFsjJiM4MjAzOzEzODk2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODk2KTogVGhlIHRlcm1pbmFsIHByb2dyZXNzIGZlYXR1cmUgYWRkZWQgaW4gcHl0ZXN0IDkuMC4wIGhhcyBiZWVuIGRpc2FibGVkIGJ5IGRlZmF1bHQsIGV4Y2VwdCBvbiBXaW5kb3dzLCBkdWUgdG8gY29tcGF0aWJpbGl0eSBpc3N1ZXMgd2l0aCBzb21lIHRlcm1pbmFsIGVtdWxhdG9ycy4KCiAgWW91IG1heSBlbmFibGUgaXQgYWdhaW4gYnkgcGFzc2luZyBgLXAgdGVybWluYWxwcm9ncmVzc2AuIFdlIG1heSBlbmFibGUgaXQgYnkgZGVmYXVsdCBhZ2FpbiBvbmNlIGNvbXBhdGliaWxpdHkgaW1wcm92ZXMgaW4gdGhlIGZ1dHVyZS4KCiAgQWRkaXRpb25hbGx5LCB3aGVuIHRoZSBlbnZpcm9ubWVudCB2YXJpYWJsZSBgVEVSTWAgaXMgYGR1bWJgLCB0aGUgZXNjYXBlIGNvZGVzIGFyZSBubyBsb25nZXIgZW1pdHRlZCwgZXZlbiBpZiB0aGUgcGx1Z2luIGlzIGVuYWJsZWQuCgotIFsjJiM4MjAzOzEzOTA0XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzOTA0KTogRml4ZWQgdGhlIFRPTUwgdHlwZSBvZiB0aGUgYHRtcF9wYXRoX3JldGVudGlvbl9jb3VudGAgc2V0dGluZ3MgaW4gdGhlIEFQSSByZWZlcmVuY2UgZnJvbSBudW1iZXIgdG8gc3RyaW5nLgoKLSBbIyYjODIwMzsxMzk0Nl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzk0Nik6IFRoZSBwcml2YXRlIGBjb25maWcuaW5pY2ZnYCBhdHRyaWJ1dGUgd2FzIGNoYW5nZWQgaW4gYSBicmVha2luZyBtYW5uZXIgaW4gcHl0ZXN0IDkuMC4wLgogIER1ZSB0byBpdHMgdXNhZ2UgaW4gdGhlIGVjb3N5c3RlbSwgaXQgaXMgbm93IHJlc3RvcmVkIHRvIHdvcmtpbmcgb3JkZXIgdXNpbmcgYSBjb21wYXRpYmlsaXR5IHNoaW0uCiAgSXQgd2lsbCBiZSBkZXByZWNhdGVkIGluIHB5dGVzdCA5LjEgYW5kIHJlbW92ZWQgaW4gcHl0ZXN0IDEwLgoKLSBbIyYjODIwMzsxMzk2NV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzk2NSk6IEZpeGVkIHF1YWRyYXRpYy10aW1lIGJlaGF2aW9yIHdoZW4gaGFuZGxpbmcgYHVuaXR0ZXN0YCBzdWJ0ZXN0cyBpbiBQeXRob24gMy4xMC4KCiMjIyMgSW1wcm92ZWQgZG9jdW1lbnRhdGlvbgoKLSBbIyYjODIwMzs0NDkyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzQ0OTIpOiBUaGUgQVBJIFJlZmVyZW5jZSBub3cgY29udGFpbnMgY3Jvc3MtcmVmZXJlbmNlLWFibGUgZG9jdW1lbnRhdGlvbiBvZiBgcHl0ZXN0J3MgY29tbWFuZC1saW5lIGZsYWdzIDxjb21tYW5kLWxpbmUtZmxhZ3M+YC4KCiMjIyBbYHY5LjAuMWBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9yZWxlYXNlcy90YWcvOS4wLjEpCgpbQ29tcGFyZSBTb3VyY2VdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9jb21wYXJlLzkuMC4wLi4uOS4wLjEpCgojIyMgcHl0ZXN0IDkuMC4xICgyMDI1LTExLTEyKQoKIyMjIyBCdWcgZml4ZXMKCi0gWyMmIzgyMDM7MTM4OTVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM4OTUpOiBSZXN0b3JlIHN1cHBvcnQgZm9yIHNraXBwaW5nIHRlc3RzIHZpYSBgcmFpc2UgdW5pdHRlc3QuU2tpcFRlc3RgLgotIFsjJiM4MjAzOzEzODk2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODk2KTogVGhlIHRlcm1pbmFsIHByb2dyZXNzIHBsdWdpbiBhZGRlZCBpbiBweXRlc3QgOS4wIGlzIG5vdyBhdXRvbWF0aWNhbGx5IGRpc2FibGVkIHdoZW4gaVRlcm0yIGlzIGRldGVjdGVkLCBpdCBnZW5lcmF0ZWQgZGVza3RvcCBub3RpZmljYXRpb25zIGluc3RlYWQgb2YgdGhlIGRlc2lyZWQgZnVuY3Rpb25hbGl0eS4KLSBbIyYjODIwMzsxMzkwNF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzkwNCk6IEZpeGVkIHRoZSBUT01MIHR5cGUgb2YgdGhlIHZlcmJvc2l0eSBzZXR0aW5ncyBpbiB0aGUgQVBJIHJlZmVyZW5jZSBmcm9tIG51bWJlciB0byBzdHJpbmcuCi0gWyMmIzgyMDM7MTM5MTBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM5MTApOiBGaXhlZCA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5Vc2VyV2FybmluZzogRG8gbm90IGV4cGVjdCBmaWxlXF9vclxfZGlyPC9zcGFuPiBvbiBzb21lIGVhcmxpZXIgUHl0aG9uIDMuMTIgYW5kIDMuMTMgcG9pbnQgdmVyc2lvbnMuCgojIyMjIFBhY2thZ2luZyB1cGRhdGVzIGFuZCBub3RlcyBmb3IgZG93bnN0cmVhbXMKCi0gWyMmIzgyMDM7MTM5MzNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM5MzMpOiBUaGUgdG94IGNvbmZpZ3VyYXRpb24gaGFzIGJlZW4gYWRqdXN0ZWQgdG8gbWFrZSBzdXJlIHRoZSBkZXNpcmVkCiAgdmVyc2lvbiBzdHJpbmcgY2FuIGJlIHBhc3NlZCBpbnRvIGl0cyBgcGFja2FnZV9lbnZgIHRocm91Z2gKICB0aGUgYFNFVFVQVE9PTFNfU0NNX1BSRVRFTkRfVkVSU0lPTl9GT1JfUFlURVNUYCBlbnZpcm9ubWVudAogIHZhcmlhYmxlIGFzIGEgcGFydCBvZiB0aGUgcmVsZWFzZSBwcm9jZXNzIC0tIGJ5IGB3ZWJrbmphemAuCgojIyMjIENvbnRyaWJ1dG9yLWZhY2luZyBjaGFuZ2VzCgotIFsjJiM4MjAzOzEzODkxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODkxKSwgWyMmIzgyMDM7MTM5NDJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM5NDIpOiBUaGUgQ0kvQ0QgcGFydCBvZiB0aGUgcmVsZWFzZSBhdXRvbWF0aW9uIGlzIG5vdyBjYXBhYmxlIG9mCiAgY3JlYXRpbmcgR2l0SHViIFJlbGVhc2VzIHdpdGhvdXQgaGF2aW5nIGEgR2l0IGNoZWNrb3V0IG9uCiAgZGlzayAtLSBieSBgYmx1ZXRlY2hgIGFuZCBgd2Via25qYXpgLgotIFsjJiM4MjAzOzEzOTMzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzOTMzKTogVGhlIHRveCBjb25maWd1cmF0aW9uIGhhcyBiZWVuIGFkanVzdGVkIHRvIG1ha2Ugc3VyZSB0aGUgZGVzaXJlZAogIHZlcnNpb24gc3RyaW5nIGNhbiBiZSBwYXNzZWQgaW50byBpdHMgYHBhY2thZ2VfZW52YCB0aHJvdWdoCiAgdGhlIGBTRVRVUFRPT0xTX1NDTV9QUkVURU5EX1ZFUlNJT05fRk9SX1BZVEVTVGAgZW52aXJvbm1lbnQKICB2YXJpYWJsZSBhcyBhIHBhcnQgb2YgdGhlIHJlbGVhc2UgcHJvY2VzcyAtLSBieSBgd2Via25qYXpgLgoKIyMjIFtgdjkuMC4wYF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L3JlbGVhc2VzL3RhZy85LjAuMCkKCltDb21wYXJlIFNvdXJjZV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2NvbXBhcmUvOC40LjIuLi45LjAuMCkKCiMjIyBweXRlc3QgOS4wLjAgKDIwMjUtMTEtMDUpCgojIyMjIE5ldyBmZWF0dXJlcwoKLSBbIyYjODIwMzsxMzY3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNjcpOiAqKlN1cHBvcnQgZm9yIHN1YnRlc3RzKiogaGFzIGJlZW4gYWRkZWQuCgogIGBzdWJ0ZXN0cyA8c3VidGVzdHM+YCBhcmUgYW4gYWx0ZXJuYXRpdmUgdG8gcGFyYW1ldHJpemF0aW9uLCB1c2VmdWwgaW4gc2l0dWF0aW9ucyB3aGVyZSB0aGUgcGFyYW1ldHJpemF0aW9uIHZhbHVlcyBhcmUgbm90IGFsbCBrbm93biBhdCBjb2xsZWN0aW9uIHRpbWUuCgogIEV4YW1wbGU6CgogIGBgYHB5dGhvbgogIGRlZiBjb250YWluc19kb2NzdHJpbmcocDogUGF0aCkgLT4gYm9vbDoKICAgICAgIiIiUmV0dXJuIFRydWUgaWYgdGhlIGdpdmVuIFB5dGhvbiBmaWxlIGNvbnRhaW5zIGEgdG9wLWxldmVsIGRvY3N0cmluZy4iIiIKICAgICAgLi4uCgogIGRlZiB0ZXN0X3B5X2ZpbGVzX2NvbnRhaW5fZG9jc3RyaW5nKHN1YnRlc3RzOiBweXRlc3QuU3VidGVzdHMpIC0+IE5vbmU6CiAgICAgIGZvciBwYXRoIGluIFBhdGguY3dkKCkuZ2xvYigiKi5weSIpOgogICAgICAgICAgd2l0aCBzdWJ0ZXN0cy50ZXN0KHBhdGg9c3RyKHBhdGgpKToKICAgICAgICAgICAgICBhc3NlcnQgY29udGFpbnNfZG9jc3RyaW5nKHBhdGgpCiAgYGBgCgogIEVhY2ggYXNzZXJ0IGZhaWx1cmUgb3IgZXJyb3IgaXMgY2F1Z2h0IGJ5IHRoZSBjb250ZXh0IG1hbmFnZXIgYW5kIHJlcG9ydGVkIGluZGl2aWR1YWxseSwgZ2l2aW5nIGEgY2xlYXIgcGljdHVyZSBvZiBhbGwgZmlsZXMgdGhhdCBhcmUgbWlzc2luZyBhIGRvY3N0cmluZy4KCiAgSW4gYWRkaXRpb24sIGB1bml0dGVzdC5UZXN0Q2FzZS5zdWJUZXN0YCBpcyBub3cgYWxzbyBzdXBwb3J0ZWQuCgogIFRoaXMgZmVhdHVyZSB3YXMgb3JpZ2luYWxseSBpbXBsZW1lbnRlZCBhcyBhIHNlcGFyYXRlIHBsdWdpbiBpbiBbcHl0ZXN0LXN1YnRlc3RzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3Qtc3VidGVzdHMpLCBidXQgc2luY2UgdGhlbiBoYXMgYmVlbiBtZXJnZWQgaW50byB0aGUgY29yZS4KCiAgPiBcWyFOT1RFXQogID4gVGhpcyBmZWF0dXJlIGlzIGV4cGVyaW1lbnRhbCBhbmQgd2lsbCBsaWtlbHkgZXZvbHZlIGluIGZ1dHVyZSByZWxlYXNlcy4gQnkgdGhhdCB3ZSBtZWFuIHRoYXQgd2UgbWlnaHQgY2hhbmdlIGhvdyBzdWJ0ZXN0cyBhcmUgcmVwb3J0ZWQgb24gZmFpbHVyZSwgYnV0IHRoZSBmdW5jdGlvbmFsaXR5IGFuZCBob3cgdG8gdXNlIGl0IGFyZSBzdGFibGUuCgotIFsjJiM4MjAzOzEzNzQzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNzQzKTogQWRkZWQgc3VwcG9ydCBmb3IgKipuYXRpdmUgVE9NTCBjb25maWd1cmF0aW9uIGZpbGVzKiouCgogIFdoaWxlIHB5dGVzdCwgc2luY2UgdmVyc2lvbiA2LCBzdXBwb3J0cyBjb25maWd1cmF0aW9uIGluIGBweXByb2plY3QudG9tbGAgZmlsZXMgdW5kZXIgYFt0b29sLnB5dGVzdC5pbmlfb3B0aW9uc11gLAogIGl0IGRvZXMgc28gaW4gYW4gIklOSSBjb21wYXRpYmlsaXR5IG1vZGUiLCB3aGVyZSBhbGwgY29uZmlndXJhdGlvbiB2YWx1ZXMgYXJlIHRyZWF0ZWQgYXMgc3RyaW5ncyBvciBsaXN0IG9mIHN0cmluZ3MuCiAgTm93LCBweXRlc3Qgc3VwcG9ydHMgdGhlIG5hdGl2ZSBUT01MIGRhdGEgbW9kZWwuCgogIEluIGBweXByb2plY3QudG9tbGAsIHRoZSBuYXRpdmUgVE9NTCBjb25maWd1cmF0aW9uIGlzIHVuZGVyIHRoZSBgW3Rvb2wucHl0ZXN0XWAgdGFibGUuCgogIGBgYHRvbWwKICAjIHB5cHJvamVjdC50b21sCiAgW3Rvb2wucHl0ZXN0XQogIG1pbnZlcnNpb24gPSAiOS4wIgogIGFkZG9wdHMgPSBbIi1yYSIsICItcSJdCiAgdGVzdHBhdGhzID0gWwogICAgICAidGVzdHMiLAogICAgICAiaW50ZWdyYXRpb24iLAogIF0KICBgYGAKCiAgVGhlIGBbdG9vbC5weXRlc3QuaW5pX29wdGlvbnNdYCB0YWJsZSByZW1haW5zIHN1cHBvcnRlZCwgYnV0IGJvdGggdGFibGVzIGNhbm5vdCBiZSB1c2VkIGF0IHRoZSBzYW1lIHRpbWUuCgogIElmIHlvdSBwcmVmZXIgdG8gdXNlIGEgc2VwYXJhdGUgY29uZmlndXJhdGlvbiBmaWxlLCBvciBkb24ndCB1c2UgYHB5cHJvamVjdC50b21sYCwgeW91IGNhbiB1c2UgYHB5dGVzdC50b21sYCBvciBgLnB5dGVzdC50b21sYDoKCiAgYGBgdG9tbAogICMgcHl0ZXN0LnRvbWwgb3IgLnB5dGVzdC50b21sCiAgW3B5dGVzdF0KICBtaW52ZXJzaW9uID0gIjkuMCIKICBhZGRvcHRzID0gWyItcmEiLCAiLXEiXQogIHRlc3RwYXRocyA9IFsKICAgICAgInRlc3RzIiwKICAgICAgImludGVncmF0aW9uIiwKICBdCiAgYGBgCgogIFRoZSBkb2N1bWVudGF0aW9uIG5vdyAoc29tZXRpbWVzKSBzaG93cyBjb25maWd1cmF0aW9uIHNuaXBwZXRzIGluIGJvdGggVE9NTCBhbmQgSU5JIGZvcm1hdHMsIGluIGEgdGFiYmVkIGludGVyZmFjZS4KCiAgU2VlIGBjb25maWcgZmlsZSBmb3JtYXRzYCBmb3IgZnVsbCBkZXRhaWxzLgoKLSBbIyYjODIwMzsxMzgyM10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzgyMyk6IEFkZGVkIGEgKioic3RyaWN0IG1vZGUiKiogZW5hYmxlZCBieSB0aGUgYHN0cmljdGAgY29uZmlndXJhdGlvbiBvcHRpb24uCgogIFdoZW4gc2V0IHRvIGB0cnVlYCwgdGhlIGBzdHJpY3RgIG9wdGlvbiBjdXJyZW50bHkgZW5hYmxlcwoKICAtIGBzdHJpY3RfY29uZmlnYAogIC0gYHN0cmljdF9tYXJrZXJzYAogIC0gYHN0cmljdF9wYXJhbWV0cml6YXRpb25faWRzYAogIC0gYHN0cmljdF94ZmFpbGAKCiAgVGhlIGluZGl2aWR1YWwgc3RyaWN0bmVzcyBvcHRpb25zIGNhbiBiZSBleHBsaWNpdGx5IHNldCB0byBvdmVycmlkZSB0aGUgZ2xvYmFsIGBzdHJpY3RgIHNldHRpbmcuCgogIFRoZSBwcmV2aW91c2x5LWRlcHJlY2F0ZWQgYC0tc3RyaWN0YCBjb21tYW5kLWxpbmUgZmxhZyBub3cgZW5hYmxlcyBzdHJpY3QgbW9kZS4KCiAgSWYgcHl0ZXN0IGFkZHMgbmV3IHN0cmljdG5lc3Mgb3B0aW9ucyBpbiB0aGUgZnV0dXJlLCB0aGV5IHdpbGwgYWxzbyBiZSBlbmFibGVkIGluIHN0cmljdCBtb2RlLgogIFRoZXJlZm9yZSwgeW91IHNob3VsZCBvbmx5IGVuYWJsZSBzdHJpY3QgbW9kZSBpZiB5b3UgdXNlIGEgcGlubmVkL2xvY2tlZCB2ZXJzaW9uIG9mIHB5dGVzdCwKICBvciBpZiB5b3Ugd2FudCB0byBwcm9hY3RpdmVseSBhZG9wdCBuZXcgc3RyaWN0bmVzcyBvcHRpb25zIGFzIHRoZXkgYXJlIGFkZGVkLgoKICBTZWUgYHN0cmljdCBtb2RlYCBmb3IgbW9yZSBkZXRhaWxzLgoKLSBbIyYjODIwMzsxMzczN10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzczNyk6IEFkZGVkIHRoZSBgc3RyaWN0X3BhcmFtZXRyaXphdGlvbl9pZHNgIGNvbmZpZ3VyYXRpb24gb3B0aW9uLgoKICBXaGVuIHNldCwgcHl0ZXN0IGVtaXRzIGFuIGVycm9yIGlmIGl0IGRldGVjdHMgbm9uLXVuaXF1ZSBwYXJhbWV0ZXIgc2V0IElEcywKICByYXRoZXIgdGhhbiBhdXRvbWF0aWNhbGx5IG1ha2luZyB0aGUgSURzIHVuaXF1ZSBieSBhZGRpbmcgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+MDwvc3Bhbj4sIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPjE8L3NwYW4+LCAuLi4gdG8gdGhlbS4KICBUaGlzIGNhbiBiZSBwYXJ0aWN1bGFybHkgdXNlZnVsIGZvciBjYXRjaGluZyB1bmludGVuZGVkIGR1cGxpY2F0ZXMuCgotIFsjJiM4MjAzOzEzMDcyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzMDcyKTogQWRkZWQgc3VwcG9ydCBmb3IgZGlzcGxheWluZyB0ZXN0IHNlc3Npb24gKipwcm9ncmVzcyBpbiB0aGUgdGVybWluYWwgdGFiKiogdXNpbmcgdGhlIFtPU0MgOTs0O10oaHR0cHM6Ly9jb25lbXUuZ2l0aHViLmlvL2VuL0Fuc2lFc2NhcGVDb2Rlcy5odG1sI0NvbkVtdV9zcGVjaWZpY19PU0MpIEFOU0kgc2VxdWVuY2UuCiAgV2hlbiBweXRlc3QgcnVucyBpbiBhIHN1cHBvcnRlZCB0ZXJtaW5hbCBlbXVsYXRvciBsaWtlIENvbkVtdSwgR25vbWUgVGVybWluYWwsIFB0eXhpcywgV2luZG93cyBUZXJtaW5hbCwgS2l0dHkgb3IgR2hvc3R0eSwKICB5b3UnbGwgc2VlIHRoZSBwcm9ncmVzcyBpbiB0aGUgdGVybWluYWwgdGFiIG9yIHdpbmRvdywKICBhbGxvd2luZyB5b3UgdG8gbW9uaXRvciBweXRlc3QncyBwcm9ncmVzcyBhdCBhIGdsYW5jZS4KCiAgVGhpcyBmZWF0dXJlIGlzIGF1dG9tYXRpY2FsbHkgZW5hYmxlZCB3aGVuIHJ1bm5pbmcgaW4gYSBUVFkuIEl0IGlzIGltcGxlbWVudGVkIGFzIGFuIGludGVybmFsIHBsdWdpbi4gSWYgbmVlZGVkLCBpdCBjYW4gYmUgZGlzYWJsZWQgYXMgZm9sbG93czoKCiAgLSBPbiBhIHVzZXIgbGV2ZWwsIHVzaW5nIGAtcCBubzp0ZXJtaW5hbHByb2dyZXNzYCBvbiB0aGUgY29tbWFuZCBsaW5lIG9yIHZpYSBhbiBlbnZpcm9ubWVudCB2YXJpYWJsZSBgUFlURVNUX0FERE9QVFM9Jy1wIG5vOnRlcm1pbmFscHJvZ3Jlc3MnYC4KICAtIE9uIGEgcHJvamVjdCBjb25maWd1cmF0aW9uIGxldmVsLCB1c2luZyBgYWRkb3B0cyA9ICItcCBubzp0ZXJtaW5hbHByb2dyZXNzImAuCgotIFsjJiM4MjAzOzQ3OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy80NzgpOiBTdXBwb3J0IFBFUDQyMCAoaW1wbGljaXQgbmFtZXNwYWNlIHBhY2thZ2VzKSBhcyA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj4tLXB5YXJnczwvc3Bhbj4gdGFyZ2V0IHdoZW4gYGNvbnNpZGVyX25hbWVzcGFjZV9wYWNrYWdlc2AgaXMgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+dHJ1ZTwvc3Bhbj4gaW4gdGhlIGNvbmZpZy4KCiAgUHJldmlvdXNseSwgdGhpcyBvcHRpb24gb25seSBpbXBhY3RlZCBwYWNrYWdlIGltcG9ydHMsIG5vdyBpdCBhbHNvIGltcGFjdHMgdGVzdHMgZGlzY292ZXJ5LgoKLSBbIyYjODIwMzsxMzY3OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzY3OCk6IEFkZGVkIGEgbmV3IGBmYXVsdGhhbmRsZXJfZXhpdF9vbl90aW1lb3V0YCBjb25maWd1cmF0aW9uIG9wdGlvbiBzZXQgdG8gImZhbHNlIiBieSBkZWZhdWx0IHRvIGxldCA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5mYXVsdGhhbmRsZXI8L3NwYW4+IGludGVycnVwdCB0aGUgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+cHl0ZXN0PC9zcGFuPiBwcm9jZXNzIGFmdGVyIGEgdGltZW91dCBpbiBjYXNlIG9mIGRlYWRsb2NrLgoKICBQcmV2aW91c2x5LCBhIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPmZhdWx0aGFuZGxlcjwvc3Bhbj4gdGltZW91dCB3b3VsZCBvbmx5IGR1bXAgdGhlIHRyYWNlYmFjayBvZiBhbGwgdGhyZWFkcyB0byBzdGRlcnIsIGJ1dCB3b3VsZCBub3QgaW50ZXJydXB0IHRoZSA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5weXRlc3Q8L3NwYW4+IHByb2Nlc3MuCgogIFwtLSBieSBgb2dyaXNlbGAuCgotIFsjJiM4MjAzOzEzODI5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODI5KTogQWRkZWQgc3VwcG9ydCBmb3IgY29uZmlndXJhdGlvbiBvcHRpb24gYWxpYXNlcyB2aWEgdGhlIGBhbGlhc2VzYCBwYXJhbWV0ZXIgaW4gYFBhcnNlci5hZGRpbmkoKSA8cHl0ZXN0LlBhcnNlci5hZGRpbmk+YC4KCiAgUGx1Z2lucyBjYW4gbm93IHJlZ2lzdGVyIGFsdGVybmF0aXZlIG5hbWVzIGZvciBjb25maWd1cmF0aW9uIG9wdGlvbnMsCiAgYWxsb3dpbmcgZm9yIG1vcmUgZmxleGliaWxpdHkgaW4gY29uZmlndXJhdGlvbiBuYW1pbmcgYW5kIHN1cHBvcnRpbmcgYmFja3dhcmQgY29tcGF0aWJpbGl0eSB3aGVuIHJlbmFtaW5nIG9wdGlvbnMuCiAgVGhlIGNhbm9uaWNhbCBuYW1lIGFsd2F5cyB0YWtlcyBwcmVjZWRlbmNlIGlmIGJvdGggdGhlIGNhbm9uaWNhbCBuYW1lIGFuZCBhbiBhbGlhcyBhcmUgc3BlY2lmaWVkIGluIHRoZSBjb25maWd1cmF0aW9uIGZpbGUuCgojIyMjIEltcHJvdmVtZW50cyBpbiBleGlzdGluZyBmdW5jdGlvbmFsaXR5CgotIFsjJiM4MjAzOzEzMzMwXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzMzMwKTogSGF2aW5nIHB5dGVzdCBjb25maWd1cmF0aW9uIHNwcmVhZCBvdmVyIG1vcmUgdGhhbiBvbmUgZmlsZSAoZm9yIGV4YW1wbGUgaGF2aW5nIGJvdGggYSBgcHl0ZXN0LmluaWAgZmlsZSBhbmQgYHB5cHJvamVjdC50b21sYCB3aXRoIGEgYFt0b29sLnB5dGVzdC5pbmlfb3B0aW9uc11gIHRhYmxlKSB3aWxsIG5vdyBwcmludCBhIHdhcm5pbmcgdG8gbWFrZSBpdCBjbGVhcmVyIHRvIHRoZSB1c2VyIHRoYXQgb25seSBvbmUgb2YgdGhlbSBpcyBhY3R1YWxseSB1c2VkLgoKICBcLS0gYnkgYHNnYWlzdGAKCi0gWyMmIzgyMDM7MTM1NzRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM1NzQpOiBUaGUgc2luZ2xlIGFyZ3VtZW50IGAtLXZlcnNpb25gIG5vIGxvbmdlciBsb2FkcyB0aGUgZW50aXJlIHBsdWdpbiBpbmZyYXN0cnVjdHVyZSwgbWFraW5nIGl0IGZhc3RlciBhbmQgbW9yZSByZWxpYWJsZSB3aGVuIGRpc3BsYXlpbmcgb25seSB0aGUgcHl0ZXN0IHZlcnNpb24uCgogIFBhc3NpbmcgYC0tdmVyc2lvbmAgdHdpY2UgKGUuZy4sIGBweXRlc3QgLS12ZXJzaW9uIC0tdmVyc2lvbmApIHJldGFpbnMgdGhlIG9yaWdpbmFsIGJlaGF2aW9yLCBzaG93aW5nIGJvdGggdGhlIHB5dGVzdCB2ZXJzaW9uIGFuZCBwbHVnaW4gaW5mb3JtYXRpb24uCgogID4gXFshTk9URV0KICA+IFNpbmNlIGAtLXZlcnNpb25gIGlzIG5vdyBwcm9jZXNzZWQgZWFybHksIGl0IG9ubHkgdGFrZXMgZWZmZWN0IHdoZW4gcGFzc2VkIGRpcmVjdGx5IHZpYSB0aGUgY29tbWFuZCBsaW5lLiBJdCB3aWxsIG5vdCB3b3JrIGlmIHNldCB0aHJvdWdoIG90aGVyIG1lY2hhbmlzbXMsIHN1Y2ggYXMgYFBZVEVTVF9BRERPUFRTYCBvciBgYWRkb3B0c2AuCgotIFsjJiM4MjAzOzEzODIzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODIzKTogQWRkZWQgYHN0cmljdF94ZmFpbGAgYXMgYW4gYWxpYXMgdG8gdGhlIGB4ZmFpbF9zdHJpY3RgIG9wdGlvbiwKICBgc3RyaWN0X2NvbmZpZ2AgYXMgYW4gYWxpYXMgdG8gdGhlIGAtLXN0cmljdC1jb25maWdgIGZsYWcsCiAgYW5kIGBzdHJpY3RfbWFya2Vyc2AgYXMgYW4gYWxpYXMgdG8gdGhlIGAtLXN0cmljdC1tYXJrZXJzYCBmbGFnLgogIFRoaXMgbWFrZXMgYWxsIHN0cmljdG5lc3Mgb3B0aW9ucyBjb25zaXN0ZW50bHkgaGF2ZSBjb25maWd1cmF0aW9uIG9wdGlvbnMgd2l0aCB0aGUgcHJlZml4IGBzdHJpY3RfYC4KCi0gWyMmIzgyMDM7MTM3MDBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3MDApOiA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj4tLWp1bml0eG1sPC9zcGFuPiBubyBsb25nZXIgcHJpbnRzIHRoZSA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5nZW5lcmF0ZWQgeG1sIGZpbGU8L3NwYW4+IHN1bW1hcnkgYXQgdGhlIGVuZCBvZiB0aGUgcHl0ZXN0IHNlc3Npb24gd2hlbiA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj4tLXF1aWV0PC9zcGFuPiBpcyBnaXZlbi4KCi0gWyMmIzgyMDM7MTM3MzJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3MzIpOiBQcmV2aW91c2x5LCB3aGVuIGZpbHRlcmluZyB3YXJuaW5ncywgcHl0ZXN0IHdvdWxkIGZhaWwgaWYgdGhlIGZpbHRlciByZWZlcmVuY2VkIGEgY2xhc3MgdGhhdCBjb3VsZCBub3QgYmUgaW1wb3J0ZWQuIE5vdywgdGhpcyBvbmx5IG91dHB1dHMgYSBtZXNzYWdlIGluZGljYXRpbmcgdGhlIHByb2JsZW0uCgotIFsjJiM4MjAzOzEzODU5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODU5KTogQ2xhcmlmeSB0aGUgZXJyb3IgbWVzc2FnZSBmb3IgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+cHl0ZXN0LnJhaXNlcygpPC9zcGFuPiB3aGVuIGEgcmVnZXggPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+bWF0Y2g8L3NwYW4+IGZhaWxzLgoKLSBbIyYjODIwMzsxMzg2MV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzg2MSk6IEJldHRlciBzZW50ZW5jZSBzdHJ1Y3R1cmUgaW4gYSB0ZXN0J3MgZXhwZWN0ZWQgZXJyb3IgbWVzc2FnZS4gUHJldmlvdXNseSwgdGhlIGVycm9yIG1lc3NhZ2Ugd291bGQgYmUgImV4cGVjdGVkIGV4Y2VwdGlvbiBtdXN0IGJlIFw8ZXhwZWN0ZWQ+LCBidXQgZ290IFw8YWN0dWFsPiIuIE5vdywgaXQgaXMgIkV4cGVjdGVkIFw8ZXhwZWN0ZWQ+LCBidXQgZ290IFw8YWN0dWFsPiIuCgojIyMjIFJlbW92YWxzIGFuZCBiYWNrd2FyZCBpbmNvbXBhdGlibGUgYnJlYWtpbmcgY2hhbmdlcwoKLSBbIyYjODIwMzsxMjA4M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMjA4Myk6IEZpeGVkIGEgYnVnIHdoZXJlIGFuIGludm9jYXRpb24gc3VjaCBhcyA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5weXRlc3QgYS8gYS9iPC9zcGFuPiB3b3VsZCBjYXVzZSBvbmx5IHRlc3RzIGZyb20gPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+YS9iPC9zcGFuPiB0byBydW4sIGFuZCBub3Qgb3RoZXIgdGVzdHMgdW5kZXIgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+YS88L3NwYW4+LgoKICBUaGUgZml4IGVudGFpbHMgYSBmZXcgYnJlYWtpbmcgY2hhbmdlcyB0byBob3cgc3VjaCBvdmVybGFwcGluZyBhcmd1bWVudHMgYW5kIGR1cGxpY2F0ZXMgYXJlIGhhbmRsZWQ6CgogIDEuIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPnB5dGVzdCBhL2IgYS88L3NwYW4+IG9yIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPnB5dGVzdCBhLyBhL2I8L3NwYW4+IGFyZSBlcXVpdmFsZW50IHRvIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPnB5dGVzdCBhPC9zcGFuPjsgaWYgYW4gYXJndW1lbnQgb3ZlcmxhcHMgYW5vdGhlciBhcmd1bWVudHMsIG9ubHkgdGhlIHByZWZpeCByZW1haW5zLgogIDIuIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPnB5dGVzdCB4LnB5IHgucHk8L3NwYW4+IGlzIGVxdWl2YWxlbnQgdG8gPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+cHl0ZXN0IHgucHk8L3NwYW4+OyBwcmV2aW91c2x5IHN1Y2ggYW4gaW52b2NhdGlvbiB3YXMgdGFrZW4gYXMgYW4gZXhwbGljaXQgcmVxdWVzdCB0byBydW4gdGhlIHRlc3RzIGZyb20gdGhlIGZpbGUgdHdpY2UuCgogIElmIHlvdSByZWx5IG9uIHRoZXNlIGJlaGF2aW9ycywgY29uc2lkZXIgdXNpbmcgYC0ta2VlcC1kdXBsaWNhdGVzIDxkdXBsaWNhdGUtcGF0aHM+YCwgd2hpY2ggcmV0YWlucyBpdHMgZXhpc3RpbmcgYmVoYXZpb3IgKGluY2x1ZGluZyB0aGUgYnVnKS4KCi0gWyMmIzgyMDM7MTM3MTldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3MTkpOiBTdXBwb3J0IGZvciBQeXRob24gMy45IGlzIGRyb3BwZWQgZm9sbG93aW5nIGl0cyBlbmQgb2YgbGlmZS4KCi0gWyMmIzgyMDM7MTM3NjZdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM3NjYpOiBQcmV2aW91c2x5LCBweXRlc3Qgd291bGQgYXNzdW1lIGl0IHdhcyBydW5uaW5nIGluIGEgQ0kvQ0QgZW52aXJvbm1lbnQgaWYgZWl0aGVyIG9mIHRoZSBlbnZpcm9ubWVudCB2YXJpYWJsZXMgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+JENJPC9zcGFuPiBvciA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj4kQlVJTERcX05VTUJFUjwvc3Bhbj4gd2FzIGRlZmluZWQ7CiAgbm93LCBDSSBtb2RlIGlzIG9ubHkgYWN0aXZhdGVkIGlmIGF0IGxlYXN0IG9uZSBvZiB0aG9zZSB2YXJpYWJsZXMgaXMgZGVmaW5lZCBhbmQgc2V0IHRvIGEgKm5vbi1lbXB0eSogdmFsdWUuCgotIFsjJiM4MjAzOzEzNzc5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNzc5KTogKipQeXRlc3RSZW1vdmVkSW45V2FybmluZyBkZXByZWNhdGlvbiB3YXJuaW5ncyBhcmUgbm93IGVycm9ycyBieSBkZWZhdWx0LioqCgogIEZvbGxvd2luZyBvdXIgcGxhbiB0byByZW1vdmUgZGVwcmVjYXRlZCBmZWF0dXJlcyB3aXRoIGFzIGxpdHRsZSBkaXNydXB0aW9uIGFzCiAgcG9zc2libGUsIGFsbCB3YXJuaW5ncyBvZiB0eXBlIGBQeXRlc3RSZW1vdmVkSW45V2FybmluZ2Agbm93IGdlbmVyYXRlIGVycm9ycwogIGluc3RlYWQgb2Ygd2FybmluZyBtZXNzYWdlcyBieSBkZWZhdWx0LgoKICAqKlRoZSBhZmZlY3RlZCBmZWF0dXJlcyB3aWxsIGJlIGVmZmVjdGl2ZWx5IHJlbW92ZWQgaW4gcHl0ZXN0IDkuMSoqLCBzbyBwbGVhc2UgY29uc3VsdCB0aGUKICBgZGVwcmVjYXRpb25zYCBzZWN0aW9uIGluIHRoZSBkb2NzIGZvciBkaXJlY3Rpb25zIG9uIGhvdyB0byB1cGRhdGUgZXhpc3RpbmcgY29kZS4KCiAgSW4gdGhlIHB5dGVzdCBgOS4wLlhgIHNlcmllcywgaXQgaXMgcG9zc2libGUgdG8gY2hhbmdlIHRoZSBlcnJvcnMgYmFjayBpbnRvIHdhcm5pbmdzIGFzIGEKICBzdG9wZ2FwIG1lYXN1cmUgYnkgYWRkaW5nIHRoaXMgdG8geW91ciBgcHl0ZXN0LmluaWAgZmlsZToKCiAgYGBgaW5pCiAgW3B5dGVzdF0KICBmaWx0ZXJ3YXJuaW5ncyA9CiAgICAgIGlnbm9yZTo6cHl0ZXN0LlB5dGVzdFJlbW92ZWRJbjlXYXJuaW5nCiAgYGBgCgogIEJ1dCB0aGlzIHdpbGwgc3RvcCB3b3JraW5nIHdoZW4gcHl0ZXN0IGA5LjFgIGlzIHJlbGVhc2VkLgoKICAqKklmIHlvdSBoYXZlIGNvbmNlcm5zKiogYWJvdXQgdGhlIHJlbW92YWwgb2YgYSBzcGVjaWZpYyBmZWF0dXJlLCBwbGVhc2UgYWRkIGEKICBjb21tZW50IHRvIGAxMzc3OWAuCgojIyMjIERlcHJlY2F0aW9ucyAocmVtb3ZhbCBpbiBuZXh0IG1ham9yIHJlbGVhc2UpCgotIFsjJiM4MjAzOzEzODA3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODA3KTogYG1vbmtleXBhdGNoLnN5c3BhdGhfcHJlcGVuZCgpIDxweXRlc3QuTW9ua2V5UGF0Y2guc3lzcGF0aF9wcmVwZW5kPmAgbm93IGlzc3VlcyBhIGRlcHJlY2F0aW9uIHdhcm5pbmcgd2hlbiB0aGUgcHJlcGVuZGVkIHBhdGggY29udGFpbnMgbGVnYWN5IG5hbWVzcGFjZSBwYWNrYWdlcyAodGhvc2UgdXNpbmcgYHBrZ19yZXNvdXJjZXMuZGVjbGFyZV9uYW1lc3BhY2UoKWApLgogIFVzZXJzIHNob3VsZCBtaWdyYXRlIHRvIG5hdGl2ZSBuYW1lc3BhY2UgcGFja2FnZXMgKGA0MjBgKS4KICBTZWUgYG1vbmtleXBhdGNoLWZpeHVwLW5hbWVzcGFjZS1wYWNrYWdlc2AgZm9yIGRldGFpbHMuCgojIyMjIEJ1ZyBmaXhlcwoKLSBbIyYjODIwMzsxMzQ0NV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzQ0NSk6IE1hZGUgdGhlIHR5cGUgYW5ub3RhdGlvbnMgb2YgYHB5dGVzdC5za2lwYCBhbmQgZnJpZW5kcyBtb3JlIHNwZWMtY29tcGxhaW50IHRvIGhhdmUgdGhlbSB3b3JrIGFjcm9zcyBtb3JlIHR5cGUgY2hlY2tlcnMuCgotIFsjJiM4MjAzOzEzNTM3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNTM3KTogRml4ZWQgYSBidWcgaW4gd2hpY2ggYEV4Y2VwdGlvbkdyb3VwYCB3aXRoIG9ubHkgYFNraXBwZWRgIGV4Y2VwdGlvbnMgaW4gdGVhcmRvd24gd2FzIG5vdCBoYW5kbGVkIGNvcnJlY3RseSBhbmQgc2hvd2VkIGFzIGVycm9yLgoKLSBbIyYjODIwMzsxMzU5OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzU5OCk6IEZpeGVkIHBvc3NpYmxlIGNvbGxlY3Rpb24gY29uZnVzaW9uIG9uIFdpbmRvd3Mgd2hlbiBzaG9ydCBwYXRocyBhbmQgc3ltbGlua3MgYXJlIGludm9sdmVkLgoKLSBbIyYjODIwMzsxMzcxNl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzcxNik6IEZpeGVkIGEgYnVnIHdoZXJlIGEgbm9uc2Vuc2ljYWwgaW52b2NhdGlvbiBsaWtlIGBweXRlc3QgeC5weVthXWAgKGEgZmlsZSBjYW5ub3QgYmUgcGFyYW1ldHJpemVkKSB3YXMgc2lsZW50bHkgdHJlYXRlZCBhcyBgcHl0ZXN0IHgucHlgLiBUaGlzIGlzIG5vdyBhIHVzYWdlIGVycm9yLgoKLSBbIyYjODIwMzsxMzcyMl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzcyMik6IEZpeGVkIGEgbWlzbGVhZGluZyBhc3NlcnRpb24gZmFpbHVyZSBtZXNzYWdlIHdoZW4gdXNpbmcgYHB5dGVzdC5hcHByb3hgIG9uIG1hcHBpbmdzIHdpdGggZGlmZmVyaW5nIGxlbmd0aHMuCgotIFsjJiM4MjAzOzEzNzczXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNzczKTogRml4ZWQgdGhlIHN0YXRpYyBmaXh0dXJlIGNsb3N1cmUgY2FsY3VsYXRpb24gdG8gcHJvcGVybHkgY29uc2lkZXIgdHJhbnNpdGl2ZSBkZXBlbmRlbmNpZXMgcmVxdWVzdGVkIGJ5IG92ZXJyaWRkZW4gZml4dHVyZXMuCgotIFsjJiM4MjAzOzEzODE2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODE2KTogRml4ZWQgYHB5dGVzdC5hcHByb3hgIHdoaWNoIG5vdyByZXR1cm5zIGEgY2xlYXJlciBlcnJvciBtZXNzYWdlIHdoZW4gY29tcGFyaW5nIG1hcHBpbmdzIHdpdGggZGlmZmVyZW50IGtleXMuCgotIFsjJiM4MjAzOzEzODQ5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODQ5KTogSGlkZGVuIGAucHl0ZXN0LmluaWAgZmlsZXMgYXJlIG5vdyBwaWNrZWQgdXAgYXMgdGhlIGNvbmZpZyBmaWxlIGV2ZW4gaWYgZW1wdHkuCiAgVGhpcyB3YXMgYW4gaW5jb25zaXN0ZW5jeSB3aXRoIG5vbi1oaWRkZW4gYHB5dGVzdC5pbmlgLgoKLSBbIyYjODIwMzsxMzg2NV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzg2NSk6IEZpeGVkIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPi0tc2hvdy1jYXB0dXJlPC9zcGFuPiB3aXRoIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPi0tdGI9bGluZTwvc3Bhbj4uCgotIFsjJiM4MjAzOzEzNTIyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNTIyKTogRml4ZWQgYHB5dGVzdGVyYCBpbiBzdWJwcm9jZXNzIG1vZGUgaWdub3JlZCBhbGwgOmF0dHJcYHB5dGVzdGVyLnBsdWdpbnMgXDxweXRlc3QuUHl0ZXN0ZXIucGx1Z2lucz5cYCBleGNlcHQgdGhlIGZpcnN0LgoKICBGaXhlZCBgcHl0ZXN0ZXJgIGluIHN1YnByb2Nlc3MgbW9kZSBzaWxlbnRseSBpZ25vcmVkIG5vbi1zdHIgYHB5dGVzdGVyLnBsdWdpbnMgPHB5dGVzdC5QeXRlc3Rlci5wbHVnaW5zPmAuCiAgTm93IGl0IGVycm9ycyBpbnN0ZWFkLgogIElmIHlvdSBhcmUgYWZmZWN0ZWQgYnkgdGhpcywgc3BlY2lmeSB0aGUgcGx1Z2luIGJ5IG5hbWUsIG9yIHN3aXRjaCB0aGUgYWZmZWN0ZWQgdGVzdHMgdG8gdXNlIGBweXRlc3Rlci5ydW5weXRlc3RfaW5wcm9jZXNzIDxweXRlc3QuUHl0ZXN0ZXIucnVucHl0ZXN0X2lucHJvY2Vzcz5gIGV4cGxpY2l0bHkgaW5zdGVhZC4KCiMjIyMgUGFja2FnaW5nIHVwZGF0ZXMgYW5kIG5vdGVzIGZvciBkb3duc3RyZWFtcwoKLSBbIyYjODIwMzsxMzc5MV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzc5MSk6IE1pbmltdW0gcmVxdWlyZW1lbnRzIG9uIGBpbmljb25maWdgIGFuZCBgcGFja2FnaW5nYCB3ZXJlIGJ1bXBlZCB0byBgMS4wLjFgIGFuZCBgMjIuMC4wYCwgcmVzcGVjdGl2ZWx5LgoKIyMjIyBDb250cmlidXRvci1mYWNpbmcgY2hhbmdlcwoKLSBbIyYjODIwMzsxMjI0NF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMjI0NCk6IEZpeGVkIHNlbGYtdGVzdCBmYWlsdXJlcyB3aGVuIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPlRFUk09ZHVtYjwvc3Bhbj4uCi0gWyMmIzgyMDM7MTI0NzRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTI0NzQpOiBBZGRlZCBzY2hlZHVsZWQgR2l0SHViIEFjdGlvbiBXb3JrZmxvdyB0byBydW4gU3BoaW54IGxpbmtjaGVja3MgaW4gcmVwbyBkb2N1bWVudGF0aW9uLgotIFsjJiM4MjAzOzEzNjIxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNjIxKTogcHl0ZXN0J3Mgb3duIHRlc3RzdWl0ZSBub3cgaGFuZGxlcyB0aGUgYGxzb2ZgIGNvbW1hbmQgaGFuZ2luZyAoZS5nLiBkdWUgdG8gdW5yZWFjaGFibGUgbmV0d29yayBmaWxlc3lzdGVtcyksIHdpdGggdGhlIGFmZmVjdGVkIHNlbGZ0ZXN0cyBiZWluZyBza2lwcGVkIGFmdGVyIDEwIHNlY29uZHMuCi0gWyMmIzgyMDM7MTM2MzhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM2MzgpOiBGaXhlZCBkZXByZWNhdGVkIGBnaCBwciBuZXdgIGNvbW1hbmQgaW4gYHNjcmlwdHMvcHJlcGFyZS1yZWxlYXNlLXByLnB5YC4KICBUaGUgc2NyaXB0IG5vdyB1c2VzIGBnaCBwciBjcmVhdGVgIHdoaWNoIGlzIGNvbXBhdGlibGUgd2l0aCBHaXRIdWIgQ0xJIHYyLjArLgotIFsjJiM4MjAzOzEzNjk1XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNjk1KTogRmx1c2ggPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+c3Rkb3V0PC9zcGFuPiBhbmQgPHNwYW4gY2xhc3M9InRpdGxlLXJlZiI+c3RkZXJyPC9zcGFuPiBpbiA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj5QeXRlc3Rlci5ydW48L3NwYW4+IHRvIGF2b2lkIHRydW5jYXRlZCBvdXRwdXRzIGluIDxzcGFuIGNsYXNzPSJ0aXRsZS1yZWYiPnRlc3RcX2ZhdWx0aGFuZGxlci5weTo6dGVzdFxfdGltZW91dDwvc3Bhbj4gb24gQ0kgLS0gYnkgYG9ncmlzZWxgLgotIFsjJiM4MjAzOzEzNzcxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNzcxKTogU2tpcCA8c3BhbiBjbGFzcz0idGl0bGUtcmVmIj50ZXN0XF9kb1xfbm90XF9jb2xsZWN0XF9zeW1saW5rXF9zaWJsaW5nczwvc3Bhbj4gb24gV2luZG93cyBlbnZpcm9ubWVudHMgd2l0aG91dCBzeW1saW5rIHN1cHBvcnQgdG8gYXZvaWQgZmFsc2UgbmVnYXRpdmVzLgotIFsjJiM4MjAzOzEzODQxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzODQxKTogYHRveD49NGAgaXMgbm93IHJlcXVpcmVkIHdoZW4gY29udHJpYnV0aW5nIHRvIHB5dGVzdC4KLSBbIyYjODIwMzsxMzYyNV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzYyNSk6IEFkZGVkIG1pc3NpbmcgZG9jc3RyaW5ncyB0byBgcHl0ZXN0X2FkZG9wdGlvbigpYCwgYHB5dGVzdF9jb25maWd1cmUoKWAsIGFuZCBgY2FjaGVzaG93KClgIGZ1bmN0aW9ucyBpbiBgY2FjaGVwcm92aWRlci5weWAuCgojIyMjIE1pc2NlbGxhbmVvdXMgaW50ZXJuYWwgY2hhbmdlcwoKLSBbIyYjODIwMzsxMzgzMF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzgzMCk6IENvbmZpZ3VyYXRpb24gb3ZlcnJpZGVzIChgLW9gL2AtLW92ZXJyaWRlLWluaWApIGFyZSBub3cgcHJvY2Vzc2VkIGR1cmluZyBzdGFydHVwIHJhdGhlciB0aGFuIGR1cmluZyBgY29uZmlnLmdldGluaSgpIDxweXRlc3QuQ29uZmlnLmdldGluaT5gLgoKIyMjIFtgdjguNC4yYF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L3JlbGVhc2VzL3RhZy84LjQuMikKCltDb21wYXJlIFNvdXJjZV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2NvbXBhcmUvOC40LjEuLi44LjQuMikKCiMjIyBweXRlc3QgOC40LjIgKDIwMjUtMDktMDMpCgojIyMjIEJ1ZyBmaXhlcwoKLSBbIyYjODIwMzsxMzQ3OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzQ3OCk6IEZpeGVkIGEgY3Jhc2ggd2hlbiB1c2luZyBgY29uc29sZV9vdXRwdXRfc3R5bGVgey5pbnRlcnByZXRlZC10ZXh0IHJvbGU9ImNvbmZ2YWwifSB3aXRoIGB0aW1lc2AgYW5kIGEgbW9kdWxlIGlzIHNraXBwZWQuCgotIFsjJiM4MjAzOzEzNTMwXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNTMwKTogRml4ZWQgYSBjcmFzaCB3aGVuIHVzaW5nIGBweXRlc3QuYXBwcm94YHsuaW50ZXJwcmV0ZWQtdGV4dCByb2xlPSJmdW5jIn0gYW5kIGBkZWNpbWFsLkRlY2ltYWxgey5pbnRlcnByZXRlZC10ZXh0IHJvbGU9ImNsYXNzIn0gaW5zdGFuY2VzIHdpdGggdGhlIGBkZWNpbWFsLkZsb2F0T3BlcmF0aW9uYHsuaW50ZXJwcmV0ZWQtdGV4dCByb2xlPSJjbGFzcyJ9IHRyYXAgc2V0LgoKLSBbIyYjODIwMzsxMzU0OV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzU0OSk6IE5vIGxvbmdlciBldmFsdWF0ZSB0eXBlIGFubm90YXRpb25zIGluIFB5dGhvbiBgMy4xNGAgd2hlbiBpbnNwZWN0aW5nIGZ1bmN0aW9uIHNpZ25hdHVyZXMuCgogIFRoaXMgcHJldmVudHMgY3Jhc2hlcyBkdXJpbmcgbW9kdWxlIGNvbGxlY3Rpb24gd2hlbiBtb2R1bGVzIGRvIG5vdCBleHBsaWNpdGx5IHVzZSBgZnJvbSBfX2Z1dHVyZV9fIGltcG9ydCBhbm5vdGF0aW9uc2AgYW5kIGltcG9ydCB0eXBlcyBmb3IgYW5ub3RhdGlvbnMgd2l0aGluIGEgYGlmIFRZUEVfQ0hFQ0tJTkc6YCBibG9jay4KCi0gWyMmIzgyMDM7MTM1NTldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM1NTkpOiBBZGRlZCBtaXNzaW5nIFxbaW50XXsudGl0bGUtcmVmfSBhbmQgXFtmbG9hdF17LnRpdGxlLXJlZn0gdmFyaWFudHMgdG8gdGhlIFxbTGl0ZXJhbF17LnRpdGxlLXJlZn0gdHlwZSBhbm5vdGF0aW9uIG9mIHRoZSBcW3R5cGVdey50aXRsZS1yZWZ9IHBhcmFtZXRlciBpbiBgcHl0ZXN0LlBhcnNlci5hZGRpbmlgey5pbnRlcnByZXRlZC10ZXh0IHJvbGU9Im1ldGgifS4KCi0gWyMmIzgyMDM7MTM1NjNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM1NjMpOiBgcHl0ZXN0LmFwcHJveGB7LmludGVycHJldGVkLXRleHQgcm9sZT0iZnVuYyJ9IG5vdyBvbmx5IGltcG9ydHMgYG51bXB5YCBpZiBOdW1QeSBpcyBhbHJlYWR5IGluIGBzeXMubW9kdWxlc2AuIFRoaXMgZml4ZXMgdW5jb25kaXRpb25hbCBpbXBvcnQgYmVoYXZpb3IgaW50cm9kdWNlZCBpbiBcWzguNC4wXXsudGl0bGUtcmVmfS4KCiMjIyMgSW1wcm92ZWQgZG9jdW1lbnRhdGlvbgoKLSBbIyYjODIwMzsxMzU3N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3B5dGVzdC1kZXYvcHl0ZXN0L2lzc3Vlcy8xMzU3Nyk6IENsYXJpZnkgdGhhdCBgcHl0ZXN0X2dlbmVyYXRlX3Rlc3RzYCBpcyBkaXNjb3ZlcmVkIGluIHRlc3QgbW9kdWxlcy9jbGFzc2VzOyBvdGhlciBob29rcyBtdXN0IGJlIGluIGBjb25mdGVzdC5weWAgb3IgcGx1Z2lucy4KCiMjIyMgQ29udHJpYnV0b3ItZmFjaW5nIGNoYW5nZXMKCi0gWyMmIzgyMDM7MTM0ODBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM0ODApOiBTZWxmLXRlc3Rpbmc6IGZpeGVkIGEgZmV3IHRlc3QgZmFpbHVyZXMgd2hlbiBydW4gd2l0aCBgLVdkZWZhdWx0YCBvciBhIHNpbWlsYXIgb3ZlcnJpZGUuCi0gWyMmIzgyMDM7MTM1NDddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9weXRlc3QtZGV2L3B5dGVzdC9pc3N1ZXMvMTM1NDcpOiBTZWxmLXRlc3Rpbmc6IGNvcnJlY3RlZCBleHBlY3RlZCBtZXNzYWdlIGZvciBgdGVzdF9kb2N0ZXN0X3VuZXhwZWN0ZWRfZXhjZXB0aW9uYCBpbiBQeXRob24gYDMuMTRgLgotIFsjJiM4MjAzOzEzNjg0XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcHl0ZXN0LWRldi9weXRlc3QvaXNzdWVzLzEzNjg0KTogTWFrZSBweXRlc3QncyBvd24gdGVzdHN1aXRlIGluc2Vuc2l0aXZlIHRvIHRoZSBwcmVzZW5jZSBvZiB0aGUgYENJYCBlbnZpcm9ubWVudCB2YXJpYWJsZSAtLSBieSBgb2dyaXNlbGB7LmludGVycHJldGVkLXRleHQgcm9sZT0idXNlciJ9LgoKPC9kZXRhaWxzPgoKLS0tCgojIyMgQ29uZmlndXJhdGlvbgoK8J+ThSAqKlNjaGVkdWxlKio6IChVVEMpCgotIEJyYW5jaCBjcmVhdGlvbgogIC0gIiIKLSBBdXRvbWVyZ2UKICAtIEF0IGFueSB0aW1lIChubyBzY2hlZHVsZSBkZWZpbmVkKQoK8J+apiAqKkF1dG9tZXJnZSoqOiBEaXNhYmxlZCBieSBjb25maWcuIFBsZWFzZSBtZXJnZSB0aGlzIG1hbnVhbGx5IG9uY2UgeW91IGFyZSBzYXRpc2ZpZWQuCgrimbsgKipSZWJhc2luZyoqOiBXaGVuZXZlciBQUiBpcyBiZWhpbmQgYmFzZSBicmFuY2gsIG9yIHlvdSB0aWNrIHRoZSByZWJhc2UvcmV0cnkgY2hlY2tib3guCgrwn5SVICoqSWdub3JlKio6IENsb3NlIHRoaXMgUFIgYW5kIHlvdSB3b24ndCBiZSByZW1pbmRlZCBhYm91dCB0aGlzIHVwZGF0ZSBhZ2Fpbi4KCi0tLQoKIC0gWyBdIDwhLS0gcmViYXNlLWNoZWNrIC0tPklmIHlvdSB3YW50IHRvIHJlYmFzZS9yZXRyeSB0aGlzIFBSLCBjaGVjayB0aGlzIGJveAoKLS0tCgpUaGlzIFBSIHdhcyBnZW5lcmF0ZWQgYnkgW01lbmQgUmVub3ZhdGVdKGh0dHBzOi8vbWVuZC5pby9yZW5vdmF0ZS8pLiBWaWV3IHRoZSBbcmVwb3NpdG9yeSBqb2IgbG9nXShodHRwczovL2RldmVsb3Blci5tZW5kLmlvL2dpdGh1Yi92ZXh4aG9zdC9hbnNpYmxlLWNvbGxlY3Rpb24tY29udGFpbmVycykuCjwhLS1yZW5vdmF0ZS1kZWJ1ZzpleUpqY21WaGRHVmtTVzVXWlhJaU9pSTBNeTR4TVRBdU1pSXNJblZ3WkdGMFpXUkpibFpsY2lJNklqUXpMakV4TUM0eUlpd2lkR0Z5WjJWMFFuSmhibU5vSWpvaWJXRnBiaUlzSW14aFltVnNjeUk2VzExOS0tPgo=
      patchset: 72e749f2e3a1fc041978492dc3fa7d2ff810a316
      pipeline: check
      playbook_context:
        playbook_projects:
          trusted/project_0/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 298983cd1253e6833abdb49d87d912527e0e6597
          trusted/project_1/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: 01384e11271b1590fe57d1c69f228708f741103e
          trusted/project_2/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          untrusted/project_0/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          untrusted/project_1/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 298983cd1253e6833abdb49d87d912527e0e6597
          untrusted/project_2/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: 01384e11271b1590fe57d1c69f228708f741103e
        playbooks:
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/run.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_0/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_0/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_2/zuul-jobs/roles
        post_playbooks:
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_0/role_2/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post-logs.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_1/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_1/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_1/role_2/zuul-jobs/roles
        pre_playbooks:
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_0/role_2/zuul-jobs/roles
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_1/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_1/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_1/role_2/zuul-jobs/roles
      post_review: false
      post_timeout: null
      pre_timeout: null
      project:
        canonical_hostname: github.com
        canonical_name: github.com/vexxhost/ansible-collection-containers
        name: vexxhost/ansible-collection-containers
        short_name: ansible-collection-containers
        src_dir: src/github.com/vexxhost/ansible-collection-containers
      projects:
        github.com/vexxhost/ansible-collection-containers:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-containers
          checkout: main
          checkout_description: zuul branch
          commit: 9b7f66d578471454c37bcf0feca5311eb7b4c230
          name: vexxhost/ansible-collection-containers
          required: false
          short_name: ansible-collection-containers
          src_dir: src/github.com/vexxhost/ansible-collection-containers
      ref: refs/pull/110/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
