Sha256: c318d8d188bbb1338db96744e350e63ff2d7e68c063878f8a44db6afbc75fcb3
Contents?: true
Size: 1.81 KB
Versions: 2
Compression:
Stored size: 1.81 KB
Contents
require 'test_helper' module DiscoApp module Flow class ProcessTriggerTest < ActiveSupport::TestCase include ActiveJob::TestHelper def setup @shop = disco_app_shops(:widget_store) @trigger = @shop.flow_triggers.create( title: 'Test trigger', resource_name: 'test_resource_name', resource_url: 'https://example.com/test-resource-url', properties: { 'Customer email' => 'name@example.com' } ) @now = Time.parse('2018-12-29T00:00:00Z') Timecop.freeze(@now) end def teardown @shop = nil @trigger = nil @now = nil Timecop.return end test 'call to process trigger that has already succeeded fails' do @trigger.succeeded! result = ProcessTrigger.call(trigger: @trigger) assert_not result.success? end test 'call to process trigger that has already failed fails' do @trigger.failed! result = ProcessTrigger.call(trigger: @trigger) assert_not result.success? end test 'processing valid pending trigger succeeds and makes the expected api call' do VCR.use_cassette('flow_trigger_valid') do result = ProcessTrigger.call(trigger: @trigger) assert result.success? assert @trigger.succeeded? assert_equal @now, @trigger.processed_at end end test 'processing invalid pending trigger makes the expected api call with errors logged' do VCR.use_cassette('flow_trigger_invalid_title') do result = ProcessTrigger.call(trigger: @trigger) assert_not result.success? assert @trigger.failed? assert_equal @now, @trigger.processed_at assert_equal 1, @trigger.processing_errors.size end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
disco_app-0.16.1.pre.sidekiq.pre.6.pre.release | test/services/disco_app/flow/process_trigger_test.rb |
disco_app-0.16.1 | test/services/disco_app/flow/process_trigger_test.rb |