spec/unit/cookbook_loader_spec.rb in microwave-1.0.4 vs spec/unit/cookbook_loader_spec.rb in microwave-11.400.2
- old
+ new
@@ -23,123 +23,185 @@
@repo_paths = [ File.expand_path(File.join(CHEF_SPEC_DATA, "kitchen")),
File.expand_path(File.join(CHEF_SPEC_DATA, "cookbooks")) ]
@cookbook_loader = Chef::CookbookLoader.new(@repo_paths)
end
- describe "[]" do
- it "should return cookbook objects with []" do
- @cookbook_loader[:openldap].should be_a_kind_of(Chef::CookbookVersion)
+ describe "loading all cookbooks" do
+ before(:each) do
+ @cookbook_loader.load_cookbooks
end
+ describe "[]" do
+ it "should return cookbook objects with []" do
+ @cookbook_loader[:openldap].should be_a_kind_of(Chef::CookbookVersion)
+ end
- it "should raise an exception if it cannot find a cookbook with []" do
- lambda { @cookbook_loader[:monkeypoop] }.should raise_error(Chef::Exceptions::CookbookNotFoundInRepo)
- end
+ it "should raise an exception if it cannot find a cookbook with []" do
+ lambda { @cookbook_loader[:monkeypoop] }.should raise_error(Chef::Exceptions::CookbookNotFoundInRepo)
+ end
- it "should allow you to look up available cookbooks with [] and a symbol" do
- @cookbook_loader[:openldap].name.should eql(:openldap)
- end
+ it "should allow you to look up available cookbooks with [] and a symbol" do
+ @cookbook_loader[:openldap].name.should eql(:openldap)
+ end
- it "should allow you to look up available cookbooks with [] and a string" do
- @cookbook_loader["openldap"].name.should eql(:openldap)
+ it "should allow you to look up available cookbooks with [] and a string" do
+ @cookbook_loader["openldap"].name.should eql(:openldap)
+ end
end
- end
- describe "each" do
- it "should allow you to iterate over cookbooks with each" do
- seen = Hash.new
- @cookbook_loader.each do |cookbook_name, cookbook|
- seen[cookbook_name] = true
+ describe "each" do
+ it "should allow you to iterate over cookbooks with each" do
+ seen = Hash.new
+ @cookbook_loader.each do |cookbook_name, cookbook|
+ seen[cookbook_name] = true
+ end
+ seen.should have_key("openldap")
+ seen.should have_key("apache2")
end
- seen.should have_key("openldap")
- seen.should have_key("apache2")
- end
- it "should iterate in alphabetical order" do
- seen = Array.new
- @cookbook_loader.each do |cookbook_name, cookbook|
- seen << cookbook_name
+ it "should iterate in alphabetical order" do
+ seen = Array.new
+ @cookbook_loader.each do |cookbook_name, cookbook|
+ seen << cookbook_name
+ end
+ seen[0].should == "angrybash"
+ seen[1].should == "apache2"
+ seen[2].should == "borken"
+ seen[3].should == "java"
+ seen[4].should == "openldap"
end
- seen[0].should == "angrybash"
- seen[1].should == "apache2"
- seen[2].should == "borken"
- seen[3].should == "java"
- seen[4].should == "openldap"
end
- end
+
+ describe "load_cookbooks" do
+ it "should find all the cookbooks in the cookbook path" do
+ Chef::Config.cookbook_path << File.expand_path(File.join(CHEF_SPEC_DATA, "hidden-cookbooks"))
+ @cookbook_loader.load_cookbooks
+ @cookbook_loader.should have_key(:openldap)
+ @cookbook_loader.should have_key(:apache2)
+ end
+
+ it "should allow you to override an attribute file via cookbook_path" do
+ @cookbook_loader[:openldap].attribute_filenames.detect { |f|
+ f =~ /cookbooks\/openldap\/attributes\/default.rb/
+ }.should_not eql(nil)
+ @cookbook_loader[:openldap].attribute_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/attributes\/default.rb/
+ }.should eql(nil)
+ end
+
+ it "should load different attribute files from deeper paths" do
+ @cookbook_loader[:openldap].attribute_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/attributes\/robinson.rb/
+ }.should_not eql(nil)
+ end
+
+ it "should allow you to override a definition file via cookbook_path" do
+ @cookbook_loader[:openldap].definition_filenames.detect { |f|
+ f =~ /cookbooks\/openldap\/definitions\/client.rb/
+ }.should_not eql(nil)
+ @cookbook_loader[:openldap].definition_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/definitions\/client.rb/
+ }.should eql(nil)
+ end
+
+ it "should load definition files from deeper paths" do
+ @cookbook_loader[:openldap].definition_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/definitions\/drewbarrymore.rb/
+ }.should_not eql(nil)
+ end
+
+ it "should allow you to override a recipe file via cookbook_path" do
+ @cookbook_loader[:openldap].recipe_filenames.detect { |f|
+ f =~ /cookbooks\/openldap\/recipes\/gigantor.rb/
+ }.should_not eql(nil)
+ @cookbook_loader[:openldap].recipe_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/recipes\/gigantor.rb/
+ }.should eql(nil)
+ end
+
+ it "should load recipe files from deeper paths" do
+ @cookbook_loader[:openldap].recipe_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/recipes\/woot.rb/
+ }.should_not eql(nil)
+ end
+
+ it "should allow you to have an 'ignore' file, which skips loading files in later cookbooks" do
+ @cookbook_loader[:openldap].recipe_filenames.detect { |f|
+ f =~ /kitchen\/openldap\/recipes\/ignoreme.rb/
+ }.should eql(nil)
+ end
+
+ it "should find files that start with a ." do
+ @cookbook_loader[:openldap].file_filenames.detect { |f|
+ f =~ /\.dotfile$/
+ }.should =~ /\.dotfile$/
+ @cookbook_loader[:openldap].file_filenames.detect { |f|
+ f =~ /\.ssh\/id_rsa$/
+ }.should =~ /\.ssh\/id_rsa$/
+ end
+
+ it "should load the metadata for the cookbook" do
+ @cookbook_loader.metadata[:openldap].name.should == :openldap
+ @cookbook_loader.metadata[:openldap].should be_a_kind_of(Chef::Cookbook::Metadata)
+ end
- describe "load_cookbooks" do
- it "should find all the cookbooks in the cookbook path" do
- Chef::Config.cookbook_path << File.expand_path(File.join(CHEF_SPEC_DATA, "hidden-cookbooks"))
- @cookbook_loader.load_cookbooks
- @cookbook_loader.should have_key(:openldap)
- @cookbook_loader.should have_key(:apache2)
- end
+ it "should check each cookbook directory only once (CHEF-3487)" do
+ cookbooks = []
+ @repo_paths.each do |repo_path|
+ cookbooks |= Dir[File.join(repo_path, "*")]
+ end
+ cookbooks.each do |cookbook|
+ File.should_receive(:directory?).with(cookbook).once;
+ end
+ @cookbook_loader.load_cookbooks
+ end
+ end # load_cookbooks
- it "should allow you to override an attribute file via cookbook_path" do
- @cookbook_loader[:openldap].attribute_filenames.detect { |f|
- f =~ /cookbooks\/openldap\/attributes\/default.rb/
- }.should_not eql(nil)
- @cookbook_loader[:openldap].attribute_filenames.detect { |f|
- f =~ /kitchen\/openldap\/attributes\/default.rb/
- }.should eql(nil)
- end
+ end # loading all cookbooks
- it "should load different attribute files from deeper paths" do
- @cookbook_loader[:openldap].attribute_filenames.detect { |f|
- f =~ /kitchen\/openldap\/attributes\/robinson.rb/
- }.should_not eql(nil)
+ describe "loading only one cookbook" do
+ before(:each) do
+ @cookbook_loader = Chef::CookbookLoader.new(@repo_paths)
+ @cookbook_loader.load_cookbook("openldap")
end
- it "should allow you to override a definition file via cookbook_path" do
- @cookbook_loader[:openldap].definition_filenames.detect { |f|
- f =~ /cookbooks\/openldap\/definitions\/client.rb/
- }.should_not eql(nil)
- @cookbook_loader[:openldap].definition_filenames.detect { |f|
- f =~ /kitchen\/openldap\/definitions\/client.rb/
- }.should eql(nil)
+ it "should have loaded the correct cookbook" do
+ seen = Hash.new
+ @cookbook_loader.each do |cookbook_name, cookbook|
+ seen[cookbook_name] = true
+ end
+ seen.should have_key("openldap")
end
- it "should load definition files from deeper paths" do
- @cookbook_loader[:openldap].definition_filenames.detect { |f|
- f =~ /kitchen\/openldap\/definitions\/drewbarrymore.rb/
- }.should_not eql(nil)
+ it "should not load the cookbook again when accessed" do
+ @cookbook_loader.should_not_receive('load_cookbook')
+ @cookbook_loader["openldap"]
end
- it "should allow you to override a recipe file via cookbook_path" do
- @cookbook_loader[:openldap].recipe_filenames.detect { |f|
- f =~ /cookbooks\/openldap\/recipes\/gigantor.rb/
- }.should_not eql(nil)
- @cookbook_loader[:openldap].recipe_filenames.detect { |f|
- f =~ /kitchen\/openldap\/recipes\/gigantor.rb/
- }.should eql(nil)
+ it "should not load the other cookbooks" do
+ seen = Hash.new
+ @cookbook_loader.each do |cookbook_name, cookbook|
+ seen[cookbook_name] = true
+ end
+ seen.should_not have_key("apache2")
end
- it "should load recipe files from deeper paths" do
- @cookbook_loader[:openldap].recipe_filenames.detect { |f|
- f =~ /kitchen\/openldap\/recipes\/woot.rb/
- }.should_not eql(nil)
+ it "should load another cookbook lazily with []" do
+ @cookbook_loader["apache2"].should be_a_kind_of(Chef::CookbookVersion)
end
- it "should allow you to have an 'ignore' file, which skips loading files in later cookbooks" do
- @cookbook_loader[:openldap].recipe_filenames.detect { |f|
- f =~ /kitchen\/openldap\/recipes\/ignoreme.rb/
- }.should eql(nil)
- end
+ describe "loading all cookbooks after loading only one cookbook" do
+ before(:each) do
+ @cookbook_loader.load_cookbooks
+ end
- it "should find files that start with a ." do
- @cookbook_loader[:openldap].file_filenames.detect { |f|
- f =~ /\.dotfile$/
- }.should =~ /\.dotfile$/
- @cookbook_loader[:openldap].file_filenames.detect { |f|
- f =~ /\.ssh\/id_rsa$/
- }.should =~ /\.ssh\/id_rsa$/
+ it "should load all cookbooks" do
+ seen = Hash.new
+ @cookbook_loader.each do |cookbook_name, cookbook|
+ seen[cookbook_name] = true
+ end
+ seen.should have_key("openldap")
+ seen.should have_key("apache2")
+ end
end
-
- it "should load the metadata for the cookbook" do
- @cookbook_loader.metadata[:openldap].name.should == :openldap
- @cookbook_loader.metadata[:openldap].should be_a_kind_of(Chef::Cookbook::Metadata)
- end
-
- end
-
+ end # loading only one cookbook
end