From 2cad3f016f3184f4485cfb96df625f599cad77cc Mon Sep 17 00:00:00 2001 From: Zdenek Veleba Date: Mon, 27 Nov 2023 08:08:18 +0100 Subject: [PATCH] Update Anaconda WebUI plugin to reflect changes made in anaconda repo --- libpermian/plugins/anaconda_webui/__init__.py | 42 +++++++++---------- libpermian/plugins/anaconda_webui/commands.py | 10 ++--- .../plugins/anaconda_webui/settings.ini | 2 +- libpermian/plugins/anaconda_webui/test.py | 2 +- 4 files changed, 28 insertions(+), 28 deletions(-) diff --git a/libpermian/plugins/anaconda_webui/__init__.py b/libpermian/plugins/anaconda_webui/__init__.py index cbc326d..d992136 100644 --- a/libpermian/plugins/anaconda_webui/__init__.py +++ b/libpermian/plugins/anaconda_webui/__init__.py @@ -153,8 +153,8 @@ def __init__(self, testRuns, crcList, setup_lock, vm_semaphore): self.debug = self.settings.getboolean('AnacondaWebUI', 'debug') self.test_timeout = self.settings.getint('AnacondaWebUI', 'test_timeout') - self.git_anaconda_repo = self.settings.get('AnacondaWebUI', 'anaconda_repo') - self.git_anaconda_branch = self.crc.configuration['branch'] + self.git_webui_repo = self.settings.get('AnacondaWebUI', 'webui_repo') + self.git_webui_branch = self.crc.configuration['branch'] self.git_cockpit_repo = self.settings.get('AnacondaWebUI', 'cockpit_repo') self.git_cockpit_branch = self.settings.get('AnacondaWebUI', 'cockpit_branch') self.git_bots_repo = self.settings.get('AnacondaWebUI', 'bots_repo') @@ -213,20 +213,19 @@ def setup(self): self.container = ExecutionContainer(container_build_log) # Add self to instances using this branch setup - if self.git_anaconda_branch in self.instances: - self.instances[self.git_anaconda_branch].append(self) + if self.git_webui_branch in self.instances: + self.instances[self.git_webui_branch].append(self) else: - self.instances[self.git_anaconda_branch] = [self] + self.instances[self.git_webui_branch] = [self] # Create temporary directory for this branch setup - if it doesn't exists - if self.git_anaconda_branch not in self.temp_dirs.keys(): - self.temp_dirs[self.git_anaconda_branch] = tempfile.TemporaryDirectory(dir='/var/tmp/', prefix="pipeline_awebui_") + if self.git_webui_branch not in self.temp_dirs.keys(): + self.temp_dirs[self.git_webui_branch] = tempfile.TemporaryDirectory(dir='/var/tmp/', prefix="pipeline_awebui_") clone_common = True - self.temp_dir = self.temp_dirs[self.git_anaconda_branch].name + self.temp_dir = self.temp_dirs[self.git_webui_branch].name os.chmod(self.temp_dir, 755) - self.anaconda_dir = os.path.join(self.temp_dir, 'anaconda') - self.webui_dir = os.path.join(self.anaconda_dir, 'ui/webui') + self.webui_dir = os.path.join(self.temp_dir, 'anaconda-webui') if self.test_repo_name: self._clone_test_repo() @@ -240,7 +239,7 @@ def setup(self): if self.installation_source is None: self._set_boot_iso_path() - self.test_workdir = self.anaconda_dir # CWD where the test is going to run + self.test_workdir = self.webui_dir # CWD where the test is going to run if self.test_repo_name: self.test_workdir = self.test_repo_dir @@ -305,6 +304,7 @@ def execute(self): test_env = {'WEBUI_TEST_DIR': os.path.abspath(os.path.join(self.webui_dir, 'test'))} test_env['TEST_AUDIT_NO_SELINUX'] = '1' + test_env['EXTENDED_LOGGING'] = '1' test_output = self.crc.openLogfile('output.txt', 'w', True) time.sleep(10) # Workaround, there is a race-condition, where WebUI is accessible but /run/anaconda/bus.address doesn't exist yet @@ -387,11 +387,11 @@ def teardown(self): with self.setup_lock: # If this instance is the last one using temp dir -> remove it - self.instances[self.git_anaconda_branch].remove(self) - if len(self.instances[self.git_anaconda_branch]) == 0: - self.temp_dirs[self.git_anaconda_branch].cleanup() + self.instances[self.git_webui_branch].remove(self) + if len(self.instances[self.git_webui_branch]) == 0: + self.temp_dirs[self.git_webui_branch].cleanup() - del self.instances[self.git_anaconda_branch] + del self.instances[self.git_webui_branch] # Remove container image, if this was the last anacoda-webui workflow if not self.instances: self.container.remove_image() @@ -579,21 +579,21 @@ def _clone_test_repo(self): self.test_repo_dir = os.path.join(self.temp_dir, self.test_repo_name) if not os.path.isdir(self.test_repo_dir): self.log(f'Clonning test repo {self.test_repo_url}') - self._clone_repo(self.test_repo_url, self.git_anaconda_branch, self.test_repo_dir) + self._clone_repo(self.test_repo_url, self.git_webui_branch, self.test_repo_dir) def _clone_common(self): """ Clones repositories common to all Anaconda WebUI tests """ self.log(f'Clonning common repositories') bots_dir = os.path.join(self.webui_dir, 'bots') - cockpit_common_dir = os.path.join(self.anaconda_dir, 'ui/webui/test/common') - parsed_anaconda_url = urllib.parse.urlparse(self.git_anaconda_repo) + cockpit_common_dir = os.path.join(self.webui_dir, 'test/common') + parsed_webui_url = urllib.parse.urlparse(self.git_webui_repo) - if parsed_anaconda_url.scheme == 'file': + if parsed_webui_url.scheme == 'file': # Create copy of anaconda repo - shutil.copytree(parsed_anaconda_url.path, self.anaconda_dir, symlinks=True, ignore_dangling_symlinks=True) + shutil.copytree(parsed_webui_url.path, self.webui_dir, symlinks=True, ignore_dangling_symlinks=True) else: # clone anaconda - self._clone_repo(self.git_anaconda_repo, self.git_anaconda_branch, self.anaconda_dir) + self._clone_repo(self.git_webui_repo, self.git_webui_branch, self.webui_dir) if not os.path.exists(cockpit_common_dir): with tempfile.TemporaryDirectory() as temp_dir: diff --git a/libpermian/plugins/anaconda_webui/commands.py b/libpermian/plugins/anaconda_webui/commands.py index 6c749fe..24df267 100644 --- a/libpermian/plugins/anaconda_webui/commands.py +++ b/libpermian/plugins/anaconda_webui/commands.py @@ -6,14 +6,14 @@ @api.cli.register_command_parser('run_awebui_tc') def run_awebui_tc_command(base_parser, args): parser = base_parser - parser.add_argument('path_to_anaconda', - help='Path to local Anaconda git repository where the test case is located') + parser.add_argument('path_to_webui', + help='Path to local Anaconda-webui git repository where the test case is located') parser.add_argument('test_case_name', help='Name of the test case as specified in tc.yaml') source_group = parser.add_mutually_exclusive_group() source_group.add_argument('--install-source', default='https://fedorapeople.org/groups/anaconda/webui_permian_tests/sources/periodic/x86_64/', - help='URL of the installation source (compose os directory or unpack iso') + help='URL of the installation source (compose os directory or iso') source_group.add_argument('--compose', help='Compose ID of a compose that should be used as installation source') parser.add_argument('--compose-url', @@ -64,11 +64,11 @@ def run_awebui_tc_command(base_parser, args): os.environ.setdefault( "PIPELINE_library_directPath", - os.path.join(options.path_to_anaconda, 'ui/webui/test/end2end/'), + os.path.join(options.path_to_webui, 'test/test_cases/'), ) os.environ.setdefault( "PIPELINE_AnacondaWebUI_anaconda_repo", - 'file://' + os.path.abspath(options.path_to_anaconda), + 'file://' + os.path.abspath(options.path_to_webui), ) return options, json.dumps(event) diff --git a/libpermian/plugins/anaconda_webui/settings.ini b/libpermian/plugins/anaconda_webui/settings.ini index 97ef66f..37e69b8 100644 --- a/libpermian/plugins/anaconda_webui/settings.ini +++ b/libpermian/plugins/anaconda_webui/settings.ini @@ -1,6 +1,6 @@ [AnacondaWebUI] # Anaconda repo, use file:// to copy local directory or anything else to clone git repo -anaconda_repo=https://github.com/rhinstaller/anaconda.git +webui_repo=https://github.com/rhinstaller/anaconda-webui.git cockpit_repo=https://github.com/cockpit-project/cockpit.git cockpit_branch=289 bots_repo=https://github.com/cockpit-project/bots.git diff --git a/libpermian/plugins/anaconda_webui/test.py b/libpermian/plugins/anaconda_webui/test.py index 2f4ddc2..df641f9 100644 --- a/libpermian/plugins/anaconda_webui/test.py +++ b/libpermian/plugins/anaconda_webui/test.py @@ -121,7 +121,7 @@ def test_execute(self, mocked_run, mocked_sleep, list_dir, mocked_openLogfile): mocked_run.assert_called_with(['podman', 'run', '--rm', '-it', '-v', '/test/temp:/root/workdir:z', '-w', '/root/workdir/workdir', '-e', 'WEBUI_TEST_DIR=/root/workdir/workdir/webui/test', '-e', 'TEST_AUDIT_NO_SELINUX=1', - 'anaconda-webui', 'file', 'Case', '--browser', '192.168.122.42:8000', + '-e', 'EXTENDED_LOGGING=1', 'anaconda-webui', 'file', 'Case', '--browser', '192.168.122.42:8000', '--machine', '192.168.122.42:11'], stderr=-2, stdout=ANY) self.workflow.reportResult.assert_called_with(Result('complete', 'PASS', True))