mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Remove ansible.posix dependency (#1157)
* Vendor plugins/module_utils/mount.py from ansible.posix, and drop ansible.posix dependency (except for testing). * Add ignore.txt entries. * Install test requirements conditionally. * Apply suggestions from code review Co-authored-by: John R Barker <john@johnrbarker.com> * Bump to major changes. Co-authored-by: John R Barker <john@johnrbarker.com>
This commit is contained in:
parent
b7713830dc
commit
20f470cc64
9 changed files with 111 additions and 6 deletions
2
changelogs/fragments/remove-ansible.posix-dependency.yml
Normal file
2
changelogs/fragments/remove-ansible.posix-dependency.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
major_changes:
|
||||||
|
- "The community.general collection no longer depends on the ansible.posix collection (https://github.com/ansible-collections/community.general/pull/1157)."
|
|
@ -10,7 +10,6 @@ tags: [community]
|
||||||
# NOTE: No more dependencies can be added to this list
|
# NOTE: No more dependencies can be added to this list
|
||||||
dependencies:
|
dependencies:
|
||||||
ansible.netcommon: '>=1.0.0'
|
ansible.netcommon: '>=1.0.0'
|
||||||
ansible.posix: '>=1.0.0'
|
|
||||||
community.kubernetes: '>=1.0.0'
|
community.kubernetes: '>=1.0.0'
|
||||||
google.cloud: '>=1.0.0'
|
google.cloud: '>=1.0.0'
|
||||||
repository: https://github.com/ansible-collections/community.general
|
repository: https://github.com/ansible-collections/community.general
|
||||||
|
|
90
plugins/module_utils/_mount.py
Normal file
90
plugins/module_utils/_mount.py
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
# This code is part of Ansible, but is an independent component.
|
||||||
|
# This particular file snippet, and this file snippet only, is based on
|
||||||
|
# Lib/posixpath.py of cpython
|
||||||
|
# It is licensed under the PYTHON SOFTWARE FOUNDATION LICENSE VERSION 2
|
||||||
|
#
|
||||||
|
# 1. This LICENSE AGREEMENT is between the Python Software Foundation
|
||||||
|
# ("PSF"), and the Individual or Organization ("Licensee") accessing and
|
||||||
|
# otherwise using this software ("Python") in source or binary form and
|
||||||
|
# its associated documentation.
|
||||||
|
#
|
||||||
|
# 2. Subject to the terms and conditions of this License Agreement, PSF hereby
|
||||||
|
# grants Licensee a nonexclusive, royalty-free, world-wide license to reproduce,
|
||||||
|
# analyze, test, perform and/or display publicly, prepare derivative works,
|
||||||
|
# distribute, and otherwise use Python alone or in any derivative version,
|
||||||
|
# provided, however, that PSF's License Agreement and PSF's notice of copyright,
|
||||||
|
# i.e., "Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
|
||||||
|
# 2011, 2012, 2013, 2014, 2015 Python Software Foundation; All Rights Reserved"
|
||||||
|
# are retained in Python alone or in any derivative version prepared by Licensee.
|
||||||
|
#
|
||||||
|
# 3. In the event Licensee prepares a derivative work that is based on
|
||||||
|
# or incorporates Python or any part thereof, and wants to make
|
||||||
|
# the derivative work available to others as provided herein, then
|
||||||
|
# Licensee hereby agrees to include in any such work a brief summary of
|
||||||
|
# the changes made to Python.
|
||||||
|
#
|
||||||
|
# 4. PSF is making Python available to Licensee on an "AS IS"
|
||||||
|
# basis. PSF MAKES NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR
|
||||||
|
# IMPLIED. BY WAY OF EXAMPLE, BUT NOT LIMITATION, PSF MAKES NO AND
|
||||||
|
# DISCLAIMS ANY REPRESENTATION OR WARRANTY OF MERCHANTABILITY OR FITNESS
|
||||||
|
# FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF PYTHON WILL NOT
|
||||||
|
# INFRINGE ANY THIRD PARTY RIGHTS.
|
||||||
|
#
|
||||||
|
# 5. PSF SHALL NOT BE LIABLE TO LICENSEE OR ANY OTHER USERS OF PYTHON
|
||||||
|
# FOR ANY INCIDENTAL, SPECIAL, OR CONSEQUENTIAL DAMAGES OR LOSS AS
|
||||||
|
# A RESULT OF MODIFYING, DISTRIBUTING, OR OTHERWISE USING PYTHON,
|
||||||
|
# OR ANY DERIVATIVE THEREOF, EVEN IF ADVISED OF THE POSSIBILITY THEREOF.
|
||||||
|
#
|
||||||
|
# 6. This License Agreement will automatically terminate upon a material
|
||||||
|
# breach of its terms and conditions.
|
||||||
|
#
|
||||||
|
# 7. Nothing in this License Agreement shall be deemed to create any
|
||||||
|
# relationship of agency, partnership, or joint venture between PSF and
|
||||||
|
# Licensee. This License Agreement does not grant permission to use PSF
|
||||||
|
# trademarks or trade name in a trademark sense to endorse or promote
|
||||||
|
# products or services of Licensee, or any third party.
|
||||||
|
#
|
||||||
|
# 8. By copying, installing or otherwise using Python, Licensee
|
||||||
|
# agrees to be bound by the terms and conditions of this License
|
||||||
|
# Agreement.
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def ismount(path):
|
||||||
|
"""Test whether a path is a mount point
|
||||||
|
This is a copy of the upstream version of ismount(). Originally this was copied here as a workaround
|
||||||
|
until Python issue 2466 was fixed. Now it is here so this will work on older versions of Python
|
||||||
|
that may not have the upstream fix.
|
||||||
|
https://github.com/ansible/ansible-modules-core/issues/2186
|
||||||
|
http://bugs.python.org/issue2466
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
s1 = os.lstat(path)
|
||||||
|
except (OSError, ValueError):
|
||||||
|
# It doesn't exist -- so not a mount point. :-)
|
||||||
|
return False
|
||||||
|
else:
|
||||||
|
# A symlink can never be a mount point
|
||||||
|
if os.path.stat.S_ISLNK(s1.st_mode):
|
||||||
|
return False
|
||||||
|
|
||||||
|
if isinstance(path, bytes):
|
||||||
|
parent = os.path.join(path, b'..')
|
||||||
|
else:
|
||||||
|
parent = os.path.join(path, '..')
|
||||||
|
parent = os.path.realpath(parent)
|
||||||
|
try:
|
||||||
|
s2 = os.lstat(parent)
|
||||||
|
except (OSError, ValueError):
|
||||||
|
return False
|
||||||
|
|
||||||
|
dev1 = s1.st_dev
|
||||||
|
dev2 = s2.st_dev
|
||||||
|
if dev1 != dev2:
|
||||||
|
return True # path/.. on a different device as path
|
||||||
|
ino1 = s1.st_ino
|
||||||
|
ino2 = s2.st_ino
|
||||||
|
if ino1 == ino2:
|
||||||
|
return True # path/.. is the same i-node as path
|
||||||
|
return False
|
|
@ -170,7 +170,7 @@ msg:
|
||||||
'''
|
'''
|
||||||
|
|
||||||
from ansible.module_utils.basic import AnsibleModule
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
from ansible_collections.ansible.posix.plugins.module_utils.mount import ismount
|
from ansible_collections.community.general.plugins.module_utils._mount import ismount
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ integration_tests_dependencies:
|
||||||
- community.kubernetes
|
- community.kubernetes
|
||||||
unit_tests_dependencies:
|
unit_tests_dependencies:
|
||||||
- ansible.netcommon
|
- ansible.netcommon
|
||||||
- ansible.posix
|
|
||||||
- community.internal_test_tools
|
- community.internal_test_tools
|
||||||
- community.kubernetes
|
- community.kubernetes
|
||||||
- google.cloud
|
- google.cloud
|
||||||
|
|
|
@ -2,6 +2,8 @@ plugins/callback/hipchat.py pylint:blacklisted-name
|
||||||
plugins/connection/lxc.py pylint:blacklisted-name
|
plugins/connection/lxc.py pylint:blacklisted-name
|
||||||
plugins/module_utils/compat/ipaddress.py no-assert
|
plugins/module_utils/compat/ipaddress.py no-assert
|
||||||
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
||||||
|
plugins/module_utils/_mount.py future-import-boilerplate
|
||||||
|
plugins/module_utils/_mount.py metaclass-boilerplate
|
||||||
plugins/modules/cloud/atomic/atomic_container.py validate-modules:doc-required-mismatch
|
plugins/modules/cloud/atomic/atomic_container.py validate-modules:doc-required-mismatch
|
||||||
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
||||||
plugins/modules/cloud/centurylink/clc_aa_policy.py yamllint:unparsable-with-libyaml
|
plugins/modules/cloud/centurylink/clc_aa_policy.py yamllint:unparsable-with-libyaml
|
||||||
|
|
|
@ -2,6 +2,8 @@ plugins/callback/hipchat.py pylint:blacklisted-name
|
||||||
plugins/connection/lxc.py pylint:blacklisted-name
|
plugins/connection/lxc.py pylint:blacklisted-name
|
||||||
plugins/module_utils/compat/ipaddress.py no-assert
|
plugins/module_utils/compat/ipaddress.py no-assert
|
||||||
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
||||||
|
plugins/module_utils/_mount.py future-import-boilerplate
|
||||||
|
plugins/module_utils/_mount.py metaclass-boilerplate
|
||||||
plugins/modules/cloud/atomic/atomic_container.py validate-modules:doc-required-mismatch
|
plugins/modules/cloud/atomic/atomic_container.py validate-modules:doc-required-mismatch
|
||||||
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
||||||
plugins/modules/cloud/centurylink/clc_aa_policy.py yamllint:unparsable-with-libyaml
|
plugins/modules/cloud/centurylink/clc_aa_policy.py yamllint:unparsable-with-libyaml
|
||||||
|
|
|
@ -2,6 +2,8 @@ plugins/callback/hipchat.py pylint:blacklisted-name
|
||||||
plugins/connection/lxc.py pylint:blacklisted-name
|
plugins/connection/lxc.py pylint:blacklisted-name
|
||||||
plugins/module_utils/compat/ipaddress.py no-assert
|
plugins/module_utils/compat/ipaddress.py no-assert
|
||||||
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
plugins/module_utils/compat/ipaddress.py no-unicode-literals
|
||||||
|
plugins/module_utils/_mount.py future-import-boilerplate
|
||||||
|
plugins/module_utils/_mount.py metaclass-boilerplate
|
||||||
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
plugins/modules/cloud/centurylink/clc_aa_policy.py validate-modules:doc-missing-type
|
||||||
plugins/modules/cloud/centurylink/clc_alert_policy.py validate-modules:doc-missing-type
|
plugins/modules/cloud/centurylink/clc_alert_policy.py validate-modules:doc-missing-type
|
||||||
plugins/modules/cloud/centurylink/clc_alert_policy.py validate-modules:no-default-for-required-parameter
|
plugins/modules/cloud/centurylink/clc_alert_policy.py validate-modules:no-default-for-required-parameter
|
||||||
|
|
|
@ -68,12 +68,21 @@ cd "${TEST_DIR}"
|
||||||
|
|
||||||
# START: HACK install dependencies
|
# START: HACK install dependencies
|
||||||
retry ansible-galaxy -vvv collection install ansible.netcommon
|
retry ansible-galaxy -vvv collection install ansible.netcommon
|
||||||
retry ansible-galaxy -vvv collection install ansible.posix
|
|
||||||
retry ansible-galaxy -vvv collection install community.crypto
|
|
||||||
retry ansible-galaxy -vvv collection install community.internal_test_tools
|
|
||||||
retry ansible-galaxy -vvv collection install community.kubernetes
|
retry ansible-galaxy -vvv collection install community.kubernetes
|
||||||
retry ansible-galaxy -vvv collection install google.cloud
|
retry ansible-galaxy -vvv collection install google.cloud
|
||||||
|
|
||||||
|
if [ "${script}" != "sanity" ] || [ "${test}" == "sanity/extra" ]; then
|
||||||
|
# Nothing further should be added to this list.
|
||||||
|
# This is to prevent modules or plugins in this collection having a runtime dependency on other collections.
|
||||||
|
retry ansible-galaxy -vvv collection install community.internal_test_tools
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${script}" != "sanity" ] && [ "${script}" != "units" ]; then
|
||||||
|
# To prevent Python dependencies on other collections only install other collections for integration tests
|
||||||
|
retry ansible-galaxy -vvv collection install ansible.posix
|
||||||
|
retry ansible-galaxy -vvv collection install community.crypto
|
||||||
|
fi
|
||||||
|
|
||||||
# END: HACK
|
# END: HACK
|
||||||
|
|
||||||
export PYTHONIOENCODING='utf-8'
|
export PYTHONIOENCODING='utf-8'
|
||||||
|
|
Loading…
Reference in a new issue