From 1e8e7ee55a11b0fe472e6efb3457cf7ce527cbed Mon Sep 17 00:00:00 2001 From: luke Date: Fri, 30 Mar 2007 00:46:38 +0000 Subject: Fixing #567. I overrode the propertychanges method to only return changes if the file exists or if the file has a property that could create the file. git-svn-id: https://reductivelabs.com/svn/puppet/trunk@2371 980ebf18-57e1-0310-9a29-db15c13687c0 --- lib/puppet/type/pfile.rb | 19 +++++++++++++++++++ test/ral/types/file.rb | 9 +++++++++ 2 files changed, 28 insertions(+) diff --git a/lib/puppet/type/pfile.rb b/lib/puppet/type/pfile.rb index e9500e07f..966896a04 100644 --- a/lib/puppet/type/pfile.rb +++ b/lib/puppet/type/pfile.rb @@ -1094,6 +1094,25 @@ module Puppet end private + + # Override the parent method, because we don't want to generate changes + # when the file is missing and there is no 'ensure' state. + def propertychanges + unless self.stat + found = false + ([:ensure] + CREATORS).each do |prop| + if @parameters.include?(prop) + found = true + break + end + end + unless found + return [] + end + end + super + end + # There are some cases where all of the work does not get done on # file creation/modification, so we have to do some extra checking. def property_fix diff --git a/test/ral/types/file.rb b/test/ral/types/file.rb index 9f7861787..e48b246d1 100755 --- a/test/ral/types/file.rb +++ b/test/ral/types/file.rb @@ -1775,6 +1775,15 @@ class TestFile < Test::Unit::TestCase assert(fobj, "did not create file object") assert(fobj.should(:ensure) != :directory, "ensure was passed to child") end + + # #567 + def test_missing_files_are_in_sync + file = tempfile + obj = Puppet::Type.newfile(:path => file, :mode => 0755) + + changes = obj.evaluate + assert(changes.empty?, "Missing file with no ensure resulted in changes") + end end # $Id$ -- cgit