# encoding: utf-8 require 'spec_helper' module Punchblock module Command describe Reject do it 'registers itself' do expect(RayoNode.class_from_registration(:reject, 'urn:xmpp:rayo:1')).to eq(described_class) end describe "when setting options in initializer" do subject { described_class.new reason: :busy, headers: { 'X-skill' => 'agent', 'X-customer-id' => '8877' } } describe '#reason' do subject { super().reason } it { should be == :busy } end describe '#headers' do subject { super().headers } it { should == { 'X-skill' => 'agent', 'X-customer-id' => '8877' } } end describe "exporting to Rayo" do it "should export to XML that can be understood by its parser" do new_instance = RayoNode.from_xml subject.to_rayo expect(new_instance).to be_instance_of described_class expect(new_instance.reason).to eq(:busy) expect(new_instance.headers).to eq({ 'X-skill' => 'agent', 'X-customer-id' => '8877' }) end it "should render to a parent node if supplied" do doc = Nokogiri::XML::Document.new parent = Nokogiri::XML::Node.new 'foo', doc doc.root = parent rayo_doc = subject.to_rayo(parent) expect(rayo_doc).to eq(parent) end context "when attributes are not set" do subject { described_class.new } it "should not include them in the XML representation" do expect(subject.to_rayo.children.count).to eq(0) end end end end describe "from a stanza" do let :stanza do <<-MESSAGE
MESSAGE end subject { RayoNode.from_xml parse_stanza(stanza).root, '9f00061', '1' } it { should be_instance_of described_class } describe '#reason' do subject { super().reason } it { should be == :busy } end describe '#headers' do subject { super().headers } it { should == { 'X-skill' => 'agent', 'X-customer-id' => '8877' } } end context "with no headers or reason provided" do let(:stanza) { '' } describe '#reason' do subject { super().reason } it { should be_nil } end describe '#headers' do subject { super().headers } it { should == {} } end end end describe "with the reason" do [nil, :decline, :busy, :error].each do |reason| describe reason do subject { described_class.new :reason => reason } describe '#reason' do subject { super().reason } it { should be == reason } end end end describe "no reason" do subject { described_class.new } describe '#reason' do subject { super().reason } it { should be_nil } end end describe "blahblahblah" do it "should raise an error" do expect { described_class.new(:reason => :blahblahblah) }.to raise_error ArgumentError end end end end end end # Punchblock