<testsuite name="rspec2" tests="626" skipped="2" failures="0" errors="0" time="13.566539" timestamp="2024-05-31T13:19:52+00:00" hostname="fv-az1114-714">
<properties>
<property name="seed" value="19596"/>
</properties>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block raises an Exception does not call the provided block" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.207205"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block raises an Exception does not call the callback block of the SafeDeferrable" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.202099"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block raises an Exception calls the errback block of the SafeDeferrable" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.103202"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result calls the provided block with result when provided" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.102770"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result returns a SafeDeferrable that catches and logs exceptions in the provided callbacks" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.001921"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result does not block EventMachine" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.102843"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result returns a SafeDeferrable that calls the callback block" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.102176"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result does not call the errback" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.302424"></testcase>
<testcase classname="spec.unit.modules.async_wrapper_spec" name="Ably::Modules::AsyncWrapper#async_wrap blocking block returns result catches exceptions in the provided block and logs them to logger" file="./spec/unit/modules/async_wrapper_spec.rb" time="0.102838"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #succeed calls the callbacks defined with #callback, but not the ones added for #errback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.010868"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #errback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.002202"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #errback adds a callback that is called when #fail is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001275"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #fail calls the callbacks defined with #errback, but not the ones added for success #callback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001266"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #callback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001776"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::ProtocolMessage behaves like a safe Deferrable #callback adds a callback that is called when #succed is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001271"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence msgbus supports messages" file="./spec/unit/realtime/presence_spec.rb" time="0.004749"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence msgbus fail with unacceptable STATE event names" file="./spec/unit/realtime/presence_spec.rb" time="0.002273"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence callbacks are supported for valid STATE events" file="./spec/unit/realtime/presence_spec.rb" time="0.001190"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence callbacks fail with unacceptable STATE event names" file="./spec/unit/realtime/presence_spec.rb" time="0.001160"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #unsubscribe with no action specified unsubscribes that block from all events" file="./spec/unit/realtime/presence_spec.rb" time="0.001806"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #unsubscribe with no block argument unsubscribes all blocks for the action argument" file="./spec/unit/realtime/presence_spec.rb" time="0.001645"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #unsubscribe with a single action argument unsubscribes the provided block with the matching action" file="./spec/unit/realtime/presence_spec.rb" time="0.001716"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #unsubscribe with a non-matching action argument has no effect" file="./spec/unit/realtime/presence_spec.rb" time="0.001684"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #unsubscribe with multiple action arguments unsubscribes each of those matching actions with the provided block" file="./spec/unit/realtime/presence_spec.rb" time="0.001734"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #subscribe without a block raises an invalid ArgumentError" file="./spec/unit/realtime/presence_spec.rb" time="0.001167"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #subscribe with a single action argument subscribes that block to matching actions" file="./spec/unit/realtime/presence_spec.rb" time="0.001653"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #subscribe with no action specified subscribes the provided block to all action" file="./spec/unit/realtime/presence_spec.rb" time="0.001705"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #subscribe with a multiple duplicate action arguments subscribes that block to all of those unique actions once" file="./spec/unit/realtime/presence_spec.rb" time="0.001654"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence subscriptions #subscribe with a multiple action arguments subscribes that block to all of those actions" file="./spec/unit/realtime/presence_spec.rb" time="0.002294"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#presence_connections should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.001395"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#subscribers should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.000882"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#presence_members should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.001094"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#presence_subscribers should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.001010"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#publishers should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.001004"></testcase>
<testcase classname="spec.unit.models.channel_metrics_spec" name="Ably::Models::ChannelMetrics#connections should return integer" file="./spec/unit/models/channel_metrics_spec.rb" time="0.000848"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter #state= sets current state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001226"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter #state returns current state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001066"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter #change_state sets current state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001045"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state? returns true if state matches" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000875"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state? returns false if state does not match" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000931"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state? and convenience predicates for states returns true for #initializing? if state matches" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000982"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state? and convenience predicates for states returns false for #connecting? if state does not match" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000820"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#unsafe_once_or_if failure block catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001056"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#unsafe_once_or_if success block catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001074"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#change_state with arguments passes the arguments through to the executed callback" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001086"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_state_changed catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001475"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_state_changed emits arguments to the block" file="./spec/unit/modules/state_emitter_spec.rb" time="0.002664"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_state_changed calls the block for any state change once" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001121"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_state_changed is not called if the state does not change" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000879"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state STATE coercion allows valid STATE values" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000993"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#state STATE coercion prevents invalid STATE values" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001014"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#unsafe_once_state_changed does not catch exceptions in the provided block" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001081"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if without :else option block calls the block only once" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001046"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if without :else option block calls the block if in the provided state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000867"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if without :else option block calls the block when the state is reached" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001005"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with an array of targets calls the block when one of the states is reached" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001055"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with an array of targets does not remove all blocks on success" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001236"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with an array of targets calls the block if in the provided state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.002986"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with an array of targets calls the block only once" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001361"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block failure block is called once a state other than target_state is reached" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001200"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block failure block is never called again once the block has been called previously" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001223"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block failure block has arguments from the error state" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001024"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block failure block is never called after success block was called" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001207"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block success block is called once target_state is reached" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001249"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block success block is never called again once target_state is reached" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001183"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block success block is never called after failure block was called" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001154"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with :else option block blocks are not called if the state does not change" file="./spec/unit/modules/state_emitter_spec.rb" time="0.000948"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with blocks that raise exceptions success block catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001371"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if with blocks that raise exceptions failure block catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001397"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if state change arguments are passed to success blocks" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001051"></testcase>
<testcase classname="spec.unit.modules.state_emitter_spec" name="Ably::Modules::StateEmitter#once_or_if state change arguments are passed to else blocks" file="./spec/unit/modules/state_emitter_spec.rb" time="0.001213"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with AES-256-CBC message with cipher payload strips the encoding" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001694"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with AES-256-CBC message with cipher payload decodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001717"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC channel_option cipher params have invalid key length raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001295"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC channel_option cipher params have missing key raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001017"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC channel_option cipher params have invalid algorithm raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001504"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with existing cipher encoding before leaves message intact as it is already encrypted" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.000983"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with existing cipher encoding before leaves encoding intact" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001056"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with binary payload encodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.026324"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with binary payload returns ASCII_8BIT encoded binary data" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.027925"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with binary payload adds the encoding without utf-8 prefixed" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001817"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with string payload adds the encoding with utf-8" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001595"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with string payload encodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001875"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with json payload encodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001745"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true message with json payload adds the encoding with utf-8" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001350"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true with encryption set to to false leaves message intact as encryption is not enable" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.000982"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#encode with channel set up for AES-128-CBC with encrypted set to true with encryption set to to false leaves encoding intact" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001092"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with AES-256-CBC message with cipher payload decodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001666"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with AES-256-CBC message with cipher payload strips the encoding" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001598"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC with invalid cipher data raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001564"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with binary payload returns ASCII_8BIT encoded binary data" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001648"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with binary payload decodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001557"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with binary payload strips the encoding" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001625"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with cipher payload before other payloads strips the encoding" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001608"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with cipher payload before other payloads decodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001567"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with cipher payload strips the encoding" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001762"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with cipher payload decodes cipher" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001537"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with another payload leaves the message data intact" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001038"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC valid cipher data message with another payload leaves the encoding intact" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001005"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC 256 bit key with invalid channel_option cipher params raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001406"></testcase>
<testcase classname="spec.unit.models.message_encoders.cipher_spec" name="Ably::Models::MessageEncoders::Cipher#decode with channel set up for AES-128-CBC 256 bit key without any configured encryption raise an exception" file="./spec/unit/models/message_encoders/cipher_spec.rb" time="0.001064"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model is immutable dups options" file="./spec/unit/models/error_info_spec.rb" time="0.000986"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model is immutable prevents changes" file="./spec/unit/models/error_info_spec.rb" time="0.000970"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/error_info_spec.rb" time="0.003236"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/error_info_spec.rb" time="0.000951"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #request_id retrieves attribute :request_id" file="./spec/unit/models/error_info_spec.rb" time="0.000806"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/error_info_spec.rb" time="0.000809"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #message retrieves attribute :message" file="./spec/unit/models/error_info_spec.rb" time="0.000922"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #href retrieves attribute :href" file="./spec/unit/models/error_info_spec.rb" time="0.000904"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #status_code retrieves attribute :status_code" file="./spec/unit/models/error_info_spec.rb" time="0.000927"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #code retrieves attribute :code" file="./spec/unit/models/error_info_spec.rb" time="0.000949"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/error_info_spec.rb" time="0.001049"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model attributes #cause retrieves attribute :cause" file="./spec/unit/models/error_info_spec.rb" time="0.000958"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/error_info_spec.rb" time="0.000940"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model #== is false when class type differs" file="./spec/unit/models/error_info_spec.rb" time="0.000866"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#TI1, #TI4 behaves like a model #== is true when attributes are the same" file="./spec/unit/models/error_info_spec.rb" time="0.001006"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#status #TI1, #TI2 is an alias for #status_code" file="./spec/unit/models/error_info_spec.rb" time="0.000976"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#cause #TI1 should return cause attribute" file="./spec/unit/models/error_info_spec.rb" time="0.000899"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo#request_id #RSC7c should return request ID" file="./spec/unit/models/error_info_spec.rb" time="0.000934"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo log entries container help link #TI5 with a specified error code includes https://help.ably.io/error/[CODE] in the stringified object" file="./spec/unit/models/error_info_spec.rb" time="0.001180"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo log entries container help link #TI5 with an error code and an href attribute includes the specified href in the stringified object" file="./spec/unit/models/error_info_spec.rb" time="0.001369"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo log entries container help link #TI5 without an error code does not include the help URL" file="./spec/unit/models/error_info_spec.rb" time="0.002194"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo log entries container help link #TI5 with an error code and a message with the same error URL includes the specified error URL only once in the stringified object" file="./spec/unit/models/error_info_spec.rb" time="0.001124"></testcase>
<testcase classname="spec.unit.models.error_info_spec" name="Ably::Models::ErrorInfo log entries container help link #TI5 with an error code and a message with a different error URL includes the specified error URL from the message and the error code URL in the stringified object" file="./spec/unit/models/error_info_spec.rb" time="0.001860"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is true when attributes are the same" file="./spec/unit/models/token_details_spec.rb" time="0.001129"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is false when attributes are not the same" file="./spec/unit/models/token_details_spec.rb" time="0.001165"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is false when class type differs" file="./spec/unit/models/token_details_spec.rb" time="0.000972"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? within grace period buffer is false" file="./spec/unit/models/token_details_spec.rb" time="0.001155"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? once grace period buffer has passed is true" file="./spec/unit/models/token_details_spec.rb" time="0.001068"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? when expires is not available (i.e. string tokens) is always false" file="./spec/unit/models/token_details_spec.rb" time="0.001016"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? with :from attribute is true" file="./spec/unit/models/token_details_spec.rb" time="0.001025"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? with :from attribute is false" file="./spec/unit/models/token_details_spec.rb" time="0.001025"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #capability retrieves attribute :capability as parsed JSON" file="./spec/unit/models/token_details_spec.rb" time="0.001109"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued with :issued option as milliseconds in constructor retrieves attribute :issued as Time" file="./spec/unit/models/token_details_spec.rb" time="0.001035"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued when converted to JSON is in milliseconds" file="./spec/unit/models/token_details_spec.rb" time="0.001053"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued with :issued option as a Time in constructor retrieves attribute :issued as Time" file="./spec/unit/models/token_details_spec.rb" time="0.001068"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires with :expires option as milliseconds in constructor retrieves attribute :expires as Time" file="./spec/unit/models/token_details_spec.rb" time="0.004307"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires with :expires option as a Time in constructor retrieves attribute :expires as Time" file="./spec/unit/models/token_details_spec.rb" time="0.001324"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires when converted to JSON is in milliseconds" file="./spec/unit/models/token_details_spec.rb" time="0.001184"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails TokenDetails conversion methods with a TokenDetails object returns the TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.001099"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails TokenDetails conversion methods with a JSON object returns a new TokenDetails object from the JSON" file="./spec/unit/models/token_details_spec.rb" time="0.000948"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model is immutable prevents changes" file="./spec/unit/models/token_details_spec.rb" time="0.001020"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model is immutable dups options" file="./spec/unit/models/token_details_spec.rb" time="0.001143"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/token_details_spec.rb" time="0.001243"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/token_details_spec.rb" time="0.001047"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/token_details_spec.rb" time="0.001059"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #token retrieves attribute :token" file="./spec/unit/models/token_details_spec.rb" time="0.001156"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #key_name retrieves attribute :key_name" file="./spec/unit/models/token_details_spec.rb" time="0.000970"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/token_details_spec.rb" time="0.001153"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/token_details_spec.rb" time="0.001171"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is false when class type differs" file="./spec/unit/models/token_details_spec.rb" time="0.001035"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is true when attributes are the same" file="./spec/unit/models/token_details_spec.rb" time="0.001152"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/token_details_spec.rb" time="0.001136"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with JSON-like object returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.001940"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with JSON string returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.001199"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with Ruby idiomatic Hash object returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.001234"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails to_json with only a token string returns populated attributes" file="./spec/unit/models/token_details_spec.rb" time="0.000967"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails to_json with all attributes and values returns all attributes" file="./spec/unit/models/token_details_spec.rb" time="0.001162"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as UTF_8 string remains as UTF-8" file="./spec/unit/auth_spec.rb" time="0.001059"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as UTF_8 string is permitted" file="./spec/unit/auth_spec.rb" time="0.001000"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/auth_spec.rb" time="0.000906"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/auth_spec.rb" time="0.001009"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/auth_spec.rb" time="0.001779"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/auth_spec.rb" time="0.000879"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option with nil value is permitted" file="./spec/unit/auth_spec.rb" time="0.000949"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as Integer raises an argument error" file="./spec/unit/auth_spec.rb" time="0.001022"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth defaults should have no default capability" file="./spec/unit/auth_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth defaults should have no default TTL" file="./spec/unit/auth_spec.rb" time="0.000735"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Java naming converts the attribute to ruby symbol naming convention" file="./spec/unit/models/message_spec.rb" time="0.001158"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#protocol_message_index (#RTL21) should return correct protocol_message_index" file="./spec/unit/models/message_spec.rb" time="0.001320"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#timestamp retrieves attribute :timestamp as Time object from ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001231"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should not modify the data payload" file="./spec/unit/models/message_spec.rb" time="0.001307"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should generate a message ID from the index, serial and connection id" file="./spec/unit/models/message_spec.rb" time="0.001366"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should not allow changes to the payload" file="./spec/unit/models/message_spec.rb" time="0.001296"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage with identical message objects recognises the index based on the object ID as opposed to message payload" file="./spec/unit/models/message_spec.rb" time="0.001502"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage with identical message objects provide a unique ID:index" file="./spec/unit/models/message_spec.rb" time="0.001496"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.001131"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000966"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.001129"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001109"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001095"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001127"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001036"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001092"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001125"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001119"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001128"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001004"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000969"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.001045"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001134"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.001070"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000973"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001100"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.001117"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.001105"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001080"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.004758"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001369"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.001269"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded_array (#TM3) with no encoding returns an Array of message objects" file="./spec/unit/models/message_spec.rb" time="0.001884"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields with protocol message #id prefers embedded ID" file="./spec/unit/models/message_spec.rb" time="0.001125"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields with protocol message #timestamp prefers embedded timestamp" file="./spec/unit/models/message_spec.rb" time="0.001268"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields without protocol message #id uses embedded ID" file="./spec/unit/models/message_spec.rb" time="0.001113"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields without protocol message #timestamp uses embedded timestamp" file="./spec/unit/models/message_spec.rb" time="0.001086"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when delta should return vcdiff format" file="./spec/unit/models/message_spec.rb" time="0.001137"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when delta should return 1234-1234-5678-9009 message id" file="./spec/unit/models/message_spec.rb" time="0.001089"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when no delta should return nil" file="./spec/unit/models/message_spec.rb" time="0.001070"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#id (#RSL1j) #as_json exposes the #id attribute" file="./spec/unit/models/message_spec.rb" time="0.001096"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#id (#RSL1j) exposes the #id attribute" file="./spec/unit/models/message_spec.rb" time="0.001057"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with an encoding returns a message object" file="./spec/unit/models/message_spec.rb" time="0.001485"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with a custom encoding returns a message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/message_spec.rb" time="0.001534"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with a Cipher encoding returns a message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/message_spec.rb" time="0.002460"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with no encoding returns a message object" file="./spec/unit/models/message_spec.rb" time="0.001535"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with no encoding with a block does not call the block" file="./spec/unit/models/message_spec.rb" time="0.001349"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with invalid Cipher encoding without a block raises an exception" file="./spec/unit/models/message_spec.rb" time="0.001784"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with invalid Cipher encoding with a block calls the block with the exception" file="./spec/unit/models/message_spec.rb" time="0.001655"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with valid data converts the attribute back to Java mixedCase notation using string keys" file="./spec/unit/models/message_spec.rb" time="0.001138"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with binary data encodes as Base64 so that it can be converted to UTF-8 automatically by JSON#dump" file="./spec/unit/models/message_spec.rb" time="0.001192"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with binary data adds Base64 encoding" file="./spec/unit/models/message_spec.rb" time="0.001186"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size String (#TO3l8a) should return 33 bytes" file="./spec/unit/models/message_spec.rb" time="0.001108"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size nil (#TO3l8e) should return 19 bytes" file="./spec/unit/models/message_spec.rb" time="0.000991"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size Array (#TO3l8b) should return 24 bytes" file="./spec/unit/models/message_spec.rb" time="0.000993"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size extras (#TO3l8d) should return 57 bytes" file="./spec/unit/models/message_spec.rb" time="0.001074"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size Object (#TO3l8b) should return 38 bytes" file="./spec/unit/models/message_spec.rb" time="0.001130"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when missing is nil" file="./spec/unit/models/message_spec.rb" time="0.001105"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a Json Array contains a Json Array object" file="./spec/unit/models/message_spec.rb" time="0.001023"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a Hash contains a Hash Json object" file="./spec/unit/models/message_spec.rb" time="0.001062"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a string raises an exception" file="./spec/unit/models/message_spec.rb" time="0.001146"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/message_spec.rb" time="0.001190"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/message_spec.rb" time="0.001191"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #encoding retrieves attribute :encoding" file="./spec/unit/models/message_spec.rb" time="0.001130"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/message_spec.rb" time="0.001092"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/message_spec.rb" time="0.001038"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #data retrieves attribute :data" file="./spec/unit/models/message_spec.rb" time="0.001136"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #name retrieves attribute :name" file="./spec/unit/models/message_spec.rb" time="0.001123"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #id retrieves attribute :id" file="./spec/unit/models/message_spec.rb" time="0.001112"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model is immutable prevents changes" file="./spec/unit/models/message_spec.rb" time="0.001212"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model is immutable dups options" file="./spec/unit/models/message_spec.rb" time="0.001130"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is false when class type differs" file="./spec/unit/models/message_spec.rb" time="0.000981"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is true when attributes are the same" file="./spec/unit/models/message_spec.rb" time="0.001277"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/message_spec.rb" time="0.001208"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/message_spec.rb" time="0.001371"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.001056"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.001033"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001058"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001024"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001069"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.001093"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001087"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.000993"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.003799"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001291"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.001170"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.001094"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001157"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.001008"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.001167"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.001127"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has no connectionId attribute and no protocol message uses the model value" file="./spec/unit/models/message_spec.rb" time="0.001149"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has no connectionId attribute with a protocol message with a connectionId uses the model value" file="./spec/unit/models/message_spec.rb" time="0.001171"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has a connectionId attribute but no protocol message uses the model value" file="./spec/unit/models/message_spec.rb" time="0.001069"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has a connectionId attribute with a protocol message with a different connectionId uses the model value" file="./spec/unit/models/message_spec.rb" time="0.001154"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel exposes the channel as attribute #channel" file="./spec/unit/rest/push_channel_spec.rb" time="0.001083"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel is available in the #push attribute of the channel" file="./spec/unit/rest/push_channel_spec.rb" time="0.001082"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel is constructed with a channel" file="./spec/unit/rest/push_channel_spec.rb" time="0.000964"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel raises an exception if constructed with an invalid type" file="./spec/unit/rest/push_channel_spec.rb" time="0.001084"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel methods not implemented as push notifications #subscribe_client_id raises an unsupported exception" file="./spec/unit/rest/push_channel_spec.rb" time="0.001120"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel methods not implemented as push notifications #unsubscribe_client_id raises an unsupported exception" file="./spec/unit/rest/push_channel_spec.rb" time="0.001120"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel methods not implemented as push notifications #get_subscriptions raises an unsupported exception" file="./spec/unit/rest/push_channel_spec.rb" time="0.000968"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel methods not implemented as push notifications #subscribe_device raises an unsupported exception" file="./spec/unit/rest/push_channel_spec.rb" time="0.001069"></testcase>
<testcase classname="spec.unit.rest.push_channel_spec" name="Ably::Rest::Channel::PushChannel methods not implemented as push notifications #unsubscribe_device raises an unsupported exception" file="./spec/unit/rest/push_channel_spec.rb" time="0.001054"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails AuthDetails conversion methods with a AuthDetails object returns the AuthDetails object" file="./spec/unit/models/auth_details_spec.rb" time="0.000979"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails AuthDetails conversion methods with a JSON object returns a new AuthDetails object from the JSON" file="./spec/unit/models/auth_details_spec.rb" time="0.000863"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/auth_details_spec.rb" time="0.000577"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model attributes #access_token retrieves attribute :access_token" file="./spec/unit/models/auth_details_spec.rb" time="0.000632"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/auth_details_spec.rb" time="0.000581"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/auth_details_spec.rb" time="0.000480"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/auth_details_spec.rb" time="0.000539"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model #== is true when attributes are the same" file="./spec/unit/models/auth_details_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/auth_details_spec.rb" time="0.000546"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model #== is false when class type differs" file="./spec/unit/models/auth_details_spec.rb" time="0.000479"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model is immutable dups options" file="./spec/unit/models/auth_details_spec.rb" time="0.000561"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails behaves like a model is immutable prevents changes" file="./spec/unit/models/auth_details_spec.rb" time="0.000614"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails == is false when attributes are not the same" file="./spec/unit/models/auth_details_spec.rb" time="0.000508"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails == is false when class type differs" file="./spec/unit/models/auth_details_spec.rb" time="0.000508"></testcase>
<testcase classname="spec.unit.models.auth_details_spec" name="Ably::Models::AuthDetails == is true when attributes are the same" file="./spec/unit/models/auth_details_spec.rb" time="0.000559"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels [] creates a channel" file="./spec/unit/rest/channels_spec.rb" time="0.001025"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#fetch retrieves a channel if it exists" file="./spec/unit/rest/channels_spec.rb" time="0.000639"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#fetch calls the block if channel is missing" file="./spec/unit/rest/channels_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when channel doesn&apos;t exist hash creates a channel (RSN3a)" file="./spec/unit/rest/channels_spec.rb" time="0.000822"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when channel doesn&apos;t exist hash is expected to be a kind of Hash" file="./spec/unit/rest/channels_spec.rb" time="0.000660"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when channel doesn&apos;t exist ChannelOptions object is expected to be a kind of Ably::Models::ChannelOptions" file="./spec/unit/rest/channels_spec.rb" time="0.000599"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when channel doesn&apos;t exist ChannelOptions object creates a channel (RSN3a)" file="./spec/unit/rest/channels_spec.rb" time="0.000713"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists with new channel_options modes hash will update channel with provided options modes (RSN3c)" file="./spec/unit/rest/channels_spec.rb" time="0.000829"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists with new channel_options modes hash is expected to be a kind of Hash" file="./spec/unit/rest/channels_spec.rb" time="0.000624"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists with new channel_options modes ChannelOptions object is expected to be a kind of Ably::Models::ChannelOptions" file="./spec/unit/rest/channels_spec.rb" time="0.000603"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists with new channel_options modes ChannelOptions object will update channel with provided options modes (RSN3c)" file="./spec/unit/rest/channels_spec.rb" time="0.000774"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists hash is expected to be a kind of Hash" file="./spec/unit/rest/channels_spec.rb" time="0.000492"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists hash will reuse a channel object if it exists (RSN3a)" file="./spec/unit/rest/channels_spec.rb" time="0.000731"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists ChannelOptions object is expected to be a kind of Ably::Models::ChannelOptions" file="./spec/unit/rest/channels_spec.rb" time="0.000622"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels#get when an existing channel exists ChannelOptions object will reuse a channel object if it exists (RSN3a)" file="./spec/unit/rest/channels_spec.rb" time="0.000730"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels destroying channels #release releases the channel resoures" file="./spec/unit/rest/channels_spec.rb" time="0.000711"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels is Enumerable provides #length" file="./spec/unit/rest/channels_spec.rb" time="0.000964"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels is Enumerable allows enumeration" file="./spec/unit/rest/channels_spec.rb" time="0.000897"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels is Enumerable #each returns an enumerator" file="./spec/unit/rest/channels_spec.rb" time="0.000859"></testcase>
<testcase classname="spec.unit.rest.channels_spec" name="Ably::Rest::Channels is Enumerable #each yields each channel" file="./spec/unit/rest/channels_spec.rb" time="0.000819"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#error_reason and #error_reason= rejects non Hash, ErrorInfo or nil values" file="./spec/unit/models/device_push_details_spec.rb" time="0.000523"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#error_reason and #error_reason= setter accepts nil values" file="./spec/unit/models/device_push_details_spec.rb" time="0.000681"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#error_reason and #error_reason= setter accepts a Hash value and getter returns a ErrorInfo object" file="./spec/unit/models/device_push_details_spec.rb" time="0.000703"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#error_reason and #error_reason= setter accepts a ErrorInfo object and getter returns a ErrorInfo object" file="./spec/unit/models/device_push_details_spec.rb" time="0.000797"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#state and #state= setter accepts nil" file="./spec/unit/models/device_push_details_spec.rb" time="0.000532"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#state and #state= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_push_details_spec.rb" time="0.000653"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#state and #state= rejects non string or nil values" file="./spec/unit/models/device_push_details_spec.rb" time="0.000601"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails camelCase constructor attributes are rubyfied and exposed as underscore case" file="./spec/unit/models/device_push_details_spec.rb" time="0.002594"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails camelCase constructor attributes are generated when the object is serialised to JSON" file="./spec/unit/models/device_push_details_spec.rb" time="0.000799"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#recipient and #recipient= setter accepts a Hash value and getter returns the new value" file="./spec/unit/models/device_push_details_spec.rb" time="0.000783"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#recipient and #recipient= rejects non Hash or nil values" file="./spec/unit/models/device_push_details_spec.rb" time="0.000697"></testcase>
<testcase classname="spec.unit.models.device_push_details_spec" name="Ably::Models::DevicePushDetails#recipient and #recipient= setter accepts nil but always returns an empty hash" file="./spec/unit/models/device_push_details_spec.rb" time="0.000617"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #errback adds a callback that is called when #fail is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000760"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #errback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001331"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #succeed calls the callbacks defined with #callback, but not the ones added for #errback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000861"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #callback adds a callback that is called when #succed is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000823"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #callback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001173"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::PresenceMessage behaves like a safe Deferrable #fail calls the callbacks defined with #errback, but not the ones added for success #callback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000864"></testcase>
<testcase classname="spec.unit.models.delta_extras_spec" name="Ably::Models::DeltaExtras should have `format` attribute" file="./spec/unit/models/delta_extras_spec.rb" time="0.000562"></testcase>
<testcase classname="spec.unit.models.delta_extras_spec" name="Ably::Models::DeltaExtras should have `from` attribute" file="./spec/unit/models/delta_extras_spec.rb" time="0.000532"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels destroying channels #release detaches and then releases the channel resources" file="./spec/unit/realtime/channels_spec.rb" time="0.001543"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels is Enumerable provides #length" file="./spec/unit/realtime/channels_spec.rb" time="0.001059"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels is Enumerable allows enumeration" file="./spec/unit/realtime/channels_spec.rb" time="0.001077"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels is Enumerable #each yields each channel" file="./spec/unit/realtime/channels_spec.rb" time="0.001072"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels is Enumerable #each returns an enumerator" file="./spec/unit/realtime/channels_spec.rb" time="0.001038"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels#fetch retrieves a channel if it exists" file="./spec/unit/realtime/channels_spec.rb" time="0.000930"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels#fetch calls the block if channel is missing" file="./spec/unit/realtime/channels_spec.rb" time="0.000815"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels [] creates a channel" file="./spec/unit/realtime/channels_spec.rb" time="0.000945"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when channel doesn&apos;t exist ChannelOptions object creates a channel (RTS3a)" file="./spec/unit/realtime/channels_spec.rb" time="0.000988"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when channel doesn&apos;t exist ChannelOptions object is expected to be a kind of Ably::Models::ChannelOptions" file="./spec/unit/realtime/channels_spec.rb" time="0.000718"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when channel doesn&apos;t exist hash creates a channel (RTS3a)" file="./spec/unit/realtime/channels_spec.rb" time="0.000904"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when channel doesn&apos;t exist hash is expected to be a kind of Hash" file="./spec/unit/realtime/channels_spec.rb" time="0.000566"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists will leave the options intact on the channel if not provided" file="./spec/unit/realtime/channels_spec.rb" time="0.000975"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists will update the options on the channel if provided (RSN3c)" file="./spec/unit/realtime/channels_spec.rb" time="0.001157"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists hash is expected to be a kind of Hash" file="./spec/unit/realtime/channels_spec.rb" time="0.000620"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists hash will reuse a channel object if it exists (RTS3a)" file="./spec/unit/realtime/channels_spec.rb" time="0.001001"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists ChannelOptions object will reuse a channel object if it exists (RTS3a)" file="./spec/unit/realtime/channels_spec.rb" time="0.000934"></testcase>
<testcase classname="spec.unit.realtime.channels_spec" name="Ably::Realtime::Channels creating channels #get when an existing channel exists ChannelOptions object is expected to be a kind of Ably::Models::ChannelOptions" file="./spec/unit/realtime/channels_spec.rb" time="0.000547"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with utf8 payload sets the encoding" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000579"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with utf8 payload strips the encoding" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000610"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with utf8 payload before other payloads strips the encoding" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000553"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with utf8 payload before other payloads sets the encoding" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000538"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with another payload leaves the message data intact" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000512"></testcase>
<testcase classname="spec.unit.models.message_encoders.utf8_spec" name="Ably::Models::MessageEncoders::Utf8#decode message with another payload leaves the encoding intact" file="./spec/unit/models/message_encoders/utf8_spec.rb" time="0.000594"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #errback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001151"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #errback adds a callback that is called when #fail is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000856"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #succeed calls the callbacks defined with #callback, but not the ones added for #errback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000818"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #fail calls the callbacks defined with #errback, but not the ones added for success #callback" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000850"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #callback catches exceptions in the callback and logs the error to the logger" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.001108"></testcase>
<testcase classname="spec.unit.realtime.safe_deferrable_spec" name="Ably::Models::Message behaves like a safe Deferrable #callback adds a callback that is called when #succed is called" file="./spec/unit/realtime/safe_deferrable_spec.rb" time="0.000830"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client push #push returns a Push object" file="./spec/unit/realtime/client_spec.rb" time="0.000905"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client push #device is not supported and raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000792"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments key and key_name raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000563"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments key and key_secret raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments key: &quot;invalid:asdad&quot; raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000629"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments nil raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000613"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments empty hash raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000555"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with invalid arguments key: &quot;invalid&quot; raises an exception" file="./spec/unit/realtime/client_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with token sets the token" file="./spec/unit/realtime/client_spec.rb" time="0.001182"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with token_details sets the token" file="./spec/unit/realtime/client_spec.rb" time="0.001100"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments key only connects to the Ably service" file="./spec/unit/realtime/client_spec.rb" time="0.000637"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments key only uses basic auth" file="./spec/unit/realtime/client_spec.rb" time="0.003114"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments logger with custom logger and log_level uses the custom logger" file="./spec/unit/realtime/client_spec.rb" time="0.000937"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments logger with custom logger and log_level sets the custom log level" file="./spec/unit/realtime/client_spec.rb" time="0.000892"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments logger default specifies Logger::WARN log level" file="./spec/unit/realtime/client_spec.rb" time="0.000865"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments logger default uses Ruby Logger" file="./spec/unit/realtime/client_spec.rb" time="0.000878"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments logger with log_level :none silences all logging with a NilLogger" file="./spec/unit/realtime/client_spec.rb" time="0.000821"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set with fallback_hosts_use_default uses the production default fallback hosts (#RTN17b)" file="./spec/unit/realtime/client_spec.rb" time="0.000713"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set with fallback_hosts_use_default sets the environment attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000635"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set with custom fallback hosts configured sets the environment attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set with custom fallback hosts configured uses the custom provided fallback hosts (#RSC15a)" file="./spec/unit/realtime/client_spec.rb" time="0.000715"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set without custom fallback hosts configured uses the default fallback hosts (#TBC, see https://github.com/ably/wiki/issues/361)" file="./spec/unit/realtime/client_spec.rb" time="0.000706"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments environment when set without custom fallback hosts configured sets the environment attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000708"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments tls defaults to TLS" file="./spec/unit/realtime/client_spec.rb" time="0.000811"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments tls set to false uses plain text" file="./spec/unit/realtime/client_spec.rb" time="0.000739"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments tls set to false uses HTTP" file="./spec/unit/realtime/client_spec.rb" time="0.000702"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint defaults to production" file="./spec/unit/realtime/client_spec.rb" time="0.000705"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint with port option and non-TLS connections uses the custom port for non-TLS requests" file="./spec/unit/realtime/client_spec.rb" time="0.000773"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint with rest_host option uses an alternate endpoint for REST clients" file="./spec/unit/realtime/client_spec.rb" time="0.000840"><skipped/></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint with environment option uses an alternate endpoint" file="./spec/unit/realtime/client_spec.rb" time="0.000896"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint with tls_port option and a TLS connection uses the custom port for TLS requests" file="./spec/unit/realtime/client_spec.rb" time="0.000884"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments endpoint with realtime_host option uses an alternate endpoint for Realtime clients" file="./spec/unit/realtime/client_spec.rb" time="0.000901"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments realtime_host when set without custom fallback hosts configured sets the realtime_host option" file="./spec/unit/realtime/client_spec.rb" time="0.000755"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments realtime_host when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="0.000779"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key" file="./spec/unit/realtime/client_spec.rb" time="0.000788"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with a string key instead of options hash uses basic auth" file="./spec/unit/realtime/client_spec.rb" time="0.000790"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key_name" file="./spec/unit/realtime/client_spec.rb" time="0.000779"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key_secret" file="./spec/unit/realtime/client_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments custom TLS port when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="0.000632"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set with custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="4.187239"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set with custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000882"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="0.000724"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set without custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured sets the environment attribute" file="./spec/unit/realtime/client_spec.rb" time="0.000701"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="0.000733"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments custom port when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/realtime/client_spec.rb" time="0.000698"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with a string token key instead of options hash sets the token" file="./spec/unit/realtime/client_spec.rb" time="0.001412"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments with token_params configures default_token_params" file="./spec/unit/realtime/client_spec.rb" time="0.001104"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer with valid arguments key_name and key_secret constructs a key" file="./spec/unit/realtime/client_spec.rb" time="0.000641"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer delegators delegates :auth_options to .auth" file="./spec/unit/realtime/client_spec.rb" time="0.000986"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client behaves like a client initializer delegators delegates :client_id to .auth" file="./spec/unit/realtime/client_spec.rb" time="0.000978"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client delegation to the REST Client passes on the options to the initializer" file="./spec/unit/realtime/client_spec.rb" time="0.001250"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client delegation to the REST Client for attribute #log_level" file="./spec/unit/realtime/client_spec.rb" time="0.000753"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client delegation to the REST Client for attribute #use_tls?" file="./spec/unit/realtime/client_spec.rb" time="0.000821"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client delegation to the REST Client for attribute #environment" file="./spec/unit/realtime/client_spec.rb" time="0.000791"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client delegation to the REST Client for attribute #custom_host" file="./spec/unit/realtime/client_spec.rb" time="0.000812"></testcase>
<testcase classname="spec.unit.realtime.client_spec" name="Ably::Realtime::Client when :transport_params option is passed converts options to strings" file="./spec/unit/realtime/client_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum two similar Enums with shared symbol values fails to match when using an incompatible method with a converter method" file="./spec/unit/modules/enum_spec.rb" time="0.000922"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum two similar Enums with shared symbol values does not consider different symbol values the same" file="./spec/unit/modules/enum_spec.rb" time="0.000597"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum two similar Enums with shared symbol values matches symbols when used with a converter method" file="./spec/unit/modules/enum_spec.rb" time="0.000597"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum two similar Enums with shared symbol values provides compatability for the equivalent symbol values" file="./spec/unit/modules/enum_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #to_sym returns a snake_case symbol" file="./spec/unit/modules/enum_spec.rb" time="0.000507"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #to_json returns a symbol string key value" file="./spec/unit/modules/enum_spec.rb" time="0.000572"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #to_i returns the Enum index" file="./spec/unit/modules/enum_spec.rb" time="0.000542"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #to_s returns ENUMNAME.CamelCase name" file="./spec/unit/modules/enum_spec.rb" time="0.000490"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #== compares with itself" file="./spec/unit/modules/enum_spec.rb" time="0.005011"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #== compares with a integer index" file="./spec/unit/modules/enum_spec.rb" time="0.000750"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #== compares with other Objects" file="./spec/unit/modules/enum_spec.rb" time="0.000565"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #== compares with a string" file="./spec/unit/modules/enum_spec.rb" time="0.000685"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum Enum instance #== compares with a symbol" file="./spec/unit/modules/enum_spec.rb" time="0.000639"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to instance converts symbols" file="./spec/unit/modules/enum_spec.rb" time="0.000680"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to instance converts integer index" file="./spec/unit/modules/enum_spec.rb" time="0.000571"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to instance converts strings" file="./spec/unit/modules/enum_spec.rb" time="0.000706"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Hash class provides a MixedCase const for each provided value" file="./spec/unit/modules/enum_spec.rb" time="0.000649"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Hash class #get by integer index for 1 returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000548"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Hash class #get by invalid integer index raises an exception" file="./spec/unit/modules/enum_spec.rb" time="0.000661"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Hash class #get by integer index for 5 returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000659"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Hash class #get by string value returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000660"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to class converts integer index" file="./spec/unit/modules/enum_spec.rb" time="0.000506"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to class converts strings" file="./spec/unit/modules/enum_spec.rb" time="0.000576"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum convertor method added to class converts symbols" file="./spec/unit/modules/enum_spec.rb" time="0.000540"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from another Enum provides a MixedCase const for each provided value" file="./spec/unit/modules/enum_spec.rb" time="0.000495"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum class method #to_sym_arr returns all keys as symbols" file="./spec/unit/modules/enum_spec.rb" time="0.000527"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class returns the provided Enum name" file="./spec/unit/modules/enum_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #to_s returns the Enum name" file="./spec/unit/modules/enum_spec.rb" time="0.000548"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class provides a MixedCase const for each provided value" file="./spec/unit/modules/enum_spec.rb" time="0.000474"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class behaves like Enumerable" file="./spec/unit/modules/enum_spec.rb" time="0.000554"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class prevents modification" file="./spec/unit/modules/enum_spec.rb" time="0.000599"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class freezes the Enum" file="./spec/unit/modules/enum_spec.rb" time="0.000511"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #[] is an alias for get" file="./spec/unit/modules/enum_spec.rb" time="0.000806"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #size has alias #length" file="./spec/unit/modules/enum_spec.rb" time="0.000570"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #size returns the number of enum items" file="./spec/unit/modules/enum_spec.rb" time="0.000545"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #each yields each channel" file="./spec/unit/modules/enum_spec.rb" time="0.000475"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #each returns an enumerator" file="./spec/unit/modules/enum_spec.rb" time="0.000555"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #get by invalid type raises an error" file="./spec/unit/modules/enum_spec.rb" time="0.000602"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #get by string value returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000499"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #get by symbol returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000478"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #get by enum returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000641"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum defined Enum from Array class #get by integer index returns an enum" file="./spec/unit/modules/enum_spec.rb" time="0.000611"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum using include? to compare Enum values allows different type comparison 1" file="./spec/unit/modules/enum_spec.rb" time="0.000465"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum using include? to compare Enum values allows different type comparison 2" file="./spec/unit/modules/enum_spec.rb" time="0.000546"><skipped/></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum using include? to compare Enum values allows same type comparison" file="./spec/unit/modules/enum_spec.rb" time="0.000563"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum using include? to compare Enum values #match_any? replacement for include? returns false if there are no matches in any value in the arguments provided" file="./spec/unit/modules/enum_spec.rb" time="0.000559"></testcase>
<testcase classname="spec.unit.modules.enum_spec" name="Ably::Modules::Enum using include? to compare Enum values #match_any? replacement for include? matches any value in the arguments provided" file="./spec/unit/modules/enum_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage initializer action coercion raises an argument error if nil" file="./spec/unit/models/protocol_message_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage initializer action coercion converts actions to Integers if a symbol" file="./spec/unit/models/protocol_message_spec.rb" time="0.000612"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage initializer action coercion converts actions to Integers if a ACTION" file="./spec/unit/models/protocol_message_spec.rb" time="0.000549"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage initializer action coercion ignores actions that are Integers" file="./spec/unit/models/protocol_message_spec.rb" time="0.000584"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage#to_msgpack returns a unpackable msgpack object" file="./spec/unit/models/protocol_message_spec.rb" time="0.001151"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/protocol_message_spec.rb" time="0.000721"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model is immutable dups options" file="./spec/unit/models/protocol_message_spec.rb" time="0.000521"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model is immutable prevents changes" file="./spec/unit/models/protocol_message_spec.rb" time="0.000635"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #id retrieves attribute :id" file="./spec/unit/models/protocol_message_spec.rb" time="0.000589"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #connection_id retrieves attribute :connection_id" file="./spec/unit/models/protocol_message_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/protocol_message_spec.rb" time="0.000528"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/protocol_message_spec.rb" time="0.000557"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #channel_serial retrieves attribute :channel_serial" file="./spec/unit/models/protocol_message_spec.rb" time="0.000566"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model attributes #channel retrieves attribute :channel" file="./spec/unit/models/protocol_message_spec.rb" time="0.000572"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/protocol_message_spec.rb" time="0.000720"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model #== is true when attributes are the same" file="./spec/unit/models/protocol_message_spec.rb" time="0.000555"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model #== is false when class type differs" file="./spec/unit/models/protocol_message_spec.rb" time="0.000551"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/protocol_message_spec.rb" time="0.000591"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #auth (#TR4p) without a JSON value contains an empty AuthDetails object" file="./spec/unit/models/protocol_message_spec.rb" time="0.000667"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #auth (#TR4p) with a JSON value contains the attributes from the JSON auth details" file="./spec/unit/models/protocol_message_spec.rb" time="0.000635"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #auth (#TR4p) with a JSON value contains a AuthDetails object" file="./spec/unit/models/protocol_message_spec.rb" time="0.002698"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #connection_details (#TR4o) with a JSON value contains the attributes from the JSON connectionDetails" file="./spec/unit/models/protocol_message_spec.rb" time="0.000979"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #connection_details (#TR4o) with a JSON value contains a ConnectionDetails object" file="./spec/unit/models/protocol_message_spec.rb" time="0.000878"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #connection_details (#TR4o) without a JSON value contains an empty ConnectionDetails object" file="./spec/unit/models/protocol_message_spec.rb" time="0.000915"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #has_message_serial? without msg_serial returns false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000782"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #has_message_serial? with msg_serial returns true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #serial with underlying msg_serial converts :msg_serial to an Integer" file="./spec/unit/models/protocol_message_spec.rb" time="0.000668"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #messages (#TR4k) contains Message objects" file="./spec/unit/models/protocol_message_spec.rb" time="0.000714"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #message_size (#TO3l8) on message should return 76 bytes (sum in bytes: data, client_id, name, extras)" file="./spec/unit/models/protocol_message_spec.rb" time="0.000739"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #message_size (#TO3l8) on presence should return 13 bytes (sum in bytes: data and client_id)" file="./spec/unit/models/protocol_message_spec.rb" time="0.000723"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #count when greater than 1 is the value of count" file="./spec/unit/models/protocol_message_spec.rb" time="0.000598"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #count when missing is 1" file="./spec/unit/models/protocol_message_spec.rb" time="0.000499"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #count when non numeric is 1" file="./spec/unit/models/protocol_message_spec.rb" time="0.000492"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when nil is zero" file="./spec/unit/models/protocol_message_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when channel resumed and presence flags present #has_channel_resumed_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000592"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when channel resumed and presence flags present #has_presence_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000595"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when attach resumed flag flags is 0 should raise an exception if flags is a float number" file="./spec/unit/models/protocol_message_spec.rb" time="0.000548"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when attach resumed flag flags is 34 #has_attach_resume_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000494"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when attach resumed flag flags is 34 #has_attach_presence_flag? is false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000657"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when presence flag present #has_channel_resumed_flag? is false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000559"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when presence flag present #has_presence_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000498"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when channel resumed flag present #has_presence_flag? is false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000508"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when channel resumed flag present #has_channel_resumed_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000554"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when has another future flag #has_backlog_flag? is true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000542"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when has another future flag #has_presence_flag? is false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000513"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #flags (#TR4i) when numeric is an Integer" file="./spec/unit/models/protocol_message_spec.rb" time="0.000593"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #action returns an Enum that matchdes the ACTION constant" file="./spec/unit/models/protocol_message_spec.rb" time="0.000563"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #action returns an Enum that behaves like a Numeric" file="./spec/unit/models/protocol_message_spec.rb" time="0.000601"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #action returns an Enum that behaves like a String" file="./spec/unit/models/protocol_message_spec.rb" time="0.000533"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #action returns an Enum that behaves like a symbol" file="./spec/unit/models/protocol_message_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #timestamp retrieves attribute :timestamp as Time object" file="./spec/unit/models/protocol_message_spec.rb" time="0.000611"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #message_serial converts :msg_serial to an Integer" file="./spec/unit/models/protocol_message_spec.rb" time="0.000512"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #error with nil error returns nil" file="./spec/unit/models/protocol_message_spec.rb" time="0.000523"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #error with no error attribute returns nil" file="./spec/unit/models/protocol_message_spec.rb" time="0.000581"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #error with error returns a valid ErrorInfo object" file="./spec/unit/models/protocol_message_spec.rb" time="0.000591"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #messages (#RTL21) contains Message objects in ascending order" file="./spec/unit/models/protocol_message_spec.rb" time="0.000933"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #params (#RTL4k1) when empty is expected to eq {}" file="./spec/unit/models/protocol_message_spec.rb" time="0.000658"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #params (#RTL4k1) when present is expected to eq {:foo=&gt;:bar}" file="./spec/unit/models/protocol_message_spec.rb" time="0.000680"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #presence (#TR4l) contains PresenceMessage objects" file="./spec/unit/models/protocol_message_spec.rb" time="0.000744"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes Java naming converts the attribute to ruby symbol naming convention" file="./spec/unit/models/protocol_message_spec.rb" time="0.000569"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #has_serial? with msg_serial returns true" file="./spec/unit/models/protocol_message_spec.rb" time="0.000648"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #has_serial? without msg_serial returns false" file="./spec/unit/models/protocol_message_spec.rb" time="0.000675"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage#to_json is aliased by #to_s " file="./spec/unit/models/protocol_message_spec.rb" time="0.001300"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage#to_json with valid data converts the attribute back to Java mixedCase notation using string keys" file="./spec/unit/models/protocol_message_spec.rb" time="0.001071"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage#to_json with valid data populates the messages" file="./spec/unit/models/protocol_message_spec.rb" time="0.001128"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage#to_json with missing msg_serial for ack message it raises an exception" file="./spec/unit/models/protocol_message_spec.rb" time="0.000790"></testcase>
<testcase classname="spec.unit.models.channel_occupancy_spec" name="Ably::Models::ChannelOccupancy#metrics should return attributes" file="./spec/unit/models/channel_occupancy_spec.rb" time="0.000725"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model is immutable dups options" file="./spec/unit/models/connection_details_spec.rb" time="0.000762"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model is immutable prevents changes" file="./spec/unit/models/connection_details_spec.rb" time="0.000809"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/connection_details_spec.rb" time="0.000940"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model #== is false when class type differs" file="./spec/unit/models/connection_details_spec.rb" time="0.000856"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model #== is true when attributes are the same" file="./spec/unit/models/connection_details_spec.rb" time="0.001067"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/connection_details_spec.rb" time="0.001120"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/connection_details_spec.rb" time="0.000840"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/connection_details_spec.rb" time="0.000752"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/connection_details_spec.rb" time="0.000821"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #connection_key retrieves attribute :connection_key" file="./spec/unit/models/connection_details_spec.rb" time="0.000795"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #max_frame_size retrieves attribute :max_frame_size" file="./spec/unit/models/connection_details_spec.rb" time="0.000752"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/connection_details_spec.rb" time="0.000728"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #max_message_size retrieves attribute :max_message_size" file="./spec/unit/models/connection_details_spec.rb" time="0.000757"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails behaves like a model attributes #max_inbound_rate retrieves attribute :max_inbound_rate" file="./spec/unit/models/connection_details_spec.rb" time="0.000759"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails ConnectionDetails conversion methods with a ConnectionDetails object returns the ConnectionDetails object" file="./spec/unit/models/connection_details_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails ConnectionDetails conversion methods with a JSON object returns a new ConnectionDetails object from the JSON" file="./spec/unit/models/connection_details_spec.rb" time="0.000716"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails attributes #connection_state_ttl (#CD2f) retrieves attribute :connection_state_ttl and converts it from ms to s" file="./spec/unit/models/connection_details_spec.rb" time="0.000756"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails attributes #max_idle_interval (#CD2h) retrieves attribute :max_idle_interval and converts it from ms to s" file="./spec/unit/models/connection_details_spec.rb" time="0.000676"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails == is false when attributes are not the same" file="./spec/unit/models/connection_details_spec.rb" time="0.000875"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails == is true when attributes are the same" file="./spec/unit/models/connection_details_spec.rb" time="0.000973"></testcase>
<testcase classname="spec.unit.models.connection_details_spec" name="Ably::Models::ConnectionDetails == is false when class type differs" file="./spec/unit/models/connection_details_spec.rb" time="0.000671"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with UTF-8 payload leaves the data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000828"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with UTF-8 payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000619"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport already encoded message with binary payload encodes binary data as base64" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000624"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport already encoded message with binary payload adds the encoding" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000767"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with binary payload adds the encoding" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000730"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with binary payload encodes binary data as base64" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000711"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with nil payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000704"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over text transport message with nil payload leaves the message data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000682"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with binary payload leaves the message data intact as Base64 encoding is not necessary" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000600"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with binary payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000658"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with empty binary string payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000620"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with empty binary string payload leaves the message data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000578"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with UTF-8 payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000685"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with UTF-8 payload leaves the data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000686"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with nil payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000537"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport message with nil payload leaves the message data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000615"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport already encoded message with binary payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000641"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#encode over binary transport already encoded message with binary payload leaves the message data intact as Base64 encoding is not necessary" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000644"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with base64 payload strips the encoding" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000637"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with base64 payload decodes base64" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000648"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with base64 payload before other payloads strips the encoding" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000634"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with base64 payload before other payloads decodes base64" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000586"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with another payload leaves the encoding intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000638"></testcase>
<testcase classname="spec.unit.models.message_encoders.base64_spec" name="Ably::Models::MessageEncoders::Base64#decode message with another payload leaves the message data intact" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#occupancy should return occupancy object" file="./spec/unit/models/channel_status_spec.rb" time="0.000749"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#is_active when occupancy is not active should return false" file="./spec/unit/models/channel_status_spec.rb" time="0.000588"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#is_active when occupancy is active should return true" file="./spec/unit/models/channel_status_spec.rb" time="0.000477"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #ttl with :ttl option as milliseconds in constructor retrieves attribute :ttl as seconds" file="./spec/unit/models/token_request_spec.rb" time="0.000618"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #ttl when converted to JSON is in milliseconds since epoch" file="./spec/unit/models/token_request_spec.rb" time="0.000554"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #timestamp with :timestamp option as milliseconds in constructor retrieves attribute :timestamp as Time" file="./spec/unit/models/token_request_spec.rb" time="0.000693"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #timestamp with :timestamp option as Time in constructor retrieves attribute :timestamp as Time" file="./spec/unit/models/token_request_spec.rb" time="0.000682"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #timestamp when converted to JSON is in milliseconds since epoch" file="./spec/unit/models/token_request_spec.rb" time="0.000622"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest attributes #capability retrieves attribute :capability as parsed JSON" file="./spec/unit/models/token_request_spec.rb" time="0.000649"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest from_json (#TE6) with JSON string returns a valid TokenRequest object" file="./spec/unit/models/token_request_spec.rb" time="0.000860"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest from_json (#TE6) with JSON-like object returns a valid TokenRequest object" file="./spec/unit/models/token_request_spec.rb" time="0.000747"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest from_json (#TE6) with Ruby idiomatic Hash object returns a valid TokenRequest object" file="./spec/unit/models/token_request_spec.rb" time="0.000690"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #mac retrieves attribute :mac" file="./spec/unit/models/token_request_spec.rb" time="0.000658"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/token_request_spec.rb" time="0.000571"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #key_name retrieves attribute :key_name" file="./spec/unit/models/token_request_spec.rb" time="0.000618"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/token_request_spec.rb" time="0.000604"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/token_request_spec.rb" time="0.000587"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model attributes #nonce retrieves attribute :nonce" file="./spec/unit/models/token_request_spec.rb" time="0.000601"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/token_request_spec.rb" time="0.000627"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model is immutable dups options" file="./spec/unit/models/token_request_spec.rb" time="0.000918"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model is immutable prevents changes" file="./spec/unit/models/token_request_spec.rb" time="0.000712"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model #== is true when attributes are the same" file="./spec/unit/models/token_request_spec.rb" time="0.000656"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/token_request_spec.rb" time="0.000595"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model #== is false when class type differs" file="./spec/unit/models/token_request_spec.rb" time="0.000513"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/token_request_spec.rb" time="0.000647"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest TokenRequest conversion methods with a TokenRequest object returns the TokenRequest object" file="./spec/unit/models/token_request_spec.rb" time="0.000576"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest TokenRequest conversion methods with a JSON object returns a new TokenRequest object from the JSON" file="./spec/unit/models/token_request_spec.rb" time="0.000565"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest == is true when attributes are the same" file="./spec/unit/models/token_request_spec.rb" time="0.000604"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest == is false when attributes are not the same" file="./spec/unit/models/token_request_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.token_request_spec" name="Ably::Models::TokenRequest == is false when class type differs" file="./spec/unit/models/token_request_spec.rb" time="0.000656"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload strips the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000686"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload decodes json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000680"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload before other payloads decodes json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000653"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload before other payloads strips the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000663"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload in camelCase decodes json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000610"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with json payload in camelCase strips the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000567"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with another payload leaves the encoding intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000536"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#decode message with another payload leaves the message data intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode already encoded message with hash payload encodes hash payload data as json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000621"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode already encoded message with hash payload adds the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000570"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with Array payload encodes Array payload data as json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000532"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with Array payload adds the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000652"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with no data payload leaves the message data intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000621"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with no data payload leaves the encoding intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000558"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with nil payload leaves the message data intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000508"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with nil payload leaves the encoding intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000636"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with UTF-8 payload leaves the encoding intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000632"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with UTF-8 payload leaves the message data intact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with hash payload adds the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000643"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with hash payload encodes hash payload data as json" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000672"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with hash payload and underscore case keys encodes hash payload data as json and leaves underscore case in tact" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000642"></testcase>
<testcase classname="spec.unit.models.message_encoders.json_spec" name="Ably::Models::MessageEncoders::Json#encode message with hash payload and underscore case keys adds the encoding" file="./spec/unit/models/message_encoders/json_spec.rb" time="0.000599"></testcase>
</testsuite>
