mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
* updated deprecated homebrew cask commands
* added methods for brew version deprecation check
* added comments and changelog fragment
* added unit test for version comparison
* switch to use disutils LooseVersion for version comparison
* updated changelog message and minor refactor for building brew command based on version
* added caching logic for retrieval of brew version and updated PR changelog yaml
* Update changelogs/fragments/1481-deprecated-brew-cask-command.yaml
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update plugins/modules/packaging/os/homebrew_cask.py
* Update plugins/modules/packaging/os/homebrew_cask.py
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update plugins/modules/packaging/os/homebrew_cask.py
Co-authored-by: Felix Fontein <felix@fontein.de>
* switch to use subprocess.check_output instead of subprocess.run
* replace subprocess with run_command
* removed unused subprocess import
* removed error handling logic to depend on check_rc=True instead
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit ed813176ce
)
Co-authored-by: Jianhao Tan <jianhao@shopback.com>
This commit is contained in:
parent
95d725a3cc
commit
7ac14f964b
2 changed files with 67 additions and 33 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
minor_changes:
|
||||||
|
- homebrew_cask - Homebrew will be deprecating use of ``brew cask`` commands as of version 2.6.0, see https://brew.sh/2020/12/01/homebrew-2.6.0/. Added logic to stop using ``brew cask`` for brew version >= 2.6.0 (https://github.com/ansible-collections/community.general/pull/1481).
|
|
@ -139,6 +139,7 @@ EXAMPLES = '''
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import tempfile
|
import tempfile
|
||||||
|
from distutils import version
|
||||||
|
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.module_utils.basic import AnsibleModule
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
@ -356,6 +357,18 @@ class HomebrewCask(object):
|
||||||
else:
|
else:
|
||||||
self._current_cask = cask
|
self._current_cask = cask
|
||||||
return cask
|
return cask
|
||||||
|
|
||||||
|
@property
|
||||||
|
def brew_version(self):
|
||||||
|
try:
|
||||||
|
return self._brew_version
|
||||||
|
except AttributeError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
@brew_version.setter
|
||||||
|
def brew_version(self, brew_version):
|
||||||
|
self._brew_version = brew_version
|
||||||
|
|
||||||
# /class properties -------------------------------------------- }}}
|
# /class properties -------------------------------------------- }}}
|
||||||
|
|
||||||
def __init__(self, module, path=path, casks=None, state=None,
|
def __init__(self, module, path=path, casks=None, state=None,
|
||||||
|
@ -434,15 +447,12 @@ class HomebrewCask(object):
|
||||||
if not self.valid_cask(self.current_cask):
|
if not self.valid_cask(self.current_cask):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
cask_is_outdated_command = (
|
if self._brew_cask_command_is_deprecated():
|
||||||
[
|
base_opts = [self.brew_path, 'outdated', '--cask']
|
||||||
self.brew_path,
|
else:
|
||||||
'cask',
|
base_opts = [self.brew_path, 'cask', 'outdated']
|
||||||
'outdated',
|
|
||||||
]
|
cask_is_outdated_command = base_opts + (['--greedy'] if self.greedy else []) + [self.current_cask]
|
||||||
+ (['--greedy'] if self.greedy else [])
|
|
||||||
+ [self.current_cask]
|
|
||||||
)
|
|
||||||
|
|
||||||
rc, out, err = self.module.run_command(cask_is_outdated_command)
|
rc, out, err = self.module.run_command(cask_is_outdated_command)
|
||||||
|
|
||||||
|
@ -454,18 +464,35 @@ class HomebrewCask(object):
|
||||||
self.message = 'Invalid cask: {0}.'.format(self.current_cask)
|
self.message = 'Invalid cask: {0}.'.format(self.current_cask)
|
||||||
raise HomebrewCaskException(self.message)
|
raise HomebrewCaskException(self.message)
|
||||||
|
|
||||||
cmd = [
|
if self._brew_cask_command_is_deprecated():
|
||||||
"{brew_path}".format(brew_path=self.brew_path),
|
base_opts = [self.brew_path, "list", "--cask"]
|
||||||
"cask",
|
else:
|
||||||
"list",
|
base_opts = [self.brew_path, "cask", "list"]
|
||||||
self.current_cask
|
|
||||||
]
|
cmd = base_opts + [self.current_cask]
|
||||||
rc, out, err = self.module.run_command(cmd)
|
rc, out, err = self.module.run_command(cmd)
|
||||||
|
|
||||||
if rc == 0:
|
if rc == 0:
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def _get_brew_version(self):
|
||||||
|
if self.brew_version:
|
||||||
|
return self.brew_version
|
||||||
|
|
||||||
|
cmd = [self.brew_path, '--version']
|
||||||
|
|
||||||
|
rc, out, err = self.module.run_command(cmd, check_rc=True)
|
||||||
|
|
||||||
|
# get version string from first line of "brew --version" output
|
||||||
|
version = out.split('\n')[0].split(' ')[1]
|
||||||
|
self.brew_version = version
|
||||||
|
return self.brew_version
|
||||||
|
|
||||||
|
def _brew_cask_command_is_deprecated(self):
|
||||||
|
# The `brew cask` replacements were fully available in 2.6.0 (https://brew.sh/2020/12/01/homebrew-2.6.0/)
|
||||||
|
return version.LooseVersion(self._get_brew_version()) >= version.LooseVersion('2.6.0')
|
||||||
# /checks ------------------------------------------------------ }}}
|
# /checks ------------------------------------------------------ }}}
|
||||||
|
|
||||||
# commands ----------------------------------------------------- {{{
|
# commands ----------------------------------------------------- {{{
|
||||||
|
@ -537,11 +564,10 @@ class HomebrewCask(object):
|
||||||
self.message = 'Casks would be upgraded.'
|
self.message = 'Casks would be upgraded.'
|
||||||
raise HomebrewCaskException(self.message)
|
raise HomebrewCaskException(self.message)
|
||||||
|
|
||||||
opts = (
|
if self._brew_cask_command_is_deprecated():
|
||||||
[self.brew_path, 'cask', 'upgrade']
|
cmd = [self.brew_path, 'upgrade', '--cask']
|
||||||
)
|
else:
|
||||||
|
cmd = [self.brew_path, 'cask', 'upgrade']
|
||||||
cmd = [opt for opt in opts if opt]
|
|
||||||
|
|
||||||
rc, out, err = '', '', ''
|
rc, out, err = '', '', ''
|
||||||
|
|
||||||
|
@ -586,10 +612,12 @@ class HomebrewCask(object):
|
||||||
)
|
)
|
||||||
raise HomebrewCaskException(self.message)
|
raise HomebrewCaskException(self.message)
|
||||||
|
|
||||||
opts = (
|
if self._brew_cask_command_is_deprecated():
|
||||||
[self.brew_path, 'cask', 'install', self.current_cask]
|
base_opts = [self.brew_path, 'install', '--cask']
|
||||||
+ self.install_options
|
else:
|
||||||
)
|
base_opts = [self.brew_path, 'cask', 'install']
|
||||||
|
|
||||||
|
opts = base_opts + [self.current_cask] + self.install_options
|
||||||
|
|
||||||
cmd = [opt for opt in opts if opt]
|
cmd = [opt for opt in opts if opt]
|
||||||
|
|
||||||
|
@ -650,11 +678,13 @@ class HomebrewCask(object):
|
||||||
)
|
)
|
||||||
raise HomebrewCaskException(self.message)
|
raise HomebrewCaskException(self.message)
|
||||||
|
|
||||||
opts = (
|
if self._brew_cask_command_is_deprecated():
|
||||||
[self.brew_path, 'cask', command]
|
base_opts = [self.brew_path, command, '--cask']
|
||||||
+ self.install_options
|
else:
|
||||||
+ [self.current_cask]
|
base_opts = [self.brew_path, 'cask', command]
|
||||||
)
|
|
||||||
|
opts = base_opts + self.install_options + [self.current_cask]
|
||||||
|
|
||||||
cmd = [opt for opt in opts if opt]
|
cmd = [opt for opt in opts if opt]
|
||||||
|
|
||||||
rc, out, err = '', '', ''
|
rc, out, err = '', '', ''
|
||||||
|
@ -703,10 +733,12 @@ class HomebrewCask(object):
|
||||||
)
|
)
|
||||||
raise HomebrewCaskException(self.message)
|
raise HomebrewCaskException(self.message)
|
||||||
|
|
||||||
opts = (
|
if self._brew_cask_command_is_deprecated():
|
||||||
[self.brew_path, 'cask', 'uninstall', self.current_cask]
|
base_opts = [self.brew_path, 'uninstall', '--cask']
|
||||||
+ self.install_options
|
else:
|
||||||
)
|
base_opts = [self.brew_path, 'cask', 'uninstall']
|
||||||
|
|
||||||
|
opts = base_opts + [self.current_cask] + self.install_options
|
||||||
|
|
||||||
cmd = [opt for opt in opts if opt]
|
cmd = [opt for opt in opts if opt]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue