mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
psrp - Fix raw and script tests for connection plugin (#55357)
* psrp - Fix raw and script tests for connection plugin * Fix error propagation with raw in psrp * uncomment test
This commit is contained in:
parent
49655a452d
commit
fdf9df89f5
5 changed files with 52 additions and 22 deletions
3
changelogs/fragments/psrp-output.yaml
Normal file
3
changelogs/fragments/psrp-output.yaml
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
bugfixes:
|
||||||
|
- psrp - Fix blank newlines appearing before ``stdout`` when using ``script`` or ``raw`` with the ``psrp`` connection plugin
|
||||||
|
- psrp - Fix issues with propagating errors back to Ansible with ``raw`` tasks
|
|
@ -219,7 +219,7 @@ $($ErrorRecord.InvocationInfo.PositionMessage)
|
||||||
$b64_output = [System.Convert]::ToBase64String([System.Text.Encoding]::UTF8.GetBytes($output))
|
$b64_output = [System.Convert]::ToBase64String([System.Text.Encoding]::UTF8.GetBytes($output))
|
||||||
Write-Output -InputObject $b64_output
|
Write-Output -InputObject $b64_output
|
||||||
} else {
|
} else {
|
||||||
Write-Output -InputObject $output
|
$output
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
Write-AnsibleError -Message "internal error: failed to run exec_wrapper action $action" -ErrorRecord $_
|
Write-AnsibleError -Message "internal error: failed to run exec_wrapper action $action" -ErrorRecord $_
|
||||||
|
|
|
@ -402,9 +402,10 @@ class Connection(ConnectionBase):
|
||||||
else:
|
else:
|
||||||
display.vvv("PSRP: EXEC %s" % script, host=self._psrp_host)
|
display.vvv("PSRP: EXEC %s" % script, host=self._psrp_host)
|
||||||
else:
|
else:
|
||||||
# in other cases we want to execute the cmd as the script
|
# In other cases we want to execute the cmd as the script. We add on the 'exit $LASTEXITCODE' to ensure the
|
||||||
script = cmd
|
# rc is propagated back to the connection plugin.
|
||||||
display.vvv("PSRP: EXEC %s" % script, host=self._psrp_host)
|
script = to_text(u"%s\nexit $LASTEXITCODE" % cmd)
|
||||||
|
display.vvv(u"PSRP: EXEC %s" % script, host=self._psrp_host)
|
||||||
|
|
||||||
rc, stdout, stderr = self._exec_psrp_script(script, in_data)
|
rc, stdout, stderr = self._exec_psrp_script(script, in_data)
|
||||||
return rc, stdout, stderr
|
return rc, stdout, stderr
|
||||||
|
@ -734,29 +735,29 @@ if ($bytes_read -gt 0) {
|
||||||
|
|
||||||
stdout_list.append(output_msg)
|
stdout_list.append(output_msg)
|
||||||
|
|
||||||
stdout = u"\r\n".join(stdout_list)
|
|
||||||
if len(self.host.ui.stdout) > 0:
|
if len(self.host.ui.stdout) > 0:
|
||||||
stdout += u"\r\n" + u"".join(self.host.ui.stdout)
|
stdout_list += self.host.ui.stdout
|
||||||
|
stdout = u"\r\n".join(stdout_list)
|
||||||
|
|
||||||
stderr_list = []
|
stderr_list = []
|
||||||
for error in pipeline.streams.error:
|
for error in pipeline.streams.error:
|
||||||
# the error record is not as fully fleshed out like we usually get
|
# the error record is not as fully fleshed out like we usually get
|
||||||
# in PS, we will manually create it here
|
# in PS, we will manually create it here
|
||||||
error_msg = "%s : %s\r\n" \
|
command_name = "%s : " % error.command_name if error.command_name else ''
|
||||||
"%s\r\n" \
|
position = "%s\r\n" % error.invocation_position_message if error.invocation_position_message else ''
|
||||||
|
error_msg = "%s%s\r\n%s" \
|
||||||
" + CategoryInfo : %s\r\n" \
|
" + CategoryInfo : %s\r\n" \
|
||||||
" + FullyQualifiedErrorId : %s" \
|
" + FullyQualifiedErrorId : %s" \
|
||||||
% (error.command_name, str(error),
|
% (command_name, str(error), position,
|
||||||
error.invocation_position_message, error.message,
|
error.message, error.fq_error)
|
||||||
error.fq_error)
|
|
||||||
stacktrace = error.script_stacktrace
|
stacktrace = error.script_stacktrace
|
||||||
if self._play_context.verbosity >= 3 and stacktrace is not None:
|
if self._play_context.verbosity >= 3 and stacktrace is not None:
|
||||||
error_msg += "\r\nStackTrace:\r\n%s" % stacktrace
|
error_msg += "\r\nStackTrace:\r\n%s" % stacktrace
|
||||||
stderr_list.append(error_msg)
|
stderr_list.append(error_msg)
|
||||||
|
|
||||||
stderr = "\r\n".join(stderr_list)
|
|
||||||
if len(self.host.ui.stderr) > 0:
|
if len(self.host.ui.stderr) > 0:
|
||||||
stderr += "\r\n" + "".join(self.host.ui.stderr)
|
stderr_list += self.host.ui.stderr
|
||||||
|
stderr = u"\r\n".join([to_text(o) for o in stderr_list])
|
||||||
|
|
||||||
display.vvvvv("PSRP RC: %d" % rc, host=self._psrp_host)
|
display.vvvvv("PSRP RC: %d" % rc, host=self._psrp_host)
|
||||||
display.vvvvv("PSRP STDOUT: %s" % stdout, host=self._psrp_host)
|
display.vvvvv("PSRP STDOUT: %s" % stdout, host=self._psrp_host)
|
||||||
|
|
|
@ -93,7 +93,9 @@
|
||||||
that:
|
that:
|
||||||
- "raw_result.stdout_lines[0] == 'wwe=raw'"
|
- "raw_result.stdout_lines[0] == 'wwe=raw'"
|
||||||
|
|
||||||
# TODO: this test doesn't work anymore since we had to internally map Write-Host to Write-Output
|
- name: unicode tests for winrm
|
||||||
|
when: ansible_connection != 'psrp' # Write-Host does not work over PSRP
|
||||||
|
block:
|
||||||
- name: run a raw command with unicode chars and quoted args (from https://github.com/ansible/ansible-modules-core/issues/1929)
|
- name: run a raw command with unicode chars and quoted args (from https://github.com/ansible/ansible-modules-core/issues/1929)
|
||||||
raw: Write-Host --% icacls D:\somedir\ /grant "! ЗАО. Руководство":F
|
raw: Write-Host --% icacls D:\somedir\ /grant "! ЗАО. Руководство":F
|
||||||
register: raw_result2
|
register: raw_result2
|
||||||
|
@ -103,6 +105,19 @@
|
||||||
that:
|
that:
|
||||||
- "raw_result2.stdout_lines[0] == '--% icacls D:\\\\somedir\\\\ /grant \"! ЗАО. Руководство\":F'"
|
- "raw_result2.stdout_lines[0] == '--% icacls D:\\\\somedir\\\\ /grant \"! ЗАО. Руководство\":F'"
|
||||||
|
|
||||||
|
- name: unicode tests for psrp
|
||||||
|
when: ansible_connection == 'psrp'
|
||||||
|
block:
|
||||||
|
# Cannot test unicode passed into separate exec as PSRP doesn't run with a preset CP of 65001 which reuslts in ? for unicode chars
|
||||||
|
- name: run a raw command with unicode chars
|
||||||
|
raw: Write-Output "! ЗАО. Руководство"
|
||||||
|
register: raw_result2
|
||||||
|
|
||||||
|
- name: make sure raw passes command as-is and doesn't split/rejoin args
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "raw_result2.stdout_lines[0] == '! ЗАО. Руководство'"
|
||||||
|
|
||||||
# Assumes MaxShellsPerUser == 30 (the default)
|
# Assumes MaxShellsPerUser == 30 (the default)
|
||||||
|
|
||||||
- name: test raw + with_items to verify that winrm connection is reused for each item
|
- name: test raw + with_items to verify that winrm connection is reused for each item
|
||||||
|
|
|
@ -71,11 +71,22 @@
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- test_script_with_large_args_result.rc == 0
|
- test_script_with_large_args_result.rc == 0
|
||||||
- test_script_with_large_args_result.stdout == long_string + "\r\n"
|
|
||||||
- not test_script_with_large_args_result.stderr
|
- not test_script_with_large_args_result.stderr
|
||||||
- test_script_with_large_args_result is not failed
|
- test_script_with_large_args_result is not failed
|
||||||
- test_script_with_large_args_result is changed
|
- test_script_with_large_args_result is changed
|
||||||
|
|
||||||
|
- name: check that script ran and received arguments correctly with winrm output
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- test_script_with_large_args_result.stdout == long_string + "\r\n"
|
||||||
|
when: ansible_connection != 'psrp'
|
||||||
|
|
||||||
|
- name: check that script ran and received arguments correctly with psrp output
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- test_script_with_large_args_result.stdout == long_string
|
||||||
|
when: ansible_connection == 'psrp'
|
||||||
|
|
||||||
- name: run test script that takes parameters passed via splatting
|
- name: run test script that takes parameters passed via splatting
|
||||||
script: test_script_with_splatting.ps1 @{ This = 'this'; That = '{{ test_win_script_value }}'; Other = 'other'}
|
script: test_script_with_splatting.ps1 @{ This = 'this'; That = '{{ test_win_script_value }}'; Other = 'other'}
|
||||||
register: test_script_with_splatting_result
|
register: test_script_with_splatting_result
|
||||||
|
|
Loading…
Reference in a new issue