spec/acceptance/rest/channels_spec.rb in ably-1.1.8 vs spec/acceptance/rest/channels_spec.rb in ably-1.2.0
- old
+ new
@@ -3,15 +3,15 @@
describe Ably::Rest::Channels do
shared_examples 'a channel' do
it 'returns a channel object' do
expect(channel).to be_a Ably::Rest::Channel
- expect(channel.name).to eql(channel_name)
+ expect(channel.name).to eq(channel_name)
end
it 'returns channel object and passes the provided options' do
- expect(channel_with_options.options).to eql(options)
+ expect(channel_with_options.options.to_h).to eq(options)
end
end
vary_by_protocol do
let(:client) do
@@ -30,29 +30,46 @@
let(:channel) { client.channels.get(channel_name) }
let(:channel_with_options) { client.channels.get(channel_name, options) }
it_behaves_like 'a channel'
end
+ describe '#set_options (#RTL16)' do
+ let(:channel) { client.channel(channel_name) }
+
+ it "updates channel's options" do
+ expect { channel.options = options }.to change { channel.options.to_h }.from({}).to(options)
+ end
+
+ context 'when providing Ably::Models::ChannelOptions object' do
+ let(:options_object) { Ably::Models::ChannelOptions.new(options) }
+
+ it "updates channel's options" do
+ expect { channel.options = options_object}.to change { channel.options.to_h }.from({}).to(options)
+ end
+ end
+ end
+
describe 'accessing an existing channel object with different options' do
let(:new_channel_options) { { encrypted: true } }
let(:original_channel) { client.channels.get(channel_name, options) }
it 'overrides the existing channel options and returns the channel object (RSN3c)' do
- expect(original_channel.options).to_not include(:encrypted)
+ expect(original_channel.options.to_h).to_not include(:encrypted)
+
new_channel = client.channels.get(channel_name, new_channel_options)
expect(new_channel).to be_a(Ably::Rest::Channel)
expect(new_channel.options[:encrypted]).to eql(true)
end
end
describe 'accessing an existing channel object without specifying any channel options' do
let(:original_channel) { client.channels.get(channel_name, options) }
it 'returns the existing channel without modifying the channel options' do
- expect(original_channel.options).to eql(options)
+ expect(original_channel.options.to_h).to eq(options)
new_channel = client.channels.get(channel_name)
expect(new_channel).to be_a(Ably::Rest::Channel)
- expect(original_channel.options).to eql(options)
+ expect(original_channel.options.to_h).to eq(options)
end
end
describe 'using undocumented array accessor [] method on client#channels' do
let(:channel) { client.channels[channel_name] }