Шеф-повар LWRP "неопределенный метод 'checkname' для nil:NilClass"
Я пытаюсь написать LWRP для поваренной книги шеф-повара, и я столкнулся со странной проблемой, когда это свойство кажется вполне допустимым в одной строке, и nil
следующий.
Из кода провайдера ошибка на source
линия:
def create_check
cookbook_file get_check_filename(@current_resource.checkname) do
source "checks/#{@current_resource.checkname}" # undefined method `checkname' for nil:NilClass
mode '0644'
action :create
end
end
и load_current_resource
Метод только для того, чтобы показать, что он инициализирован:
def load_current_resource
@current_resource = Chef::Resource::OmdCheck.new(@new_resource_name)
@current_resource.checkname(@new_resource.checkname) # right here!
@current_resource.sitename(@new_resource.sitename)
@current_resource.sitecfgroot(sprintf(CMK_CFGROOT_FRM, @new_resource.sitename))
@current_resource.perfometer(@new_resource.perfometer)
@current_resource.pnptemplate(@new_resource.pnptemplate)
@current_resource.exists = check_exists?(@current_resource.checkname)
end
Буду признателен за любую оказанную помощь.
2 ответа
Решение
Итак, я получил ответ на #chef:
<@coderanger> Sammitch: Use current_resource, not @current_resource
< Sammitch> it's passed in as an instance var?
<@coderanger> Sammitch: No, its actually a method on Provider
<@coderanger> as is new_resource
<@coderanger> the issue is that the block on a resource is evaluated against the resource object
<@coderanger> So in there, @foo is looking at an ivar on the new resource object
<@coderanger> _but_ there is some magic
<@coderanger> Chef::Resource has a method_missing to forward unknown method calls to the enclosing provider
<@coderanger> So #current_resource gets forwarded up for you
<@coderanger> Basically never use the ivar form
<@coderanger> Always new_resource and current_resource instead
<@coderanger> and it will mostly JFW
И я довольно зелен, насколько Руби и Шеф идут, так что только около 20% из этого имеют смысл для меня, но я изменил свой код к приведенному ниже, и он работает:
def create_check
cookbook_file get_check_filename(@current_resource.checkname) do
source "checks/#{current_resource.checkname}" # removed the @
mode '0644'
action :create
end
end
Обычно вы должны поместить методы в "#{}" в ()
Пример:
"#{method}" # does not work
"#{(method)}" # works
a = method; "#{a}" # works too