summaryrefslogtreecommitdiffstats
path: root/spec/unit
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit')
-rwxr-xr-xspec/unit/file_serving/base.rb124
-rwxr-xr-xspec/unit/file_serving/content.rb4
-rwxr-xr-xspec/unit/indirector/file_metadata/modules.rb2
-rwxr-xr-xspec/unit/indirector/module_files.rb64
4 files changed, 158 insertions, 36 deletions
diff --git a/spec/unit/file_serving/base.rb b/spec/unit/file_serving/base.rb
new file mode 100755
index 000000000..9d900e30a
--- /dev/null
+++ b/spec/unit/file_serving/base.rb
@@ -0,0 +1,124 @@
+#!/usr/bin/env ruby
+
+require File.dirname(__FILE__) + '/../../spec_helper'
+
+require 'puppet/file_serving/base'
+
+describe Puppet::FileServing::Base do
+ it "should accept a key in the form of a URI" do
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file").key.should == "puppet://host/module/dir/file"
+ end
+
+ it "should allow specification of whether links should be managed" do
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file", :links => :manage).links.should == :manage
+ end
+
+ it "should consider :ignore links equivalent to :manage links" do
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file", :links => :ignore).links.should == :manage
+ end
+
+ it "should fail if :links is set to anything other than :manage, :follow, or :ignore" do
+ proc { Puppet::FileServing::Base.new("puppet://host/module/dir/file", :links => :else) }.should raise_error(ArgumentError)
+ end
+
+ it "should default to :manage for :links" do
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file").links.should == :manage
+ end
+
+ it "should allow specification of a path" do
+ FileTest.stubs(:exists?).returns(true)
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file", :path => "/my/file").path.should == "/my/file"
+ end
+
+ it "should allow specification of a relative path" do
+ FileTest.stubs(:exists?).returns(true)
+ Puppet::FileServing::Base.new("puppet://host/module/dir/file", :relative_path => "my/file").relative_path.should == "my/file"
+ end
+
+ it "should have a means of determining if the file exists" do
+ Puppet::FileServing::Base.new("blah").should respond_to(:exist?)
+ end
+
+ it "should correctly indicate if the file is present" do
+ File.expects(:lstat).with("/my/file").returns(mock("stat"))
+ Puppet::FileServing::Base.new("blah", :path => "/my/file").exist?.should be_true
+ end
+
+ it "should correctly indicate if the file is asbsent" do
+ File.expects(:lstat).with("/my/file").raises RuntimeError
+ Puppet::FileServing::Base.new("blah", :path => "/my/file").exist?.should be_false
+ end
+
+ describe "when setting the base path" do
+ before do
+ @file = Puppet::FileServing::Base.new("puppet://host/module/dir/file")
+ end
+
+ it "should require that the base path be fully qualified" do
+ FileTest.stubs(:exists?).returns(true)
+ proc { @file.path = "unqualified/file" }.should raise_error(ArgumentError)
+ end
+ end
+
+ describe "when setting the relative path" do
+ it "should require that the relative path be unqualified" do
+ @file = Puppet::FileServing::Base.new("puppet://host/module/dir/file")
+ FileTest.stubs(:exists?).returns(true)
+ proc { @file.relative_path = "/qualified/file" }.should raise_error(ArgumentError)
+ end
+ end
+
+ describe "when determining the full file path" do
+ before do
+ @file = Puppet::FileServing::Base.new("mykey", :path => "/this/file")
+ end
+
+ it "should return the path if there is no relative path" do
+ @file.full_path.should == "/this/file"
+ end
+
+ it "should return the path if the relative_path is set to ''" do
+ @file.relative_path = ""
+ @file.full_path.should == "/this/file"
+ end
+
+ it "should return the path joined with the relative path if there is a relative path and it is not set to '/' or ''" do
+ @file.relative_path = "not/qualified"
+ @file.full_path.should == "/this/file/not/qualified"
+ end
+
+ it "should should fail if there is no path set" do
+ @file = Puppet::FileServing::Base.new("not/qualified")
+ proc { @file.full_path }.should raise_error(ArgumentError)
+ end
+ end
+
+ describe "when stat'ing files" do
+ before do
+ @file = Puppet::FileServing::Base.new("mykey", :path => "/this/file")
+ end
+
+ it "should stat the file's full path" do
+ @file.stubs(:full_path).returns("/this/file")
+ File.expects(:lstat).with("/this/file").returns stub("stat", :ftype => "file")
+ @file.stat
+ end
+
+ it "should fail if the file does not exist" do
+ @file.stubs(:full_path).returns("/this/file")
+ File.expects(:lstat).with("/this/file").raises(Errno::ENOENT)
+ proc { @file.stat }.should raise_error(Errno::ENOENT)
+ end
+
+ it "should use :lstat if :links is set to :manage" do
+ File.expects(:lstat).with("/this/file").returns stub("stat", :ftype => "file")
+ @file.stat
+ end
+
+ it "should use :stat if :links is set to :follow" do
+ File.expects(:stat).with("/this/file").returns stub("stat", :ftype => "file")
+ @file.links = :follow
+ @file.stat
+ end
+ end
+end
diff --git a/spec/unit/file_serving/content.rb b/spec/unit/file_serving/content.rb
index b747ced78..82353d23d 100755
--- a/spec/unit/file_serving/content.rb
+++ b/spec/unit/file_serving/content.rb
@@ -5,8 +5,8 @@ require File.dirname(__FILE__) + '/../../spec_helper'
require 'puppet/file_serving/content'
describe Puppet::FileServing::Content do
- it "should should be a subclass of FileBase" do
- Puppet::FileServing::Content.superclass.should equal(Puppet::FileServing::FileBase)
+ it "should should be a subclass of Base" do
+ Puppet::FileServing::Content.superclass.should equal(Puppet::FileServing::Base)
end
it "should indirect file_content" do
diff --git a/spec/unit/indirector/file_metadata/modules.rb b/spec/unit/indirector/file_metadata/modules.rb
index 3905a49ad..838ac3b5f 100755
--- a/spec/unit/indirector/file_metadata/modules.rb
+++ b/spec/unit/indirector/file_metadata/modules.rb
@@ -24,7 +24,7 @@ describe Puppet::Indirector::FileMetadata::Modules, " when finding metadata" do
@module = Puppet::Module.new("mymod", "/path/to")
@finder.stubs(:find_module).returns(@module)
- @request = Puppet::Indirector::Request.new(:metadata, :find, "puppetmounts://hostname/modules/mymod/my/file")
+ @request = Puppet::Indirector::Request.new(:metadata, :find, "puppet://hostname/modules/mymod/my/file")
end
it "should return nil if the file is not found" do
diff --git a/spec/unit/indirector/module_files.rb b/spec/unit/indirector/module_files.rb
index 32dedd4f1..20c9f499a 100755
--- a/spec/unit/indirector/module_files.rb
+++ b/spec/unit/indirector/module_files.rb
@@ -25,49 +25,47 @@ describe Puppet::Indirector::ModuleFiles do
@module_files = @module_files_class.new
- @uri = "puppetmounts://host/modules/my/local/file"
@module = Puppet::Module.new("mymod", "/module/path")
- @request = stub 'request', :key => @uri, :options => {}, :node => nil, :ip => nil, :method => :find
+ @request = Puppet::Indirector::Request.new(:mytype, :find, "puppet://host/modules/mymod/local/file")
end
describe Puppet::Indirector::ModuleFiles, " when finding files" do
+ before do
+ Puppet::Module.stubs(:find).returns @module
+ end
- it "should strip off the leading '/modules' mount name" do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ it "should strip off the leading 'modules/' mount name" do
+ Puppet::Module.expects(:find).with { |key, env| key == 'mymod' }.returns @module
@module_files.find(@request)
end
- it "should not strip off leading terms that start with '/modules' but are longer words" do
- @request.stubs(:key).returns "puppetmounts://host/modulestart/my/local/file"
- Puppet::Module.expects(:find).with('modulestart', "myenv").returns nil
+ it "should not strip off leading terms that start with 'modules' but are longer words" do
+ @request.stubs(:key).returns "modulestart/mymod/local/file"
+ Puppet::Module.expects(:find).with { |key, env| key == 'modulestart'}.returns nil
@module_files.find(@request)
end
it "should search for a module whose name is the first term in the remaining file path" do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
@module_files.find(@request)
end
it "should search for a file relative to the module's files directory" do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file")
@module_files.find(@request)
end
it "should return nil if the module does not exist" do
- Puppet::Module.expects(:find).with('my', "myenv").returns nil
+ Puppet::Module.expects(:find).returns nil
@module_files.find(@request).should be_nil
end
it "should return nil if the module exists but the file does not" do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(false)
@module_files.find(@request).should be_nil
end
it "should return an instance of the model if a module is found and the file exists" do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(true)
@model.expects(:new).returns(:myinstance)
@module_files.find(@request).should == :myinstance
@@ -76,7 +74,7 @@ describe Puppet::Indirector::ModuleFiles do
it "should use the node's environment to look up the module if the node name is provided" do
node = stub "node", :environment => "testing"
Puppet::Node.expects(:find).with("mynode").returns(node)
- Puppet::Module.expects(:find).with('my', "testing")
+ Puppet::Module.expects(:find).with('mymod', "testing")
@request.stubs(:node).returns "mynode"
@module_files.find(@request)
@@ -85,7 +83,7 @@ describe Puppet::Indirector::ModuleFiles do
it "should use the default environment setting to look up the module if the node name is not provided" do
env = stub "environment", :name => "testing"
Puppet::Node::Environment.stubs(:new).returns(env)
- Puppet::Module.expects(:find).with('my', "testing")
+ Puppet::Module.expects(:find).with('mymod', "testing")
@module_files.find(@request)
end
end
@@ -93,13 +91,13 @@ describe Puppet::Indirector::ModuleFiles do
describe Puppet::Indirector::ModuleFiles, " when returning instances" do
before do
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(true)
@instance = mock 'instance'
end
it "should create the instance with the key used to find the instance" do
- @model.expects(:new).with { |key, *options| key == @uri }
+ @model.expects(:new).with { |key, *options| key == @request.key }
@module_files.find(@request)
end
@@ -149,19 +147,19 @@ describe Puppet::Indirector::ModuleFiles do
end
it "should use the path directly from the URI if it already includes /modules" do
- @request.expects(:key).returns "puppetmounts://host/modules/my/file"
- @configuration.expects(:authorized?).with { |uri, *args| uri == "/modules/my/file" }
+ @request.expects(:key).returns "modules/my/file"
+ @configuration.expects(:authorized?).with { |uri, *args| uri == "modules/my/file" }
@module_files.authorized?(@request)
end
- it "should add /modules to the file path if it's not included in the URI" do
- @request.expects(:key).returns "puppetmounts://host/my/file"
- @configuration.expects(:authorized?).with { |uri, *args| uri == "/modules/my/file" }
+ it "should add modules/ to the file path if it's not included in the URI" do
+ @request.expects(:key).returns "my/file"
+ @configuration.expects(:authorized?).with { |uri, *args| uri == "modules/my/file" }
@module_files.authorized?(@request)
end
it "should pass the node name to the file server configuration" do
- @request.expects(:key).returns "puppetmounts://host/my/file"
+ @request.expects(:key).returns "my/file"
@configuration.expects(:authorized?).with { |key, options| options[:node] == "mynode" }
@request.stubs(:node).returns "mynode"
@module_files.authorized?(@request)
@@ -186,41 +184,41 @@ describe Puppet::Indirector::ModuleFiles do
describe Puppet::Indirector::ModuleFiles, " when searching for files" do
- it "should strip off the leading '/modules' mount name" do
+ it "should strip off the leading 'modules/' mount name" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with { |key, env| key == 'mymod'}.returns @module
@module_files.search(@request)
end
it "should not strip off leading terms that start with '/modules' but are longer words" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
Puppet::Module.expects(:find).with('modulestart', "myenv").returns nil
- @request.stubs(:key).returns "puppetmounts://host/modulestart/my/local/file"
+ @request.stubs(:key).returns "modulestart/my/local/file"
@module_files.search @request
end
it "should search for a module whose name is the first term in the remaining file path" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
@module_files.search(@request)
end
it "should search for a file relative to the module's files directory" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file")
@module_files.search(@request)
end
it "should return nil if the module does not exist" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns nil
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns nil
@module_files.search(@request).should be_nil
end
it "should return nil if the module exists but the file does not" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(false)
@module_files.search(@request).should be_nil
end
@@ -228,7 +226,7 @@ describe Puppet::Indirector::ModuleFiles do
it "should use the node's environment to look up the module if the node name is provided" do
node = stub "node", :environment => "testing"
Puppet::Node.expects(:find).with("mynode").returns(node)
- Puppet::Module.expects(:find).with('my', "testing")
+ Puppet::Module.expects(:find).with('mymod', "testing")
@request.stubs(:node).returns "mynode"
@module_files.search(@request)
end
@@ -236,13 +234,13 @@ describe Puppet::Indirector::ModuleFiles do
it "should use the default environment setting to look up the module if the node name is not provided and the environment is not set to ''" do
env = stub 'env', :name => "testing"
Puppet::Node::Environment.stubs(:new).returns(env)
- Puppet::Module.expects(:find).with('my', "testing")
+ Puppet::Module.expects(:find).with('mymod', "testing")
@module_files.search(@request)
end
it "should use :path2instances from the terminus_helper to return instances if a module is found and the file exists" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(true)
@module_files.expects(:path2instances).with(@request, "/module/path/files/local/file")
@module_files.search(@request)
@@ -250,7 +248,7 @@ describe Puppet::Indirector::ModuleFiles do
it "should pass the request directly to :path2instances" do
Puppet::Node::Environment.stubs(:new).returns(stub('env', :name => "myenv"))
- Puppet::Module.expects(:find).with('my', "myenv").returns @module
+ Puppet::Module.expects(:find).with('mymod', "myenv").returns @module
FileTest.expects(:exists?).with("/module/path/files/local/file").returns(true)
@module_files.expects(:path2instances).with(@request, "/module/path/files/local/file")
@module_files.search(@request)