0

我有一个简单的开拓者操作如下:

class User::Delete < Trailblazer::Operation
  extend Contract::DSL

  contract 'params' do
    property :token

    validates :token, presence: true
  end

  step    Contract::Validate(name: 'params'), before: 'operation.new'
  success :kill_zombie

  def kill_zombie(options, params:, **)
    options['killed'] = true
  end

end

当我在 rails 控制台下运行操作时,输出如下:

irb(main):003:0> User::Delete.()
NoMethodError: undefined method `call' for nil:NilClass
    from (irb):3

如果我删除合同行:

class User::Delete < Trailblazer::Operation
  extend Contract::DSL

  contract 'params' do
    property :token

    validates :token, presence: true
  end

  success :kill_zombie

  def kill_zombie(options, params:, **)
    options['killed'] = true
  end

end

它按预期工作:

irb(main):005:0> User::Delete.()
=> <Result:true <Skill {"killed"=>true} {"params"=>{}} {"pipetree"=>[>operation.new,>kill_zombie], "contract.params.class"=>#<Class:0x0000000003e54e50>}> >
irb(main):006:0>

有什么想法吗?

4

2 回答 2

2

使用改革合同时需要一个Contract::Buildbefore 。Contract::Validate使用Dry模式,不需要构建步骤。

于 2017-12-29T09:25:37.540 回答
1

我会深入研究文档http://trailblazer.to/gems/operation/2.0/contract.html

该消息意味着您正在尝试调用nil对象上的方法。

对象是User::Delete,方法是.()

User::Delete.()

User::Delete可能是未定义的,因为它没有通过您的验证?

step    Contract::Validate(name: 'params'), before: 'operation.new'

只是发帖给你一些意见,我没有解决方案。我会User::Delete在调用该方法之前进行检查。

User::Delete将是nil并且您需要更改验证或确保正确实例化该对象。

于 2017-12-29T08:55:21.873 回答