diff options
author | cos <cos> | 2024-04-20 10:08:13 +0200 |
---|---|---|
committer | cos <cos> | 2024-04-20 10:12:35 +0200 |
commit | 9d0c7ef4dc8d7f3bea3ff70c977a87d154316a26 (patch) | |
tree | 7e3797bdd2403982f4a351608d9633c910aadc12 /changelogs/changelog.yaml | |
parent | c224b4bf4a6538c3ddc5cb762367c0d53462fa12 (diff) | |
download | debian-ansible-core-upstream/second-failed-recreation-attempt.zip |
Recreate upstream branch stateupstream/second-failed-recreation-attempt
Work around that version control is behind the actual package version in
trixie. As is obvious from the lacking commits in the salsa repository
and also visible on https://tracker.debian.org/pkg/ansible-core with the
report from vcswatch stating: VCS repository is not up to date.
This commit was generated using `gbp import-dsc`, which should hopefully
have made it a squashed representation on the same set of changes on the
uploader's unpushed git tree.
Diffstat (limited to 'changelogs/changelog.yaml')
-rw-r--r-- | changelogs/changelog.yaml | 2343 |
1 files changed, 1483 insertions, 860 deletions
diff --git a/changelogs/changelog.yaml b/changelogs/changelog.yaml index 3e241228..97eb4c13 100644 --- a/changelogs/changelog.yaml +++ b/changelogs/changelog.yaml @@ -1,977 +1,1600 @@ -ancestor: 2.15.0 +ancestor: 2.13.0 releases: - 2.16.0: + 2.14.0: changes: bugfixes: - - ansible-test - Fix parsing of cgroup entries which contain a ``:`` in the - path (https://github.com/ansible/ansible/issues/81977). - release_summary: '| Release Date: 2023-11-06 + - ansible-test - Fix broken documentation link for ``aws`` test plugin error + messages. + minor_changes: + - ansible-test - Improve consistency of version specific documentation links. + release_summary: '| Release Date: 2022-11-07 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.0_summary.yaml - - ansible-test-cgroup-split.yml - release_date: '2023-11-06' - 2.16.0b1: + - ansible-test-docs-links.yml + - v2.14.0_summary.yaml + release_date: '2022-11-07' + 2.14.0b1: changes: breaking_changes: - - Any plugin using the config system and the `cli` entry to use the `timeout` - from the command line, will see the value change if the use had configured - it in any of the lower precedence methods. If relying on this behaviour to - consume the global/generic timeout from the DEFAULT_TIMEOUT constant, please - consult the documentation on plugin configuration to add the overlaping entries. - - ansible-test - Test plugins that rely on containers no longer support reusing - running containers. The previous behavior was an undocumented, untested feature. - - service module will not permanently configure variables/flags for openbsd - when doing enable/disable operation anymore, this module was never meant to - do this type of work, just to manage the service state itself. A rcctl_config - or similar module should be created and used instead. + - Allow for lazy evaluation of Jinja2 expressions (https://github.com/ansible/ansible/issues/56017) + - The default ansible-galaxy role skeletons no longer contain .travis.yml files. + You can configure ansible-galaxy to use a custom role skeleton that contains + a .travis.yml file to continue using Galaxy's integration with Travis CI. + - ansible - At startup the filesystem encoding and locale are checked to verify + they are UTF-8. If not, the process exits with an error reporting the errant + encoding. + - ansible - Increase minimum Python requirement to Python 3.9 for CLI utilities + and controller code + - ansible-test - At startup the filesystem encoding is checked to verify it + is UTF-8. If not, the process exits with an error reporting the errant encoding. + - ansible-test - At startup the locale is configured as ``en_US.UTF-8``, with + a fallback to ``C.UTF-8``. If neither encoding is available the process exits + with an error. If the fallback is used, a warning is displayed. In previous + versions the ``en_US.UTF-8`` locale was always requested. However, no startup + checking was performed to verify the locale was successfully configured. + - strategy plugins - Make ``ignore_unreachable`` to increase ``ignored`` and + ``ok`` and counter, not ``skipped`` and ``unreachable``. (https://github.com/ansible/ansible/issues/77690) + bugfixes: + - '"meta: refresh_inventory" does not clobber entries added by add_host/group_by + anymore.' + - Add PyYAML >= 5.1 as a dependency of ansible-core to be compatible with Python + 3.8+. + - Avoid 'unreachable' error when chmod on AIX has 255 as return code. + - Bug fix for when handlers were ran on failed hosts after an ``always`` section + was executed (https://github.com/ansible/ansible/issues/52561) + - Do not allow handlers from dynamic includes to be notified (https://github.com/ansible/ansible/pull/78399) + - Ensure handlers observe ``any_errors_fatal`` (https://github.com/ansible/ansible/issues/46447) + - Ensure syntax check errors include playbook filenames + - Ensure the correct ``environment_class`` is set on ``AnsibleJ2Template`` + - Error for collection redirects that do not use fully qualified collection + names, as the redirect would be determined by the ``collections`` keyword. + - Fix PluginLoader to mimic Python import machinery by adding module to sys.modules + before exec + - Fix ``-vv`` output for meta tasks to not have an empty message when skipped, + print the skip reason instead. (https://github.com/ansible/ansible/issues/77315) + - Fix an issue where ``ansible_play_hosts`` and ``ansible_play_batch`` were + not properly updated when a failure occured in an explicit block inside the + rescue section (https://github.com/ansible/ansible/issues/78612) + - Fix dnf module documentation to indicate that comparison operators for package + version require spaces around them (https://github.com/ansible/ansible/issues/78295) + - Fix for linear strategy when tasks were executed in incorrect order or even + removed from execution. (https://github.com/ansible/ansible/issues/64611, + https://github.com/ansible/ansible/issues/64999, https://github.com/ansible/ansible/issues/72725, + https://github.com/ansible/ansible/issues/72781) + - Fix for network_cli not getting all relevant connection options + - Fix handlers execution with ``serial`` in the ``linear`` strategy (https://github.com/ansible/ansible/issues/54991) + - Fix potential, but unlikely, cases of variable use before definition. + - Fix traceback when installing a collection from a git repository and git is + not installed (https://github.com/ansible/ansible/issues/77479). + - GALAXY_IGNORE_CERTS reworked to allow each server entry to override + - More gracefully handle separator errors in jinja2 template overrides (https://github.com/ansible/ansible/pull/77495). + - Move undefined check from concat to finalize (https://github.com/ansible/ansible/issues/78156) + - Prevent losing unsafe on results returned from lookups (https://github.com/ansible/ansible/issues/77535) + - Propagate ``ansible_failed_task`` and ``ansible_failed_result`` to an outer + rescue (https://github.com/ansible/ansible/issues/43191) + - Properly execute rescue section when an include task fails in all loop iterations + (https://github.com/ansible/ansible/issues/23161) + - Properly send a skipped message when a list in a ``loop`` is empty and comes + from a template (https://github.com/ansible/ansible/issues/77934) + - Support colons in jinja2 template override values (https://github.com/ansible/ansible/pull/77495). + - '``ansible-galaxy`` - remove extra server api call during dependency resolution + for requirements and dependencies that are already satisfied (https://github.com/ansible/ansible/issues/77443).' + - '`ansible-config init -f vars` will now use shorthand format' + - action plugins now pass cannonical info to modules instead of 'temporary' + info from play_context + - ansible - Exclude Python 2.6 from Python interpreter discovery. + - ansible-config dump - Only display plugin type headers when plugin options + are changed if --only-changed is specified. + - ansible-configi init should now skip internal reserved config entries + - ansible-connection - decrypt vaulted parameters before sending over the socket, + as vault secrets are not available on the other side. + - ansible-console - Renamed the first argument of ``ConsoleCLI.default`` from + ``arg`` to ``line`` to match the first argument of the same method on the + base class ``Cmd``. + - ansible-console commands now all have a help entry. + - ansible-console fixed to load modules via fqcn, short names and handle redirects. + - ansible-console now shows installed collection modules. + - ansible-doc - fix listing plugins. + - ansible-doc will not add 'website for' in ":ref:" substitutions as it made + them confusing. + - ansible-doc will not again warn and skip when missing docs, always show the + doc file (for edit on github) and match legacy plugins. + - ansible-doc will not traceback when legacy plugins don't have docs nor adjacent + file with docs + - ansible-doc will now also display until as an 'implicit' templating keyword. + - ansible-doc will now not display version_added_collection under same conditions + it does not display version_added. + - ansible-galaxy - Fix detection of ``--role-file`` in arguments for implicit + role invocation (https://github.com/ansible/ansible/issues/78204) + - ansible-galaxy - Fix exit codes for role search and delete (https://github.com/ansible/ansible/issues/78516) + - ansible-galaxy - Fix loading boolean server options so False doesn't become + a truthy string (https://github.com/ansible/ansible/issues/77416). + - ansible-galaxy - Fix reinitializing the whole collection directory with ``ansible-galaxy + collection init ns.coll --force``. Now directories and files that are not + included in the collection skeleton will be removed. + - ansible-galaxy - Fix unhandled traceback if a role's dependencies in meta/main.yml + or meta/requirements.yml are not lists. + - ansible-galaxy - do not require mandatory keys in the ``galaxy.yml`` of source + collections when listing them (https://github.com/ansible/ansible/issues/70180). + - ansible-galaxy - fix installing collections that have dependencies in the + metadata set to null instead of an empty dictionary (https://github.com/ansible/ansible/issues/77560). + - ansible-galaxy - fix listing collections that contains metadata but the namespace + or name are not strings. + - ansible-galaxy - fix missing meta/runtime.yml in default galaxy skeleton used + for ansible-galaxy collection init + - ansible-galaxy - fix setting the cache for paginated responses from Galaxy + NG/AH (https://github.com/ansible/ansible/issues/77911). + - ansible-galaxy - handle unsupported versions of resolvelib gracefully. + - ansible-galaxy --ignore-certs now has proper precedence over configuration + - ansible-test - Allow disabled, unsupported, unstable and destructive integration + test targets to be selected using their respective prefixes. + - ansible-test - Allow unstable tests to run when targeted changes are made + and the ``--allow-unstable-changed`` option is specified (resolves https://github.com/ansible/ansible/issues/74213). + - ansible-test - Always remove containers after failing to create/run them. + This avoids leaving behind created containers when using podman. + - ansible-test - Correctly detect when running as the ``root`` user (UID 0) + on the origin host. The result of the detection was incorrectly being inverted. + - ansible-test - Delegation for commands which generate output for programmatic + consumption no longer redirect all output to stdout. The affected commands + and options are ``shell``, ``sanity --lint``, ``sanity --list-tests``, ``integration + --list-targets``, ``coverage analyze`` + - ansible-test - Delegation now properly handles arguments given after ``--`` + on the command line. + - ansible-test - Don't fail if network cannot be disconnected (https://github.com/ansible/ansible/pull/77472) + - ansible-test - Fix bootstrapping of Python 3.9 on Ubuntu 20.04 remotes. + - ansible-test - Fix change detection for ansible-test's own integration tests. + - ansible-test - Fix internal validation of remote completion configuration. + - ansible-test - Fix skipping of tests marked ``needs/python`` on the origin + host. + - ansible-test - Fix skipping of tests marked ``needs/root`` on the origin host. + - ansible-test - Prevent ``--target-`` prefixed options for the ``shell`` command + from being combined with legacy environment options. + - ansible-test - Sanity test output with the ``--lint`` option is no longer + mixed in with bootstrapping output. + - ansible-test - Subprocesses are now isolated from the stdin, stdout and stderr + of ansible-test. This avoids issues with subprocesses tampering with the file + descriptors, such as SSH making them non-blocking. As a result of this change, + subprocess output from unit and integration tests on stderr now go to stdout. + - ansible-test - Subprocesses no longer have access to the TTY ansible-test + is connected to, if any. This maintains consistent behavior between local + testing and CI systems, which typically do not provide a TTY. Tests which + require a TTY should use pexpect or another mechanism to create a PTY. + - ansible-test - Temporary executables are now verified as executable after + creation. Without this check, path injected scripts may not be found, typically + on systems with ``/tmp`` mounted using the "noexec" option. This can manifest + as a missing Python interpreter, or use of the wrong Python interpreter, as + well as other error conditions. + - 'ansible-test - Test configuration for collections is now parsed only once, + prior to delegation. Fixes issue: https://github.com/ansible/ansible/issues/78334' + - ansible-test - Test containers are now run with the ``--tmpfs`` option for + ``/tmp``, ``/run`` and ``/run/lock``. This allows use of containers built + without the ``VOLUME`` instruction. Additionally, containers with those volumes + defined no longer create anonymous volumes for them. This avoids leaving behind + volumes on the container host after the container is stopped and deleted. + - ansible-test - The ``shell`` command no longer redirects all output to stdout + when running a provided command. Any command output written to stderr will + be mixed with the stderr output from ansible-test. + - ansible-test - The ``shell`` command no longer requests a TTY when using delegation + unless an interactive shell is being used. An interactive shell is the default + behavior when no command is given to pass to the shell. + - ansible-test - ansible-doc sanity test - Correctly determine the fully-qualified + collection name for plugins in subdirectories, resolving https://github.com/ansible/ansible/issues/78490. + - ansible-test - validate-modules - Documentation-only modules, used for documenting + actions, are now allowed to have docstrings (https://github.com/ansible/ansible/issues/77972). + - ansible-test compile sanity test - do not crash if a column could not be determined + for an error (https://github.com/ansible/ansible/pull/77465). + - apt - Fix module failure when a package is not installed and only_upgrade=True. + Skip that package and check the remaining requested packages for upgrades. + (https://github.com/ansible/ansible/issues/78762) + - apt - don't actually update the cache in check mode with update_cache=true. + - apt - don't mark existing packages as manually installed in check mode (https://github.com/ansible/ansible/issues/66413). + - apt - fix package selection to include /etc/apt/preferences(.d) (https://github.com/ansible/ansible/issues/77969) + - apt module now correctly handles virtual packages. + - arg_spec - Fix incorrect ``no_log`` warning when a parameter alias is used + (https://github.com/ansible/ansible/pull/77576) + - callback plugins - do not crash when ``exception`` passed from a module is + not a string (https://github.com/ansible/ansible/issues/75726, https://github.com/ansible/ansible/pull/77781). + - cli now emits clearer error on no hosts selected + - config, ensure that pulling values from configmanager are templated if possible. + - display itself should be single source of 'verbosity' level to the engine. + - dnf - Condense a few internal boolean returns. + - dnf - The ``nobest`` option now also works for ``state=latest``. + - dnf - The ``skip_broken`` option is now used in installs (https://github.com/ansible/ansible/issues/73072). + - dnf - fix output parsing on systems with ``LANGUAGE`` set to a language other + than English (https://github.com/ansible/ansible/issues/78193) + - facts - fix IP address discovery for specific interface names (https://github.com/ansible/ansible/issues/77792). + - 'facts - fix processor facts on AIX: correctly detect number of cores and + threads, turn ``processor`` into a list (https://github.com/ansible/ansible/pull/78223).' + - fetch_file - Ensure we only use the filename when calculating a tempfile, + and do not incude the query string (https://github.com/ansible/ansible/issues/29680) + - fetch_file - properly split files with multiple file extensions (https://github.com/ansible/ansible/pull/75257) + - file - setting attributes of symbolic links or files that are hard linked + no longer fails when the link target is unspecified (https://github.com/ansible/ansible/issues/76142). + - file backed cache plugins now handle concurrent access by making atomic updates + to the files. + - git module fix docs and proper use of ssh wrapper script and GIT_SSH_COMMAND + depending on version. + - if a config setting prevents running ansible it should at least show it's + "origin". + - include module - add docs url to include deprecation message (https://github.com/ansible/ansible/issues/76684). + - items2dict - Handle error if an item is not a dictionary or is missing the + required keys (https://github.com/ansible/ansible/issues/70337). + - local facts - if a local fact in the facts directory cannot be stated, store + an error message as the fact value and emit a warning just as if just as if + the facts execution has failed. The stat can fail e.g. on dangling symlinks. + - lookup plugin - catch KeyError when lookup returns dictionary (https://github.com/ansible/ansible/pull/77789). + - module_utils - Make distro.id() report newer versions of OpenSuSE (at least + >=15) also report as ``opensuse``. They report themselves as ``opensuse-leap``. + - module_utils.service - daemonize - Avoid modifying the list of file descriptors + while iterating over it. + - null_representation config entry changed to 'raw' as it must allow 'none/null' + and empty string. + - paramiko - Add a new option to allow paramiko >= 2.9 to easily work with all + devices now that rsa-sha2 support was added to paramiko, which prevented communication + with numerous platforms. (https://github.com/ansible/ansible/issues/76737) + - paramiko - Add back support for ``ssh_args``, ``ssh_common_args``, and ``ssh_extra_args`` + for parsing the ``ProxyCommand`` (https://github.com/ansible/ansible/issues/78750) + - password lookup does not ignore k=v arguments anymore. + - pause module will now report proper 'echo' vs always being true. + - pip - fix cases where resolution of pip Python module fails when importlib.util + has not already been imported + - plugin loader - Sort results when fuzzy matching plugin names (https://github.com/ansible/ansible/issues/77966). + - plugin loader will now load config data for plugin by name instead of by file + to avoid issues with the same file being loaded under different names (fqcn + + short name). + - plugin loader, now when skipping a plugin due to an abstract method error + we provide that in 'verbose' mode instead of totally obscuring the error. + The current implementation assumed only the base classes would trigger this + and failed to consider 'in development' plugins. + - prevent lusermod from using group name instead of group id (https://github.com/ansible/ansible/pull/77914) + - prevent type annotation shim failures from causing runtime failures (https://github.com/ansible/ansible/pull/77860) + - psrp connection now handles default to inventory_hostname correctly. + - roles, fixed issue with roles loading paths not contained in the role itself + when using the `_from` options. + - setup - Adds a default value to ``lvm_facts`` when lvm or lvm2 is not installed + on linux (https://github.com/ansible/ansible/issues/17393) + - shell plugins now give a more user friendly error when fed the wrong type + of data. + - template module/lookup - fix ``convert_data`` option that was effectively + always set to True for Jinja macros (https://github.com/ansible/ansible/issues/78141) + - unarchive - if unzip is available but zipinfo is not, use unzip -Z instead + of zipinfo (https://github.com/ansible/ansible/issues/76959). + - uri - properly use uri parameter use_proxy (https://github.com/ansible/ansible/issues/58632) + - uri module - failed status when Authentication Bearer used with netrc, because + Basic authentication was by default. Fix now allows to ignore netrc by changing + use_netrc=False (https://github.com/ansible/ansible/issues/74397). + - urls - Guard imports of ``urllib3`` by catching ``Exception`` instead of ``ImportError`` + to prevent exceptions in the import process of optional dependencies from + preventing use of ``urls.py`` (https://github.com/ansible/ansible/issues/78648) + - user - Fix error "Permission denied" in user module while generating SSH keys + (https://github.com/ansible/ansible/issues/78017). + - user - fix creating a local user if the user group already exists (https://github.com/ansible/ansible/pull/75042) + - user module - Replace uses of the deprecated ``spwd`` python module with ctypes + (https://github.com/ansible/ansible/pull/78050) + - validate-modules - fix validating version_added for new options. + - variablemanager, more efficient read of vars files + - vault secrets file now executes in the correct context when it is a symlink + (not resolved to canonical file). + - wait_for - Read file and perform comparisons using bytes to avoid decode errors + (https://github.com/ansible/ansible/issues/78214) + - winrm - Ensure ``kinit`` is run with the same ``PATH`` env var as the Ansible + process + - winrm connection now handles default to inventory_hostname correctly. + - yaml inventory plugin - fix the error message for non-string hostnames (https://github.com/ansible/ansible/issues/77519). + - yum - fix traceback when ``releasever`` is specified with ``latest`` (https://github.com/ansible/ansible/issues/78058) + deprecated_features: + - Deprecate ability of lookup plugins to return arbitrary data. Lookup plugins + must return lists, failing to do so will be an error in 2.18. (https://github.com/ansible/ansible/issues/77788) + - Encryption - Deprecate use of the Python crypt module due to it's impending + removal from Python 3.13 + - PlayContext.verbosity is deprecated and will be removed in 2.18. Use ansible.utils.display.Display().verbosity + as the single source of truth. + - '``DEFAULT_FACT_PATH``, ``DEFAULT_GATHER_SUBSET`` and ``DEFAULT_GATHER_TIMEOUT`` + are deprecated and will be removed in 2.18. Use ``module_defaults`` keyword + instead.' + - '``PlayIterator`` - deprecate ``cache_block_tasks`` and ``get_original_task`` + which are noop and unused.' + - '``Templar`` - deprecate ``shared_loader_obj`` option which is unused. ``ansible.plugins.loader`` + is used directly instead.' + - listify_lookup_plugin_terms, deprecate 'loader/dataloader' parameter as it + not used. + - vars plugins - determining whether or not to run ansible.legacy vars plugins + with the class attribute REQUIRES_WHITELIST is deprecated, set REQUIRES_ENABLED + instead. + major_changes: + - Move handler processing into new ``PlayIterator`` phase to use the configured + strategy (https://github.com/ansible/ansible/issues/65067) + - ansible - At startup the filesystem encoding and locale are checked to verify + they are UTF-8. If not, the process exits with an error reporting the errant + encoding. + - ansible - Increase minimum Python requirement to Python 3.9 for CLI utilities + and controller code + - ansible-test - At startup the filesystem encoding is checked to verify it + is UTF-8. If not, the process exits with an error reporting the errant encoding. + - ansible-test - At startup the locale is configured as ``en_US.UTF-8``, with + a fallback to ``C.UTF-8``. If neither encoding is available the process exits + with an error. If the fallback is used, a warning is displayed. In previous + versions the ``en_US.UTF-8`` locale was always requested. However, no startup + checking was performed to verify the locale was successfully configured. + minor_changes: + - Add a new "INVENTORY_UNPARSED_WARNING" flag add to hide the "No inventory + was parsed, only implicit localhost is available" warning + - "Add an 'action_plugin' field for modules in runtime.yml plugin_routing.\n\nThis + fixes module_defaults by supporting modules-as-redirected-actions\nwithout + redirecting module_defaults entries to the common action.\n\n.. code: yaml\n\n + \ plugin_routing:\n action:\n facts:\n redirect: ns.coll.eos\n + \ command:\n redirect: ns.coll.eos\n modules:\n facts:\n + \ redirect: ns.coll.eos_facts\n command:\n redirect: + ns.coll.eos_command\n\nWith the runtime.yml above for ns.coll, a task such + as\n\n.. code: yaml\n\n - hosts: all\n module_defaults:\n ns.coll.eos_facts: + {'valid_for_eos_facts': 'value'}\n ns.coll.eos_command: {'not_valid_for_eos_facts': + 'value'}\n tasks:\n - ns.coll.facts:\n\nwill end up with defaults + for eos_facts and eos_command\nsince both modules redirect to the same action.\n\nTo + select an action plugin for a module without merging\nmodule_defaults, define + an action_plugin field for the resolved\nmodule in the runtime.yml.\n\n.. + code: yaml\n\n plugin_routing:\n modules:\n facts:\n redirect: + ns.coll.eos_facts\n action_plugin: ns.coll.eos\n command:\n + \ redirect: ns.coll.eos_command\n action_plugin: ns.coll.eos\n\nThe + action_plugin field can be a redirected action plugin, as\nit is resolved + normally.\n\nUsing the modified runtime.yml, the example task will only use\nthe + ns.coll.eos_facts defaults.\n" + - Add support for parsing ``-a`` module options as JSON and not just key=value + arguments - https://github.com/ansible/ansible/issues/78112 + - Added Kylin Linux Advanced Server OS in RedHat OS Family. + - Allow ``when`` conditionals to be used on ``flush_handlers`` (https://github.com/ansible/ansible/issues/77616) + - Allow meta tasks to be used as handlers. + - Display - The display class will now proxy calls to Display.display via the + queue from forks/workers to be handled by the parent process for actual display. + This reduces some reliance on the fork start method and improves reliability + of displaying messages. + - Jinja version test - Add pep440 version_type for version test. (https://github.com/ansible/ansible/issues/78288) + - Loops - Add new ``loop_control.extended_allitems`` to allow users to disable + tracking all loop items for each loop (https://github.com/ansible/ansible/issues/75216) + - NetBSD - Add uptime_seconds fact + - Provide a `utc` option for strftime to show time in UTC rather than local + time + - Raise a proper error when ``include_role`` or ``import_role`` is used as a + handler. + - Remove the ``AnsibleContext.resolve`` method as its override is not necessary. + Furthermore the ability to override the ``resolve`` method was deprecated + in Jinja 3.0.0 and removed in Jinja 3.1.0. + - Utilize @classmethod and @property together to form classproperty (Python + 3.9) to access field attributes of a class + - '``LoopControl`` is now templated through standard ``post_validate`` method + (https://github.com/ansible/ansible/pull/75715)' + - '``ansible-galaxy collection install`` - add an ``--offline`` option to prevent + querying distribution servers (https://github.com/ansible/ansible/issues/77443).' + - ansible - Add support for Python 3.11 to Python interpreter discovery. + - ansible - At startup the stdin/stdout/stderr file handles are checked to verify + they are using blocking IO. If not, the process exits with an error reporting + which file handle(s) are using non-blocking IO. + - ansible-config adds JSON and YAML output formats for list and dump actions. + - ansible-connection now supports verbosity directly on cli + - ansible-console added 'collections' command to match playbook keyword. + - ansible-doc - remove some of the manual formatting, and use YAML more uniformly. + This in particular means that ``true`` and ``false`` are used for boolean + values, instead of ``True`` and ``False`` (https://github.com/ansible/ansible/pull/78668). + - ansible-galaxy - Support resolvelib versions 0.6.x, 0.7.x, and 0.8.x. The + full range of supported versions is now >= 0.5.3, < 0.9.0. + - ansible-galaxy now supports a user defined timeout, instead of existing hardcoded + 60s (now the default). + - ansible-test - Add FreeBSD 13.1 remote support. + - ansible-test - Add RHEL 9.0 remote support. + - ansible-test - Add support for Python 3.11. + - ansible-test - Add support for RHEL 8.6 remotes. + - ansible-test - Add support for Ubuntu VMs using the ``--remote`` option. + - ansible-test - Add support for exporting inventory with ``ansible-test shell + --export {path}``. + - ansible-test - Add support for multi-arch remotes. + - ansible-test - Add support for provisioning Alpine 3.16 remote instances. + - ansible-test - Add support for provisioning Fedora 36 remote instances. + - ansible-test - Add support for provisioning Ubuntu 20.04 remote instances. + - ansible-test - Add support for provisioning remotes which require ``doas`` + for become. + - ansible-test - Add support for running non-interactive commands with ``ansible-test + shell``. + - ansible-test - Alpine remotes now use ``sudo`` for tests, using ``doas`` only + for bootstrapping. + - ansible-test - An improved error message is shown when the download of a pip + bootstrap script fails. The download now uses ``urllib2`` instead of ``urllib`` + on Python 2. + - ansible-test - Avoid using the ``mock_use_standalone_module`` setting for + unit tests running on Python 3.8 or later. + - ansible-test - Become support for remote instance provisioning is no longer + tied to a fixed list of platforms. + - ansible-test - Blocking mode is now enforced for stdin, stdout and stderr. + If any of these are non-blocking then ansible-test will exit during startup + with an error. + - ansible-test - Distribution specific test containers are now multi-arch, supporting + both x86_64 and aarch64. + - ansible-test - Distribution specific test containers no longer contain a ``/etc/ansible/hosts`` + file. + - ansible-test - Enable loading of ``coverage`` data files created by older + supported ansible-test releases. + - ansible-test - Fedora 36 has been added as a test container. + - ansible-test - FreeBSD remotes now use ``sudo`` for tests, using ``su`` only + for bootstrapping. + - ansible-test - Improve consistency of output messages by using stdout or stderr + for most output, but not both. + - ansible-test - Remote Alpine instances now have the ``acl`` package installed. + - ansible-test - Remote Fedora instances now have the ``acl`` package installed. + - ansible-test - Remote FreeBSD instances now have ACLs enabled on the root + filesystem. + - ansible-test - Remote Ubuntu instances now have the ``acl`` package installed. + - ansible-test - Remove Fedora 34 test container. + - ansible-test - Remove Fedora 35 test container. + - ansible-test - Remove FreeBSD 13.0 remote support. + - ansible-test - Remove RHEL 8.5 remote support. + - ansible-test - Remove Ubuntu 18.04 test container. + - ansible-test - Remove support for Python 2.7 on provisioned FreeBSD instances. + - ansible-test - Remove support for Python 3.8 on the controller. + - ansible-test - Remove the ``opensuse15py2`` container. + - ansible-test - Support multiple pinned versions of the ``coverage`` module. + The version used now depends on the Python version in use. + - ansible-test - Test containers have been updated to remove the ``VOLUME`` + instruction. + - ansible-test - The Alpine 3 test container has been updated to Alpine 3.16.0. + - ansible-test - The ``http-test-container`` container is now multi-arch, supporting + both x86_64 and aarch64. + - ansible-test - The ``pypi-test-container`` container is now multi-arch, supporting + both x86_64 and aarch64. + - ansible-test - The ``shell`` command can be used outside a collection if no + controller delegation is required. + - ansible-test - The openSUSE test container has been updated to openSUSE Leap + 15.4. + - ansible-test - Ubuntu 22.04 has been added as a test container. + - ansible-test - Update pinned sanity test requirements for all tests. + - ansible-test - Update the ``base`` container to 3.4.0. + - ansible-test - Update the ``default`` containers to 6.6.0. + - apt_repository remove dependency on apt-key and use gpg + /usr/share/keyrings + directly instead + - blockinfile - The presence of the multiline flag (?m) in the regular expression + for insertafter opr insertbefore controls whether the match is done line by + line or with multiple lines (https://github.com/ansible/ansible/pull/75090). + - calls to listify_lookup_plugin_terms in core do not pass in loader/dataloader + anymore. + - collections - ``ansible-galaxy collection build`` can now utilize ``MANIFEST.in`` + style directives from ``galaxy.yml`` instead of ``build_ignore`` effectively + inverting the logic from include by default, to exclude by default. (https://github.com/ansible/ansible/pull/78422) + - config manager, move templating into main query function in config instead + of constants + - config manager, remove updates to configdata as it is mostly unused + - configuration entry INTERPRETER_PYTHON_DISTRO_MAP is now 'private' and won't + show up in normal configuration queries and docs, since it is not 'settable' + this avoids user confusion. + - distribution - add distribution_minor_version for Debian Distro (https://github.com/ansible/ansible/issues/74481). + - documentation construction now gives more information on error. + - facts - add OSMC to Debian os_family mapping + - get_url - permit to pass to parameter ``checksum`` an URL pointing to a file + containing only a checksum (https://github.com/ansible/ansible/issues/54390). + - new tests url, uri and urn will verify string as such, but they don't check + existance of the resource + - plugin loader - add ansible_name and ansible_aliases attributes to plugin + objects/classes. + - systemd is now systemd_service to better reflect the scope of the module, + systemd is kept as an alias for backwards compatibility. + - templating - removed internal template cache + - uri - cleanup write_file method, remove overkill safety checks and report + any exception, change shutilcopyfile to use module.atomic_move + - urls - Add support to specify SSL/TLS ciphers to use during a request (https://github.com/ansible/ansible/issues/78633) + - 'validate-modules - Allow ``type: raw`` on a module return type definition + for values that have a dynamic type' + - version output now includes the path to the python executable that Ansible + is running under + - yum_repository - do not give the ``async`` parameter a default value anymore, + since this option is deprecated in RHEL 8. This means that ``async = 1`` won't + be added to repository files if omitted, but it can still be set explicitly + if needed. + release_summary: '| Release Date: 2022-09-26 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + removed_features: + - PlayIterator - remove deprecated ``PlayIterator.ITERATING_*`` and ``PlayIterator.FAILED_*`` + - Remove deprecated ``ALLOW_WORLD_READABLE_TMPFILES`` configuration option (https://github.com/ansible/ansible/issues/77393) + - Remove deprecated ``COMMAND_WARNINGS`` configuration option (https://github.com/ansible/ansible/issues/77394) + - Remove deprecated ``DISPLAY_SKIPPED_HOSTS`` environment variable (https://github.com/ansible/ansible/issues/77396) + - Remove deprecated ``LIBVIRT_LXC_NOSECLABEL`` environment variable (https://github.com/ansible/ansible/issues/77395) + - Remove deprecated ``NETWORK_GROUP_MODULES`` environment variable (https://github.com/ansible/ansible/issues/77397) + - Remove deprecated ``UnsafeProxy`` + - Remove deprecated ``plugin_filters_cfg`` config option from ``default`` section + (https://github.com/ansible/ansible/issues/77398) + - Remove deprecated functionality that allows loading cache plugins directly + without using ``cache_loader``. + - Remove deprecated functionality that allows subclassing ``DefaultCallback`` + without the corresponding ``doc_fragment``. + - Remove deprecated powershell functions ``Load-CommandUtils`` and ``Import-PrivilegeUtil`` + - apt_key - remove deprecated ``key`` module param + - command/shell - remove deprecated ``warn`` module param + - get_url - remove deprecated ``sha256sum`` module param + - import_playbook - remove deprecated functionality that allows providing additional + parameters in free form + codename: C'mon Everybody + fragments: + - 17393-fix_silently_failing_lvm_facts.yaml + - 23161-includes-loops-rescue.yml + - 29680-fetch-file-file-name-too-long.yml + - 43191-72638-ansible_failed_task-fixes.yml + - 56017-allow-lazy-eval-on-jinja2-expr.yml + - 58632-uri-include_use_proxy.yaml + - 61965-user-module-fails-to-change-primary-group.yml + - 64612-fetch_file-multi-part-extension.yml + - 65499-no_inventory_parsed.yml + - 70180-collection-list-more-robust.yml + - 73072-dnf-skip-broken.yml + - 74446-network-conn-options.yaml + - 74481_debian_minor_version.yml + - 75042-lowercase-dash-n-with-luseradd-on-all-distros.yml + - 75090-multiline-flag-support-for-blockinfile.yml + - 75216-loop-control-extended-allitems.yml + - 75364-yum-repository-async.yml + - 75431-Add-uptime-fact-for-NetBSD.yml + - 75715-post_validate-LoopControl.yml + - 75740-remove-travis-file-from-role-skeletons.yml + - 76167-update-attributes-of-files-that-are-links.yml + - 76737-paramiko-rsa-sha2.yml + - 76971-unarchive-remove-unnecessary-zipinfo-dependency.yml + - 77014-ansible-galaxy-list-fix-null-metadata-namespace-name.yml + - 77265-module_defaults-with-modules-as-redirected-actions.yaml + - 77315-fix-meta-vv-header.yml + - 77393-remove-allow_world_readable_tmpfiles.yml + - 77394-remove-command_warnings.yml + - 77395-remove-libvirt_lxc_noseclabel.yml + - 77396-remove-display_skipped_hosts.yml + - 77397-remove-network_group_modules.yml + - 77398-remove-plugin_filters_cfg-default.yml + - 77418-ansible-galaxy-init-include-meta-runtime.yml + - 77424-fix-False-ansible-galaxy-server-config-options.yaml + - 77465-ansible-test-compile-crash.yml + - 77468-ansible-galaxy-remove-unnecessary-api-call.yml + - 77472-ansible-test-network-disconnect-warning.yml + - 77493-ansible-galaxy-find-git-executable-before-using.yaml + - 77507-deprecate-pc-verbosity.yml + - 77535-prevent-losing-unsafe-lookups.yml + - 77544-fix-error-yaml-inventory-int-hostnames.yml + - 77561-ansible-galaxy-coll-install-null-dependencies.yml + - 77576-arg_spec-no_log-aliases.yml + - 77599-add-url-include-deprecation.yml + - 77630-ansible-galaxy-fix-unsupported-resolvelib-version.yml + - 77649-support-recent-resolvelib-versions.yml + - 77679-syntax-error-mention-filename.yml + - 77693-actually-ignore-unreachable.yml + - 77781-callback-crash.yml + - 77788-deprecate-non-lists-lookups.yml + - 77789-catch-keyerror-lookup-dict.yml + - 77792-fix-facts-discovery-specific-interface-names.yml + - 77898-ansible-config-dump-only-changed-all-types.yml + - 77934-empty-loop-template-callback.yml + - 77936-add-pyyaml-version.yml + - 77969-apt-preferences.yml + - 78050-replace-spwd.yml + - 78058-yum-releasever-latest.yml + - 78112-adhoc-args-as-json.yml + - 78141-template-fix-convert_data.yml + - 78156-undefined-check-in-finalize.yml + - 78204-galaxy-role-file-detection.yml + - 78214-wait-for-compare-bytes.yml + - 78223_aix_fix_processor_facts.yml + - 78295-dnf-fix-comparison-operators-docs.yml + - 78325-ansible-galaxy-fix-caching-paginated-responses-from-v3-servers.yml + - 78496-fix-apt-check-mode.yml + - 78512-uri-use-netrc-true-false-argument.yml + - 78516-galaxy-cli-exit-codes.yml + - 78562-deprecate-vars-plugin-attr.yml + - 78612-rescue-block-ansible_play_hosts.yml + - 78633-urls-ciphers.yml + - 78648-urllib3-import-exceptions.yml + - 78668-ansible-doc-formatting.yml + - 78678-add-a-g-install-offline.yml + - 78700-add-plugin-name-and-aliases.yml + - 78750-paramiko-ssh-args-compat.yml + - 78781-fix-apt-only_upgrade-behavior.yml + - abstract_errors_info.yml + - add-omsc-os-family.yml + - added_uri_tests.yml + - adoc_moarf.yml + - aix_chmod_255.yml + - ansible-connection_decode.yml + - ansible-console-renamed-arg.yml + - ansible-galaxy-collection-init-force.yml + - ansible-require-blocking-io.yml + - ansible-require-utf8.yml + - ansible-test-ansible-core-mock.yml + - ansible-test-ansible-doc-sanity-fqcn.yml + - ansible-test-container-tmpfs.yml + - ansible-test-containers-no-volume.yml + - ansible-test-content-config.yml + - ansible-test-coverage.yml + - ansible-test-default-containers.yml + - ansible-test-distro-containers-hosts.yml + - ansible-test-distro-containers.yml + - ansible-test-drop-python-3.8-controller.yml + - ansible-test-fedora-35.yml + - ansible-test-filter-options.yml + - ansible-test-generalize-become.yml + - ansible-test-integration-targets-filter.yml + - ansible-test-less-python-2.7.yml + - ansible-test-locale.yml + - ansible-test-more-remotes.yml + - ansible-test-multi-arch-cloud-containers.yml + - ansible-test-multi-arch-distro-containers.yml + - ansible-test-multi-arch-remotes.yml + - ansible-test-pip-bootstrap.yml + - ansible-test-podman-create-retry.yml + - ansible-test-remote-acl.yml + - ansible-test-remote-become.yml + - ansible-test-remote-completion-validation.yml + - ansible-test-remotes.yml + - ansible-test-rhel-8.6.yml + - ansible-test-sanity-requirements.yml + - ansible-test-self-change-classification.yml + - ansible-test-shell-features.yml + - ansible-test-subprocess-isolation.yml + - ansible-test-target-filter.yml + - ansible-test-target-options.yml + - ansible-test-tty-output-handling.yml + - ansible-test-ubuntu-bootstrap-fix.yml + - ansible-test-ubuntu-remote.yml + - ansible-test-validate-modules-docs-only-docstring.yml + - ansible-test-verify-executables.yml + - ansible_connection_verbosity.yml + - apt_key-remove-deprecated-key.yml + - apt_repository_sans_apt_key.yml + - apt_virtual_fix.yml + - atomic_cache_files.yml + - better-msg-role-in-handler.yml + - better_info_sources.yml + - better_nohosts_error.yml + - collection-build-manifest.yml + - config_error_origin.yml + - config_formats.yml + - config_load_by_name.yml + - config_manager_changes.yml + - console_list_all.yml + - deprecate-crypt-support.yml + - deprecate-fact_path-gather_subset-gather_timeout-defaults.yml + - display_verbosity.yml + - dnf-fix-locale-language.yml + - doc_errors.yml + - doc_vac_ignore.yml + - dont-expose-included-handlers.yml + - ensure_config_always_templated.yml + - fieldattributes-classproperty.yml + - fix-change-while-iterating-module-utils-service.yml + - fix_adoc_text.yml + - fix_init_commented.yml + - fix_inv_refresh.yml + - forked-display-via-queue.yml + - galaxy_server_timeout.yml + - get_url-accept-file-for-checksum.yml + - get_url-remove-deprecated-sha256sum.yml + - git_fixes.yml + - handle-role-dependency-type-error.yml + - hide_distro_map.yml + - import_playbook-remove-params.yml + - items2dict-error-handling.yml + - kylin_linux_advanced_server_distribution_support.yml + - legacy_no_file_skip.yml + - loader_in_listify.yml + - local_fact_unreadable.yml + - null_means_none.yml + - opensuse_disto_id.yml + - password_lookup_fix.yml + - pause_echo_fix.yml + - pep440-version-type.yml + - permission-denied-spwd-module.yml + - pip-lazy-import.yml + - play_iterator-remove_deprecations.yml + - play_iterator_iterating_handlers.yml + - playiterator-deprecate-methods.yml + - plugin-loader-deterministic-fuzzy-match.yml + - powershell-deprecated-functions.yml + - python-2.6-discovery.yml + - python-3.11.yml + - python39-min-controller.yml + - python_version_path.yml + - remove-ansiblecontext-resolve.yml + - remove-deprecated-default-callback-without-doc.yml + - remove-import-cache-plugin-directly.yml + - require-fqcn-redirects.yml + - restrict_role_files_to_role.yml + - self_referential.yml + - shell_env_typeerror.yml + - strftime-in-utc.yml + - systemd_services.yml + - templar-correct-environment_class-template.yml + - templar-deprecate-shared_loader_obj.yml + - template_override.yml + - type_shim_exception_swallow.yml + - unsafeproxy-deprecated.yml + - until_also_implicit.yml + - use-before-definition.yml + - v2.14.0-initial-commit.yaml + - v2.14.0b1_summary.yaml + - validate-modules-module-raw-return-type.yml + - validate-modules-version_added.yaml + - vault_syml_allow.yml + - vm_more_efficient.yml + - windows_conn_option_fix.yml + - winrm-kinit-path.yml + - write_file_uri_cleanup.yml + - zap_template_cache.yml + release_date: '2022-09-26' + 2.14.0b2: + changes: + breaking_changes: + - ansible-test validate-modules - Removed the ``missing-python-doc`` error code + in validate modules, ``missing-documentation`` is used instead for missing + PowerShell module documentation. + bugfixes: + - Fix reusing a connection in a task loop that uses a redirected or aliased + name - https://github.com/ansible/ansible/issues/78425 + - Fix setting become activation in a task loop - https://github.com/ansible/ansible/issues/78425 + - apt module should not traceback on invalid type given as package. issue 78663. + - known_hosts - do not return changed status when a non-existing key is removed + (https://github.com/ansible/ansible/issues/78598) + - plugin loader, fix detection for existing configuration before initializing + for a plugin + minor_changes: + - ansible-test validate-modules - Added support for validating module documentation + stored in a sidecar file alongside the module (``{module}.yml`` or ``{module}.yaml``). + Previously these files were ignored and documentation had to be placed in + ``{module}.py``. + - apt_repository will use the trust repo directories in order of preference + (more appropriate to less) as they exist on the target. + release_summary: '| Release Date: 2022-10-03 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 78881-fix-known-hosts-wrong-changed-status.yaml + - apt_notb.yml + - apt_repo_trust_prefs.yml + - become-loop-setting.yml + - plugin_loader_fix.yml + - v2.14.0b2_summary.yaml + - validate-modules-sidecar.yml + release_date: '2022-10-03' + 2.14.0b3: + changes: + bugfixes: + - Do not crash when templating an expression with a test or filter that is not + a valid Ansible filter name (https://github.com/ansible/ansible/issues/78912, + https://github.com/ansible/ansible/pull/78913). + - 'handlers - fix an issue where the ``flush_handlers`` meta task could not + be used with FQCN: ``ansible.builtin.meta`` (https://github.com/ansible/ansible/issues/79023)' + - keyword inheritance - Ensure that we do not squash keywords in validate (https://github.com/ansible/ansible/issues/79021) + - omit on keywords was resetting to default value, ignoring inheritance. + - service_facts - Use python re to parse service output instead of grep (https://github.com/ansible/ansible/issues/78541) + release_summary: '| Release Date: 2022-10-10 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 78541-service-facts-re.yml + - 78913-template-missing-filter-test.yml + - 79021-dont-squash-in-validate.yml + - 79023-fix-flush_handlers-fqcn.yml + - fix_omit_key.yml + - v2.14.0b3_summary.yaml + plugins: + test: + - description: is the string a valid URI + name: uri + namespace: null + - description: is the string a valid URL + name: url + namespace: null + - description: is the string a valid URN + name: urn + namespace: null + release_date: '2022-10-10' + 2.14.0rc1: + changes: + bugfixes: + - BSD network facts - Do not assume column indexes, look for ``netmask`` and + ``broadcast`` for determining the correct columns when parsing ``inet`` line + (https://github.com/ansible/ansible/issues/79117) + - ansible-config limit shorthand format to assigned values + - ansible-test - Update the ``pylint`` sanity test to use version 2.15.4. + release_summary: '| Release Date: 2022-10-17 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 79117-bsd-ifconfig-inet-fix.yml + - adjust_config_list.yml + - ansible-test-pylint-2.15.4.yml + - v2.14.0rc1_summary.yaml + release_date: '2022-10-13' + 2.14.0rc2: + changes: + bugfixes: + - ansible-test - Add ``wheel < 0.38.0`` constraint for Python 3.6 and earlier. + - ansible-test - Update the ``pylint`` sanity test requirements to resolve crashes + on Python 3.11. (https://github.com/ansible/ansible/issues/78882) + - ansible-test - Update the ``pylint`` sanity test to use version 2.15.5. + minor_changes: + - ansible-test - Update ``base`` and ``default`` containers to include Python + 3.11.0. + - ansible-test - Update ``default`` containers to include new ``docs-build`` + sanity test requirements. + release_summary: '| Release Date: 2022-10-31 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 79187--wheel-0.38.0.yml + - ansible-test-containers-docs-build.yml + - ansible-test-containers-python-3.11.0.yml + - ansible-test-pylint-2.15.5.yml + - v2.14.0rc2_summary.yaml + release_date: '2022-10-31' + 2.14.1: + changes: + bugfixes: + - display - reduce risk of post-fork output deadlocks (https://github.com/ansible/ansible/pull/79522) + release_summary: '| Release Date: 2022-12-06 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - fork_safe_stdio.yml + - v2.14.1_summary.yaml + release_date: '2022-12-06' + 2.14.10: + changes: + release_summary: '| Release Date: 2023-09-11 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.10_summary.yaml + release_date: '2023-09-11' + 2.14.10rc1: + changes: bugfixes: - - Allow for searching handler subdir for included task via include_role (https://github.com/ansible/ansible/issues/81722) - - AnsibleModule.run_command - Only use selectors when needed, and rely on Python - stdlib subprocess for the simple task of collecting stdout/stderr when prompt - matching is not required. - - Display - Defensively configure writing to stdout and stderr with a custom - encoding error handler that will replace invalid characters while providing - a deprecation warning that non-utf8 text will result in an error in a future - version. - - Exclude internal options from man pages and docs. - - Fix ``ansible-config init`` man page option indentation. - - Fix ``ast`` deprecation warnings for ``Str`` and ``value.s`` when using Python - 3.12. - - Fix exceptions caused by various inputs when performing arg splitting or parsing - key/value pairs. Resolves issue https://github.com/ansible/ansible/issues/46379 - and issue https://github.com/ansible/ansible/issues/61497 - - Fix incorrect parsing of multi-line Jinja2 blocks when performing arg splitting - or parsing key/value pairs. - - Fix post-validating looped task fields so the strategy uses the correct values - after task execution. - - Fixed `pip` module failure in case of usage quotes for `virtualenv_command` - option for the venv command. (https://github.com/ansible/ansible/issues/76372) - - From issue https://github.com/ansible/ansible/issues/80880, when notifying - a handler from another handler, handler notifications must be registered immediately - as the flush_handler call is not recursive. - - Import ``FILE_ATTRIBUTES`` from ``ansible.module_utils.common.file`` in ``ansible.module_utils.basic`` - instead of defining it twice. - - Inventory scripts parser not treat exception when getting hostsvar (https://github.com/ansible/ansible/issues/81103) - - On Python 3 use datetime methods ``fromtimestamp`` and ``now`` with UTC timezone - instead of ``utcfromtimestamp`` and ``utcnow``, which are deprecated in Python - 3.12. - - PluginLoader - fix Jinja plugin performance issues (https://github.com/ansible/ansible/issues/79652) - PowerShell - Remove some code which is no longer valid for dotnet 5+ - - Prevent running same handler multiple times when included via ``include_role`` - (https://github.com/ansible/ansible/issues/73643) - - Prompting - add a short sleep between polling for user input to reduce CPU - consumption (https://github.com/ansible/ansible/issues/81516). - - Properly disable ``jinja2_native`` in the template module when jinja2 override - is used in the template (https://github.com/ansible/ansible/issues/80605) - - Remove unreachable parser error for removed ``static`` parameter of ``include_role`` - - Replace uses of ``configparser.ConfigParser.readfp()`` which was removed in - Python 3.12 with ``configparser.ConfigParser.read_file()`` (https://github.com/ansible/ansible/issues/81656) - - Set filters ``intersect``, ``difference``, ``symmetric_difference`` and ``union`` - now always return a ``list``, never a ``set``. Previously, a ``set`` would - be returned if the inputs were a hashable type such as ``str``, instead of - a collection, such as a ``list`` or ``tuple``. - - Set filters ``intersect``, ``difference``, ``symmetric_difference`` and ``union`` - now use set operations when the given items are hashable. Previously, list - operations were performed unless the inputs were a hashable type such as ``str``, - instead of a collection, such as a ``list`` or ``tuple``. - - Switch result queue from a ``multiprocessing.queues.Queue` to ``multiprocessing.queues.SimpleQueue``, - primarily to allow properly handling pickling errors, to prevent an infinite - hang waiting for task results - - The ``ansible-config init`` command now has a documentation description. - - The ``ansible-galaxy collection download`` command now has a documentation - description. - - The ``ansible-galaxy collection install`` command documentation is now visible - (previously hidden by a decorator). - - The ``ansible-galaxy collection verify`` command now has a documentation description. - - The ``ansible-galaxy role install`` command documentation is now visible (previously - hidden by a decorator). - - The ``ansible-inventory`` command command now has a documentation description - (previously used as the epilog). - - The ``hostname`` module now also updates both current and permanent hostname - on OpenBSD. Before it only updated the permanent hostname (https://github.com/ansible/ansible/issues/80520). - - Update module_utils.urls unit test to work with cryptography >= 41.0.0. - - When generating man pages, use ``func`` to find the command function instead - of looking it up by the command name. - - '``StrategyBase._process_pending_results`` - create a ``Templar`` on demand - for templating ``changed_when``/``failed_when``.' - - '``ansible-galaxy`` now considers all collection paths when identifying which - collection requirements are already installed. Use the ``COLLECTIONS_PATHS`` - and ``COLLECTIONS_SCAN_SYS_PATHS`` config options to modify these. Previously - only the install path was considered when resolving the candidates. The install - path will remain the only one potentially modified. (https://github.com/ansible/ansible/issues/79767, - https://github.com/ansible/ansible/issues/81163)' - - '``ansible.module_utils.service`` - ensure binary data transmission in ``daemonize()``' - - '``ansible.module_utils.service`` - fix inter-process communication in ``daemonize()``' - - '``pkg_mgr`` - fix the default dnf version detection' - - ansiballz - Prevent issue where the time on the control host could change - part way through building the ansiballz file, potentially causing a pre-1980 - date to be used during ansiballz unpacking leading to a zip file error (https://github.com/ansible/ansible/issues/80089) - - ansible terminal color settings were incorrectly limited to 16 options via - 'choices', removing so all 256 can be accessed. - - ansible-console - fix filtering by collection names when a collection search - path was set (https://github.com/ansible/ansible/pull/81450). - ansible-galaxy - Enabled the ``data`` tarfile filter during role installation for Python versions that support it. A probing mechanism is used to avoid Python versions with a broken implementation. - - ansible-galaxy - Fix issue installing collections containing directories with - more than 100 characters on python versions before 3.10.6 - - ansible-galaxy - Fix variable type error when installing subdir collections - (https://github.com/ansible/ansible/issues/80943) - - ansible-galaxy - fix installing collections from directories that have a trailing - path separator (https://github.com/ansible/ansible/issues/77803). - - ansible-galaxy - fix installing signed collections (https://github.com/ansible/ansible/issues/80648). - - ansible-galaxy - reduce API calls to servers by fetching signatures only for - final candidates. - - ansible-galaxy - started allowing the use of pre-releases for collections - that do not have any stable versions published. (https://github.com/ansible/ansible/pull/81606) - - ansible-galaxy - started allowing the use of pre-releases for dependencies - on any level of the dependency tree that specifically demand exact pre-release - versions of collections and not version ranges. (https://github.com/ansible/ansible/pull/81606) - - ansible-galaxy collection verify - fix verifying signed collections when the - keyring is not configured. - - ansible-test - Add support for ``argcomplete`` version 3. - - ansible-test - All containers created by ansible-test now include the current - test session ID in their name. This avoids conflicts between concurrent ansible-test - invocations using the same container host. - ansible-test - Always use ansible-test managed entry points for ansible-core CLI tools when not running from source. This fixes issues where CLI entry points created during install are not compatible with ansible-test. - - ansible-test - Fix a traceback that occurs when attempting to test Ansible - source using a different ansible-test. A clear error message is now given - when this scenario occurs. - - ansible-test - Fix handling of timeouts exceeding one day. - - ansible-test - Fix several possible tracebacks when using the ``-e`` option - with sanity tests. - - ansible-test - Fix various cases where the test timeout could expire without - terminating the tests. - - ansible-test - Pre-build a PyYAML wheel before installing requirements to - avoid a potential Cython build failure. - - ansible-test - Remove redundant warning about missing programs before attempting - to execute them. - - ansible-test - The ``import`` sanity test now checks the collection loader - for remote-only Python support when testing ansible-core. - - ansible-test - Unit tests now report warnings generated during test runs. - Previously only warnings generated during test collection were reported. - - ansible-test - Update ``pylint`` to 2.17.2 to resolve several possible false - positives. - - ansible-test - Update ``pylint`` to 2.17.3 to resolve several possible false - positives. - - ansible-test - Use ``raise ... from ...`` when raising exceptions from within - an exception handler. - - ansible-test - When bootstrapping remote FreeBSD instances, use the OS packaged - ``setuptools`` instead of installing the latest version from PyPI. - - ansible-test local change detection - use ``git merge-base <branch> HEAD`` - instead of ``git merge-base --fork-point <branch>`` (https://github.com/ansible/ansible/pull/79734). - - ansible-vault - fail when the destination file location is not writable before - performing encryption (https://github.com/ansible/ansible/issues/81455). - - apt - ignore fail_on_autoremove and allow_downgrade parameters when using - aptitude (https://github.com/ansible/ansible/issues/77868). - - blockinfile - avoid crash with Python 3 if creating the directory fails when - ``create=true`` (https://github.com/ansible/ansible/pull/81662). - - connection timeouts defined in ansible.cfg will now be properly used, the - --timeout cli option was obscuring them by always being set. - - copy - print correct destination filename when using `content` and `--diff` - (https://github.com/ansible/ansible/issues/79749). - - copy unit tests - Fixing "dir all perms" documentation and formatting for - easier reading. - - core will now also look at the connection plugin to force 'local' interpreter - for networking path compatibility as just ansible_network_os could be misleading. - - deb822_repository - use http-agent for receiving content (https://github.com/ansible/ansible/issues/80809). - - debconf - idempotency in questions with type 'password' (https://github.com/ansible/ansible/issues/47676). - - distribution facts - fix Source Mage family mapping - - dnf - fix a failure when a package from URI was specified and ``update_only`` - was set (https://github.com/ansible/ansible/issues/81376). - - dnf5 - Update dnf5 module to handle API change for setting the download directory - (https://github.com/ansible/ansible/issues/80887) - - dnf5 - Use ``transaction.check_gpg_signatures`` API call to check package - signatures AND possibly to recover from when keys are missing. - - dnf5 - fix module and package names in the message following failed module - respawn attempt - - dnf5 - use the logs API to determine transaction problems - - dpkg_selections - check if the package exists before performing the selection - operation (https://github.com/ansible/ansible/issues/81404). - - encrypt - deprecate passlib_or_crypt API (https://github.com/ansible/ansible/issues/55839). - - fetch - Handle unreachable errors properly (https://github.com/ansible/ansible/issues/27816) - - file modules - Make symbolic modes with X use the computed permission, not - original file (https://github.com/ansible/ansible/issues/80128) - - file modules - fix validating invalid symbolic modes. - - first found lookup has been updated to use the normalized argument parsing - (pythonic) matching the documented examples. - - first found lookup, fixed an issue with subsequent items clobbering information - from previous ones. - - first_found lookup now gets 'untemplated' loop entries and handles templating - itself as task_executor was removing even 'templatable' entries and breaking - functionality. https://github.com/ansible/ansible/issues/70772 - - galaxy - check if the target for symlink exists (https://github.com/ansible/ansible/pull/81586). - - galaxy - cross check the collection type and collection source (https://github.com/ansible/ansible/issues/79463). - - gather_facts parallel option was doing the reverse of what was stated, now - it does run modules in parallel when True and serially when False. - - handlers - fix ``v2_playbook_on_notify`` callback not being called when notifying - handlers - - handlers - the ``listen`` keyword can affect only one handler with the same - name, the last one defined as it is a case with the ``notify`` keyword (https://github.com/ansible/ansible/issues/81013) - - include_role - expose variables from parent roles to role's handlers (https://github.com/ansible/ansible/issues/80459) - - inventory_ini - handle SyntaxWarning while parsing ini file in inventory (https://github.com/ansible/ansible/issues/81457). - - iptables - remove default rule creation when creating iptables chain to be - more similar to the command line utility (https://github.com/ansible/ansible/issues/80256). - - lib/ansible/utils/encrypt.py - remove unused private ``_LOCK`` (https://github.com/ansible/ansible/issues/81613) - - lookup/url.py - Fix incorrect var/env/ini entry for `force_basic_auth` - - man page build - Remove the dependency on the ``docs`` directory for building - man pages. - - man page build - Sub commands of ``ansible-galaxy role`` and ``ansible-galaxy - collection`` are now documented. - - module responses - Ensure that module responses are utf-8 adhereing to JSON - RFC and expectations of the core code. - - module/role argument spec - validate the type for options that are None when - the option is required or has a non-None default (https://github.com/ansible/ansible/issues/79656). - - modules/user.py - Add check for valid directory when creating new user homedir - (allows /dev/null as skeleton) (https://github.com/ansible/ansible/issues/75063) - - paramiko_ssh, psrp, and ssh connection plugins - ensure that all values for - options that should be strings are actually converted to strings (https://github.com/ansible/ansible/pull/81029). - - password_hash - fix salt format for ``crypt`` (only used if ``passlib`` is - not installed) for the ``bcrypt`` algorithm. - - pep517 build backend - Copy symlinks when copying the source tree. This avoids - tracebacks in various scenarios, such as when a venv is present in the source - tree. - - pep517 build backend - Use the documented ``import_module`` import from ``importlib``. - - pip module - Update module to prefer use of the python ``packaging`` and ``importlib.metadata`` - modules due to ``pkg_resources`` being deprecated (https://github.com/ansible/ansible/issues/80488) - - pkg_mgr.py - Fix `ansible_pkg_mgr` incorrect in TencentOS Server Linux - - pkg_mgr.py - Fix `ansible_pkg_mgr` is unknown in Kylin Linux (https://github.com/ansible/ansible/issues/81332) - - powershell modules - Only set an rc of 1 if the PowerShell pipeline signaled - an error occurred AND there are error records present. Previously it would - do so only if the error signal was present without checking the error count. - - replace - handle exception when bad escape character is provided in replace - (https://github.com/ansible/ansible/issues/79364). - - role deduplication - don't deduplicate before a role has had a task run for - that particular host (https://github.com/ansible/ansible/issues/81486). - - service module, does not permanently configure flags flags on Openbsd when - enabling/disabling a service. - - service module, enable/disable is not a exclusive action in checkmode anymore. - - setup gather_timeout - Fix timeout in get_mounts_facts for linux. - - setup module (fact gathering) will now try to be smarter about different versions - of facter emitting error when --puppet flag is used w/o puppet. - - syntax check - Limit ``--syntax-check`` to ``ansible-playbook`` only, as that - is the only CLI affected by this argument (https://github.com/ansible/ansible/issues/80506) - tarfile - handle data filter deprecation warning message for extract and extractall (https://github.com/ansible/ansible/issues/80832). - - template - Fix for formatting issues when a template path contains valid jinja/strftime - pattern (especially line break one) and using the template path in ansible_managed - (https://github.com/ansible/ansible/pull/79129) - - templating - In the template action and lookup, use local jinja2 environment - overlay overrides instead of mutating the templars environment - - templating - prevent setting arbitrary attributes on Jinja2 environments via - Jinja2 overrides in templates - - templating escape and single var optimization now use correct delimiters when - custom ones are provided either via task or template header. - - unarchive - fix unarchiving sources that are copied to the remote node using - a relative temporory directory path (https://github.com/ansible/ansible/issues/80710). - - uri - fix search for JSON type to include complex strings containing '+' - - urls.py - fixed cert_file and key_file parameters when running on Python 3.12 - - https://github.com/ansible/ansible/issues/80490 - - user - set expiration value correctly when unable to retrieve the current - value from the system (https://github.com/ansible/ansible/issues/71916) - - validate-modules sanity test - replace semantic markup parsing and validating - code with the code from `antsibull-docs-parser 0.2.0 <https://github.com/ansible-community/antsibull-docs-parser/releases/tag/0.2.0>`__ - (https://github.com/ansible/ansible/pull/80406). - - vars_prompt - internally convert the ``unsafe`` value to ``bool`` - - vault and unvault filters now properly take ``vault_id`` parameter. - - win_fetch - Add support for using file with wildcards in file name. (https://github.com/ansible/ansible/issues/73128) - deprecated_features: - - Deprecated ini config option ``collections_paths``, use the singular form - ``collections_path`` instead - - Deprecated the env var ``ANSIBLE_COLLECTIONS_PATHS``, use the singular form - ``ANSIBLE_COLLECTIONS_PATH`` instead - - Support for Windows Server 2012 and 2012 R2 has been removed as the support - end of life from Microsoft is October 10th 2023. These versions of Windows - will no longer be tested in this Ansible release and it cannot be guaranteed - that they will continue to work going forward. - - '``STRING_CONVERSION_ACTION`` config option is deprecated as it is no longer - used in the Ansible Core code base.' - - the 'smart' option for setting a connection plugin is being removed as its - main purpose (choosing between ssh and paramiko) is now irrelevant. - - vault and unfault filters - the undocumented ``vaultid`` parameter is deprecated - and will be removed in ansible-core 2.20. Use ``vault_id`` instead. - - yum_repository - deprecated parameter 'keepcache' (https://github.com/ansible/ansible/issues/78693). - known_issues: - - ansible-galaxy - dies in the middle of installing a role when that role contains - Java inner classes (files with $ in the file name). This is by design, to - exclude temporary or backup files. (https://github.com/ansible/ansible/pull/81553). - - ansible-test - The ``pep8`` sanity test is unable to detect f-string spacing - issues (E201, E202) on Python 3.10 and 3.11. They are correctly detected under - Python 3.12. See (https://github.com/PyCQA/pycodestyle/issues/1190). minor_changes: - - Add Python type hints to the Display class (https://github.com/ansible/ansible/issues/80841) - - Add ``GALAXY_COLLECTIONS_PATH_WARNING`` option to disable the warning given - by ``ansible-galaxy collection install`` when installing a collection to a - path that isn't in the configured collection paths. - - Add ``python3.12`` to the default ``INTERPRETER_PYTHON_FALLBACK`` list. - - Add ``utcfromtimestamp`` and ``utcnow`` to ``ansible.module_utils.compat.datetime`` - to return fixed offset datetime objects. - - Add a general ``GALAXY_SERVER_TIMEOUT`` config option for distribution servers - (https://github.com/ansible/ansible/issues/79833). - - Added Python type annotation to connection plugins - - CLI argument parsing - Automatically prepend to the help of CLI arguments - that support being specified multiple times. (https://github.com/ansible/ansible/issues/22396) - - DEFAULT_TRANSPORT now defaults to 'ssh', the old 'smart' option is being deprecated - as versions of OpenSSH without control persist are basically not present anymore. - - Documentation for set filters ``intersect``, ``difference``, ``symmetric_difference`` - and ``union`` now states that the returned list items are in arbitrary order. - - Record ``removal_date`` in runtime metadata as a string instead of a date. - - Remove the ``CleansingNodeVisitor`` class and its usage due to the templating - changes that made it superfluous. Also simplify the ``Conditional`` class. - - Removed ``exclude`` and ``recursive-exclude`` commands for generated files - from the ``MANIFEST.in`` file. These excludes were unnecessary since releases - are expected to be built with a clean worktree. - - Removed ``exclude`` commands for sanity test files from the ``MANIFEST.in`` - file. These tests were previously excluded because they did not pass when - run from an sdist. However, sanity tests are not expected to pass from an - sdist, so excluding some (but not all) of the failing tests makes little sense. - - Removed redundant ``include`` commands from the ``MANIFEST.in`` file. These - includes either duplicated default behavior or another command. - - The ``ansible-core`` sdist no longer contains pre-generated man pages. Instead, - a ``packaging/cli-doc/build.py`` script is included in the sdist. This script - can generate man pages and standalone RST documentation for ``ansible-core`` - CLI programs. - - The ``docs`` and ``examples`` directories are no longer included in the ``ansible-core`` - sdist. These directories have been moved to the https://github.com/ansible/ansible-documentation - repository. - - The minimum required ``setuptools`` version is now 66.1.0, as it is the oldest - version to support Python 3.12. - - Update ``ansible_service_mgr`` fact to include init system for SMGL OS family - - Use ``ansible.module_utils.common.text.converters`` instead of ``ansible.module_utils._text``. - - Use ``importlib.resources.abc.TraversableResources`` instead of deprecated - ``importlib.abc.TraversableResources`` where available (https:/github.com/ansible/ansible/pull/81082). - - Use ``include`` where ``recursive-include`` is unnecessary in the ``MANIFEST.in`` - file. - - Use ``package_data`` instead of ``include_package_data`` for ``setup.cfg`` - to avoid ``setuptools`` warnings. - - Utilize gpg check provided internally by the ``transaction.run`` method as - oppose to calling it manually. - - '``Templar`` - do not add the ``dict`` constructor to ``globals`` as all required - Jinja2 versions already do so' - - ansible-doc - allow to filter listing of collections and metadata dump by - more than one collection (https://github.com/ansible/ansible/pull/81450). - - ansible-galaxy - Add a plural option to improve ignoring multiple signature - error status codes when installing or verifying collections. A space-separated - list of error codes can follow --ignore-signature-status-codes in addition - to specifying --ignore-signature-status-code multiple times (for example, - ``--ignore-signature-status-codes NO_PUBKEY UNEXPECTED``). - - ansible-galaxy - Remove internal configuration argument ``v3`` (https://github.com/ansible/ansible/pull/80721) - - ansible-galaxy - add note to the collection dependency resolver error message - about pre-releases if ``--pre`` was not provided (https://github.com/ansible/ansible/issues/80048). - - ansible-galaxy - used to crash out with a "Errno 20 Not a directory" error - when extracting files from a role when hitting a file with an illegal name - (https://github.com/ansible/ansible/pull/81553). Now it gives a warning identifying - the culprit file and the rule violation (e.g., ``my$class.jar`` has a ``$`` - in the name) before crashing out, giving the user a chance to remove the invalid - file and try again. (https://github.com/ansible/ansible/pull/81555). - - ansible-test - Add Alpine 3.18 to remotes - - ansible-test - Add Fedora 38 container. - - ansible-test - Add Fedora 38 remote. - - ansible-test - Add FreeBSD 13.2 remote. - - ansible-test - Add new pylint checker for new ``# deprecated:`` comments within - code to trigger errors when time to remove code that has no user facing deprecation - message. Only supported in ansible-core, not collections. - - ansible-test - Add support for RHEL 8.8 remotes. - - ansible-test - Add support for RHEL 9.2 remotes. - - ansible-test - Add support for testing with Python 3.12. - - ansible-test - Allow float values for the ``--timeout`` option to the ``env`` - command. This simplifies testing. - - ansible-test - Enable ``thread`` code coverage in addition to the existing - ``multiprocessing`` coverage. - - ansible-test - RHEL 8.8 provisioning can now be used with the ``--python 3.11`` - option. - - ansible-test - RHEL 9.2 provisioning can now be used with the ``--python 3.11`` - option. - - ansible-test - Refactored ``env`` command logic and timeout handling. - - ansible-test - Remove Fedora 37 remote support. - - ansible-test - Remove Fedora 37 test container. - - ansible-test - Remove Python 3.8 and 3.9 from RHEL 8.8. - - ansible-test - Remove obsolete embedded script for configuring WinRM on Windows - remotes. - - ansible-test - Removed Ubuntu 20.04 LTS image from the `--remote` option. - - ansible-test - Removed `freebsd/12.4` remote. - - ansible-test - Removed `freebsd/13.1` remote. - - 'ansible-test - Removed test remotes: rhel/8.7, rhel/9.1' - - ansible-test - Removed the deprecated ``--docker-no-pull`` option. - - ansible-test - Removed the deprecated ``--no-pip-check`` option. - - ansible-test - Removed the deprecated ``foreman`` test plugin. - - ansible-test - Removed the deprecated ``govcsim`` support from the ``vcenter`` - test plugin. - - ansible-test - Replace the ``pytest-forked`` pytest plugin with a custom plugin. - - ansible-test - The ``no-get-exception`` sanity test is now limited to plugins - in collections. Previously any Python file in a collection was checked for - ``get_exception`` usage. - - ansible-test - The ``replace-urlopen`` sanity test is now limited to plugins - in collections. Previously any Python file in a collection was checked for - ``urlopen`` usage. - - ansible-test - The ``use-compat-six`` sanity test is now limited to plugins - in collections. Previously any Python file in a collection was checked for - ``six`` usage. - - ansible-test - The openSUSE test container has been updated to openSUSE Leap - 15.5. - - ansible-test - Update pip to ``23.1.2`` and setuptools to ``67.7.2``. - - ansible-test - Update the ``default`` containers. - - ansible-test - Update the ``nios-test-container`` to version 2.0.0, which - supports API version 2.9. - - ansible-test - Update the logic used to detect when ``ansible-test`` is running - from source. - - ansible-test - Updated the CloudStack test container to version 1.6.1. - - ansible-test - Updated the distro test containers to version 6.3.0 to include - coverage 7.3.2 for Python 3.8+. The alpine3 container is now based on 3.18 - instead of 3.17 and includes Python 3.11 instead of Python 3.10. - - ansible-test - Use ``datetime.datetime.now`` with ``tz`` specified instead - of ``datetime.datetime.utcnow``. - - ansible-test - Use a context manager to perform cleanup at exit instead of - using the built-in ``atexit`` module. - - ansible-test - remove Alpine 3.17 from remotes - - "ansible-test \u2014 Python 3.8\u20133.12 will use ``coverage`` v7.3.2." - - "ansible-test \u2014 ``coverage`` v6.5.0 is to be used only under Python 3.7." - - 'ansible-vault create: Now raises an error when opening the editor without - tty. The flag --skip-tty-check restores previous behaviour.' - - ansible_user_module - tweaked macos user defaults to reflect expected defaults - (https://github.com/ansible/ansible/issues/44316) - - apt - return calculated diff while running apt clean operation. - - blockinfile - add append_newline and prepend_newline options (https://github.com/ansible/ansible/issues/80835). - - cli - Added short option '-J' for asking for vault password (https://github.com/ansible/ansible/issues/80523). - - command - Add option ``expand_argument_vars`` to disable argument expansion - and use literal values - https://github.com/ansible/ansible/issues/54162 - - config lookup new option show_origin to also return the origin of a configuration - value. - - display methods for warning and deprecation are now proxied to main process - when issued from a fork. This allows for the deduplication of warnings and - deprecations to work globally. - - dnf5 - enable environment groups installation testing in CI as its support - was added. - - dnf5 - enable now implemented ``cacheonly`` functionality - - executor now skips persistent connection when it detects an action that does - not require a connection. - - find module - Add ability to filter based on modes - - gather_facts now will use gather_timeout setting to limit parallel execution - of modules that do not themselves use gather_timeout. - - group - remove extraneous warning shown when user does not exist (https://github.com/ansible/ansible/issues/77049). - - include_vars - os.walk now follows symbolic links when traversing directories - (https://github.com/ansible/ansible/pull/80460) - - module compression is now sourced directly via config, bypassing play_context - possibly stale values. - - reboot - show last error message in verbose logs (https://github.com/ansible/ansible/issues/81574). - - service_facts now returns more info for rcctl managed systesm (OpenBSD). - - tasks - the ``retries`` keyword can be specified without ``until`` in which - case the task is retried until it succeeds but at most ``retries`` times (https://github.com/ansible/ansible/issues/20802) - - user - add new option ``password_expire_warn`` (supported on Linux only) to - set the number of days of warning before a password change is required (https://github.com/ansible/ansible/issues/79882). - - yum_repository - Align module documentation with parameters - release_summary: '| Release Date: 2023-09-26 - - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + - "ansible-test \u2014 Replaced `freebsd/12.3` remote with `freebsd/12.4`. The + former is no longer functional." + release_summary: '| Release Date: 2023-09-05 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' - removed_features: - - ActionBase - remove deprecated ``_remote_checksum`` method - - PlayIterator - remove deprecated ``cache_block_tasks`` and ``get_original_task`` - methods - - Remove deprecated ``FileLock`` class - - Removed Python 3.9 as a supported version on the controller. Python 3.10 or - newer is required. - - Removed ``include`` which has been deprecated in Ansible 2.12. Use ``include_tasks`` - or ``import_tasks`` instead. - - '``Templar`` - remove deprecated ``shared_loader_obj`` parameter of ``__init__``' - - '``fetch_url`` - remove auto disabling ``decompress`` when gzip is not available' - - '``get_action_args_with_defaults`` - remove deprecated ``redirected_names`` - method parameter' - - ansible-test - Removed support for the remote Windows targets 2012 and 2012-R2 - - inventory_cache - remove deprecated ``default.fact_caching_prefix`` ini configuration - option, use ``defaults.fact_caching_prefix`` instead. - - module_utils/basic.py - Removed Python 3.5 as a supported remote version. - Python 2.7 or Python 3.6+ is now required. - - stat - removed unused `get_md5` parameter. - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.0b1_summary.yaml - - 20802-until-default.yml - - 22396-indicate-which-args-are-multi.yml - - 27816-fetch-unreachable.yml - - 50603-tty-check.yaml - - 71916-user-expires-int.yml - - 73643-handlers-prevent-multiple-runs.yml - - 74723-support-wildcard-win_fetch.yml - - 75063-allow-dev-nul-as-skeleton-for-new-homedir.yml - - 76372-fix-pip-virtualenv-command-parsing.yml - - 78487-galaxy-collections-path-warnings.yml - - 79129-ansible-managed-filename-format.yaml - - 79364_replace.yml - - 79677-fix-argspec-type-check.yml - - 79734-ansible-test-change-detection.yml - - 79844-fix-timeout-mounts-linux.yml - - 79999-ansible-user-tweak-macos-defaults.yaml - - 80089-prevent-module-build-date-issue.yml - - 80128-symbolic-modes-X-use-computed.yml - - 80257-iptables-chain-creation-does-not-populate-a-rule.yml - - 80258-defensive-display-non-utf8.yml - - 80334-reduce-ansible-galaxy-api-calls.yml - - 80406-validate-modules-semantic-markup.yml - - 80449-fix-symbolic-mode-error-msg.yml - - 80459-handlers-nested-includes-vars.yml - - 80460-add-symbolic-links-with-dir.yml - - 80476-fix-loop-task-post-validation.yml - - 80488-pip-pkg-resources.yml - - 80506-syntax-check-playbook-only.yml - - 80520-fix-current-hostname-openbsd.yml - - 80523_-_adding_short_option_for_--ask-vault-pass.yml - - 80605-template-overlay-native-jinja.yml - - 80648-fix-ansible-galaxy-cache-signatures-bug.yml - - 80721-ansible-galaxy.yml - - 80738-abs-unarachive-src.yml - - 80841-display-type-annotation.yml - - 80880-register-handlers-immediately-if-iterating-handlers.yml - - 80887-dnf5-api-change.yml - - 80943-ansible-galaxy-collection-subdir-install.yml - - 80968-replace-deprecated-ast-attr.yml - - 80985-fix-smgl-family-mapping.yml - - 81005-use-overlay-overrides.yml - - 81013-handlers-listen-last-defined-only.yml - - 81029-connection-types.yml - - 81064-daemonize-fixes.yml - - 81082-deprecated-importlib-abc.yml - - 81083-add-blockinfile-append-and-prepend-new-line-options.yml - - 81104-inventory-script-plugin-raise-execution-error.yml - - 81319-cloudstack-test-container-bump-version.yml - - 81332-fix-pkg-mgr-in-kylin.yml - - 81450-list-filters.yml - - 81494-remove-duplicated-file-attribute-constant.yml - - 81555-add-warning-for-illegal-filenames-in-roles.yaml - - 81584-daemonize-follow-up-fixes.yml - - 81606-ansible-galaxy-collection-pre-releases.yml - - 81613-remove-unusued-private-lock.yml - - 81656-cf_readfp-deprecated.yml - - 81662-blockinfile-exc.yml - - 81722-handler-subdir-include_tasks.yml - - CleansingNodeVisitor-removal.yml - - a-g-col-install-directory-with-trailing-sep.yml - - a-g-col-prevent-reinstalling-satisfied-req.yml - - a_test_rmv_alpine_317.yml - - add-missing-cli-docs.yml - - ag-ignore-multiple-signature-statuses.yml - - ansible-galaxy-server-timeout.yml - - ansible-runtime-metadata-removal-date.yml - - ansible-test-added-fedora-38.yml - - ansible-test-argcomplete-3.yml - - ansible-test-atexit.yml - - ansible-test-coverage-update.yml - - ansible-test-default-containers.yml - - ansible-test-deprecated-cleanup.yml - - ansible-test-distro-containers.yml + - 2.14.10rc1_summary.yaml - ansible-test-entry-points.yml - - ansible-test-explain-traceback.yml - - ansible-test-fedora-37.yml - - ansible-test-freebsd-bootstrap-setuptools.yml - - ansible-test-import-sanity-fix.yml - - ansible-test-layout-detection.yml - - ansible-test-long-timeout-fix.yml - - ansible-test-minimum-setuptools.yml - - ansible-test-nios-container.yml - - ansible-test-pylint-update.yml - - ansible-test-pytest-forked.yml - - ansible-test-python-3.12.yml - - ansible-test-pyyaml-build.yml - - ansible-test-remove-old-rhel-remotes.yml - - ansible-test-remove-ubuntu-2004.yml - - ansible-test-rhel-9.2-python-3.11.yml - - ansible-test-rhel-9.2.yml - - ansible-test-sanity-scope.yml - - ansible-test-source-detection.yml - - ansible-test-thread-coverage.yml - - ansible-test-timeout-fix.yml - - ansible-test-unique-container-names.yml - - ansible-test-use-raise-from.yml - - ansible-test-utcnow.yml - - ansible-test-winrm-config.yml - - ansible-vault.yml - - ansible_test_alpine_3.18.yml - - apt_fail_on_autoremove.yml - - aptclean_diff.yml - - basestrategy-lazy-templar.yml - - ci_freebsd_new.yml - - collections_paths-deprecation.yml - - colors.yml - - command-expand-args.yml - - config_origins_option.yml - - connection-type-annotation.yml - - copy_diff.yml - - deb822_open_url.yml - - debconf.yml - - deprecated_string_conversion_action.yml - - display_proxy.yml - - dnf-update-only-latest.yml - - dnf5-cacheonly.yml - - dnf5-fix-interpreter-fail-msg.yml - - dnf5-gpg-check-api.yml - - dnf5-gpg-check-builtin.yml - - dnf5-logs-api.yml - - dnf5-test-env-groups.yml - dotnet-preparation.yml - - dpkg_selections.yml - - fbsd13_1_remove.yml - - fetch_url-remove-auto-disable-decompress.yml - - find-mode.yml - - first_found_fixes.yml - - first_found_template_fix.yml - - fix-display-prompt-cpu-consumption.yml - - fix-handlers-callback.yml - - fix-pkg-mgr-in-TencentOS.yml - - fix-setuptools-warnings.yml - - fix-url-lookup-plugin-docs.yml - - forced_local+fix+.yml - - freebsd_12_4_removal.yml - - galaxy_check_type.yml - - galaxy_symlink.yml - - gather_facts_fix_parallel.yml - - get_action_args_with_defaults-remove-deprecated-arg.yml - - group_warning.yml - - inventory_cache-remove-deprecated-default-section.yml - - inventory_ini.yml - - jinja_plugin_cache_cleanup.yml - - long-collection-paths-fix.yml - - man-page-build-docs-dependency.yml - - man-page-subcommands.yml - - manifest-in-cleanup.yml - - mc_from_config.yml - - missing-doc-func.yml - - no-arbitrary-j2-override.yml - - omit-man-pages-from-sdist.yml - - parsing-splitter-fixes.yml - - passlib_or_crypt.yml - - password_hash-fix-crypt-salt-bcrypt.yml - - pep517-backend-import-fix.yml - - pep517-backend-traceback-fix.yml - - pep8-known-issue.yml - - persist_skip.yml - - pkg_mgr-default-dnf.yml - - powershell-module-error-handling.yml - - pre-release-hint-for-dep-resolution-error.yml - - pylint-deprecated-comment-checker.yml - - reboot.yml - - remove-deprecated-actionbase-_remote_checksum.yml - - remove-deprecated-datetime-methods.yml - - remove-deprecated-filelock-class.yml - - remove-docs-examples.yml - - remove-include.yml - - remove-play_iterator-deprecated-methods.yml - - remove-python3.5.yml - - remove-python3.9-controller-support.yml - - remove-templar-shared_loader_obj-arg.yml - - remove-unreachable-include_role-static-err.yml - - remove_md5.yml - - role-deduplication-condition.yml - - run-command-selectors-prompt-only.yml - - server2012-deprecation.yml - - service_facts_rcctl.yml - - service_facts_simpleinit_msb.yml - - service_fix_obsd.yml - - set-filters.yml - - setup_facter_fix.yml - - simple-result-queue.yml - - smart_connection_bye.yml - - suppressed-options.yml + - freebsd-12.3-replacement.yml - tarfile_extract_warn.yml - - templar-globals-dict.yml - - templating_fixes.yml - - text-converters.yml - - timeout_config_fix.yml - - update-maybe-json-uri.yml - - urls-client-cert-py12.yml - - urls-unit-test-latest-cryptography.yml - - user-add-password-exp-warning.yml - - v2.16.0-initial-commit.yaml - - vault_unvault_id_fix.yml - - yum-repository-docs-fixes.yml - - yum_repository_keepcache.yml - release_date: '2023-09-26' - 2.16.0b2: + release_date: '2023-09-05' + 2.14.11: + changes: + release_summary: '| Release Date: 2023-10-09 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.11_summary.yaml + release_date: '2023-10-09' + 2.14.11rc1: changes: bugfixes: - - '``import_role`` reverts to previous behavior of exporting vars at compile - time.' + - PluginLoader - fix Jinja plugin performance issues (https://github.com/ansible/ansible/issues/79652) + - ansible-galaxy error on dependency resolution will not error itself due to + 'virtual' collections not having a name/namespace. - ansible-galaxy info - fix reporting no role found when lookup_role_by_name returns None. - - uri/urls - Add compat function to handle the ability to parse the filename - from a Content-Disposition header (https://github.com/ansible/ansible/issues/81806) - winrm - Better handle send input failures when communicating with hosts under load minor_changes: - - ansible-test - When invoking ``sleep`` in containers during container setup, - the ``env`` command is used to avoid invoking the shell builtin, if present. + - ansible-galaxy dependency resolution messages have changed the unexplained + 'virtual' collection for the specific type ('scm', 'dir', etc) that is more + user friendly release_summary: '| Release Date: 2023-10-03 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' security_fixes: - ansible-galaxy - Prevent roles from using symlinks to overwrite files outside of the installation directory (CVE-2023-5115) - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.0b2_summary.yaml - - 81806-py2-content-disposition.yml - - ansible-test-container-sleep.yml + - 2.14.11rc1_summary.yaml - cve-2023-5115.yml - fix-ansible-galaxy-info-no-role-found.yml - - import_role_goes_public.yml + - galaxy_dep_res_msgs.yml + - jinja_plugin_cache_cleanup.yml - winrm-send-input.yml release_date: '2023-10-03' - 2.16.0rc1: - changes: - bugfixes: - - Cache host_group_vars after instantiating it once and limit the amount of - repetitive work it needs to do every time it runs. - - Call PluginLoader.all() once for vars plugins, and load vars plugins that - run automatically or are enabled specifically by name subsequently. - - Fix ``run_once`` being incorrectly interpreted on handlers (https://github.com/ansible/ansible/issues/81666) - - Properly template tags in parent blocks (https://github.com/ansible/ansible/issues/81053) - - ansible-galaxy - Provide a better error message when using a requirements - file with an invalid format - https://github.com/ansible/ansible/issues/81901 - - ansible-inventory - index available_hosts for major performance boost when - dumping large inventories - - ansible-test - Add a ``pylint`` plugin to work around a known issue on Python - 3.12. - - ansible-test - Include missing ``pylint`` requirements for Python 3.10. - - ansible-test - Update ``pylint`` to version 3.0.1. - deprecated_features: - - Old style vars plugins which use the entrypoints `get_host_vars` or `get_group_vars` - are deprecated. The plugin should be updated to inherit from `BaseVarsPlugin` - and define a `get_vars` method as the entrypoint. - minor_changes: - - ansible-test - Make Python 3.12 the default version used in the ``base`` and - ``default`` containers. - release_summary: '| Release Date: 2023-10-16 - - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ - - ' - codename: All My Love - fragments: - - 2.16.0rc1_summary.yaml - - 79945-host_group_vars-improvements.yml - - 81053-templated-tags-inheritance.yml - - 81666-handlers-run_once.yml - - 81901-galaxy-requirements-format.yml - - ansible-test-pylint3-update.yml - - ansible-test-python-3.12-compat.yml - - ansible-test-python-default.yml - - inv_available_hosts_to_frozenset.yml - release_date: '2023-10-16' - 2.16.1: + 2.14.12: changes: release_summary: '| Release Date: 2023-12-04 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.1_summary.yaml + - 2.14.12_summary.yaml release_date: '2023-12-04' - 2.16.1rc1: + 2.14.12rc1: changes: breaking_changes: - assert - Nested templating may result in an inability for the conditional to be evaluated. See the porting guide for more information. bugfixes: - - Fix issue where an ``include_tasks`` handler in a role was not able to locate - a file in ``tasks/`` when ``tasks_from`` was used as a role entry point and - ``main.yml`` was not present (https://github.com/ansible/ansible/issues/82241) - - Plugin loader does not dedupe nor cache filter/test plugins by file basename, - but full path name. - - Restoring the ability of filters/tests can have same file base name but different - tests/filters defined inside. - ansible-pull now will expand relative paths for the ``-d|--directory`` option is now expanded before use. - - ansible-pull will now correctly handle become and connection password file - options for ansible-playbook. - - flush_handlers - properly handle a handler failure in a nested block when - ``force_handlers`` is set (http://github.com/ansible/ansible/issues/81532) - - module no_log will no longer affect top level booleans, for example ``no_log_module_parameter='a'`` - will no longer hide ``changed=False`` as a 'no log value' (matches 'a'). - - role params now have higher precedence than host facts again, matching documentation, - this had unintentionally changed in 2.15. - - wait_for should not handle 'non mmapable files' again. + - ansible-test - Fix parsing of cgroup entries which contain a ``:`` in the + path (https://github.com/ansible/ansible/issues/81977). + minor_changes: + - ansible-test - Windows 2012 and 2012-R2 instances are now requested from Azure + instead of AWS. release_summary: '| Release Date: 2023-11-27 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' security_fixes: - templating - Address issues where internal templating can cause unsafe variables to lose their unsafe designation (CVE-2023-5764) - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.1rc1_summary.yaml - - 81532-fix-nested-flush_handlers.yml - - 82241-handler-include-tasks-from.yml + - 2.14.12rc1_summary.yaml + - ansible-test-cgroup-split.yml + - ansible-test-windows-2012-and-2012-R2.yml - cve-2023-5764.yml - - j2_load_fix.yml - - no_log_booly.yml - - pull_file_secrets.yml - pull_unfrack_dest.yml - - restore_role_param_precedence.yml - - wait_for_mmap.yml release_date: '2023-11-27' - 2.16.2: + 2.14.13: changes: bugfixes: - unsafe data - Address an incompatibility when iterating or getting a single index from ``AnsibleUnsafeBytes`` - unsafe data - Address an incompatibility with ``AnsibleUnsafeText`` and ``AnsibleUnsafeBytes`` when pickling with ``protocol=0`` + minor_changes: + - ansible-test - Add FreeBSD 13.2 remote. + - ansible-test - Removed `freebsd/13.1` remote. release_summary: '| Release Date: 2023-12-11 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.2_summary.yaml + - 2.14.13_summary.yaml + - ci_freebsd_new.yml + - fbsd13_1_remove.yml - unsafe-fixes-2.yml release_date: '2023-12-11' - 2.16.3: + 2.14.1rc1: + changes: + bugfixes: + - Fixes leftover _valid_attrs usage. + - ansible-galaxy - make initial call to Galaxy server on-demand only when installing, + getting info about, and listing roles. + - copy module will no longer move 'non files' set as src when remote_src=true. + - 'jinja2_native: preserve quotes in strings (https://github.com/ansible/ansible/issues/79083)' + - updated error messages to include 'acl' and not just mode changes when failing + to set required permissions on remote. + minor_changes: + - ansible-test - Improve consistency of executed ``pylint`` commands by making + the plugins ordered. + release_summary: '| Release Date: 2022-11-28 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 79083-jinja2_native-preserve-quotes-in-strings.yml + - 79376-replace-valid-attrs-with-fattributes.yaml + - ansible-galaxy-install-delay-initial-api-call.yml + - ansible-test-pylint-command.yml + - dont_move_non_files.yml + - mention_acl.yml + - v2.14.1rc1_summary.yaml + release_date: '2022-11-28' + 2.14.2: changes: - release_summary: '| Release Date: 2024-01-29 + bugfixes: + - Fix traceback when using the ``template`` module and running with ``ANSIBLE_DEBUG=1`` + (https://github.com/ansible/ansible/issues/79763) + release_summary: '| Release Date: 2023-01-30 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.3_summary.yaml - release_date: '2024-01-29' - 2.16.3rc1: + - 79763-ansible_debug_template_tb_fix.yml + - v2.14.2_summary.yaml + release_date: '2023-01-30' + 2.14.2rc1: changes: bugfixes: - - Run all handlers with the same ``listen`` topic, even when notified from another - handler (https://github.com/ansible/ansible/issues/82363). - - '``ansible-galaxy role import`` - fix using the ``role_name`` in a standalone - role''s ``galaxy_info`` metadata by disabling automatic removal of the ``ansible-role-`` - prefix. This matches the behavior of the Galaxy UI which also no longer implicitly - removes the ``ansible-role-`` prefix. Use the ``--role-name`` option or add - a ``role_name`` to the ``galaxy_info`` dictionary in the role''s ``meta/main.yml`` - to use an alternate role name.' - - '``ansible-test sanity --test runtime-metadata`` - add ``action_plugin`` as - a valid field for modules in the schema (https://github.com/ansible/ansible/pull/82562).' - - ansible-config init will now dedupe ini entries from plugins. - - ansible-galaxy role import - exit with 1 when the import fails (https://github.com/ansible/ansible/issues/82175). - - ansible-galaxy role install - normalize tarfile paths and symlinks using ``ansible.utils.path.unfrackpath`` - and consider them valid as long as the realpath is in the tarfile's role directory - (https://github.com/ansible/ansible/issues/81965). - - delegate_to when set to an empty or undefined variable will now give a proper - error. - - dwim functions for lookups should be better at detectging role context even - in abscense of tasks/main. - - roles, code cleanup and performance optimization of dependencies, now cached, and - ``public`` setting is now determined once, at role instantiation. - - roles, the ``static`` property is now correctly set, this will fix issues - with ``public`` and ``DEFAULT_PRIVATE_ROLE_VARS`` controls on exporting vars. - - unsafe data - Enable directly using ``AnsibleUnsafeText`` with Python ``pathlib`` - (https://github.com/ansible/ansible/issues/82414) - release_summary: '| Release Date: 2024-01-22 - - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + - Correctly count rescued tasks in play recap (https://github.com/ansible/ansible/issues/79711) + - Fix using ``GALAXY_IGNORE_CERTS`` in conjunction with collections in requirements + files which specify a specific ``source`` that isn't in the configured servers. + - Fix using ``GALAXY_IGNORE_CERTS`` when downloading tarballs from Galaxy servers + (https://github.com/ansible/ansible/issues/79557). + - Module and role argument validation - include the valid suboption choices + in the error when an invalid suboption is provided. + - ansible-doc now will correctly display short descriptions on listing filters/tests + no matter the directory sorting. + - ansible-inventory will not explicitly sort groups/hosts anymore, giving a + chance (depending on output format) to match the order in the input sources. + - ansible-test - Added a work-around for a traceback under Python 3.11 when + completing certain command line options. + - ansible-test - Avoid using ``exec`` after container startup when possible. + This improves container startup performance and avoids intermittent startup + issues with some old containers. + - ansible-test - Connection attempts to managed remote instances no longer abort + on ``Permission denied`` errors. + - ansible-test - Detection for running in a Podman or Docker container has been + fixed to detect more scenarios. The new detection relies on ``/proc/self/mountinfo`` + instead of ``/proc/self/cpuset``. Detection now works with custom cgroups + and private cgroup namespaces. + - ansible-test - Fix validate-modules error when retrieving PowerShell argspec + when retrieved inside a Cmdlet + - ansible-test - Handle server errors when executing the ``docker info`` command. + - ansible-test - Multiple containers now work under Podman without specifying + the ``--docker-network`` option. + - ansible-test - Pass the ``XDG_RUNTIME_DIR`` environment variable through to + container commands. + - ansible-test - Perform PyPI proxy configuration after instances are ready + and bootstrapping has been completed. Only target instances are affected, + as controller instances were already handled this way. This avoids proxy configuration + errors when target instances are not yet ready for use. + - ansible-test - Prevent concurrent / repeat inspections of the same container + image. + - ansible-test - Prevent concurrent / repeat pulls of the same container image. + - ansible-test - Prevent concurrent execution of cached methods. + - ansible-test - Show the exception type when reporting errors during instance + provisioning. + - ansible-test sanity - correctly report invalid YAML in validate-modules (https://github.com/ansible/ansible/issues/75837). + - argument spec validation - again report deprecated parameters for Python-based + modules. This was accidentally removed in ansible-core 2.11 when argument + spec validation was refactored (https://github.com/ansible/ansible/issues/79680, + https://github.com/ansible/ansible/pull/79681). + - argument spec validation - ensure that deprecated aliases in suboptions are + also reported (https://github.com/ansible/ansible/pull/79740). + - argument spec validation - fix warning message when two aliases of the same + option are used for suboptions to also mention the option's name they are + in (https://github.com/ansible/ansible/pull/79740). + - connection local now avoids traceback on invalid user being used to execuet + ansible (valid in host, but not in container). + - file - touch action in check mode was always returning ok. Fix now evaluates + the different conditions and returns the appropriate changed status. (https://github.com/ansible/ansible/issues/79360) + - get_url - Ensure we are passing ciphers to all url_get calls (https://github.com/ansible/ansible/issues/79717) + - plugin filter now works with rejectlist as documented (still falls back to + blacklist if used). + - uri - improve JSON content type detection + known_issues: + - ansible-test - Additional configuration may be required for certain container + host and container combinations. Further details are available in the testing + documentation. + - ansible-test - Custom containers with ``VOLUME`` instructions may be unable + to start, when previously the containers started correctly. Remove the ``VOLUME`` + instructions to resolve the issue. Containers with this condition will cause + ``ansible-test`` to emit a warning. + - ansible-test - Systems with Podman networking issues may be unable to run + containers, when previously the issue went unreported. Correct the networking + issues to continue using ``ansible-test`` with Podman. + - ansible-test - Using Docker on systems with SELinux may require setting SELinux + to permissive mode. Podman should work with SELinux in enforcing mode. + major_changes: + - ansible-test - Docker Desktop on WSL2 is now supported (additional configuration + required). + - ansible-test - Docker and Podman are now supported on hosts with cgroup v2 + unified. Previously only cgroup v1 and cgroup v2 hybrid were supported. + - ansible-test - Podman now works on container hosts without systemd. Previously + only some containers worked, while others required rootfull or rootless Podman, + but would not work with both. Some containers did not work at all. + - ansible-test - Podman on WSL2 is now supported. + - ansible-test - When additional cgroup setup is required on the container host, + this will be automatically detected. Instructions on how to configure the + host will be provided in the error message shown. + minor_changes: + - ansible-test - A new ``audit`` option is available when running custom containers. + This option can be used to indicate whether a container requires the AUDIT_WRITE + capability. The default is ``required``, which most containers will need when + using Podman. If necessary, the ``none`` option can be used to opt-out of + the capability. This has no effect on Docker, which always provides the capability. + - ansible-test - A new ``cgroup`` option is available when running custom containers. + This option can be used to indicate a container requires cgroup v1 or that + it does not use cgroup. The default behavior assumes the container works with + cgroup v2 (as well as v1). + - ansible-test - Additional log details are shown when containers fail to start + or SSH connections to containers fail. + - ansible-test - Connection failures to remote provisioned hosts now show failure + details as a warning. + - ansible-test - Containers included with ansible-test no longer disable seccomp + by default. + - ansible-test - Failure to connect to a container over SSH now results in a + clear error. Previously tests would be attempted even after initial connection + attempts failed. + - ansible-test - Integration tests can be excluded from retries triggered by + the ``--retry-on-error`` option by adding the ``retry/never`` alias. This + is useful for tests that cannot pass on a retry or are too slow to make retries + useful. + - ansible-test - More details are provided about an instance when provisioning + fails. + - ansible-test - Reduce the polling limit for SSHD startup in containers from + 60 retries to 10. The one second delay between retries remains in place. + - ansible-test - SSH connections from OpenSSH 8.8+ to CentOS 6 containers now + work without additional configuration. However, clients older than OpenSSH + 7.0 can no longer connect to CentOS 6 containers as a result. The container + must have ``centos6`` in the image name for this work-around to be applied. + - ansible-test - SSH shell connections from OpenSSH 8.8+ to ansible-test provisioned + network instances now work without additional configuration. However, clients + older than OpenSSH 7.0 can no longer open shell sessions for ansible-test + provisioned network instances as a result. + - ansible-test - The ``ansible-test env`` command now detects and reports the + container ID if running in a container. + - ansible-test - Unit tests now support network disconnect by default when running + under Podman. Previously this feature only worked by default under Docker. + - ansible-test - Use ``stop --time 0`` followed by ``rm`` to remove ephemeral + containers instead of ``rm -f``. This speeds up teardown of ephemeral containers. + - ansible-test - Warnings are now shown when using containers that were built + with VOLUME instructions. + - ansible-test - When setting the max open files for containers, the container + host's limit will be checked. If the host limit is lower than the preferred + value, it will be used and a warning will be shown. + - ansible-test - When using Podman, ansible-test will detect if the loginuid + used in containers is incorrect. When this occurs a warning is displayed and + the container is run with the AUDIT_CONTROL capability. Previously containers + would fail under this situation, with no useful warnings or errors given. + release_summary: '| Release Date: 2023-01-23 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ ' - security_fixes: - - ANSIBLE_NO_LOG - Address issue where ANSIBLE_NO_LOG was ignored (CVE-2024-0690) - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.3rc1_summary.yaml - - 82175-fix-ansible-galaxy-role-import-rc.yml - - 82363-multiple-handlers-with-recursive-notification.yml - - ansible-galaxy-role-install-symlink.yml - - cve-2024-0690.yml - - dedupe_config_init.yml - - delegate_to_invalid.yml - - dwim_is_role_fix.yml - - fix-default-ansible-galaxy-role-import-name.yml - - fix-runtime-metadata-modules-action_plugin.yml - - role_fixes.yml - - unsafe-intern.yml - release_date: '2024-01-22' - 2.16.4: + - 75837-validate-modules-invalid-yaml.yml + - 76578-fix-role-argspec-suboptions-error.yml + - 79525-fix-file-touch-check-mode-status.yaml + - 79561-fix-a-g-global-ignore-certs-cfg.yml + - 79681-argspec-param-deprecation.yml + - 79711-fix-play-stats-rescued.yml + - 79717-get-url-ciphers.yml + - 79740-aliases-warnings-deprecations-in-suboptions.yml + - adoc_fix_list.yml + - ansible-test-container-management.yml + - ansible-test-fix-python-3.11-traceback.yml + - ansible-test-pypi-proxy-fix.yml + - better-maybe-json-uri.yml + - local_bad_user.yml + - rejectlist_fix.yml + - unsorted.yml + - v2.14.2rc1_summary.yaml + - validate-module-ps-cmdlet.yml + release_date: '2023-01-23' + 2.14.3: changes: - release_summary: '| Release Date: 2024-02-26 + release_summary: '| Release Date: 2023-02-27 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.4_summary.yaml - release_date: '2024-02-26' - 2.16.4rc1: + - v2.14.3_summary.yaml + release_date: '2023-02-27' + 2.14.3rc1: changes: bugfixes: - - Fix loading vars_plugins in roles (https://github.com/ansible/ansible/issues/82239). - - expect - fix argument spec error using timeout=null (https://github.com/ansible/ansible/issues/80982). - - include_vars - fix calculating ``depth`` relative to the root and ensure all - files are included (https://github.com/ansible/ansible/issues/80987). - - templating - ensure syntax errors originating from a template being compiled - into Python code object result in a failure (https://github.com/ansible/ansible/issues/82606) - release_summary: '| Release Date: 2024-02-19 + - Ansible.Basic.cs - Ignore compiler warning (reported as an error) when running + under PowerShell 7.3.x. + - Fix conditionally notifying ``include_tasks` handlers when ``force_handlers`` + is used (https://github.com/ansible/ansible/issues/79776) + - TaskExecutor - don't ignore templated _raw_params that k=v parser failed to + parse (https://github.com/ansible/ansible/issues/79862) + - ansible-galaxy - fix installing collections in git repositories/directories + which contain a MANIFEST.json file (https://github.com/ansible/ansible/issues/79796). + - ansible-test - Support Podman 4.4.0+ by adding the ``SYS_CHROOT`` capability + when running containers. + - ansible-test - fix warning message about failing to run an image to include + the image name + - strategy plugins now correctly identify bad registered variables, even on + skip. + minor_changes: + - Make using blocks as handlers a parser error (https://github.com/ansible/ansible/issues/79968) + - 'ansible-test - Specify the configuration file location required by test plugins + when the config file is not found. This resolves issue: https://github.com/ansible/ansible/issues/79411' + - ansible-test - Update error handling code to use Python 3.x constructs, avoiding + direct use of ``errno``. + - ansible-test acme test container - update version to update used Pebble version, + underlying Python and Go base containers, and Python requirements (https://github.com/ansible/ansible/pull/79783). + release_summary: '| Release Date: 2023-02-20 + + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + ' + codename: C'mon Everybody + fragments: + - 79776-fix-force_handlers-cond-include.yml + - 79783-acme-test-container.yml + - 79862-fix-varargs.yml + - 79968-blocks-handlers-error.yml + - ansible-galaxy-install-git-src-manifest.yml + - ansible-test-errno.yml + - ansible-test-fix-warning-msg.yml + - ansible-test-podman-chroot.yml + - ansible-test-test-plugin-error-message.yml + - powershell-7.3-fix.yml + - strategy_badid_fix.yml + - v2.14.3rc1_summary.yaml + release_date: '2023-02-20' + 2.14.4: + changes: + release_summary: '| Release Date: 2023-03-27 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.4rc1_summary.yaml - - 80995-include-all-var-files.yml - - 82606-template-python-syntax-error.yml - - fix-expect-indefinite-timeout.yml - - fix-vars-plugins-in-roles.yml - release_date: '2024-02-19' - 2.16.5: + - 2.14.4_summary.yaml + release_date: '2023-03-27' + 2.14.4rc1: changes: + breaking_changes: + - ansible-test - Integration tests which depend on specific file permissions + when running in an ansible-test managed host environment may require changes. + Tests that require permissions other than ``755`` or ``644`` may need to be + updated to set the necessary permissions as part of the test run. bugfixes: - - ansible-test - The ``libexpat`` package is automatically upgraded during remote - bootstrapping to maintain compatibility with newer Python packages. - release_summary: '| Release Date: 2024-03-25 + - Fix ``MANIFEST.in`` to exclude unwanted files in the ``packaging/`` directory. + - Fix ``MANIFEST.in`` to include ``*.md`` files in the ``test/support/`` directory. + - Fix an issue where the value of ``become`` was ignored when used on a role + used as a dependency in ``main/meta.yml`` (https://github.com/ansible/ansible/issues/79777) + - '``ansible_eval_concat`` - avoid redundant unsafe wrapping of templated strings + converted to Python types' + - ansible-galaxy role info - fix unhandled AttributeError by catching the correct + exception. + - ansible-test - Always indicate the Python version being used before installing + requirements. Resolves issue https://github.com/ansible/ansible/issues/72855 + - ansible-test - Exclude ansible-core vendored Python packages from ansible-test + payloads. + - ansible-test - Integration test target prefixes defined in a ``tests/integration/target-prefixes.{group}`` + file can now contain an underscore (``_``) character. Resolves issue https://github.com/ansible/ansible/issues/79225 + - ansible-test - Removed pointless comparison in diff evaluation logic. + - ansible-test - Set ``PYLINTHOME`` for the ``pylint`` sanity test to prevent + failures due to ``pylint`` checking for the existence of an obsolete home + directory. + - ansible-test - Support loading of vendored Python packages from ansible-core. + - ansible-test - Use consistent file permissions when delegating tests to a + container or remote host. Files with any execute bit set will use permissions + ``755``. All other files will use permissions ``644``. (Resolves issue https://github.com/ansible/ansible/issues/75079) + - copy - fix creating the dest directory in check mode with remote_src=True + (https://github.com/ansible/ansible/issues/78611). + - copy - fix reporting changes to file attributes in check mode with remote_src=True + (https://github.com/ansible/ansible/issues/77957). + minor_changes: + - ansible-test - Moved git handling out of the validate-modules sanity test + and into ansible-test. + - ansible-test - Removed the ``--keep-git`` sanity test option, which was limited + to testing ansible-core itself. + - ansible-test - Updated the Azure Pipelines CI plugin to work with newer versions + of git. + release_summary: '| Release Date: 2023-03-21 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible/devel/porting_guides.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.5_summary.yaml - - ansible-test-alpine-libexpat.yml - release_date: '2024-03-25' - 2.16.5rc1: + - 2.14.4rc1_summary.yaml + - 78624-copy-remote-src-check-mode.yml + - 79777-fix-inheritance-roles-meta.yml + - a-g-role-fix-catching-exception.yml + - ansible-test-fix-pointless-comparison.yml + - ansible-test-git-handling.yml + - ansible-test-integration-target-prefixes.yml + - ansible-test-payload-file-permissions.yml + - ansible-test-pylint-home.yml + - ansible-test-requirements-message.yml + - ansible-test-vendoring-support.yml + - ansible_eval_concat-remove-redundant-unsafe-wrap.yml + - fix-manifest.yml + release_date: '2023-03-21' + 2.14.5: + changes: + release_summary: '| Release Date: 2023-04-24 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.5_summary.yaml + release_date: '2023-04-24' + 2.14.5rc1: changes: bugfixes: - - 'Fix an issue when setting a plugin name from an unsafe source resulted in - ``ValueError: unmarshallable object`` (https://github.com/ansible/ansible/issues/82708)' - - Harden python templates for respawn and ansiballz around str literal quoting - - template - Fix error when templating an unsafe string which corresponds to - an invalid type in Python (https://github.com/ansible/ansible/issues/82600). - - winrm - does not hang when attempting to get process output when stdin write - failed + - Windows - Display a warning if the module failed to cleanup any temporary + files rather than failing the task. The warning contains a brief description + of what failed to be deleted. + - Windows - Ensure the module temp directory contains more unique values to + avoid conflicts with concurrent runs - https://github.com/ansible/ansible/issues/80294 + - Windows - Improve temporary file cleanup used by modules. Will use a more + reliable delete operation on Windows Server 2016 and newer to delete files + that might still be open by other software like Anti Virus scanners. There + are still scenarios where a file or directory cannot be deleted but the new + method should work in more scenarios. + - ansible-doc - stop generating wrong module URLs for module see-alsos. The + URLs for modules in ansible.builtin do now work, and URLs for modules outside + ansible.builtin are no longer added (https://github.com/ansible/ansible/pull/80280). + - ansible-galaxy - Improve retries for collection installs, to properly retry, + and extend retry logic to common URL related connection errors (https://github.com/ansible/ansible/issues/80170 + https://github.com/ansible/ansible/issues/80174) + - ansible-galaxy - reduce API calls to servers by fetching signatures only for + final candidates. + - ansible-test - Add support for ``argcomplete`` version 3. + - jinja2_native - fix intermittent 'could not find job' failures when a value + of ``ansible_job_id`` from a result of an async task was inadvertently changed + during execution; to prevent this a format of ``ansible_job_id`` was changed. + - password lookup now correctly reads stored ident fields. + - pep517 build backend - Use the documented ``import_module`` import from ``importlib``. + - roles - Fix templating ``public``, ``allow_duplicates`` and ``rolespec_validate`` + (https://github.com/ansible/ansible/issues/80304). + - syntax check - Limit ``--syntax-check`` to ``ansible-playbook`` only, as that + is the only CLI affected by this argument (https://github.com/ansible/ansible/issues/80506) + release_summary: '| Release Date: 2023-04-17 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.5rc1_summary.yaml + - 80280-ansible-doc-seealso-urls.yml + - 80334-reduce-ansible-galaxy-api-calls.yml + - 80506-syntax-check-playbook-only.yml + - ansible-basic-tmpdir-uniqueness.yml + - ansible-test-argcomplete-3.yml + - fix-templating-private-role-FA.yml + - fix_jinja_native_async.yml + - galaxy-improve-retries.yml + - password_lookup_file_fix.yml + - pep517-backend-import-fix.yml + - win-temp-cleanup.yml + release_date: '2023-04-17' + 2.14.6: + changes: + release_summary: '| Release Date: 2023-05-22 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.6_summary.yaml + release_date: '2023-05-22' + 2.14.6rc1: + changes: + bugfixes: + - Display - Defensively configure writing to stdout and stderr with the replace + encoding error handler that will replace invalid characters (https://github.com/ansible/ansible/issues/80258) + - Properly disable ``jinja2_native`` in the template module when jinja2 override + is used in the template (https://github.com/ansible/ansible/issues/80605) + - ansible-galaxy - fix installing signed collections (https://github.com/ansible/ansible/issues/80648). + - ansible-galaxy collection verify - fix verifying signed collections when the + keyring is not configured. + - ansible-test - Fix handling of timeouts exceeding one day. + - ansible-test - Fix various cases where the test timeout could expire without + terminating the tests. + - ansible-test - When bootstrapping remote FreeBSD instances, use the OS packaged + ``setuptools`` instead of installing the latest version from PyPI. + - pep517 build backend - Copy symlinks when copying the source tree. This avoids + tracebacks in various scenarios, such as when a venv is present in the source + tree. minor_changes: - - ansible-test - Add a work-around for permission denied errors when using ``pytest - >= 8`` on multi-user systems with an installed version of ``ansible-test``. - release_summary: '| Release Date: 2024-03-18 + - ansible-test - Allow float values for the ``--timeout`` option to the ``env`` + command. This simplifies testing. + - ansible-test - Refactored ``env`` command logic and timeout handling. + - ansible-test - Use ``datetime.datetime.now`` with ``tz`` specified instead + of ``datetime.datetime.utcnow``. + release_summary: '| Release Date: 2023-05-15 - | `Porting Guide <https://docs.ansible.com/ansible-core/2.16/porting_guides/porting_guide_core_2.16.html>`__ + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ ' - codename: All My Love + codename: C'mon Everybody fragments: - - 2.16.5rc1_summary.yaml - - 82675-fix-unsafe-templating-leading-to-type-error.yml - - 82708-unsafe-plugin-name-error.yml - - ansible-test-pytest-8.yml - - py-tmpl-hardening.yml - - winrm-timeout.yml - release_date: '2024-03-18' + - 2.14.6rc1_summary.yaml + - 80258-defensive-display-non-utf8.yml + - 80605-template-overlay-native-jinja.yml + - 80648-fix-ansible-galaxy-cache-signatures-bug.yml + - ansible-test-freebsd-bootstrap-setuptools.yml + - ansible-test-long-timeout-fix.yml + - ansible-test-timeout-fix.yml + - ansible-test-utcnow.yml + - pep517-backend-traceback-fix.yml + release_date: '2023-05-15' + 2.14.7: + changes: + release_summary: '| Release Date: 2023-06-20 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.7_summary.yaml + release_date: '2023-06-20' + 2.14.7rc1: + changes: + bugfixes: + - ansible-test - Fix a traceback that occurs when attempting to test Ansible + source using a different ansible-test. A clear error message is now given + when this scenario occurs. + - ansible-test local change detection - use ``git merge-base <branch> HEAD`` + instead of ``git merge-base --fork-point <branch>`` (https://github.com/ansible/ansible/pull/79734). + - man page build - Remove the dependency on the ``docs`` directory for building + man pages. + - uri - fix search for JSON type to include complex strings containing '+' + minor_changes: + - Removed ``straight.plugin`` from the build and packaging requirements. + release_summary: '| Release Date: 2023-06-12 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.7rc1_summary.yaml + - 79734-ansible-test-change-detection.yml + - ansible-test-source-detection.yml + - build-no-straight.yaml + - man-page-build-docs-dependency.yml + - update-maybe-json-uri.yml + release_date: '2023-06-12' + 2.14.8: + changes: + release_summary: '| Release Date: 2023-07-18 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.8_summary.yaml + release_date: '2023-07-17' + 2.14.8rc1: + changes: + bugfixes: + - ansible-galaxy - Fix issue installing collections containing directories with + more than 100 characters on python versions before 3.10.6 + minor_changes: + - Cache field attributes list on the playbook classes + - Playbook objects - Replace deprecated stacked ``@classmethod`` and ``@property`` + - ansible-test - Use a context manager to perform cleanup at exit instead of + using the built-in ``atexit`` module. + release_summary: '| Release Date: 2023-07-10 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.8rc1_summary.yaml + - ansible-test-atexit.yml + - cache-fa-on-pb-cls.yml + - long-collection-paths-fix.yml + - no-stacked-descriptors.yaml + release_date: '2023-07-10' + 2.14.9: + changes: + release_summary: '| Release Date: 2023-08-14 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.9_summary.yaml + release_date: '2023-08-14' + 2.14.9rc1: + changes: + bugfixes: + - Exclude internal options from man pages and docs. + - Fix ``ansible-config init`` man page option indentation. + - The ``ansible-config init`` command now has a documentation description. + - The ``ansible-galaxy collection download`` command now has a documentation + description. + - The ``ansible-galaxy collection install`` command documentation is now visible + (previously hidden by a decorator). + - The ``ansible-galaxy collection verify`` command now has a documentation description. + - The ``ansible-galaxy role install`` command documentation is now visible (previously + hidden by a decorator). + - The ``ansible-inventory`` command command now has a documentation description + (previously used as the epilog). + - Update module_utils.urls unit test to work with cryptography >= 41.0.0. + - When generating man pages, use ``func`` to find the command function instead + of looking it up by the command name. + - ansible-test - Pre-build a PyYAML wheel before installing requirements to + avoid a potential Cython build failure. + - man page build - Sub commands of ``ansible-galaxy role`` and ``ansible-galaxy + collection`` are now documented. + minor_changes: + - Removed ``exclude`` and ``recursive-exclude`` commands for generated files + from the ``MANIFEST.in`` file. These excludes were unnecessary since releases + are expected to be built with a clean worktree. + - Removed ``exclude`` commands for sanity test files from the ``MANIFEST.in`` + file. These tests were previously excluded because they did not pass when + run from an sdist. However, sanity tests are not expected to pass from an + sdist, so excluding some (but not all) of the failing tests makes little sense. + - Removed redundant ``include`` commands from the ``MANIFEST.in`` file. These + includes either duplicated default behavior or another command. + - The ``ansible-core`` sdist no longer contains pre-generated man pages. Instead, + a ``packaging/cli-doc/build.py`` script is included in the sdist. This script + can generate man pages and standalone RST documentation for ``ansible-core`` + CLI programs. + - The ``docs`` and ``examples`` directories are no longer included in the ``ansible-core`` + sdist. These directories have been moved to the https://github.com/ansible/ansible-documentation + repository. + - The minimum required ``setuptools`` version is now 45.2.0, as it is the oldest + version to support Python 3.10. + - Use ``include`` where ``recursive-include`` is unnecessary in the ``MANIFEST.in`` + file. + - Use ``package_data`` instead of ``include_package_data`` for ``setup.cfg`` + to avoid ``setuptools`` warnings. + - ansible-test - Update the logic used to detect when ``ansible-test`` is running + from source. + release_summary: '| Release Date: 2023-08-07 + + | `Porting Guide <https://docs.ansible.com/ansible-core/2.14/porting_guides/porting_guide_core_2.14.html>`__ + + ' + codename: C'mon Everybody + fragments: + - 2.14.9rc1_summary.yaml + - add-missing-cli-docs.yml + - ansible-test-layout-detection.yml + - ansible-test-minimum-setuptools.yml + - ansible-test-pyyaml-build.yml + - fix-setuptools-warnings.yml + - man-page-subcommands.yml + - manifest-in-cleanup.yml + - missing-doc-func.yml + - omit-man-pages-from-sdist.yml + - remove-docs-examples.yml + - suppressed-options.yml + - urls-unit-test-latest-cryptography.yml + release_date: '2023-08-07' |