summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Keiser <john@johnkeiser.com>2015-11-16 11:03:40 -0800
committerJohn Keiser <john@johnkeiser.com>2015-11-18 10:53:43 -0800
commit090a2f80e4d453e9ea0f04a574a5f3f7ccdc685f (patch)
treec6822aab42b7745ad4061e621d525d56c665f03f
parent1f8dde87ca01348fe84cf6c3e3c35198e8ac51dd (diff)
downloadchef-090a2f80e4d453e9ea0f04a574a5f3f7ccdc685f.tar.gz
Properly rescue ENOENT on delete and send DataNotFoundError
so that callers can 404 when deleting a nonexistent path
-rw-r--r--lib/chef/chef_fs/file_system/file_system_entry.rb16
1 files changed, 10 insertions, 6 deletions
diff --git a/lib/chef/chef_fs/file_system/file_system_entry.rb b/lib/chef/chef_fs/file_system/file_system_entry.rb
index 478631eac2..5ce8b3320a 100644
--- a/lib/chef/chef_fs/file_system/file_system_entry.rb
+++ b/lib/chef/chef_fs/file_system/file_system_entry.rb
@@ -72,13 +72,17 @@ class Chef
end
def delete(recurse)
- if dir?
- if !recurse
- raise MustDeleteRecursivelyError.new(self, $!)
+ begin
+ if dir?
+ if !recurse
+ raise MustDeleteRecursivelyError.new(self, $!)
+ end
+ FileUtils.rm_r(file_path)
+ else
+ File.delete(file_path)
end
- FileUtils.rm_rf(file_path)
- else
- File.delete(file_path)
+ rescue Errno::ENOENT
+ raise Chef::ChefFS::FileSystem::NotFoundError.new(self, $!)
end
end