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:
parent
70700644b0
commit
7226efce60
@ -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)
|
||||||
with open(outfile_name, 'w') as out_f:
|
if not dry_run:
|
||||||
out_f.write(r_template)
|
with open(outfile_name, 'w') as out_f:
|
||||||
|
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)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user