summaryrefslogtreecommitdiff
path: root/lib/chef/resource.rb
diff options
context:
space:
mode:
authorJohn Keiser <john@johnkeiser.com>2015-05-07 16:34:30 -0700
committerJohn Keiser <john@johnkeiser.com>2015-05-13 13:43:15 -0700
commit95e77aace5fa40ecbdee6fe9d341184b3cf7b8a3 (patch)
treef1b8c728799ae1806ed96dada17a329ae7f8c9c9 /lib/chef/resource.rb
parent146f0809c1912988751688fff2ef6945c90a4513 (diff)
downloadchef-95e77aace5fa40ecbdee6fe9d341184b3cf7b8a3.tar.gz
Replace lookup_provider_constant and protect against deprecation in tests
Diffstat (limited to 'lib/chef/resource.rb')
-rw-r--r--lib/chef/resource.rb17
1 files changed, 9 insertions, 8 deletions
diff --git a/lib/chef/resource.rb b/lib/chef/resource.rb
index e62e63a44a..2f5c2b7798 100644
--- a/lib/chef/resource.rb
+++ b/lib/chef/resource.rb
@@ -686,8 +686,6 @@ class Chef
#
def provider(arg=nil)
klass = if arg.kind_of?(String) || arg.kind_of?(Symbol)
- # TODO deprecate. This does class munging. If you know
- # the class name, just pass the class.
lookup_provider_constant(arg)
else
arg
@@ -1173,14 +1171,17 @@ class Chef
end
extend DeprecatedLWRPClass
+ # @api private
def lookup_provider_constant(name, action=:nothing)
- resource = Chef::Resource.new(self.name, self.run_context)
- resource.instance_eval { @resource_name = name }
- provider = Chef::ProviderResolver.new(self.node, resource, action).resolve
- if !provider
- raise ArgumentError, "No provider found to match '#{name}'"
+ begin
+ self.class.provider_base.const_get(convert_to_class_name(name.to_s))
+ rescue NameError => e
+ if e.to_s =~ /#{Regexp.escape(self.class.provider_base.to_s)}/
+ raise ArgumentError, "No provider found to match '#{name}'"
+ else
+ raise e
+ end
end
- provider
end
end
end