我有一个简单的开拓者行动如下:
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>有什么想法吗?
发布于 2017-12-29 09:25:37
在使用“改革契约”时,需要在使用Contract::Build之前使用Contract::Validate。对于Dry模式,不需要构建步骤。
发布于 2017-12-29 08:55:21
我会深入研究文档http://trailblazer.to/gems/operation/2.0/contract.html
这条消息意味着 object。
对象是User::Delete,方法是.()。
User::Delete.()User::Delete可能是未定义的,因为它没有通过验证?
step Contract::Validate(name: 'params'), before: 'operation.new'只是张贴给你一些投入,我没有一个解决方案。在调用该方法之前,我将检查User::Delete。
User::Delete将是nil,您需要更改验证或确保对象被正确实例化。
https://stackoverflow.com/questions/48019496
复制相似问题