Skip to content
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

Add new python module (explicit) and ansible collections #92

Closed
wants to merge 5 commits into from

Conversation

kladiv
Copy link

@kladiv kladiv commented Oct 30, 2021

Hi @shanemcd.
this PR should resolve #90 and #91.
In addition:

  • it adds main python modules for the defined EE ansible collections in explicit way
  • it adds new few useful collections

Copy link
Member

@relrod relrod left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @kladiv - I don't think we're interested in adding all of these collections to the awx-ee, we've intentionally kept it relatively slim (see #126 (comment)).

That said, I think we'd accept a patch to add ansible.utils (which will pull in netaddr as a dep).

I think we'd also add a patch to add in google-cloud-storage as a pip dep.

Would you be willing to update this PR to just include those two things?

@kladiv
Copy link
Author

kladiv commented Dec 16, 2022

Hi @relrod,
i added all those modules in requirements.txt 'cause i see that lots of collections are included in the requirements.yml of devel branch

I guess most of the included python modules are required by Ansible modules of those collections.
E.g. for:

Without some python modules, there should be some Ansible collections modules won't work. Isn't it?

To keep AWX EE slim, maybe additional collections could be removed?

@relrod
Copy link
Member

relrod commented Dec 16, 2022

@kladiv necessary deps should automatically get installed with the collections. If there's something you've noticed missing, it's likely something that should be reported to the collections.

For example, the azure collection has https://github.com/ansible-collections/azure/blob/dev/meta/execution-environment.yml to point to its list of required python deps and ansible-builder should resolve/install these.

@kladiv kladiv closed this Dec 17, 2022
@kladiv kladiv force-pushed the add-modules-and-collections branch from 130830f to a23672d Compare December 17, 2022 08:46
@kladiv
Copy link
Author

kladiv commented Dec 17, 2022

Hi @relrod,
i see not all collections included in the requirements.yml of devel branch use this method (meta/execution-environment.yml) so some deps are still missing.

I suggest you check internally if it's strictly required that all those collections should be already included in the base AWX EE or you can keep it slim removing some external collections.

To resolve #90 and #91 i changed this PR to add only:

  • netaddr
  • google-cloud-storage

For some reason PR is closed. Are you able to check and reopen it?

@relrod relrod reopened this Dec 17, 2022
@relrod
Copy link
Member

relrod commented Dec 17, 2022

@kladiv First, thanks so much for your work on this!

We've not gotten any reports that I'm aware of about these collections being broken due to missing deps. Do you have a specific example or two of something that doesn't work from some collection we include in the current EE?

That file I linked is one way that ansible-builder can resolve dependencies. It can also look at a repo-root-level requirements.txt and bindep.txt :) So I think we are okay, but if you notice something missing/broken, please let us know!

To resolve #90 and #91 i changed this PR to add only:

netaddr
google-cloud-storage

Researching a bit more -- the google.cloud collection has a requirements.txt file already, and I just checked and we actually do bring in google-cloud-storage already as a result:

[rick@fedora awx-ee]$ docker run -it --rm quay.io/ansible/awx-ee pip list | grep google-cloud-storage
google-cloud-storage               2.7.0

This might have been something the collection fixed since #91 was opened. But I don't think we actually need that change anymore.

So that leaves netaddr... I think we could do one of two things here.

Just adding netaddr on its own doesn't make too much sense, I don't think, because I don't think any collection we currently install actually makes use of it.

So then - we could discuss pulling in the ansible.utils collection (which would bring in netaddr as a dep). It seems like some people have been wanting to use ipaddr (#90 and comments therein) and next_nth_usable (ansible/awx#10370). These are both in ansible.utils.

There's also https://github.com/ansible/network-ee which already has ansible.utils, so we could just refer users to that EE. But I suspect it is useful to have these filters available in a more general setting like awx-ee here.

So to that end, I think my suggestion would be: Let's add ansible.utils to _build/requirements.yml -- and that would be the only change in this PR (so then revert the changes to _build/requirements.txt).

I think I would be inclined to approve that PR, because I think the things in ansible.utils are generally useful, and the size difference to the final image is pretty negligible (2.08GB up to 2.12GB in my quick testing).

I might bounce it off @shanemcd for a final +1 after that, just to make sure I'm not crazy, though 😉

@relrod
Copy link
Member

relrod commented Jan 17, 2023

Hi @kladiv

Are you able to make the changes above? I'd like to get this PR out of the queue.

@relrod
Copy link
Member

relrod commented Jan 30, 2023

Going to close this for now, feel free to open a new PR with the requested changes above. Thanks!

@relrod relrod closed this Jan 30, 2023
@AdamEldred AdamEldred mentioned this pull request Aug 1, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

add netaddr library to awx-ee
2 participants