Fix Python 3 bytes vs strings differences

Writing files was done fairly naively with our Python 2 code - this
change introduces explicit ASCII encoding when writing files.

Change-Id: I93c9fa4ba2fd8af9c9bf9424adaec602dbdca5f0
This commit is contained in:
Nolan Brubaker 2017-06-06 21:36:59 -04:00 committed by Jesse Pretorius (odyssey4me)
parent fa5336ca36
commit e2f56ec634
2 changed files with 4 additions and 4 deletions

View File

@ -193,7 +193,7 @@ def write_hostnames(save_path, hostnames_ips):
indent=4, indent=4,
separators=(',', ': '), separators=(',', ': '),
sort_keys=True sort_keys=True
) ).encode('ascii')
) )
@ -212,7 +212,7 @@ def _load_from_json(filename, preferred_path=None, raise_if_missing=True):
dictionary = False dictionary = False
if target_file is not False: if target_file is not False:
with open(target_file, 'rb') as f_handle: with open(target_file, 'rb') as f_handle:
dictionary = json.loads(f_handle.read()) dictionary = json.loads(f_handle.read().decode('ascii'))
return dictionary, target_file return dictionary, target_file
@ -264,7 +264,7 @@ def save_inventory(inventory_json, save_path):
else: else:
inventory_file = os.path.join(save_path, INVENTORY_FILENAME) inventory_file = os.path.join(save_path, INVENTORY_FILENAME)
with open(inventory_file, 'wb') as f: with open(inventory_file, 'wb') as f:
f.write(inventory_json) f.write(inventory_json.encode('ascii'))
logger.info("Inventory written") logger.info("Inventory written")

View File

@ -570,7 +570,7 @@ class TestConfigCheckBase(unittest.TestCase):
self.config_changed = True self.config_changed = True
# Save new user_config_file # Save new user_config_file
with open(USER_CONFIG_FILE, 'wb') as f: with open(USER_CONFIG_FILE, 'wb') as f:
f.write(yaml.dump(self.user_defined_config)) f.write(yaml.dump(self.user_defined_config).encode('ascii'))
def restore_config(self): def restore_config(self):
# get back our initial user config file # get back our initial user config file