spec/acceptance/realtime/channels_spec.rb in ably-1.1.8 vs spec/acceptance/realtime/channels_spec.rb in ably-1.2.0

- old
+ new

@@ -8,22 +8,61 @@ expect(channel.name).to eql(channel_name) stop_reactor end it 'returns channel object and passes the provided options' do - expect(channel_with_options.options).to eql(options) + expect(channel_options).to be_a(Ably::Models::ChannelOptions) + expect(channel_options.to_h).to eq(options) stop_reactor end end vary_by_protocol do + let(:client_options) do + { key: api_key, environment: environment, protocol: protocol } + end let(:client) do - auto_close Ably::Realtime::Client.new(key: api_key, environment: environment, protocol: protocol) + auto_close Ably::Realtime::Client.new(client_options) end let(:channel_name) { random_str } - let(:options) { { key: 'value' } } + let(:options) do + { params: { key: 'value' } } + end + subject(:channel_options) { channel_with_options.options } + + context 'when channel supposed to trigger reattachment per RTL16a (#RTS3c1)' do + it 'will raise an error' do + channel = client.channels.get(channel_name, options) + + channel.on(:attached) do + expect { client.channels.get(channel_name, { modes: [] }) }.to raise_error ArgumentError, /use Channel#set_options directly/ + stop_reactor + end + + channel.attach + end + + context 'params keys are the same but values are different' do + let(:options) do + { params: { x: '1' } } + end + + it 'will raise an error' do + channel = client.channels.get(channel_name, options) + + channel.on(:attached) do + expect { client.channels.get(channel_name, { params: { x: '2' } }) }.to raise_error ArgumentError, /use Channel#set_options directly/ + + stop_reactor + end + + channel.attach + end + end + end + describe 'using shortcut method #channel on the client object' do let(:channel) { client.channel(channel_name) } let(:channel_with_options) { client.channel(channel_name, options) } it_behaves_like 'a channel' end @@ -33,29 +72,42 @@ let(:channel_with_options) { client.channels.get(channel_name, options) } it_behaves_like 'a channel' end describe 'accessing an existing channel object with different options' do + let(:client_options) { super().merge(logger: custom_logger_object) } + let(:custom_logger_object) { TestLogger.new } let(:new_channel_options) { { encrypted: true } } - let(:original_channel) { client.channels.get(channel_name, options) } + let!(:original_channel) { client.channels.get(channel_name, options) } it 'overrides the existing channel options and returns the channel object' 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::Realtime::Channel) expect(new_channel.options[:encrypted]).to eql(true) stop_reactor end + + it 'shows deprecation warning' do + client.channels.get(channel_name, new_channel_options) + + warning = custom_logger_object.logs.find do |severity, message| + message.match(/Using this method to update channel options is deprecated and may be removed/) + end + + expect(warning).to_not be_nil + stop_reactor + 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::Realtime::Channel) - expect(original_channel.options).to eql(options) + expect(original_channel.options.to_h).to eq(options) stop_reactor end end describe 'using undocumented array accessor [] method on client#channels' do