summaryrefslogtreecommitdiff
path: root/spec/unit/resource/remote_file_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit/resource/remote_file_spec.rb')
-rw-r--r--spec/unit/resource/remote_file_spec.rb192
1 files changed, 0 insertions, 192 deletions
diff --git a/spec/unit/resource/remote_file_spec.rb b/spec/unit/resource/remote_file_spec.rb
deleted file mode 100644
index 8f1633119d..0000000000
--- a/spec/unit/resource/remote_file_spec.rb
+++ /dev/null
@@ -1,192 +0,0 @@
-#
-# Author:: Adam Jacob (<adam@opscode.com>)
-# Author:: Tyler Cloke (<tyler@opscode.com>)
-# Copyright:: Copyright (c) 2008 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'
-
-describe Chef::Resource::RemoteFile do
-
- before(:each) do
- @resource = Chef::Resource::RemoteFile.new("fakey_fakerton")
- end
-
- describe "initialize" do
- it "should create a new Chef::Resource::RemoteFile" do
- @resource.should be_a_kind_of(Chef::Resource)
- @resource.should be_a_kind_of(Chef::Resource::File)
- @resource.should be_a_kind_of(Chef::Resource::RemoteFile)
- end
- end
-
- it "says its provider is RemoteFile when the source is an absolute URI" do
- @resource.source("http://www.google.com/robots.txt")
- @resource.provider.should == Chef::Provider::RemoteFile
- Chef::Platform.find_provider(:noplatform, 'noversion', @resource).should == Chef::Provider::RemoteFile
- end
-
-
- describe "source" do
- it "does not have a default value for 'source'" do
- @resource.source.should eql([])
- end
-
- it "should accept a URI for the remote file source" do
- @resource.source "http://opscode.com/"
- @resource.source.should eql([ "http://opscode.com/" ])
- end
-
- it "should accept a delayed evalutator (string) for the remote file source" do
- @resource.source Chef::DelayedEvaluator.new {"http://opscode.com/"}
- @resource.source.should eql([ "http://opscode.com/" ])
- end
-
- it "should accept an array of URIs for the remote file source" do
- @resource.source([ "http://opscode.com/", "http://puppetlabs.com/" ])
- @resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
- end
-
- it "should accept a delated evaluator (array) for the remote file source" do
- @resource.source Chef::DelayedEvaluator.new { [ "http://opscode.com/", "http://puppetlabs.com/" ] }
- @resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
- end
-
- it "should accept an multiple URIs as arguments for the remote file source" do
- @resource.source("http://opscode.com/", "http://puppetlabs.com/")
- @resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
- end
-
- it "should only accept a single argument if a delayed evalutor is used" do
- lambda {
- @resource.source("http://opscode.com/", Chef::DelayedEvaluator.new {"http://opscode.com/"})
- }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
- end
-
- it "should only accept a single array item if a delayed evalutor is used" do
- lambda {
- @resource.source(["http://opscode.com/", Chef::DelayedEvaluator.new {"http://opscode.com/"}])
- }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
- end
-
- it "does not accept a non-URI as the source" do
- lambda { @resource.source("not-a-uri") }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
- end
-
- it "does not accept a non-URI as the source when read from a delayed evaluator" do
- lambda {
- @resource.source(Chef::DelayedEvaluator.new {"not-a-uri"})
- @resource.source
- }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
- end
-
- it "should raise an exception when source is an empty array" do
- lambda { @resource.source([]) }.should raise_error(ArgumentError)
- end
-
- end
-
- describe "checksum" do
- it "should accept a string for the checksum object" do
- @resource.checksum "asdf"
- @resource.checksum.should eql("asdf")
- end
-
- it "should default to nil" do
- @resource.checksum.should == nil
- end
- end
-
- describe "ftp_active_mode" do
- it "should accept a boolean for the ftp_active_mode object" do
- @resource.ftp_active_mode true
- @resource.ftp_active_mode.should be_true
- end
-
- it "should default to false" do
- @resource.ftp_active_mode.should be_false
- end
- end
-
- describe "conditional get options" do
- it "defaults to using etags and last modified" do
- @resource.use_etags.should be_true
- @resource.use_last_modified.should be_true
- end
-
- it "enable or disables etag and last modified options as a group" do
- @resource.use_conditional_get(false)
- @resource.use_etags.should be_false
- @resource.use_last_modified.should be_false
-
- @resource.use_conditional_get(true)
- @resource.use_etags.should be_true
- @resource.use_last_modified.should be_true
- end
-
- it "disables etags indivdually" do
- @resource.use_etags(false)
- @resource.use_etags.should be_false
- @resource.use_last_modified.should be_true
- end
-
- it "disables last modified individually" do
- @resource.use_last_modified(false)
- @resource.use_last_modified.should be_false
- @resource.use_etags.should be_true
- end
-
- end
-
- describe "when it has group, mode, owner, source, and checksum" do
- before do
- if Chef::Platform.windows?
- @resource.path("C:/temp/origin/file.txt")
- @resource.rights(:read, "Everyone")
- @resource.deny_rights(:full_control, "Clumsy_Sam")
- else
- @resource.path("/this/path/")
- @resource.group("pokemon")
- @resource.mode("0664")
- @resource.owner("root")
- end
- @resource.source("https://www.google.com/images/srpr/logo3w.png")
- @resource.checksum("1"*26)
- end
-
- it "describes its state" do
- state = @resource.state
- if Chef::Platform.windows?
- puts state
- state[:rights].should == [{:permissions => :read, :principals => "Everyone"}]
- state[:deny_rights].should == [{:permissions => :full_control, :principals => "Clumsy_Sam"}]
- else
- state[:group].should == "pokemon"
- state[:mode].should == "0664"
- state[:owner].should == "root"
- state[:checksum].should == "1"*26
- end
- end
-
- it "returns the path as its identity" do
- if Chef::Platform.windows?
- @resource.identity.should == "C:/temp/origin/file.txt"
- else
- @resource.identity.should == "/this/path/"
- end
- end
- end
-end