From 62878cc5c95386097ea432e7761b3885f90de439 Mon Sep 17 00:00:00 2001 From: Nick Sutterer Date: Mon, 13 Nov 2023 17:56:53 +0100 Subject: [PATCH] add step_test. --- test/docs/mechanics_test.rb | 17 ++++++++-- test/docs/step_dsl_test.rb | 68 +++++++++++++++++++++++++++++++++++++ test/test_helper.rb | 1 + 3 files changed, 83 insertions(+), 3 deletions(-) create mode 100644 test/docs/step_dsl_test.rb diff --git a/test/docs/mechanics_test.rb b/test/docs/mechanics_test.rb index d2849f9..a1f97f5 100644 --- a/test/docs/mechanics_test.rb +++ b/test/docs/mechanics_test.rb @@ -91,7 +91,7 @@ def validate(ctx, params:, **) end class WriteToCtx_DocsMechanicsTest < Minitest::Spec - Memo = Class.new do + class Memo def initialize(*); end end it "what" do @@ -124,7 +124,17 @@ def notify(ctx, model:, **) end #:ctx-write-read end - result = Memo::Operation::Create.call(params: {memo: nil}) + #:result-read + result = Memo::Operation::Create.call(params: {memo: {content: "remember that"}}) + + result[:model] #=> # + #:result-read end + + #:result-success + puts result.success? #=> true + #:result-success end + + assert_equal result[:model].class, Memo assert_equal result.success?, true user = Object @@ -198,6 +208,7 @@ class NetworkError < Trailblazer::Activity::Signal #:signal-steps step :validate step :save + left :handle_errors step :notify, Output(NetworkError, :network_error) => End(:network_error) #:signal-steps end @@ -231,7 +242,7 @@ def notify(ctx, model:, params:, **) result = Memo::Operation::Create.call(params: {memo: nil, network_broken: true}) assert_equal result.success?, false - assert_equal result.event.inspect, %(asdf) + assert_equal result.event.inspect, %(#) end end diff --git a/test/docs/step_dsl_test.rb b/test/docs/step_dsl_test.rb new file mode 100644 index 0000000..33d3d6b --- /dev/null +++ b/test/docs/step_dsl_test.rb @@ -0,0 +1,68 @@ +require "test_helper" + +module A + class DocsStepTest < Minitest::Spec + Memo = Module.new + + #:railway + module Memo::Operation + class Create < Trailblazer::Operation + step :validate + step :save + #~step + left :handle_errors + #~left + step :notify + #~meths + # fail :log_error + # step :save + def validate(ctx, params:, **) + ctx[:input] = Form.validate(params) # true/false + end + + # def create(ctx, input:, create:, **) + # create + # end + + # def log_error(ctx, logger:, params:, **) + # logger.error("wrong params: #{params.inspect}") + # end + #~meths end + end + end + #~step end + #~left end + #:railway end + + # it "what" do + # ctx = {params: {text: "Hydrate!"}, create: true} + # signal, (ctx, _flow_options) = D::Create.([ctx, {}]) + # end + end +end + + +module B + class DocsStepTest < Minitest::Spec + Memo = Module.new + + #:fail + module Memo::Operation + class Create < Trailblazer::Operation + step :validate + step :save + fail :handle_errors # just like {#left} + #~meths + step :notify + include T.def_steps(:validate, :save, :handle_errors, :notify) + #~meths end + end + end + #:fail end + + it "what" do + assert_invoke Memo::Operation::Create, seq: "[:validate, :save, :notify]" + assert_invoke Memo::Operation::Create, validate: false, terminus: :failure, seq: "[:validate, :handle_errors]" + end + end +end diff --git a/test/test_helper.rb b/test/test_helper.rb index 16d807f..6eee5f0 100644 --- a/test/test_helper.rb +++ b/test/test_helper.rb @@ -10,6 +10,7 @@ Minitest::Spec.class_eval do Activity = Trailblazer::Activity T = Activity::Testing + include Trailblazer::Activity::Testing::Assertions end # TODO: replace all this with {Activity::Testing.def_steps}