1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
|
# frozen_string_literal: true
RSpec.describe Slack::Messenger::PayloadMiddleware::Stack do
let(:return_one) do
double(call: 1)
end
let(:return_one_twice) do
double(call: [1, 1])
end
let(:return_two) do
double(call: 2)
end
let(:return_three) do
double(call: 3)
end
before(:each) do
# setup our middleware in the registry
@registry_backup = Slack::Messenger::PayloadMiddleware.registry.dup
Slack::Messenger::PayloadMiddleware.send(:remove_instance_variable, :@registry)
Slack::Messenger::PayloadMiddleware.register return_one, :return_one
Slack::Messenger::PayloadMiddleware.register return_one_twice, :return_one_twice
Slack::Messenger::PayloadMiddleware.register return_two, :return_two
Slack::Messenger::PayloadMiddleware.register return_three, :return_three
end
after(:each) do
# cleanup middleware registry
Slack::Messenger::PayloadMiddleware.send(:remove_instance_variable, :@registry)
Slack::Messenger::PayloadMiddleware.send(:instance_variable_set, :@registry, @registry_backup)
end
describe "::initialize" do
it "sets messenger to given messenger" do
expect(described_class.new(:messenger).messenger).to eq :messenger
end
it "has empty stack" do
expect(described_class.new(:messenger).stack).to match_array []
end
end
describe "#set" do
it "initializes each middleware w/ the messenger instance" do
expect(return_one).to receive(:new).with(:messenger)
expect(return_two).to receive(:new).with(:messenger)
described_class.new(:messenger).set(:return_one, :return_two)
end
it "creates the stack in an array" do
allow(return_one).to receive(:new).and_return(return_one)
allow(return_two).to receive(:new).and_return(return_two)
subject = described_class.new(:messenger)
subject.set(:return_one, :return_two)
expect(subject.stack).to be_a Array
expect(subject.stack.first.call).to eq 1
expect(subject.stack.last.call).to eq 2
end
it "creates a stack from hashes passing them as opts" do
expect(return_one).to receive(:new).with(:messenger, { opts: :for_one })
expect(return_two).to receive(:new).with(:messenger, { opts: :for_two })
subject = described_class.new(:messenger)
subject.set return_one: { opts: :for_one },
return_two: { opts: :for_two }
end
it "raises if a middleware is missing" do
expect do
described_class.new(:messenger).set(:missing)
end.to raise_exception KeyError
end
end
describe "#call" do
it "calls the middleware in order, passing return of each to the next" do
allow(return_one).to receive(:new).and_return(return_one)
allow(return_two).to receive(:new).and_return(return_two)
allow(return_three).to receive(:new).and_return(return_three)
subject = described_class.new(:messenger)
subject.set(:return_one, :return_three, :return_two)
expect(return_one).to receive(:call).with(5)
expect(return_three).to receive(:call).with(1)
expect(return_two).to receive(:call).with(3)
expect(subject.call(5)).to eq [2]
end
it "allows any middleware to return an array but other's don't need special behavior" do
allow(return_one_twice).to receive(:new).and_return(return_one_twice)
allow(return_two).to receive(:new).and_return(return_two)
subject = described_class.new(:messenger)
subject.set(:return_one_twice, :return_two)
expect(subject.call(5)).to eq [2, 2]
end
it "handles multiple middleware splitting payload" do
allow(return_one_twice).to receive(:new).and_return(return_one_twice)
allow(return_two).to receive(:new).and_return(return_two)
subject = described_class.new(:messenger)
subject.set(:return_one_twice, :return_one_twice, :return_two)
expect(subject.call(5)).to eq [2, 2, 2, 2]
end
end
end
|