# 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