Skip to content
This repository was archived by the owner on Jul 14, 2021. It is now read-only.

Allow setting CHEFDK_HOME #412

Merged
merged 7 commits into from
Jun 12, 2015
Merged

Allow setting CHEFDK_HOME #412

merged 7 commits into from
Jun 12, 2015

Conversation

jaym
Copy link
Contributor

@jaym jaym commented Jun 8, 2015

Related omnibus changes: chef-boneyard/omnibus-chef#406


require 'chef/http/simple'

# Configure CookbookOmnifetch's dependency injection settings to use our classes and config.
CookbookOmnifetch.configure do |c|
c.cache_path = File.expand_path('~/.chefdk/cache')
c.storage_path = Pathname.new(File.expand_path('~/.chefdk/cache/cookbooks'))
helpers = Class.new do
Copy link
Contributor

Choose a reason for hiding this comment

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

If all of the helpers are stateless functions, you could just add extend self over there and then you can call all the methods as module functions.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

They memoize :(
it broke my tests, and had to change it this way.
OTOH, we could just not do the whole ||= thing

Copy link
Contributor

Choose a reason for hiding this comment

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

If the output would only reasonably change during tests, then we could have an @api private method like reset!.

if chefdk_home_set
ENV['CHEFDK_HOME']
else
old_home = File.join(Gem.user_home, '.chefdk')
Copy link
Contributor

Choose a reason for hiding this comment

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

I don't think backcompat is strictly require if this only affects Policyfiles. We can just document it in the release announcement.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Fair enough. It will actually do the right thing if people use chefdk through the omnibus package. I'll remove the backcompat stuff here.

@danielsdeleo
Copy link
Contributor

👍 modulo the nitpicks. BTW, is the local app data directory something all windows admins will know about? Maybe we should have a chef env (or something) to tell you where your default config location is?

@jaym
Copy link
Contributor Author

jaym commented Jun 9, 2015

chef env would be a great idea. Will add it before we release this

@tyler-ball
Copy link
Contributor

👍

jaym added a commit that referenced this pull request Jun 12, 2015
@jaym jaym merged commit c9e1366 into master Jun 12, 2015
@jtimberman jtimberman deleted the jdm/chefdk-home branch June 13, 2015 01:32
jaym added a commit that referenced this pull request Jun 16, 2015
jaym added a commit that referenced this pull request Jun 17, 2015
ksubrama pushed a commit that referenced this pull request Jan 11, 2016
@chef-boneyard chef-boneyard locked and limited conversation to collaborators Feb 14, 2018
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Development

Successfully merging this pull request may close these issues.

4 participants