spec/punchblock/command/reject_spec.rb in punchblock-2.5.2 vs spec/punchblock/command/reject_spec.rb in punchblock-2.5.3
- old
+ new
@@ -4,40 +4,47 @@
module Punchblock
module Command
describe Reject do
it 'registers itself' do
- RayoNode.class_from_registration(:reject, 'urn:xmpp:rayo:1').should be == described_class
+ 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' } }
- its(:reason) { should be == :busy }
- its(:headers) { should == { '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
- new_instance.should be_instance_of described_class
- new_instance.reason.should == :busy
- new_instance.headers.should == { 'X-skill' => 'agent', 'X-customer-id' => '8877' }
+ 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)
- rayo_doc.should == 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
- subject.to_rayo.children.count.should == 0
+ expect(subject.to_rayo.children.count).to eq(0)
end
end
end
end
@@ -55,33 +62,53 @@
subject { RayoNode.from_xml parse_stanza(stanza).root, '9f00061', '1' }
it { should be_instance_of described_class }
- its(:reason) { should be == :busy }
- its(:headers) { should == { '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
+
context "with no headers or reason provided" do
let(:stanza) { '<reject xmlns="urn:xmpp:rayo:1"/>' }
- its(:reason) { should be_nil }
- its(:headers) { should == {} }
+ 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 }
- its(:reason) { should be == reason }
+ describe '#reason' do
+ subject { super().reason }
+ it { should be == reason }
+ end
end
end
describe "no reason" do
subject { described_class.new }
- its(:reason) { should be_nil }
+ 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