Шеф-повар 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
Другие вопросы по тегам