Fix a traceback with python3 and diff output
When retrieving file contents for diffing we need to get the contents as binary. Otherwise python3 will try to convert the file to text and fail with non-decodable contents. Fixes #23171
This commit is contained in:
parent
d4bd54d3b8
commit
2fdb8e7f90
1 changed files with 3 additions and 3 deletions
|
@ -952,12 +952,12 @@ class ActionBase(with_metaclass(ABCMeta, object)):
|
||||||
else:
|
else:
|
||||||
display.debug("Reading local copy of the file %s" % source)
|
display.debug("Reading local copy of the file %s" % source)
|
||||||
try:
|
try:
|
||||||
src = open(source)
|
with open(source, 'rb') as src:
|
||||||
src_contents = src.read()
|
src_contents = src.read()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
raise AnsibleError("Unexpected error while reading source (%s) for diff: %s " % (source, str(e)))
|
raise AnsibleError("Unexpected error while reading source (%s) for diff: %s " % (source, str(e)))
|
||||||
|
|
||||||
if "\x00" in src_contents:
|
if b"\x00" in src_contents:
|
||||||
diff['src_binary'] = 1
|
diff['src_binary'] = 1
|
||||||
else:
|
else:
|
||||||
diff['after_header'] = source
|
diff['after_header'] = source
|
||||||
|
|
Loading…
Reference in a new issue