diff options
-rw-r--r-- | lib/puppet/file_serving/fileset.rb | 4 | ||||
-rw-r--r-- | lib/puppet/file_serving/terminus_helper.rb | 1 | ||||
-rw-r--r-- | lib/puppet/type/file.rb | 9 | ||||
-rwxr-xr-x | lib/puppet/type/file/checksum.rb | 3 | ||||
-rw-r--r-- | lib/puppet/util/checksums.rb | 5 | ||||
-rwxr-xr-x | spec/unit/file_serving/fileset.rb | 6 | ||||
-rwxr-xr-x | spec/unit/file_serving/terminus_helper.rb | 10 | ||||
-rwxr-xr-x | spec/unit/type/file.rb | 7 | ||||
-rw-r--r-- | spec/unit/type/file/checksum.rb | 28 | ||||
-rwxr-xr-x | spec/unit/util/checksums.rb | 8 |
10 files changed, 76 insertions, 5 deletions
diff --git a/lib/puppet/file_serving/fileset.rb b/lib/puppet/file_serving/fileset.rb index 50e4e1e80..a66d9356f 100644 --- a/lib/puppet/file_serving/fileset.rb +++ b/lib/puppet/file_serving/fileset.rb @@ -9,7 +9,7 @@ require 'puppet/file_serving/metadata' # Operate recursively on a path, returning a set of file paths. class Puppet::FileServing::Fileset attr_reader :path, :ignore, :links - attr_accessor :recurse, :recurselimit + attr_accessor :recurse, :recurselimit, :checksum_type # Produce a hash of files, with merged so that earlier files # with the same postfix win. E.g., /dir1/subfile beats /dir2/subfile. @@ -105,7 +105,7 @@ class Puppet::FileServing::Fileset end def initialize_from_request(request) - [:links, :ignore, :recurse, :recurselimit].each do |param| + [:links, :ignore, :recurse, :recurselimit, :checksum_type].each do |param| if request.options.include?(param) # use 'include?' so the values can be false value = request.options[param] elsif request.options.include?(param.to_s) diff --git a/lib/puppet/file_serving/terminus_helper.rb b/lib/puppet/file_serving/terminus_helper.rb index c88bacc4a..6f5d52b25 100644 --- a/lib/puppet/file_serving/terminus_helper.rb +++ b/lib/puppet/file_serving/terminus_helper.rb @@ -16,6 +16,7 @@ module Puppet::FileServing::TerminusHelper Puppet::FileServing::Fileset.merge(*filesets).collect do |file, base_path| inst = model.new(base_path, :relative_path => file) + inst.checksum_type = request.options[:checksum_type] if request.options[:checksum_type] inst.links = request.options[:links] if request.options[:links] inst.collect inst diff --git a/lib/puppet/type/file.rb b/lib/puppet/type/file.rb index 2f5b5dfaf..fdb5a3578 100644 --- a/lib/puppet/type/file.rb +++ b/lib/puppet/type/file.rb @@ -592,7 +592,14 @@ module Puppet end def perform_recursion(path) - Puppet::FileServing::Metadata.search(path, :links => self[:links], :recurse => (self[:recurse] == :remote ? true : self[:recurse]), :recurselimit => self[:recurselimit], :ignore => self[:ignore]) + params = { + :links => self[:links], + :recurse => (self[:recurse] == :remote ? true : self[:recurse]), + :recurselimit => self[:recurselimit], + :ignore => self[:ignore] + } + params[:checksum_type] = self[:checksum] if self[:checksum] == :none + Puppet::FileServing::Metadata.search(path, params) end # Remove any existing data. This is only used when dealing with diff --git a/lib/puppet/type/file/checksum.rb b/lib/puppet/type/file/checksum.rb index 23a3e5adc..0c45aad32 100755 --- a/lib/puppet/type/file/checksum.rb +++ b/lib/puppet/type/file/checksum.rb @@ -23,7 +23,7 @@ Puppet::Type.type(:file).newproperty(:checksum) do @unmanaged = true - @validtypes = %w{md5 md5lite timestamp mtime time} + @validtypes = %w{md5 md5lite timestamp mtime time none} def self.validtype?(type) @validtypes.include?(type) @@ -52,6 +52,7 @@ Puppet::Type.type(:file).newproperty(:checksum) do cache(type, sum) return type else + return :none if value.nil? or value.to_s == "" or value.to_s == "none" if FileTest.directory?(@resource[:path]) return :time elsif @resource[:source] and value.to_s != "md5" diff --git a/lib/puppet/util/checksums.rb b/lib/puppet/util/checksums.rb index 98bf5de8f..39477ee2b 100644 --- a/lib/puppet/util/checksums.rb +++ b/lib/puppet/util/checksums.rb @@ -68,6 +68,11 @@ module Puppet::Util::Checksums File.stat(filename).send(:ctime) end + # Return a "no checksum" + def none_file(filename) + "" + end + private # Perform an incremental checksum on a file. diff --git a/spec/unit/file_serving/fileset.rb b/spec/unit/file_serving/fileset.rb index 55cc2a911..c03522d0e 100755 --- a/spec/unit/file_serving/fileset.rb +++ b/spec/unit/file_serving/fileset.rb @@ -42,6 +42,12 @@ describe Puppet::FileServing::Fileset, " when initializing" do set.links.should == :manage end + it "should accept a 'checksum_type' option" do + File.expects(:lstat).with("/some/file").returns stub("stat") + set = Puppet::FileServing::Fileset.new("/some/file", :checksum_type => :test) + set.checksum_type.should == :test + end + it "should fail if 'links' is set to anything other than :manage or :follow" do proc { Puppet::FileServing::Fileset.new("/some/file", :links => :whatever) }.should raise_error(ArgumentError) end diff --git a/spec/unit/file_serving/terminus_helper.rb b/spec/unit/file_serving/terminus_helper.rb index d0c06f126..98c64b712 100755 --- a/spec/unit/file_serving/terminus_helper.rb +++ b/spec/unit/file_serving/terminus_helper.rb @@ -76,6 +76,16 @@ describe Puppet::FileServing::TerminusHelper do @helper.path2instances(@request, "/my/file") end + it "should set the request checksum_type if one is provided" do + @one.expects(:checksum_type=).with :test + @two.expects(:checksum_type=).with :test + @model.expects(:new).returns(@one) + @model.expects(:new).returns(@two) + + @request.options[:checksum_type] = :test + @helper.path2instances(@request, "/my/file") + end + it "should collect the instance's attributes" do @one.expects(:collect) @two.expects(:collect) diff --git a/spec/unit/type/file.rb b/spec/unit/type/file.rb index 1b3fe6a60..b5963a666 100755 --- a/spec/unit/type/file.rb +++ b/spec/unit/type/file.rb @@ -320,6 +320,13 @@ describe Puppet::Type.type(:file) do @file.expects(:newchild).with("my/file").returns "fiebar" @file.recurse_local.should == {"my/file" => "fiebar"} end + + it "should set checksum_type to none if this file checksum is none" do + @file[:checksum] = :none + Puppet::FileServing::Metadata.expects(:search).with { |path,params| params[:checksum_type] == :none }.returns [@metadata] + @file.expects(:newchild).with("my/file").returns "fiebar" + @file.recurse_local + end end it "should have a method for performing link recursion" do diff --git a/spec/unit/type/file/checksum.rb b/spec/unit/type/file/checksum.rb new file mode 100644 index 000000000..5d715d15c --- /dev/null +++ b/spec/unit/type/file/checksum.rb @@ -0,0 +1,28 @@ +#!/usr/bin/env ruby + +Dir.chdir(File.dirname(__FILE__)) { (s = lambda { |f| File.exist?(f) ? require(f) : Dir.chdir("..") { s.call(f) } }).call("spec/spec_helper.rb") } + +checksum = Puppet::Type.type(:file).attrclass(:checksum) +describe checksum do + before do + # Wow that's a messy interface to the resource. + @resource = stub 'resource', :[] => nil, :[]= => nil, :property => nil, :newattr => nil, :parameter => nil + end + + it "should be a subclass of Property" do + checksum.superclass.must == Puppet::Property + end + + it "should have default checksum of :md5" do + @checksum = checksum.new(:resource => @resource) + @checksum.checktype.should == :md5 + end + + [:none, nil, ""].each do |ck| + it "should use a none checksum for #{ck.inspect}" do + @checksum = checksum.new(:resource => @resource) + @checksum.should = "none" + @checksum.checktype.should == :none + end + end +end diff --git a/spec/unit/util/checksums.rb b/spec/unit/util/checksums.rb index d31d7a000..615ed902c 100755 --- a/spec/unit/util/checksums.rb +++ b/spec/unit/util/checksums.rb @@ -14,7 +14,7 @@ describe Puppet::Util::Checksums do end content_sums = [:md5, :md5lite, :sha1, :sha1lite] - file_only = [:ctime, :mtime] + file_only = [:ctime, :mtime, :none] content_sums.each do |sumtype| it "should be able to calculate %s sums from strings" % sumtype do @@ -104,4 +104,10 @@ describe Puppet::Util::Checksums do end end end + + describe "when using the none checksum" do + it "should return an empty string" do + @summer.none_file("/my/file").should == "" + end + end end |