Vagrant: Reducing whitespace in Vagrantfile #289
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Reopen of #277, reproducing here for convenience.
Per the discussion there, the merge conflicts have been resolved, and the linting error seems to be gone.
The current implementation in
src/molecule_plugins/vagrant/modules/vagrant.py
generates a Vagrantfile with excessive white space (a total of 42 empty lines with themolecule.yml
sample indriver.py
), and some indentation issues for theoverwrite
entries, making troubleshooting less pleasant. The proposed changes greatly reduce blank lines and keep the Vagrantfile in a more easily readable form.I have first attempted to clear white space by
{%-
/-%}
, however this proved challenging with indentation and other desired whitespace (separating blocks of code in the Vagrantfile). Eventually I went with addingtrim_blocks=True, lstrip_blocks=True
to thejinja2.Environment
invocation and reworking the template. I have tried various forms of input inmolecule.yml
and get consistent spacing in Vagrantfile (see some examples below).All Vagrant related tests pass (
box_url
modified as per #274 / #275) and I have verified every Vagrantfile produced by the tests has no spurious empty lines or uneven indentation.Examples:
The example from #276:
molecule.yml:
Vagrantfile:
A very basic config:
molecule.yml:
Vagrantfile:
molecule.yml:
Vagrantfile:
libvirt:
molecule.yml:
Vagrantfile: