From d29d64ea711a57ccd13137214148a676bdefa002 Mon Sep 17 00:00:00 2001 From: Mike Sul Date: Fri, 22 Mar 2024 16:13:05 +0100 Subject: [PATCH] apps: Convert shortlist string to list - Convert the comma-separated list of apps represented as a string and provided as an input parameter to a list of string. - Define the app shortlist as a list of strings in each function of the app fetcher. Signed-off-by: Mike Sul --- apps/fetch.py | 4 +++- apps/target_apps_fetcher.py | 6 +++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/apps/fetch.py b/apps/fetch.py index 5b24c9ab..35724e94 100755 --- a/apps/fetch.py +++ b/apps/fetch.py @@ -15,7 +15,7 @@ from helpers import cmd -def fetch_target_apps(targets: dict, apps_shortlist: str, token: str, dst_dir: str): +def fetch_target_apps(targets: dict, apps_shortlist: [str], token: str, dst_dir: str): apps_fetcher = SkopeAppFetcher(token, dst_dir) for target_name, target_json in targets.items(): apps_fetcher.fetch_target(FactoryClient.Target(target_name, target_json), @@ -45,6 +45,8 @@ def get_args(): help='TUF targets to be updated with URI to fetched app archive') args = parser.parse_args() + if args.apps_shortlist: + args.apps_shortlist = [x.strip() for x in args.apps_shortlist.split(',') if x] return args diff --git a/apps/target_apps_fetcher.py b/apps/target_apps_fetcher.py index 9f633c37..9417be83 100644 --- a/apps/target_apps_fetcher.py +++ b/apps/target_apps_fetcher.py @@ -41,12 +41,12 @@ def apps_dir(self, target_name): def images_dir(self, target_name): return os.path.join(self.target_dir(target_name), self.ImagesDir) - def fetch_target(self, target: FactoryClient.Target, shortlist=None, force=False): + def fetch_target(self, target: FactoryClient.Target, shortlist: [str] = None, force=False): self.target_apps.clear() self.fetch_target_apps(target, apps_shortlist=target.shortlist or shortlist, force=force) self.fetch_apps_images(force=force) - def fetch_target_apps(self, target: FactoryClient.Target, apps_shortlist=None, force=False): + def fetch_target_apps(self, target: FactoryClient.Target, apps_shortlist: [str] = None, force=False): self.target_apps[target] = self._fetch_apps(target, apps_shortlist=apps_shortlist, force=force) def fetch_apps_images(self, graphdriver='overlay2', force=False): @@ -71,7 +71,7 @@ def _download_apps_images(apps: ComposeApps, app_images_dir, platform, graphdriv for app in apps: app.download_images(platform, dockerd.host) - def _fetch_apps(self, target, apps_shortlist=None, force=False): + def _fetch_apps(self, target, apps_shortlist: [str] = None, force=False): for app_name, app_uri in target.apps(): if apps_shortlist and app_name not in apps_shortlist: logger.info('{} is not in the shortlist, skipping it'.format(app_name))