-
Notifications
You must be signed in to change notification settings - Fork 28
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
Simplify for loop/regex in Linux_installmq.yml
#68
Comments
The |
Hi @CharlieParker @James-Bennett-295, this is great stuff! The initial design for this list was to give customers the freedom to select/deselect which components they'd like to install (across both debian and rpm package file patterns) - but you both raise a good point in that a lot of the default components in the list are part of the core MQ installation, where customisation doesn't make sense. So I'll pass this back to you, do you guys think it would be valuable to have the core installation components as part of one regex pattern as you have proposed, PLUS the additional components (like samples, ams etc.) as single regex patterns for customers to select? Either way, encapsulating the core mq installation components into one regex pattern would be a welcome optimisation to the codebase! |
If the intention is to have things like samples and ams (that's this right? 😅) as optional or configurable to the user who simply wants to automate the deployment of mq then I think it shouldn't be done by commenting out regex in an ansible playbook. I think the options should be exposed perhaps on the cli or even be set in a config file if they're not trivial. I think it's perhaps worth us discussing this list and grouping options to make customer selection as intuitive as possible. |
I would recommend keeping the regex as simple as possible, if that means a couple of extra entries I would prefer that over a complex regex. Customers should be aware of and in control of the packages they are installing, the list makes a suggestion but it is easy to modify in its current form. |
Potentially useful for further conversation is this snippet that I used to check the logic here: ---
- name: Local test
hosts: localhost
# hosts: [amd64]
tasks:
- name: What dir are we in?
ansible.builtin.debug:
msg: The DIR we're in is {{ playbook_dir }}
- name: Find required package files
ansible.builtin.find:
paths: "{{ playbook_dir }}"
use_regex: true
patterns: "{{ item }}"
register: package_files
with_items:
- "*.yml"
- .*mq.*
- "*.py"
- name: Debug package_files from above regex loop
ansible.builtin.debug:
var: package_files I would say, even if you want to stick with the regex implementation for this, I'd break up the logic in the single task I'd also say we should perhaps define the lists of patterns elsewhere such that we only need to specify an abstracted variable or two (rather than look at a long list of regex patterns) |
Discussed early on with @scottcurtis2605, the following
Find required package files
task is rather confusing:mq-ansible/ansible_collections/ibm/ibmmq/roles/installmq/tasks/Linux_installmq.yml
Lines 18 to 60 in 7243a4a
I'd like to discuss this more, we're fairly sure it can be made cleaner but there might be something we're missing.
Initial Thoughts
find
files in a certain directory orpath
/var/MQServerpatterns
key will have a single value"{{ item }}"
package_files
look like throughout this process? My understanding is it will be rewritten based on theregister
in every iterationI think if the intention is to select only files that match a certain regex pattern, then this needs to be rethought.
Luckily it would be simplifying the code/process, I believe
find
and the followingregex
should be sufficient:The text was updated successfully, but these errors were encountered: