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.rb123
1 files changed, 123 insertions, 0 deletions
diff --git a/spec/unit/resource/remote_file_spec.rb b/spec/unit/resource/remote_file_spec.rb
new file mode 100644
index 0000000000..d91f80d1a7
--- /dev/null
+++ b/spec/unit/resource/remote_file_spec.rb
@@ -0,0 +1,123 @@
+#
+# 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 be_nil
+ 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 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 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 "does not accept a non-URI as the source" do
+ lambda { @resource.source("not-a-uri") }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
+ end
+
+ it "should raise and 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 "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