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

(PUP-11655) Use run_mode for better platform independence #9294

Merged
merged 2 commits into from
Jun 24, 2024

Conversation

joshcooper
Copy link
Contributor

The run mode already determines the platform. Moving all platform specific paths into RunMode makes it easier to get a complete overview and change things where needed.

@ekohl originally filed this #8938. I've retargeted his commit for main and updated some spec failures.

@ekohl
Copy link
Contributor

ekohl commented Mar 21, 2024

Thanks for taking this over @joshcooper.

@joshcooper joshcooper added the enhancement New feature or request label Apr 23, 2024
@ekohl
Copy link
Contributor

ekohl commented Jun 12, 2024

Test failures look relevant.

@joshcooper joshcooper force-pushed the PUP-11655 branch 2 times, most recently from 842a949 to 0ea3dbc Compare June 14, 2024 19:15
spec/unit/provider/package/puppet_gem_spec.rb Outdated Show resolved Hide resolved
end
end
allow(provider.class).to receive(:which).with(provider_gem_cmd).and_return(provider_gem_cmd)
allow(Puppet.run_mode).to receive(:gem_cmd).and_return(provider_gem_cmd)
Copy link
Contributor

Choose a reason for hiding this comment

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

I think this mocking isn't working because of the order. Something loads the provider which resolves command. Then the stubbing happens, but no more lookup. I got it to work by stubbing the command lookup:

Suggested change
allow(Puppet.run_mode).to receive(:gem_cmd).and_return(provider_gem_cmd)
allow(provider.class).to receive(:command).with(:gemcmd).and_return(provider_gem_cmd)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

As a rule of thumb, I avoid stubbing out the class I'm testing (including code that is inherited or mixed in). Otherwise, the tests can pass for the wrong reason. For example, if I stub out what Provider#command returns, then I could have a typo in the puppet_gem provider like:

command :gemcmd => "/whatever"

and the test would still pass.

But the provider/command code is really complicated due to the load time vs runtime time behaviors you mention. So sometimes stubbing the command method is a necessary evil.

Copy link
Contributor

Choose a reason for hiding this comment

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

Yes, stubbing and mocking in general are tools I love to avoid when possible. Here it really feels like you can't avoid it. Perhaps a separate test to assert it's not nil without mocking would help?

Don't stub methods on the provider we're testing like `validate_command`,
`execute_gem_command` and `puppetservercmd`. As much as possible, only stub the
call to `Puppet::Util::Execute.execution`.

puppet_gem_spec was stubbing `Puppet::Util::Platform.windows?` to return false,
which meant we were pretending to be POSIX when running specs on Windows.
else
'/opt/puppetlabs/puppet/vendor_modules'
end
Puppet.run_mode.vendor_module_dir
Copy link
Contributor Author

Choose a reason for hiding this comment

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

To preserve API compatibility, I kept the Puppet.default_vendormoduledir. It also makes testing the default values for settings a bit easier, because of the way settings definitions are loaded once

@joshcooper joshcooper force-pushed the PUP-11655 branch 2 times, most recently from ca80242 to 9133064 Compare June 19, 2024 01:49
The run mode already determines the platform. Moving all platform
specific paths into RunMode makes it easier to get a complete overview
and change things where needed.

Co-authored-by: Josh Cooper <[email protected]>
@joshcooper
Copy link
Contributor Author

@ekohl I had to update your commit, could you review when you have some time?

Copy link
Contributor

@ekohl ekohl left a comment

Choose a reason for hiding this comment

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

Thanks for finishing this up. I think it's a nice improvement to build on. I have written down 2 mental notes I had while working on it myself, but didn't pick up.

end

def common_module_dir
"#{installdir}/puppet/modules" if installdir
Copy link
Contributor

Choose a reason for hiding this comment

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

I kept this as it used to be, but I was wondering if this is better

Suggested change
"#{installdir}/puppet/modules" if installdir
File.join(installdir, 'puppet', 'modules') if installdir

end

def vendor_module_dir
"#{installdir}\\puppet\\vendor_modules" if installdir
Copy link
Contributor

Choose a reason for hiding this comment

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

And the same here:

Suggested change
"#{installdir}\\puppet\\vendor_modules" if installdir
File.join(installdir, 'puppet', 'vendor_modules') if installdir

@mhashizume mhashizume merged commit 8047d1c into puppetlabs:main Jun 24, 2024
9 checks passed
@joshcooper joshcooper deleted the PUP-11655 branch June 24, 2024 18:52
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants