summaryrefslogtreecommitdiff
path: root/spec/unit/environment_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit/environment_spec.rb')
-rw-r--r--spec/unit/environment_spec.rb466
1 files changed, 0 insertions, 466 deletions
diff --git a/spec/unit/environment_spec.rb b/spec/unit/environment_spec.rb
deleted file mode 100644
index 5a2c400d3c..0000000000
--- a/spec/unit/environment_spec.rb
+++ /dev/null
@@ -1,466 +0,0 @@
-#
-# Author:: Stephen Delano (<stephen@ospcode.com>)
-# Author:: Seth Falcon (<seth@ospcode.com>)
-# Author:: John Keiser (<jkeiser@ospcode.com>)
-# Author:: Kyle Goodwin (<kgoodwin@primerevenue.com>)
-# Copyright:: Copyright 2010-2011 Opscode, Inc.
-# License:: Apache License, Version 2.0
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-#
-
-require 'spec_helper'
-require 'chef/environment'
-
-describe Chef::Environment do
- before(:each) do
- @environment = Chef::Environment.new
- end
-
- describe "initialize" do
- it "should be a Chef::Environment" do
- @environment.should be_a_kind_of(Chef::Environment)
- end
- end
-
- describe "name" do
- it "should let you set the name to a string" do
- @environment.name("production").should == "production"
- end
-
- it "should return the current name" do
- @environment.name("production")
- @environment.name.should == "production"
- end
-
- it "should not accept spaces" do
- lambda { @environment.name("production environment") }.should raise_error(ArgumentError)
- end
-
- it "should not accept anything but strings" do
- lambda { @environment.name(Array.new) }.should raise_error(ArgumentError)
- lambda { @environment.name(Hash.new) }.should raise_error(ArgumentError)
- lambda { @environment.name(2) }.should raise_error(ArgumentError)
- end
- end
-
- describe "description" do
- it "should let you set the description to a string" do
- @environment.description("this is my test environment").should == "this is my test environment"
- end
-
- it "should return the correct description" do
- @environment.description("I like running tests")
- @environment.description.should == "I like running tests"
- end
-
- it "should not accept anything but strings" do
- lambda { @environment.description(Array.new) }.should raise_error(ArgumentError)
- lambda { @environment.description(Hash.new) }.should raise_error(ArgumentError)
- lambda { @environment.description(42) }.should raise_error(ArgumentError)
- end
- end
-
- describe "default attributes" do
- it "should let you set the attributes hash explicitly" do
- @environment.default_attributes({ :one => 'two' }).should == { :one => 'two' }
- end
-
- it "should let you return the attributes hash" do
- @environment.default_attributes({ :one => 'two' })
- @environment.default_attributes.should == { :one => 'two' }
- end
-
- it "should throw an ArgumentError if we aren't a kind of hash" do
- lambda { @environment.default_attributes(Array.new) }.should raise_error(ArgumentError)
- end
- end
-
- describe "override attributes" do
- it "should let you set the attributes hash explicitly" do
- @environment.override_attributes({ :one => 'two' }).should == { :one => 'two' }
- end
-
- it "should let you return the attributes hash" do
- @environment.override_attributes({ :one => 'two' })
- @environment.override_attributes.should == { :one => 'two' }
- end
-
- it "should throw an ArgumentError if we aren't a kind of hash" do
- lambda { @environment.override_attributes(Array.new) }.should raise_error(ArgumentError)
- end
- end
-
- describe "cookbook_versions" do
- before(:each) do
- @cookbook_versions = {
- "apt" => "= 1.0.0",
- "god" => "= 2.0.0",
- "apache2" => "= 4.2.0"
- }
- end
-
- it "should let you set the cookbook versions in a hash" do
- @environment.cookbook_versions(@cookbook_versions).should == @cookbook_versions
- end
-
- it "should return the cookbook versions" do
- @environment.cookbook_versions(@cookbook_versions)
- @environment.cookbook_versions.should == @cookbook_versions
- end
-
- it "should not accept anything but a hash" do
- lambda { @environment.cookbook_versions("I am a string!") }.should raise_error(ArgumentError)
- lambda { @environment.cookbook_versions(Array.new) }.should raise_error(ArgumentError)
- lambda { @environment.cookbook_versions(42) }.should raise_error(ArgumentError)
- end
-
- it "should validate the hash" do
- Chef::Environment.should_receive(:validate_cookbook_versions).with(@cookbook_versions).and_return true
- @environment.cookbook_versions(@cookbook_versions)
- end
- end
-
- describe "cookbook" do
- it "should set the version of the cookbook in the cookbook_versions hash" do
- @environment.cookbook("apt", "~> 1.2.3")
- @environment.cookbook_versions["apt"].should == "~> 1.2.3"
- end
-
- it "should validate the cookbook version it is passed" do
- Chef::Environment.should_receive(:validate_cookbook_version).with(">= 1.2.3").and_return true
- @environment.cookbook("apt", ">= 1.2.3")
- end
- end
-
- describe "update_from!" do
- before(:each) do
- @environment.name("prod")
- @environment.description("this is prod")
- @environment.cookbook_versions({ "apt" => "= 1.2.3" })
-
- @example = Chef::Environment.new
- @example.name("notevenprod")
- @example.description("this is pre-prod")
- @example.cookbook_versions({ "apt" => "= 2.3.4" })
- end
-
- it "should update everything but name" do
- @environment.update_from!(@example)
- @environment.name.should == "prod"
- @environment.description.should == @example.description
- @environment.cookbook_versions.should == @example.cookbook_versions
- end
- end
-
- describe "to_hash" do
- before(:each) do
- @environment.name("spec")
- @environment.description("Where we run the spec tests")
- @environment.cookbook_versions({:apt => "= 1.2.3"})
- @hash = @environment.to_hash
- end
-
- %w{name description cookbook_versions}.each do |t|
- it "should include '#{t}'" do
- @hash[t].should == @environment.send(t.to_sym)
- end
- end
-
- it "should include 'json_class'" do
- @hash["json_class"].should == "Chef::Environment"
- end
-
- it "should include 'chef_type'" do
- @hash["chef_type"].should == "environment"
- end
- end
-
- describe "to_json" do
- before(:each) do
- @environment.name("spec")
- @environment.description("Where we run the spec tests")
- @environment.cookbook_versions({:apt => "= 1.2.3"})
- @json = @environment.to_json
- end
-
- %w{name description cookbook_versions}.each do |t|
- it "should include '#{t}'" do
- @json.should =~ /"#{t}":#{Regexp.escape(@environment.send(t.to_sym).to_json)}/
- end
- end
-
- it "should include 'json_class'" do
- @json.should =~ /"json_class":"Chef::Environment"/
- end
-
- it "should include 'chef_type'" do
- @json.should =~ /"chef_type":"environment"/
- end
- end
-
- describe "from_json" do
- before(:each) do
- @data = {
- "name" => "production",
- "description" => "We are productive",
- "cookbook_versions" => {
- "apt" => "= 1.2.3",
- "god" => ">= 4.2.0",
- "apache2" => "= 2.0.0"
- },
- "json_class" => "Chef::Environment",
- "chef_type" => "environment"
- }
- @environment = Chef::JSONCompat.from_json(@data.to_json)
- end
-
- it "should return a Chef::Environment" do
- @environment.should be_a_kind_of(Chef::Environment)
- end
-
- %w{name description cookbook_versions}.each do |t|
- it "should match '#{t}'" do
- @environment.send(t.to_sym).should == @data[t]
- end
- end
- end
-
- describe "self.validate_cookbook_versions" do
- before(:each) do
- @cookbook_versions = {
- "apt" => "= 1.0.0",
- "god" => "= 2.0.0",
- "apache2" => "= 4.2.0"
- }
- end
-
- it "should validate the version string of each cookbook" do
- @cookbook_versions.each do |cookbook, version|
- Chef::Environment.should_receive(:validate_cookbook_version).with(version).and_return true
- end
- Chef::Environment.validate_cookbook_versions(@cookbook_versions)
- end
-
- it "should return false if anything other than a hash is passed as the argument" do
- Chef::Environment.validate_cookbook_versions(Array.new).should == false
- Chef::Environment.validate_cookbook_versions(42).should == false
- Chef::Environment.validate_cookbook_versions(Chef::CookbookVersion.new("meta")).should == false
- Chef::Environment.validate_cookbook_versions("cookbook => 1.2.3").should == false
- end
- end
-
- describe "self.validate_cookbook_version" do
- it "should validate correct version numbers" do
- Chef::Environment.validate_cookbook_version("= 1.2.3").should == true
- Chef::Environment.validate_cookbook_version("=1.2.3").should == true
- Chef::Environment.validate_cookbook_version(">= 0.0.3").should == true
- Chef::Environment.validate_cookbook_version(">=0.0.3").should == true
- # A lone version is allowed, interpreted as implicit '='
- Chef::Environment.validate_cookbook_version("1.2.3").should == true
- end
-
- it "should return false when an invalid version is given" do
- Chef::Environment.validate_cookbook_version(Chef::CookbookVersion.new("meta")).should == false
- Chef::Environment.validate_cookbook_version("= 1.2.3a").should == false
- Chef::Environment.validate_cookbook_version("=1.2.3a").should == false
- Chef::Environment.validate_cookbook_version("= 1").should == false
- Chef::Environment.validate_cookbook_version("=1").should == false
- Chef::Environment.validate_cookbook_version("= a").should == false
- Chef::Environment.validate_cookbook_version("=a").should == false
- Chef::Environment.validate_cookbook_version("= 1.2.3.4").should == false
- Chef::Environment.validate_cookbook_version("=1.2.3.4").should == false
- end
-
- describe "in solo mode" do
- before do
- Chef::Config[:solo] = true
- end
-
- after do
- Chef::Config[:solo] = false
- end
-
- it "should raise and exception" do
- lambda {
- Chef::Environment.validate_cookbook_version("= 1.2.3.4")
- }.should raise_error Chef::Exceptions::IllegalVersionConstraint,
- "Environment cookbook version constraints not allowed in chef-solo"
- end
- end
-
- end
-
- describe "when updating from a parameter hash" do
- before do
- @environment = Chef::Environment.new
- end
-
- it "updates the name from parameters[:name]" do
- @environment.update_from_params(:name => "kurrupt")
- @environment.name.should == "kurrupt"
- end
-
- it "validates the name given in the params" do
- @environment.update_from_params(:name => "@$%^&*()").should be_false
- @environment.invalid_fields[:name].should == %q|Option name's value @$%^&*() does not match regular expression /^[\-[:alnum:]_]+$/|
- end
-
- it "updates the description from parameters[:description]" do
- @environment.update_from_params(:description => "wow, writing your own object mapper is kinda painful")
- @environment.description.should == "wow, writing your own object mapper is kinda painful"
- end
-
- it "updates cookbook version constraints from the hash in parameters[:cookbook_version_constraints]" do
- # NOTE: I'm only choosing this (admittedly weird) structure for the hash b/c the better more obvious
- # one, i.e, {:cookbook_version_constraints => {COOKBOOK_NAME => CONSTRAINT}} is difficult to implement
- # the way merb does params
- params = {:name=>"superbowl", :cookbook_version => {"0" => "apache2 ~> 1.0.0", "1" => "nginx < 2.0.0"}}
- @environment.update_from_params(params)
- @environment.cookbook_versions.should == {"apache2" => "~> 1.0.0", "nginx" => "< 2.0.0"}
- end
-
- it "validates the cookbook constraints" do
- params = {:cookbook_version => {"0" => "apache2 >>> 1.0.0"}}
- @environment.update_from_params(params).should be_false
- err_msg = @environment.invalid_fields[:cookbook_version]["0"]
- err_msg.should == "apache2 >>> 1.0.0 is not a valid cookbook constraint"
- end
-
- it "is not valid if the name is not present" do
- @environment.validate_required_attrs_present.should be_false
- @environment.invalid_fields[:name].should == "name cannot be empty"
- end
-
- it "is not valid after updating from params if the name is not present" do
- @environment.update_from_params({}).should be_false
- @environment.invalid_fields[:name].should == "name cannot be empty"
- end
-
- it "updates default attributes from a JSON string in params[:attributes]" do
- @environment.update_from_params(:name => "fuuu", :default_attributes => %q|{"fuuu":"RAGE"}|)
- @environment.default_attributes.should == {"fuuu" => "RAGE"}
- end
-
- it "updates override attributes from a JSON string in params[:attributes]" do
- @environment.update_from_params(:name => "fuuu", :override_attributes => %q|{"foo":"override"}|)
- @environment.override_attributes.should == {"foo" => "override"}
- end
-
- end
-
- describe "api model" do
- before(:each) do
- @rest = double("Chef::REST")
- Chef::REST.stub(:new).and_return(@rest)
- @query = double("Chef::Search::Query")
- Chef::Search::Query.stub(:new).and_return(@query)
- end
-
- describe "list" do
- describe "inflated" do
- it "should return a hash of environment names and objects" do
- e1 = double("Chef::Environment", :name => "one")
- @query.should_receive(:search).with(:environment).and_yield(e1)
- r = Chef::Environment.list(true)
- r["one"].should == e1
- end
- end
-
- it "should return a hash of environment names and urls" do
- @rest.should_receive(:get_rest).and_return({ "one" => "http://foo" })
- r = Chef::Environment.list
- r["one"].should == "http://foo"
- end
- end
- end
-
- describe "when loading" do
- describe "in solo mode" do
- before do
- Chef::Config[:solo] = true
- Chef::Config[:environment_path] = '/var/chef/environments'
- end
-
- after do
- Chef::Config[:solo] = false
- end
-
- it "should get the environment from the environment_path" do
- File.should_receive(:directory?).with(Chef::Config[:environment_path]).and_return(true)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.json')).and_return(false)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.rb')).exactly(2).times.and_return(true)
- File.should_receive(:readable?).with(File.join(Chef::Config[:environment_path], 'foo.rb')).and_return(true)
- role_dsl="name \"foo\"\ndescription \"desc\"\n"
- IO.should_receive(:read).with(File.join(Chef::Config[:environment_path], 'foo.rb')).and_return(role_dsl)
- Chef::Environment.load('foo')
- end
-
- it "should return a Chef::Environment object from JSON" do
- File.should_receive(:directory?).with(Chef::Config[:environment_path]).and_return(true)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.json')).and_return(true)
- environment_hash = {
- "name" => "foo",
- "default_attributes" => {
- "foo" => {
- "bar" => 1
- }
- },
- "json_class" => "Chef::Environment",
- "description" => "desc",
- "chef_type" => "environment"
- }
- IO.should_receive(:read).with(File.join(Chef::Config[:environment_path], 'foo.json')).and_return(Chef::JSONCompat.to_json(environment_hash))
- environment = Chef::Environment.load('foo')
-
- environment.should be_a_kind_of(Chef::Environment)
- environment.name.should == environment_hash['name']
- environment.description.should == environment_hash['description']
- environment.default_attributes.should == environment_hash['default_attributes']
- end
-
- it "should return a Chef::Environment object from Ruby DSL" do
- File.should_receive(:directory?).with(Chef::Config[:environment_path]).and_return(true)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.json')).and_return(false)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.rb')).exactly(2).times.and_return(true)
- File.should_receive(:readable?).with(File.join(Chef::Config[:environment_path], 'foo.rb')).and_return(true)
- role_dsl="name \"foo\"\ndescription \"desc\"\n"
- IO.should_receive(:read).with(File.join(Chef::Config[:environment_path], 'foo.rb')).and_return(role_dsl)
- environment = Chef::Environment.load('foo')
-
- environment.should be_a_kind_of(Chef::Environment)
- environment.name.should == 'foo'
- environment.description.should == 'desc'
- end
-
- it 'should raise an error if the configured environment_path is invalid' do
- File.should_receive(:directory?).with(Chef::Config[:environment_path]).and_return(false)
-
- lambda {
- Chef::Environment.load('foo')
- }.should raise_error Chef::Exceptions::InvalidEnvironmentPath, "Environment path '/var/chef/environments' is invalid"
- end
-
- it 'should raise an error if the file does not exist' do
- File.should_receive(:directory?).with(Chef::Config[:environment_path]).and_return(true)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.json')).and_return(false)
- File.should_receive(:exists?).with(File.join(Chef::Config[:environment_path], 'foo.rb')).and_return(false)
-
- lambda {
- Chef::Environment.load('foo')
- }.should raise_error Chef::Exceptions::EnvironmentNotFound, "Environment 'foo' could not be loaded from disk"
- end
- end
- end
-
-end