Be more sane about cookbook_paths default in Chef

This commit is contained in:
Mitchell Hashimoto 2013-02-05 22:00:03 -08:00
parent a09c72d84e
commit 1af3255559
3 changed files with 28 additions and 28 deletions

View File

@ -12,29 +12,28 @@ module VagrantPlugins
attr_accessor :encrypted_data_bag_secret_key_path
attr_accessor :encrypted_data_bag_secret
def encrypted_data_bag_secret; @encrypted_data_bag_secret || "/tmp/encrypted_data_bag_secret"; end
def initialize
super
@__default = ["cookbooks", [:vm, "cookbooks"]]
@cookbooks_path = UNSET_VALUE
@encrypted_data_bag_secret = UNSET_VALUE
@nfs = UNSET_VALUE
end
# Provide defaults in such a way that they won't override the instance
# variable. This is so merging continues to work properly.
def cookbooks_path
@cookbooks_path || _default_cookbook_path
def finalize!
if @cookbooks_path == UNSET_VALUE
@cookbooks_path = [[:host, "cookbooks"], [:vm, "cookbooks"]]
end
# This stores a reference to the default cookbook path which is used
# later. Do not use this publicly. I apologize for not making it
# "protected" but it has to be called by Vagrant internals later.
def _default_cookbook_path
@__default
# Make sure all the paths are the proper format
@cookbooks_path.map! do |path|
path = [:host, path] if !path.is_a?(Array)
path
end
def nfs
@nfs || false
@encrypted_data_bag_secret = "/tmp/encrypted_data_bag_secret" if \
@encrypted_data_bag_secret == UNSET_VALUE
@nfs = false if @nfs == UNSET_VALUE
end
def validate(machine)
@ -44,6 +43,16 @@ module VagrantPlugins
errors << I18n.t("vagrant.config.chef.run_list_empty") if \
!run_list || run_list.empty?
@cookbooks_path.each do |type, path|
next if type != :host
expanded_path = File.expand_path(path, machine.env.root_path)
if !File.exist?(expanded_path)
errors << I18n.t("vagrant.config.chef.cookbooks_path_missing",
:path => expanded_path)
end
end
{ "chef solo provisioner" => errors }
end
end

View File

@ -62,10 +62,7 @@ module VagrantPlugins
paths = [paths] if paths.is_a?(String) || paths.first.is_a?(Symbol)
results = []
paths.each do |path|
path = [:host, path] if !path.is_a?(Array)
type, path = path
paths.each do |type, path|
# Create the local/remote path based on whether this is a host
# or VM path.
local_path = nil
@ -74,14 +71,6 @@ module VagrantPlugins
# Get the expanded path that the host path points to
local_path = File.expand_path(path, @machine.env.root_path)
# Super hacky but if we're expanded the default cookbook paths,
# and one of the host paths doesn't exist, then just ignore it,
# because that is fine.
if paths.equal?(@config._default_cookbook_path) && !File.directory?(local_path)
@logger.info("'cookbooks' folder doesn't exist on defaults. Ignoring.")
next
end
# Path exists on the host, setup the remote path
remote_path = "#{@config.provisioning_path}/chef-solo-#{get_and_update_counter(:cookbooks_path)}"
else

View File

@ -377,6 +377,8 @@ en:
error_empty: "`%{field}` must be not be empty."
chef:
cookbooks_path_empty: "Must specify a cookbooks path for chef solo."
cookbooks_path_missing: |-
Cookbook path doesn't exist: %{path}
run_list_empty: "Run list must not be empty."
server_url_empty: "Chef server URL must be populated."
validation_key_path: "Validation key path must be valid path to your chef server validation key."