Add dry-run mode for process templates

Sometimes it is nice to know which templates
should be rendered into which files. For example,
if we need to define additional checks in the client.

Change-Id: I10d4dffcd3802f62fc824c808728c0b5b4f1002c
Signed-off-by: Bogdan Dobrelya <bdobreli@redhat.com>
This commit is contained in:
Bogdan Dobrelya 2018-04-18 16:33:11 +02:00
parent 70700644b0
commit 7226efce60

View File

@ -62,15 +62,23 @@ def parse_opts(argv):
action='store_true', action='store_true',
help=("""clean the templates dir by deleting """ help=("""clean the templates dir by deleting """
"""generated templates""")) """generated templates"""))
parser.add_argument('-d', '--dry-run',
action='store_true',
help=("""only output file names normally generated """
"""from j2 templates"""))
opts = parser.parse_args(argv[1:]) opts = parser.parse_args(argv[1:])
return opts return opts
def _j2_render_to_file(j2_template, j2_data, outfile_name=None, def _j2_render_to_file(j2_template, j2_data, outfile_name=None,
overwrite=True): overwrite=True, dry_run=False):
yaml_f = outfile_name or j2_template.replace('.j2.yaml', '.yaml') yaml_f = outfile_name or j2_template.replace('.j2.yaml', '.yaml')
print('rendering j2 template to file: %s' % outfile_name) if dry_run:
amend = 'dry run processing'
else:
amend = 'rendering'
print('%s j2 template to file: %s' % (amend, outfile_name))
if not overwrite and os.path.exists(outfile_name): if not overwrite and os.path.exists(outfile_name):
print('ERROR: path already exists for file: %s' % outfile_name) print('ERROR: path already exists for file: %s' % outfile_name)
@ -90,12 +98,12 @@ def _j2_render_to_file(j2_template, j2_data, outfile_name=None,
% (yaml_f, six.text_type(ex))) % (yaml_f, six.text_type(ex)))
print(error_msg) print(error_msg)
raise Exception(error_msg) raise Exception(error_msg)
if not dry_run:
with open(outfile_name, 'w') as out_f: with open(outfile_name, 'w') as out_f:
out_f.write(r_template) out_f.write(r_template)
def process_templates(template_path, role_data_path, output_dir, def process_templates(template_path, role_data_path, output_dir,
network_data_path, overwrite): network_data_path, overwrite, dry_run):
with open(role_data_path) as role_data_file: with open(role_data_path) as role_data_file:
role_data = yaml.safe_load(role_data_file) role_data = yaml.safe_load(role_data_file)
@ -196,7 +204,8 @@ def process_templates(template_path, role_data_path, output_dir,
j2_data = {'role': r_map[role], j2_data = {'role': r_map[role],
'networks': network_data} 'networks': network_data}
_j2_render_to_file(template_data, j2_data, _j2_render_to_file(template_data, j2_data,
out_f_path, overwrite) out_f_path, overwrite,
dry_run)
else: else:
# Backwards compatibility with templates # Backwards compatibility with templates
# that specify {{role}} vs {{role.name}} # that specify {{role}} vs {{role.name}}
@ -210,7 +219,7 @@ def process_templates(template_path, role_data_path, output_dir,
j2_data['disable_constraints'] = True j2_data['disable_constraints'] = True
_j2_render_to_file( _j2_render_to_file(
template_data, j2_data, template_data, j2_data,
out_f_path, overwrite) out_f_path, overwrite, dry_run)
else: else:
print('skipping rendering of %s' % out_f_path) print('skipping rendering of %s' % out_f_path)
@ -234,7 +243,7 @@ def process_templates(template_path, role_data_path, output_dir,
out_f_path = os.path.join(out_dir, out_f) out_f_path = os.path.join(out_dir, out_f)
if not (out_f_path in excl_templates): if not (out_f_path in excl_templates):
_j2_render_to_file(template_data, j2_data, _j2_render_to_file(template_data, j2_data,
out_f_path) out_f_path, overwrite, dry_run)
else: else:
print('skipping rendering of %s' % out_f_path) print('skipping rendering of %s' % out_f_path)
@ -247,7 +256,7 @@ def process_templates(template_path, role_data_path, output_dir,
out_f = os.path.basename(f).replace('.j2.yaml', '.yaml') out_f = os.path.basename(f).replace('.j2.yaml', '.yaml')
out_f_path = os.path.join(out_dir, out_f) out_f_path = os.path.join(out_dir, out_f)
_j2_render_to_file(template_data, j2_data, out_f_path, _j2_render_to_file(template_data, j2_data, out_f_path,
overwrite) overwrite, dry_run)
elif output_dir: elif output_dir:
_shutil_copy_if_not_same(os.path.join(subdir, f), out_dir) _shutil_copy_if_not_same(os.path.join(subdir, f), out_dir)
@ -330,4 +339,4 @@ if opts.clean:
clean_templates(opts.base_path, role_data_path, network_data_path) clean_templates(opts.base_path, role_data_path, network_data_path)
else: else:
process_templates(opts.base_path, role_data_path, opts.output_dir, process_templates(opts.base_path, role_data_path, opts.output_dir,
network_data_path, (not opts.safe)) network_data_path, (not opts.safe), opts.dry_run)