Skip to content

Commit

Permalink
effective user with non-ascii password
Browse files Browse the repository at this point in the history
  • Loading branch information
pondrejk committed Mar 14, 2024
1 parent b950e48 commit 291b7ec
Showing 1 changed file with 19 additions and 4 deletions.
23 changes: 19 additions & 4 deletions tests/foreman/cli/test_remoteexecution.py
Original file line number Diff line number Diff line change
Expand Up @@ -157,25 +157,31 @@ def test_positive_run_default_job_template(
@pytest.mark.pit_server
@pytest.mark.rhel_ver_list([7, 8, 9])
def test_positive_run_job_effective_user(self, rex_contenthost, module_target_sat):
"""Run default job template as effective user on a host
"""Run default job template as effective user on a host, test ssh user as well
:id: 0cd75cab-f699-47e6-94d3-4477d2a94bb7
:BZ: 1451675, 1804685
:BZ: 1451675, 1804685, 2258968
:expectedresults: Verify the job was successfully run under the
effective user identity on host
effective user identity on host, make sure the password is
used
:parametrized: yes
:customerscenario: true
"""
client = rex_contenthost
# create a user on client via remote job
ssh_username = gen_string('alpha')
ssh_password = gen_string('alpha')
username = gen_string('alpha')
password = gen_string('cjk')
filename = gen_string('alpha')
make_user_job = module_target_sat.cli_factory.job_invocation(
{
'job-template': 'Run Command - Script Default',
'inputs': f"command=useradd -m {username}",
'inputs': f"command=useradd -m {ssh_username} -p {ssh_password}; useradd -m {username} -p {password} ",
'search-query': f"name ~ {client.hostname}",
}
)
Expand All @@ -186,7 +192,10 @@ def test_positive_run_job_effective_user(self, rex_contenthost, module_target_sa
'job-template': 'Run Command - Script Default',
'inputs': f"command=touch /home/{username}/{filename}",
'search-query': f"name ~ {client.hostname}",
'ssh-user': f'{ssh_username}',
'password': f'{ssh_password}',
'effective-user': f'{username}',
'effective-user-password': f'{password}',
}
)
assert_job_invocation_result(module_target_sat, invocation_command['id'], client.hostname)
Expand All @@ -196,6 +205,12 @@ def test_positive_run_job_effective_user(self, rex_contenthost, module_target_sa
)
# assert the file is owned by the effective user
assert username == result.stdout.strip('\n')
result = client.execute(
f'''stat -c '%G' /home/{username}/{filename}''',
)
# assert the file is in the effective user's group
assert username == result.stdout.strip('\n')
# TODO: negative assert to check the pwd is used

@pytest.mark.tier3
@pytest.mark.e2e
Expand Down

0 comments on commit 291b7ec

Please sign in to comment.