spec/punchblock/event/end_spec.rb in punchblock-1.9.4 vs spec/punchblock/event/end_spec.rb in punchblock-2.0.0.beta1
- old
+ new
@@ -4,43 +4,53 @@
module Punchblock
class Event
describe End do
it 'registers itself' do
- RayoNode.class_from_registration(:end, 'urn:xmpp:rayo:1').should be == End
+ RayoNode.class_from_registration(:end, 'urn:xmpp:rayo:1').should be == described_class
end
describe "from a stanza" do
let :stanza do
<<-MESSAGE
<end xmlns="urn:xmpp:rayo:1">
- <timeout />
+ <timeout platform-code="18" />
<!-- Signaling (e.g. SIP) Headers -->
<header name="X-skill" value="agent" />
<header name="X-customer-id" value="8877" />
</end>
MESSAGE
end
- subject { RayoNode.import parse_stanza(stanza).root, '9f00061', '1' }
+ subject { RayoNode.from_xml parse_stanza(stanza).root, '9f00061', '1' }
- it { should be_instance_of End }
+ it { should be_instance_of described_class }
it_should_behave_like 'event'
- it_should_behave_like 'event_headers'
its(:reason) { should be == :timeout }
- its(:xmlns) { should be == 'urn:xmpp:rayo:1' }
+ its(:platform_code) { should be == '18' }
+ its(:headers) { should == { 'X-skill' => 'agent', 'X-customer-id' => '8877' } }
+
+ context "with no headers or reason provided" do
+ let(:stanza) { '<end xmlns="urn:xmpp:rayo:1"/>' }
+
+ its(:reason) { should be_nil}
+ its(:platform_code) { should be_nil }
+ its(:headers) { should == {} }
+ end
end
describe "when setting options in initializer" do
subject do
- End.new :reason => :hangup,
- :headers => { :x_skill => "agent", :x_customer_id => "8877" }
+ described_class.new reason: :hangup,
+ platform_code: 18,
+ headers: { 'X-skill' => 'agent', 'X-customer-id' => '8877' }
end
its(:reason) { should be == :hangup }
- it_should_behave_like 'command_headers'
+ its(:platform_code) { should be == '18' }
+ its(:headers) { should be == { 'X-skill' => 'agent', 'X-customer-id' => '8877' } }
end
end
end
-end # Punchblock
+end