diff options
author | John Keiser <john@johnkeiser.com> | 2015-11-16 11:03:40 -0800 |
---|---|---|
committer | John Keiser <john@johnkeiser.com> | 2015-11-18 10:53:43 -0800 |
commit | 090a2f80e4d453e9ea0f04a574a5f3f7ccdc685f (patch) | |
tree | c6822aab42b7745ad4061e621d525d56c665f03f | |
parent | 1f8dde87ca01348fe84cf6c3e3c35198e8ac51dd (diff) | |
download | chef-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.rb | 16 |
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 |