adds output for installing and removing packages

This commit is contained in:
Stanislav Shamilov 2024-12-03 22:21:30 +02:00
parent 7349127609
commit 01c36742dd
2 changed files with 39 additions and 24 deletions

View file

@ -32,6 +32,14 @@ class Package:
def __str__(self): def __str__(self):
return "%s;%s (%s)" % (self.name, self.version, self.description) return "%s;%s (%s)" % (self.name, self.version, self.description)
def __hash__(self):
return hash((self.name, self.version))
def __ne__(self, other):
if not isinstance(other, Package):
return True
return self.name != other.name or self.version != other
def __eq__(self, other): def __eq__(self, other):
if not isinstance(other, Package): if not isinstance(other, Package):
return False return False
@ -51,6 +59,13 @@ class AndroidSdkManager(object):
re.compile(r'^\s+(?P<name>\S+)\s+\|\s+(?P<version>\S+)\s+\|\s(?P<description>.+)\s\|\s+(\S+)$') re.compile(r'^\s+(?P<name>\S+)\s+\|\s+(?P<version>\S+)\s+\|\s(?P<description>.+)\s\|\s+(\S+)$')
) )
@staticmethod
def package_split(package):
parts = package.split(';', maxsplit=1)
if len(parts) > 1:
return parts
return parts[0], None
def __init__(self, runner): def __init__(self, runner):
self.runner = runner self.runner = runner
@ -58,7 +73,7 @@ class AndroidSdkManager(object):
with self.runner('installed') as ctx: with self.runner('installed') as ctx:
rc, stdout, stderr = ctx.run() rc, stdout, stderr = ctx.run()
packages = [] packages = set()
data = stdout.split('\n') data = stdout.split('\n')
lines_count = len(data) lines_count = len(data)
@ -72,8 +87,9 @@ class AndroidSdkManager(object):
else: else:
p = self._RE_INSTALLED_PACKAGES.search(line) p = self._RE_INSTALLED_PACKAGES.search(line)
if p: if p:
package = Package(p.group('name'), p.group('version'), p.group('description')) name = AndroidSdkManager.package_split(p.group('name'))[0]
packages.append(package) package = Package(name, p.group('version'), p.group('description'))
packages.add(package)
i += 1 i += 1
return packages return packages
@ -86,6 +102,9 @@ class AndroidSdkManager(object):
def apply_packages_changes(self, packages, state): def apply_packages_changes(self, packages, state):
if len(packages) == 0: if len(packages) == 0:
return return
command_arg = ''.join(x.get_formatted() for x in packages) command_arg = [x.get_formatted() for x in packages]
# ValueError: ['build-tools;34.0.0', 'build-tools;35.0.0']
# raise ValueError(command_arg)
with self.runner('state name') as ctx: with self.runner('state name') as ctx:
ctx.run(name=command_arg, state=state) ctx.run(name=command_arg, state=state)

View file

@ -12,10 +12,10 @@ class AndroidSdk(StateModuleHelper):
) )
) )
use_old_vardict = False use_old_vardict = False
output_params = ('installed') output_params = ('installed', 'removed')
@staticmethod @staticmethod
def package_split(package): def arg_package_split(package):
parts = package.split('=', maxsplit=1) parts = package.split('=', maxsplit=1)
if len(parts) > 1: if len(parts) > 1:
return parts return parts
@ -26,43 +26,39 @@ class AndroidSdk(StateModuleHelper):
def _parse_packages(self): def _parse_packages(self):
arg_pkgs = self.vars.package arg_pkgs = self.vars.package
packages = [] packages = set()
for arg_pkg in arg_pkgs: for arg_pkg in arg_pkgs:
pkg, version = AndroidSdk.package_split(arg_pkg) pkg, version = AndroidSdk.arg_package_split(arg_pkg)
package = Package(pkg, version) package = Package(pkg, version)
packages.append(package) packages.add(package)
if len(packages) < len(arg_pkgs):
self.do_raise("Packages may not repeat")
return packages return packages
def state_present(self): def state_present(self):
packages = self._parse_packages() packages = self._parse_packages()
installed = self.sdkmanager.get_installed_packages() installed = self.sdkmanager.get_installed_packages()
pending_installation = [] pending_installation = packages.difference(installed)
for package in packages:
for existing in installed:
if existing.name == package.name:
if existing.version == package.version:
pass # do nothing, package exists
# else:
# package exists, but needs to be updated/downgraded
else:
pending_installation.append(package)
self.sdkmanager.install_packages(pending_installation) self.sdkmanager.install_packages(pending_installation)
self.vars.installed = AndroidSdk._packages_to_str(pending_installation)
def state_absent(self): def state_absent(self):
packages = self._parse_packages() packages = self._parse_packages()
installed = self.sdkmanager.get_installed_packages() installed = self.sdkmanager.get_installed_packages()
to_be_deleted = [] to_be_deleted = packages.intersection(installed)
for package in packages:
for existing in installed:
if existing == package:
to_be_deleted.append(package)
self.sdkmanager.uninstall_packages(to_be_deleted) self.sdkmanager.uninstall_packages(to_be_deleted)
self.vars.removed = AndroidSdk._packages_to_str(to_be_deleted)
def update_packages(self): def update_packages(self):
pass pass
# with self.sdkmanager('update') as ctx: # with self.sdkmanager('update') as ctx:
# ctx.run() # ctx.run()
@staticmethod
def _packages_to_str(packages):
return [{'name': x.name, 'version': x.version} for x in packages]
def __run__(self): def __run__(self):
super().__run__() super().__run__()