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

Collection version 1.2.0 breaks my ability to install chocolatey from a custom source. #74

Closed
watsonb opened this issue Feb 14, 2022 · 4 comments · Fixed by #77
Closed
Labels
5 - Released The issue has been resolved, and released to the public for consumption Documentation Issues for changes that only need to change documentation Improvement Issues that enhances existing functionality, or adds new features
Milestone

Comments

@watsonb
Copy link

watsonb commented Feb 14, 2022

What You Are Seeing?

Version 1.2.0 of collection breaks my existing role that installs chocolatey from a custom source (on-prem Sonatype Nexus OSS caching proxy). Versions 1.0.2 and 1.1.0 work without any modification on my side.

What is Expected?

My custom Ansible role that installs chocolatey from a custom source still works when moving to collection version 1.2.0 as it did when using collection versions 1.0.2 and 1.1.0.

How Did You Get This To Happen? (Steps to Reproduce)

I tested a different role with molecule that leverages my custom chocolatey role (in molecule prepare) and did not pin the version of chocolatey.chocolatey collection. I saw the following error repeatedly:

fatal: [knemol-ar-win-java-2019-benlocal.example.com]: FAILED! => changed=false 
  msg: 'Failed to download Chocolatey script from ''http:/nexus.example.com:8081/repository/choco-all/install.ps1''; Exception calling "DownloadString" with "1" argument(s): "The given path''s format is not supported."'
  rc: 0

I think this stems from an improvement I saw in the 1.2.0 changlog:

Improved automatic URL handling for getting the install.ps1 script from a custom source URL

For now, I'll be looking at my custom chocolatey role to see what adjustments I can make to make it work with v1.2.0 of this collection and pin my other dependencies to 1.1.0.

The failing task in my custom role looks like this:

- name: WIN_CHOCOLATEY | install chocolatey
  chocolatey.chocolatey.win_chocolatey:
    name: chocolatey
    source: "{{ chocolatey_sources[0].source }}"
  environment:
    - chocolateyDownloadUrl: "{{ chocolatey_sources[0].source }}/{{ chocolatey_package_download_suffix }}"

And the task in my molecule prepare that applies the custom role looks like this:

    - name: apply win_chocolatey role
      ansible.builtin.import_role:
        name: ar_win_chocolatey
      vars:
        chocolatey_version: 0.10.15
        chocolatey_package_download_suffix: 'chocolatey/0.10.15'
        chocolatey_sources:
          - name: nexus
            source: http://nexus.example.com:8081/repository/choco-all/
            state: present
        chocolatey_features: []
        chocolatey_configs:
          - name: webRequestTimeoutSeconds
            state: present
            value: 45
        chocolatey_packages: []
        chocolatey_display_facts: false

System Details

N/A

Output Log

N/A

@vexx32
Copy link
Member

vexx32 commented Feb 14, 2022

Thanks for the report! We'll have a look over the changes and look to see what went wrong there. At a glance, I can see you're looking to download chocolatey as a nupkg directly, which is not something the initial installation would normally do -- typically the bootstrapping installation downloads an install.ps1 file, similar to https://community.chocolatey.org/install.ps1, which then handles the actual getting of the nupkg and installing it.

I suspect this may have worked somewhat "by accident" in the past, the collection likely presumed it couldn't handle the URL, went to fetch the default install.ps1 from Chocolatey.org instead, and used that script to download the nupkg you'd supplied.

It's clear that we need to be more careful in our assumptions around the URL format. Perhaps we should simply have an additional parameter to find the install script for installing chocolatey itself rather than attempting to reuse source in this fashion. 🤔

For now, I think removing the source option from your playbook task would get you the pre-1.2.0 behaviour again. Even in earlier versions, source shouldn't do anything when applied to a chocolatey installation itself unless Chocolatey is already installed.

@watsonb
Copy link
Author

watsonb commented Feb 15, 2022

Hmmm, I was afraid of that (i.e. it worked earlier due to a bug [unintended feature]). I started iterating over different URL paths and eventually got it to work with the 1.2.0 collection and my custom role unmodified. I merely had to pass a different URL.

For posterity:

  1. My Nexus server does offer up an install.ps1 script up at the root of the public resources (/opt/nexus-latest/public/install.ps1) that is then GETtable from https://nexus.example.com:8081/install.ps1
  2. My Nexus server is configured to host NuGet packages and cache/proxy them from chocolatey.org. http://nexus.example.com:8081/repository/choco-all/
  3. The chocolatey installer itself (the nupkg) is available at http://nexus.example.com:8081/repository/choco-all/chocolatey/0.10.15

So now my task that applies my custom role for installing/bootstrapping chocolatey looks like this:

    - name: apply win_chocolatey role
      ansible.builtin.import_role:
        name: ar_win_chocolatey
      vars:
        chocolatey_version: 0.10.15
        # chocolatey_package_download_suffix: 'chocolatey/0.10.15'
        # chocolatey_package_download_suffix: ''
        chocolatey_package_download_suffix: 'repository/choco-all/chocolatey/0.10.15'
        chocolatey_sources:
          - name: nexus
            # source: http://nexus.example.com:8081/repository/choco-all/
            source: http://nexus.example.com:8081
            state: present
        chocolatey_features: []
        chocolatey_configs:
          - name: webRequestTimeoutSeconds
            state: present
            value: 45
        chocolatey_packages: []
        chocolatey_display_facts: false

I left the commented out YAML bits in there so you could see how the URLs were changed as I experimented and found something that worked.

In short, it looks like the "source" is where to obtain the bootstrap install.ps1 and my "suffix" is appended to that as an environment variable to indicate where to get the nupkg.

@vexx32
Copy link
Member

vexx32 commented Feb 15, 2022

Glad you could get it working! At least now we can be sure it's actually using the install.ps1 you have. 😄

Yeah, it's probably not ideal to have the source reused in this fashion to discover the install.ps1, and I think it's probably better to have a specific parameter to target the install.ps1 directly. I suppose we could add that on top of the logic we have, leaving the current logic as a fallback. 🤔

It certainly would make the behaviour more discoverable and easier to work with, I think. We should also add some docs to source indicating how this fallback behaviour actually works.

@vexx32 vexx32 added 0 - _Triaging Issue is accepted, but a milestone has yet to be added for the issue Documentation Issues for changes that only need to change documentation Improvement Issues that enhances existing functionality, or adds new features labels Feb 15, 2022
@watsonb
Copy link
Author

watsonb commented Feb 15, 2022

Yeah, I'm running into other behavior issues now when managing sources pointing to my Nexus. Previous when I would add the source, the URL was http://nexus.example.com:8081/repository/choco-all/, which is the location of all cached packages. But by now specifying the root (for bootstrapping), I'd have to adjust the source when installing any other packages. I think I've found a way to work around it a little more elegantly for my use case (really just a variable data management issue).

Thanks for all the good work on this collection thus far! Using Ansible in a "Windows shop", I leverage this quite often.

@vexx32 vexx32 added 2 - Working A user or team member has started working on the issue and removed 0 - _Triaging Issue is accepted, but a milestone has yet to be added for the issue labels Apr 1, 2022
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 24, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 24, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 24, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 24, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 24, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 27, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 27, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 27, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 27, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 27, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
vexx32 added a commit to vexx32/chocolatey-ansible that referenced this issue Jun 28, 2022
Made sense to move the test package files into a subfolder, so did that
in order to keep test files a bit more organised.
corbob added a commit that referenced this issue Jun 28, 2022
(#74) Add bootstrap_script option for win_chocolatey
@vexx32 vexx32 added 4 - Done Code has been added to the repository, and has been reviewed by a team member and removed 2 - Working A user or team member has started working on the issue labels Jun 28, 2022
@vexx32 vexx32 added this to the 1.3.0 milestone Jun 29, 2022
@vexx32 vexx32 added 5 - Released The issue has been resolved, and released to the public for consumption and removed 4 - Done Code has been added to the repository, and has been reviewed by a team member labels Jun 29, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
5 - Released The issue has been resolved, and released to the public for consumption Documentation Issues for changes that only need to change documentation Improvement Issues that enhances existing functionality, or adds new features
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants