# encoding: utf-8
require 'spec_helper'
module Punchblock
module Component
describe Prompt do
it 'registers itself' do
expect(RayoNode.class_from_registration(:prompt, 'urn:xmpp:rayo:prompt:1')).to eq(described_class)
end
describe "when setting options in initializer" do
let(:output) { Output.new :render_document => {content_type: 'text/uri-list', value: Punchblock::URIList.new('http://example.com/hello.mp3')} }
let(:input) { Input.new :mode => :voice }
subject { described_class.new output, input, :barge_in => true }
describe '#output' do
subject { super().output }
it { should be == output }
end
describe '#input' do
subject { super().input }
it { should be == input }
end
describe '#barge_in' do
subject { super().barge_in }
it { should be_true }
end
context "with barge-in unset" do
subject { described_class.new output, input }
describe '#barge_in' do
subject { super().barge_in }
it { should be_nil }
end
end
context "with options for sub-components" do
subject { described_class.new({renderer: :foo}, {recognizer: :bar}) }
describe '#output' do
subject { super().output }
it { should be == Output.new(renderer: :foo) }
end
describe '#input' do
subject { super().input }
it { should be == Input.new(recognizer: :bar) }
end
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.output).to eq(output)
expect(new_instance.input).to eq(input)
expect(new_instance.barge_in).to be_true
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
end
end
describe "from a stanza" do
let :ssml do
RubySpeech::SSML.draw do
audio :src => 'http://foo.com/bar.mp3'
end
end
let :stanza do
<<-MESSAGE
MESSAGE
end
subject { RayoNode.from_xml parse_stanza(stanza).root, '9f00061', '1' }
it { should be_instance_of described_class }
describe '#barge_in' do
subject { super().barge_in }
it { should be_true }
end
describe '#output' do
subject { super().output }
it { should be == Output.new(:voice => 'allison', :render_document => {:value => ssml}) }
end
describe '#input' do
subject { super().input }
it { should be == Input.new(:mode => :voice, :grammar => {:value => '[5 DIGITS]', :content_type => 'application/grammar+custom'}) }
end
end
describe "actions" do
let(:mock_client) { double 'Client' }
let(:command) { described_class.new }
before do
command.component_id = 'abc123'
command.target_call_id = '123abc'
command.client = mock_client
end
describe '#stop_action' do
subject { command.stop_action }
describe '#to_xml' do
subject { super().to_xml }
it { should be == '' }
end
describe '#component_id' do
subject { super().component_id }
it { should be == 'abc123' }
end
describe '#target_call_id' do
subject { super().target_call_id }
it { should be == '123abc' }
end
end
describe '#stop!' do
describe "when the command is executing" do
before do
command.request!
command.execute!
end
it "should send its command properly" do
expect(mock_client).to receive(:execute_command).with(command.stop_action, :target_call_id => '123abc', :component_id => 'abc123')
command.stop!
end
end
describe "when the command is not executing" do
it "should raise an error" do
expect { command.stop! }.to raise_error(InvalidActionError, "Cannot stop a Prompt that is new")
end
end
end
end
end
end
end # Punchblock