-
-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement singularity-compose.yml override configuration feature #48
Implement singularity-compose.yml override configuration feature #48
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Very cool idea! We could definitely support this. I've added some comments because we need to:
- support previous functionality (e.g., the user providing no -f defaults to a single singularity-compose.yml as before)
- the Python client in project.py also needs to work the same, still accepting a string (and you are extending to allow a list to merge).
- The merge / load multiple yaml should not live in project.py - you can create a new module for it until utils if that's appropriate!
scompose/project/project.py
Outdated
@@ -64,8 +64,8 @@ def set_filename(self, filename): | |||
========== | |||
filename: the singularity-compose.yml file to use | |||
""" | |||
self.filename = filename or "singularity-compose.yml" | |||
self.working_dir = os.path.dirname(os.path.abspath(self.filename)) | |||
self.filename = filename |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would leave the default here to "singularity-compose.yml" - and if you are changing this to require a list, then please support the old behavior to still provide a single filename, and have it checked if it's a list, single string, or None, and process accordingly. And then if your preference is to store in a list, the variable should be self.filenames to indicate plural / multiple files.
And if I understand correctly, the working directory is changed to os.getcwd() to account for possibly different compose files in different directories. Of course the issue here is that all compose files need to then have their context relevant to that directory (is that your intention?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would leave the default here to "singularity-compose.yml"
The reason why I removed it is because this default value comes from the argparse as well, so I thought it was redundant. Quick question, the reason why you want the default value here as well is because you are envisioning devs instantiating this class programatically instead of using the CLI, is that correct?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes correct! We wouldn't want to break previous scripts that are providing a string. The simple solution I think is to allow either.
scompose/project/project.py
Outdated
for f in self.filename: | ||
# ensure file exists | ||
if not os.path.exists(f): | ||
bot.error("%s does not exist." % f) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please move the multiple load of yaml files outside of the project.py - there should ideally be a separate utils function or set of config functions (some config.py or similar) that takes the list. and returns the single config here. Also - self.filename implies one file, and there should either be a self.filenames or self.filename to match the arity.
scompose/project/project.py
Outdated
def deep_merge(self, yaml_files): | ||
"""merge singularity-compose.yml files into a single dict""" | ||
if len(yaml_files) == 1: | ||
# nothing to merge as the user specified a single file | ||
return yaml_files[0] | ||
|
||
base_yaml = None | ||
for idx, item in enumerate(yaml_files): | ||
if idx == 0: | ||
base_yaml = item | ||
else: | ||
base_yaml = self.merge(base_yaml, item) | ||
|
||
return base_yaml | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All of this logic should not be in project.py - it's for merging yaml.
scompose/project/project.py
Outdated
|
||
return base_yaml | ||
|
||
def merge(self, a, b): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Move this too.
Also - if we provide this functionality I'd add an ability to preview a merge, basically taking the files, doing the merge, and printing yaml back to the screen. |
Do you mean like a CLI option similar to what |
It could be that we have a separate command group for the config, and then something like a
We can definitely split this into two different PRs - the reason I mentioned it is because not having the final file in a repository, for example, hinders reproducibility. So minimally I think we'd want to be able to output it to slightly better encourage saving it :) |
Hi @vsoch, apologies for asking one more question on that subject, I just want to make sure I understood what needs to be done. Currently, if we run (that's the part which I'm not 100% sure if I got right, please correct me where I'm wrong): If the above is not correct, I am not sure if I got the |
Yes sorry I'm not being clear!
So my higher level idea in adding this check (akin to # Tell me if my config file(s) look okay (run against json schema)
$ singularity-compose config --check
$ echo $?
# 0 indicates everything looks okay
# Without --check we _could_ do a preview, but for one config this wouldn't make sense, so I'd suggest `--preview`
$ singularity-compose config --preview which would then print the consolidated config to the screen. Perhaps for one config it would show default options that aren't explicitly stated. To be clear, adding a command group is a big thing, and I'd be happy to help with this! If you want to focus on working on the merge functionality (which you've already done most of, just need to move it around to a different spot) I'd be happy to extend that PR this weekend to get the config command group to preview results, and it would be logical to add tests.
We can easily yaml.dump the json to see the yaml instead! The user might want to dump (and save) the new compiled yaml file. |
thanks for the clarification, I got it now :) Sure, feel free to commit stuff to this PR. For now, I will focus on adding the tests and docs related to this feature before taking on any of the other stuff. |
Sounds good! And I can definitely help too - I've done a bit of work with jsonschema so it's pretty quick for me to do. |
Your help is always welcome 😃 |
I moved the logic out of project, added tests and docs. I will mark this PR as 'ready to review' just in case you want to expand those functionalities in a different PR. |
this will add jsonschema as an optional dependency to check the validity of a singularity-compose.yml file. We will eventually extend this to check (and preview) combined files. Signed-off-by: vsoch <[email protected]>
Here is what I had in mind for check! #49 So if we add a |
Just saw your last message - I can pull down your changes into my branch and make a combined PR - not tonight but probably another night / this weekend (unless you beat me to it) |
Nice! I liked your implementation for check, I can implement the the |
And I am aware of the comedic value of failing my own lint check! I think it's probably time to remove the version constraint for black, and assume that most people will create a new venv to have it installed freshly. 😆 |
A bit off-topic (in relation to this PR) but something that it would be nice for us to start thinking before writing any code... another thing I would love to have on singularity-compose is to be able to create volumes and reference them by name rather than path. Usually docker create these persistent volumes under I cannot count how many times I've (accidentally) deleted my 'persistent' paths before as I'm always tempted to have those mapped folders within my project directory structure 😬 There are other cases in which this is relevant (such as file system capabilities) but the key point is, if we could start thinking about this now, we can get a nice implementation shortly 😄 |
Moved that to an issue to make sure the 2 subjects won't get mixed (I should've thought about that before 😓 ) |
I pulled your check feature PR (and tweaked it so it could take into consideration multiple files. I also implemented implemented the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Beautiful documentation, and tests too! Am I in OSS heaven?
I added a few changes, and once those are in I'll test locally!
Co-authored-by: Vanessasaurus <[email protected]>
Done, feel free to pull it locally and run your tests :) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A few more comments after local testing!
- See updates to printing logic in the main function of check,py - basically removing extra output so it's a little cleaner and we only get what we ask for w.r.t the check command.
- for the tests folder, please rename config_override to config_merge to match what we are doing.
And that should do it!
Done, I also moved the tests belonging to this feature to a new file since we moved it out of the utils module |
Signed-off-by: vsoch <[email protected]>
and moving validate.py into its own file so we do not always import Signed-off-by: vsoch <[email protected]>
Signed-off-by: vsoch <[email protected]>
This is such a great feature - thank you @PauloMigAlmeida ! |
There is one feature in docker-compose that I would love to have in singularity-compose that is the ability to specify multiple composer.yml files in which the properties would get either merged or overidden.
Example:
singularity-compose.yml
singularity-compose-dev.yml
By executing something like:
we would get the runtime config combined into:
which essentially overrode cvat->start->options and appended/merged cvatproxy to the runtime config.
I'm looking for feedback on the following points