From a6ce5f76262bfc0379540ef7720eb747f747771d Mon Sep 17 00:00:00 2001 From: Griffin Sullivan <48397354+Griffin-Sullivan@users.noreply.github.com> Date: Mon, 6 May 2024 09:09:52 -0400 Subject: [PATCH] Copy config files for FAM to server (#14866) --- conf/fam.yaml.template | 101 ++++++++++++++++++++++++++++++++ robottelo/constants/__init__.py | 4 +- robottelo/hosts.py | 9 ++- tests/foreman/sys/test_fam.py | 30 ++++------ 4 files changed, 123 insertions(+), 21 deletions(-) create mode 100644 conf/fam.yaml.template diff --git a/conf/fam.yaml.template b/conf/fam.yaml.template new file mode 100644 index 00000000000..079225d0048 --- /dev/null +++ b/conf/fam.yaml.template @@ -0,0 +1,101 @@ +FAM: + SERVER: + # Parameter for all tests + foreman_username: admin + foreman_password: "changeme" + foreman_server_url: "https://foreman.example.com" + foreman_validate_certs: false + + foreman_proxy: "foreman.example.com" + + # Parameter for snapshot test + snapshot_host_name: "test_host" + + # Parameter for job invocation test + foreman_host: "foreman.example.com" + + # Parameter for subscription_manifest test + subscription_manifest_path: "data/manifest_foreman-ansible-modules.zip" + + # Parameter for redhat_manifest test + manifest_name: "katello.example.com" + rhsm_username: "john-smith" + rhsm_password: "changeme" + rhsm_pool_id: 8a85f99a7db4827d017dc512fcad00b0 + rhsm_validate_certs: false + + # Parameter for scc_product test + scc_account_name_for_scc_product: testaccount + scc_account_login_for_scc_product: testuser + scc_account_password_for_scc_product: testpass + + # Parameter for external_usergroup testing + auth_source_ldap_host: ldap.example.com + auth_source_ldap_account: ansible + auth_source_ldap_account_password: pass + auth_source_ldap_base_dn: dc=example,dc=com + auth_source_ldap_attr_login: uid + auth_source_ldap_groups_base: cn=groups,cn=accounts,dc=example,dc=com + external_usergroup_name: "admins" + + COMPUTE_PROFILE: + libvirt: + compute_resource: + name: libvirt-cr01 + organizations: + - Test Organization + locations: + - Test Location + params: + url: qemu+ssh://libvirtuser@localhost/system + compute_profile: + name: app-small + attrs: + cpus: 1 + memory: 2147483648 + nics_attributes: + 0: + type: bridge + bridge: "" + model: virtio + volumes_attributes: + 0: + pool_name: default + capacity: 10G + allocation: 0G + format_type: raw + ovirt: + compute_resource: + name: ovirt-cr01 + organizations: + - Test Organization + locations: + - Test Location + params: + url: "https://ovirt.example.com/ovirt-engine/api" + user: compute-user@internal + password: ovirtcompute123 + use_v4: true + datacenter: c1479626-99a2-44eb-8401-14b5630f417f + ovirt_quota: 502a76bb-a3fe-42f1-aed6-2a7c892a6786 + compute_profile: + name: app-small + attrs: + cluster: Devel-Infra + cores: 2 + sockets: 1 + memory: 1073741824 + ha: 0 + interfaces_attributes: + 0: + name: "" + network: ovirtmgmt + interface: virtio + volumes_attributes: + 0: + size_gb: '16' + storage_domain: 'Local-IBM' + preallocate: '1' + wipe_after_delete: '0' + interface: 'virtio_scsi' + bootable: 'true' diff --git a/robottelo/constants/__init__.py b/robottelo/constants/__init__.py index b3cfcdd8f38..05571d2c3e3 100644 --- a/robottelo/constants/__init__.py +++ b/robottelo/constants/__init__.py @@ -1894,7 +1894,6 @@ class Colored(Box): "content_export_repository", "content_export_version", "content_rhel_role", - "content_upload_ostree", "content_upload", "content_view_filter_info", "content_view_filter_rule_info", @@ -1955,9 +1954,9 @@ class Colored(Box): "puppet_environment", "realm", "redhat_manifest", + "registration_command", "repositories_role", "repository_info", - "repository_ostree", "repository_set_info", "repository_set", "repository_sync", @@ -1984,6 +1983,7 @@ class Colored(Box): "usergroup", "user", "wait_for_task", + "webhook", ] FAM_ROOT_DIR = '/usr/share/ansible/collections/ansible_collections/redhat/satellite' diff --git a/robottelo/hosts.py b/robottelo/hosts.py index 72dc0bb392d..57dec9e9f04 100644 --- a/robottelo/hosts.py +++ b/robottelo/hosts.py @@ -883,12 +883,17 @@ def get(self, remote_path, local_path=None): """Get a remote file from the broker virtual machine.""" self.session.sftp_read(source=remote_path, destination=local_path) - def put(self, local_path, remote_path=None): + def put(self, local_path, remote_path=None, temp_file=False): """Put a local file to the broker virtual machine. If local_path is a manifest object, write its contents to a temporary file then continue with the upload. """ - if 'utils.manifest' in str(local_path): + if temp_file: + with NamedTemporaryFile(dir=robottelo_tmp_dir) as content_file: + content_file.write(str.encode(local_path)) + content_file.flush() + self.session.sftp_write(source=content_file.name, destination=remote_path) + elif 'utils.manifest' in str(local_path): with NamedTemporaryFile(dir=robottelo_tmp_dir) as content_file: content_file.write(local_path.content.read()) content_file.flush() diff --git a/tests/foreman/sys/test_fam.py b/tests/foreman/sys/test_fam.py index e4675d4f581..a797c39d792 100644 --- a/tests/foreman/sys/test_fam.py +++ b/tests/foreman/sys/test_fam.py @@ -46,6 +46,19 @@ def setup_fam(module_target_sat, module_sca_manifest): # Execute AAP WF for FAM setup Broker().execute(workflow='fam-test-setup', source_vm=module_target_sat.name) + # Setup provisioning resources and copy config files to the Satellite + module_target_sat.configure_libvirt_cr() + module_target_sat.put( + settings.fam.server.to_yaml(), + f'{FAM_ROOT_DIR}/tests/test_playbooks/vars/server.yml', + temp_file=True, + ) + module_target_sat.put( + settings.fam.compute_profile.to_yaml(), + f'{FAM_ROOT_DIR}/tests/test_playbooks/vars/compute_profile.yml', + temp_file=True, + ) + # Edit Makefile to not try to rebuild the collection when tests run module_target_sat.execute(f"sed -i '/^live/ s/$(MANIFEST)//' {FAM_ROOT_DIR}/Makefile") @@ -54,27 +67,10 @@ def setup_fam(module_target_sat, module_sca_manifest): module_target_sat.execute( f'mv {module_sca_manifest.name} {FAM_ROOT_DIR}/tests/test_playbooks/data' ) - - # Edit config file config_file = f'{FAM_ROOT_DIR}/tests/test_playbooks/vars/server.yml' - module_target_sat.execute( - f'cp {FAM_ROOT_DIR}/tests/test_playbooks/vars/server.yml.example {config_file}' - ) - module_target_sat.execute( - f'sed -i "s/foreman.example.com/{module_target_sat.hostname}/g" {config_file}' - ) - module_target_sat.execute( - f'sed -i "s/rhsm_pool_id:.*/rhsm_pool_id: {settings.subscription.rhn_poolid}/g" {config_file}' - ) - module_target_sat.execute( - f'''sed -i 's/rhsm_username:.*/rhsm_username: "{settings.subscription.rhn_username}"/g' {config_file}''' - ) module_target_sat.execute( f'''sed -i 's|subscription_manifest_path:.*|subscription_manifest_path: "data/{module_sca_manifest.name}"|g' {config_file}''' ) - module_target_sat.execute( - f'''sed -i 's/rhsm_password:.*/rhsm_password: "{settings.subscription.rhn_password}"/g' {config_file}''' - ) @pytest.mark.pit_server