<testsuite name="rspec2" tests="566" skipped="1" failures="0" errors="0" time="2.908857" timestamp="2026-03-02T14:08:05+00:00" hostname="runnervmnay03">
<properties>
<property name="seed" value="13682"/>
</properties>
<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.118994"></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.202396"></testcase>
<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.202239"></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.103133"></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.101988"></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.002119"></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.302579"></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.102878"></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.103167"></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.001134"></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.001313"></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.000787"></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.001000"></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.000796"></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.000714"></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.002149"></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.001930"></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.000773"></testcase>
<testcase classname="spec.unit.realtime.presence_spec" name="Ably::Realtime::Presence msgbus supports messages" file="./spec/unit/realtime/presence_spec.rb" time="0.001121"></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.001055"></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.001097"></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.001611"></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.001085"></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.000674"></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.000971"></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.000925"></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.000941"></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.000918"></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.000951"></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.000646"></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.002849"></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.000759"></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.000510"></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.000685"></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.000703"></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.000706"></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.000588"></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.000669"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#event(#TA5) is an attribute" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#event(#TA5) is not required" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000625"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#retry_in (#TA2) is not required" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000506"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#retry_in (#TA2) is an attribute" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000642"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#reason (#TA3) is an attribute" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000575"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#reason (#TA3) is not required" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000527"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#previous(#TA2) is an attribute" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000577"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#previous(#TA2) is required" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000632"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#current (#TA2) is an attribute" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000491"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange#current (#TA2) is required" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.connection_state_change_spec" name="Ably::Models::ConnectionStateChange invalid attributes raises an argument error" file="./spec/unit/models/connection_state_change_spec.rb" time="0.000603"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded_array (#TP4) with no encoding returns an Array of presence message objects" file="./spec/unit/models/presence_message_spec.rb" time="0.001500"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model #== is true when attributes are the same" file="./spec/unit/models/presence_message_spec.rb" time="0.000819"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model #== is false when class type differs" file="./spec/unit/models/presence_message_spec.rb" time="0.000734"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/presence_message_spec.rb" time="0.000826"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/presence_message_spec.rb" time="0.002194"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/presence_message_spec.rb" time="0.000863"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #encoding retrieves attribute :encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.000736"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/presence_message_spec.rb" time="0.000741"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/presence_message_spec.rb" time="0.000770"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #id retrieves attribute :id" file="./spec/unit/models/presence_message_spec.rb" time="0.000714"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/presence_message_spec.rb" time="0.000727"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model attributes #data retrieves attribute :data" file="./spec/unit/models/presence_message_spec.rb" time="0.002176"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model is immutable prevents changes" file="./spec/unit/models/presence_message_spec.rb" time="0.000835"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage behaves like a model is immutable dups options" file="./spec/unit/models/presence_message_spec.rb" time="0.000824"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#member_key attribute is string in format connection_id:client_id" file="./spec/unit/models/presence_message_spec.rb" time="0.000720"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#member_key attribute with a single connection and different client_ids is unique" file="./spec/unit/models/presence_message_spec.rb" time="0.000939"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#member_key attribute with the same client id across multiple connections is unique" file="./spec/unit/models/presence_message_spec.rb" time="0.001164"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000846"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON without ProtocolMessage initializes with the JSON" file="./spec/unit/models/presence_message_spec.rb" time="0.000942"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000804"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON without ProtocolMessage returns a PresenceMessage object" file="./spec/unit/models/presence_message_spec.rb" time="0.000750"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.001105"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON with ProtocolMessage returns a PresenceMessage object" file="./spec/unit/models/presence_message_spec.rb" time="0.001046"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON with ProtocolMessage initializes with the JSON" file="./spec/unit/models/presence_message_spec.rb" time="0.001061"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with JSON with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.001045"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000893"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000704"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage with ProtocolMessage returns a PresenceMessage object" file="./spec/unit/models/presence_message_spec.rb" time="0.000769"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage with ProtocolMessage initializes with the JSON" file="./spec/unit/models/presence_message_spec.rb" time="0.000751"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000753"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.000766"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage without ProtocolMessage initializes with the JSON" file="./spec/unit/models/presence_message_spec.rb" time="0.000866"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage PresenceMessage conversion method with another PresenceMessage without ProtocolMessage returns a PresenceMessage object" file="./spec/unit/models/presence_message_spec.rb" time="0.000816"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with no encoding returns a presence message object" file="./spec/unit/models/presence_message_spec.rb" time="0.001223"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with no encoding with a block does not call the block" file="./spec/unit/models/presence_message_spec.rb" time="0.001250"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with an encoding returns a presence message object" file="./spec/unit/models/presence_message_spec.rb" time="0.001186"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with invalid Cipher encoding without a block raises an exception" file="./spec/unit/models/presence_message_spec.rb" time="0.002387"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with invalid Cipher encoding with a block calls the block with the exception" file="./spec/unit/models/presence_message_spec.rb" time="0.001521"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with a custom encoding returns a presence message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/presence_message_spec.rb" time="0.002347"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#from_encoded (#TP4) with a Cipher encoding returns a presence message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/presence_message_spec.rb" time="0.002016"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#size String (#TO3l8a) should return 20 bytes" file="./spec/unit/models/presence_message_spec.rb" time="0.001026"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#size extras (#TO3l8d) should return 51 bytes" file="./spec/unit/models/presence_message_spec.rb" time="0.000787"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#size Array (#TO3l8b) should return 18 bytes" file="./spec/unit/models/presence_message_spec.rb" time="0.000909"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#size Object (#TO3l8b) should return 32 bytes" file="./spec/unit/models/presence_message_spec.rb" time="0.000899"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#size nil (#TO3l8e) should return 1 bytes" file="./spec/unit/models/presence_message_spec.rb" time="0.000978"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#to_json with valid data converts the attribute back to Java mixedCase notation using string keys" file="./spec/unit/models/presence_message_spec.rb" time="0.001055"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#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/presence_message_spec.rb" time="0.000942"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#to_json with binary data adds Base64 encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.000949"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#to_json with invalid data raises an exception" file="./spec/unit/models/presence_message_spec.rb" time="0.001286"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.001498"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000893"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as UTF_8 string remains as UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000816"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as UTF_8 string is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.000799"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as Integer raises an argument error" file="./spec/unit/models/presence_message_spec.rb" time="0.000894"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as Nil is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.001149"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.001154"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :client_id as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.001141"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.001110"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000989"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as UTF_8 string is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.000956"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as UTF_8 string remains as UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.001158"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as Nil is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.001039"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.001135"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.001053"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :connection_id as Integer raises an argument error" file="./spec/unit/models/presence_message_spec.rb" time="0.000756"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as Nil is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.000854"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as Integer raises an argument error" file="./spec/unit/models/presence_message_spec.rb" time="0.000900"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.000947"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000822"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as UTF_8 string is permitted" file="./spec/unit/models/presence_message_spec.rb" time="0.000910"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as UTF_8 string remains as UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000836"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/presence_message_spec.rb" time="0.000823"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage initialized with :encoding as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/presence_message_spec.rb" time="0.000914"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#timestamp retrieves attribute :timestamp as a Time object from ProtocolMessage" file="./spec/unit/models/presence_message_spec.rb" time="0.001484"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#connection_id attribute when this model has no connectionId attribute and no protocol message uses the model value" file="./spec/unit/models/presence_message_spec.rb" time="0.000960"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#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/presence_message_spec.rb" time="0.000965"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#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/presence_message_spec.rb" time="0.001049"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#connection_id attribute when this model has a connectionId attribute but no protocol message uses the model value" file="./spec/unit/models/presence_message_spec.rb" time="0.001022"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage from REST request with embedded fields without protocol message #timestamp uses embedded timestamp" file="./spec/unit/models/presence_message_spec.rb" time="0.000966"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage from REST request with embedded fields without protocol message #id uses embedded ID" file="./spec/unit/models/presence_message_spec.rb" time="0.001020"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage from REST request with embedded fields with protocol message #timestamp prefers embedded timestamp" file="./spec/unit/models/presence_message_spec.rb" time="0.000928"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage from REST request with embedded fields with protocol message #id prefers embedded ID" file="./spec/unit/models/presence_message_spec.rb" time="0.001064"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage with action enter provides action as an Enum" file="./spec/unit/models/presence_message_spec.rb" time="0.001004"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage with action absent provides action as an Enum" file="./spec/unit/models/presence_message_spec.rb" time="0.000854"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage part of ProtocolMessage should generate a message ID from the index, serial and connection id" file="./spec/unit/models/presence_message_spec.rb" time="0.001389"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage part of ProtocolMessage should not modify the data payload" file="./spec/unit/models/presence_message_spec.rb" time="0.001290"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#shallow_clone with new attributes passed in to the method creates a duplicate of the message without any ProtocolMessage dependency" file="./spec/unit/models/presence_message_spec.rb" time="0.001555"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#shallow_clone with new attributes passed in to the method with mixing of cases resolves case issues and can use camelCase or snake_case" file="./spec/unit/models/presence_message_spec.rb" time="0.003361"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#shallow_clone with new attributes passed in to the method with an invalid ProtocolMessage (missing an ID) allows an ID to be passed in to the shallow clone that takes precedence" file="./spec/unit/models/presence_message_spec.rb" time="0.001309"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#shallow_clone with inherited attributes from ProtocolMessage creates a duplicate of the message without any ProtocolMessage dependency" file="./spec/unit/models/presence_message_spec.rb" time="0.001371"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage#shallow_clone with embedded attributes for all fields creates a duplicate of the message without any ProtocolMessage dependency" file="./spec/unit/models/presence_message_spec.rb" time="0.001010"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage without action raises an exception when accessed" file="./spec/unit/models/presence_message_spec.rb" time="0.000893"></testcase>
<testcase classname="spec.unit.models.presence_message_spec" name="Ably::Models::PresenceMessage Java naming converts the attribute to ruby symbol naming convention" file="./spec/unit/models/presence_message_spec.rb" time="0.000988"></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.001141"></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.000907"></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.000784"></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.000557"></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.000591"></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.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 encodes binary data as base64" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000702"></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.000594"></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.000646"></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.000692"></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 binary payload adds the encoding" file="./spec/unit/models/message_encoders/base64_spec.rb" time="0.000702"></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.001110"></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.001083"></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.000811"></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.000613"></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.000998"></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.000935"></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.000496"></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.000690"></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.000744"></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.000727"></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.000771"></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.000927"></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.000936"></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.000796"></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.000638"></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.000839"></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.000882"></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.000595"></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.000675"></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.000794"></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.000749"></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.000568"></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.000712"></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.000707"></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.000637"></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.000662"></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.000833"></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.000895"></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.000855"></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.000981"></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.000993"></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.000870"></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.001006"></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.000964"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub#unsubscribe continues if the block does not exist" file="./spec/unit/util/pub_sub_spec.rb" time="0.001253"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub#unsubscribe deletes matching callbacks" file="./spec/unit/util/pub_sub_spec.rb" time="0.001085"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub#unsubscribe deletes all callbacks if not block given" file="./spec/unit/util/pub_sub_spec.rb" time="0.000927"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub event fan out #publish allows publishing to more than on subscriber" file="./spec/unit/util/pub_sub_spec.rb" time="0.001153"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub event fan out #publish sends only messages to #subscribe callbacks matching event names" file="./spec/unit/util/pub_sub_spec.rb" time="0.001061"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub event fan out without coercion only matches event names on type matches" file="./spec/unit/util/pub_sub_spec.rb" time="0.000977"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub event fan out with coercion calls the provided proc to coerce the event name" file="./spec/unit/util/pub_sub_spec.rb" time="0.000936"></testcase>
<testcase classname="spec.unit.util.pub_sub_spec" name="Ably::Util::PubSub event fan out with coercion and two different configurations but sharing the same class does not share state" file="./spec/unit/util/pub_sub_spec.rb" time="0.002731"></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.001710"></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.001435"></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.001509"></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.001200"></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.001941"></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.000996"></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.001269"></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.001488"></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.001387"></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.001432"></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.001353"></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.000952"></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.001627"></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.000921"></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.001384"></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.000774"></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.001374"></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.000881"></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.001253"></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.001309"></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.000958"></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.002536"></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.000932"></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.001455"></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.000947"></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.000848"></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.000575"></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.000873"></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.000689"></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.000865"></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.000899"></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.000680"></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.000918"></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.001020"></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.000929"></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.000899"></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.000830"></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.000878"></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.000950"></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.000833"></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.000829"></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.000722"></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.000711"></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.000759"></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.000736"></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.000748"></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.018535"></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.016570"></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.007095"></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.001000"></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.000972"></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.000778"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#dispatch_protocol_message should raise an exception if a message is sent that is not a ProtocolMessage" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.000951"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#dispatch_protocol_message should warn if a message is received for a non-existent channel" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.002875"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with a MESSAGE_UPDATE action and publish_result succeeds with an UpdateDeleteResult" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001713"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with a regular message (no action) succeeds the message with itself" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001236"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with a MESSAGE_UPDATE action but no publish_result succeeds the message with itself (fallback)" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001326"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with presence messages succeeds with the message itself (no publish_result handling)" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001141"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with multiple regular messages and publish_result assigns the correct serial to each message by index" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001366"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with symbol-keyed publish_result handles symbol keys for serials" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001310"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with a regular message and publish_result (PublishResult) succeeds with a PublishResult" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001219"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with a regular message and symbol-keyed publish_result handles symbol keys for serials" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001200"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#ack_messages with multiple update messages and a publish_result with multiple serials assigns the correct version serial to each message by index" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.001720"></testcase>
<testcase classname="spec.unit.realtime.incoming_message_dispatcher_spec" name="Ably::Realtime::Client::IncomingMessageDispatcher#initialize should subscribe to protocol messages from the connection" file="./spec/unit/realtime/incoming_message_dispatcher_spec.rb" time="0.000955"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #unsubscribe with no event name specified unsubscribes that block from all events" file="./spec/unit/realtime/channel_spec.rb" time="0.002030"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #unsubscribe with a single event name argument unsubscribes the provided block with the matching event name" file="./spec/unit/realtime/channel_spec.rb" time="0.001652"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #unsubscribe with a non-matching event name argument has no effect" file="./spec/unit/realtime/channel_spec.rb" time="0.003662"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #unsubscribe with multiple event name arguments unsubscribes each of those matching event names with the provided block" file="./spec/unit/realtime/channel_spec.rb" time="0.001715"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #unsubscribe with no block argument unsubscribes all blocks for the event name argument" file="./spec/unit/realtime/channel_spec.rb" time="0.001618"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #subscribe with a single event name subscribes that block to matching events" file="./spec/unit/realtime/channel_spec.rb" time="0.001519"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #subscribe without a block raises an invalid ArgumentError" file="./spec/unit/realtime/channel_spec.rb" time="0.001463"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #subscribe with no event name specified subscribes the provided block to all events" file="./spec/unit/realtime/channel_spec.rb" time="0.001581"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #subscribe with a multiple duplicate event name arguments subscribes that block to all of those unique event names once" file="./spec/unit/realtime/channel_spec.rb" time="0.001437"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel subscriptions #subscribe with a multiple event name arguments subscribes that block to all of those event names" file="./spec/unit/realtime/channel_spec.rb" time="0.001838"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as Nil raises an argument error" file="./spec/unit/realtime/channel_spec.rb" time="0.001129"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as Integer raises an argument error" file="./spec/unit/realtime/channel_spec.rb" time="0.001067"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as UTF_8 string is permitted" file="./spec/unit/realtime/channel_spec.rb" time="0.001220"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as UTF_8 string remains as UTF-8" file="./spec/unit/realtime/channel_spec.rb" time="0.001209"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/realtime/channel_spec.rb" time="0.001340"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/realtime/channel_spec.rb" time="0.001201"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/realtime/channel_spec.rb" time="0.002572"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#initializer as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/realtime/channel_spec.rb" time="0.001318"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel msgbus supports messages" file="./spec/unit/realtime/channel_spec.rb" time="0.001662"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel msgbus fail with unacceptable STATE event names" file="./spec/unit/realtime/channel_spec.rb" time="0.001376"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel callbacks fail with unacceptable STATE event names" file="./spec/unit/realtime/channel_spec.rb" time="0.001422"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel callbacks are supported for valid STATE events" file="./spec/unit/realtime/channel_spec.rb" time="0.001296"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#publish name argument as SHIFT_JIS string is permitted" file="./spec/unit/realtime/channel_spec.rb" time="0.001933"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#publish name argument as Nil is permitted" file="./spec/unit/realtime/channel_spec.rb" time="0.001771"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#publish name argument as ASCII_8BIT string is permitted" file="./spec/unit/realtime/channel_spec.rb" time="0.002086"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#publish name argument as UTF_8 string is permitted" file="./spec/unit/realtime/channel_spec.rb" time="0.001775"></testcase>
<testcase classname="spec.unit.realtime.channel_spec" name="Ably::Realtime::Channel#publish name argument as Integer raises an argument error" file="./spec/unit/realtime/channel_spec.rb" time="0.001563"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange invalid attributes raises an argument error" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000540"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#reason (#TH3) is not required" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000652"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#reason (#TH3) is an attribute" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000578"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#current (#TH1) is an attribute" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000613"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#current (#TH1) is required" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000595"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#resumed (#TH4) is true when provided" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000606"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#resumed (#TH4) is false when ommitted" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000634"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#previous (#TH2) is an attribute" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000584"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#previous (#TH2) is required" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000659"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#event (#TH5) is not required" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000588"></testcase>
<testcase classname="spec.unit.models.channel_state_change_spec" name="Ably::Models::ChannelStateChange#event (#TH5) is an attribute" file="./spec/unit/models/channel_state_change_spec.rb" time="0.000655"></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.001797"></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.000584"><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.000662"></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.000650"></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.000562"></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.000562"></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.000580"></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.000572"></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.000557"></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.000515"></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.000568"></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.000557"></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.000548"></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.000546"></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.001363"></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.000556"></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.000609"></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.000670"></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.000619"></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.000620"></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.000797"></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.000928"></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.000676"></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.000657"></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.000615"></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.000634"></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.000568"></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.000639"></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.000630"></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.000616"></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.000654"></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.000616"></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.000637"></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.000631"></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.000613"></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.000599"></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.000670"></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.000661"></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.000630"></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.000607"></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.000565"></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.000589"></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.000623"></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.000635"></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.000591"></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.000654"></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.000592"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails camelCase constructor attributes are generated when the object is serialised to JSON" file="./spec/unit/models/device_details_spec.rb" time="0.000642"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails camelCase constructor attributes are rubyfied and exposed as underscore case" file="./spec/unit/models/device_details_spec.rb" time="0.000619"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#device_secret and #device_secret= rejects non string or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.003480"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#device_secret and #device_secret= setter accepts nil" file="./spec/unit/models/device_details_spec.rb" time="0.000854"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#device_secret and #device_secret= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000784"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#id and #id= setter accepts nil" file="./spec/unit/models/device_details_spec.rb" time="0.000603"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#id and #id= rejects non string or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000653"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#id and #id= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000751"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#platform and #platform= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000746"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#platform and #platform= rejects non string or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000582"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#platform and #platform= setter accepts nil" file="./spec/unit/models/device_details_spec.rb" time="0.000716"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#client_id and #client_id= setter accepts nil" file="./spec/unit/models/device_details_spec.rb" time="0.000710"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#client_id and #client_id= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#client_id and #client_id= rejects non string or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000613"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#metadata and #metadata= setter accepts a Hash value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000713"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#metadata and #metadata= setter accepts nil but always returns an empty hash" file="./spec/unit/models/device_details_spec.rb" time="0.000752"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#metadata and #metadata= rejects non Hash or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000646"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#push and #push= rejects non Hash, DevicePushDetails or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000460"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#push and #push= setter accepts a DevicePushDetails object and getter returns a DevicePushDetails object" file="./spec/unit/models/device_details_spec.rb" time="0.000791"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#push and #push= setter accepts a Hash value and getter returns a DevicePushDetails object" file="./spec/unit/models/device_details_spec.rb" time="0.000746"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#push and #push= setter accepts nil but always returns a DevicePushDetails object" file="./spec/unit/models/device_details_spec.rb" time="0.000741"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#form_factor and #form_factor= setter accepts nil" file="./spec/unit/models/device_details_spec.rb" time="0.000661"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#form_factor and #form_factor= setter accepts a string value and getter returns the new value" file="./spec/unit/models/device_details_spec.rb" time="0.000665"></testcase>
<testcase classname="spec.unit.models.device_details_spec" name="Ably::Models::DeviceDetails#form_factor and #form_factor= rejects non string or nil values" file="./spec/unit/models/device_details_spec.rb" time="0.000559"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult#version_serial (#UDR2a) when present returns the version serial" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000586"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult#version_serial (#UDR2a) when nil returns nil" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000618"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult#version_serial (#UDR2a) when not provided returns nil" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000579"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult#attributes returns the underlying attributes" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000443"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult#attributes prevents modification" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000556"></testcase>
<testcase classname="spec.unit.models.update_delete_result_spec" name="Ably::Models::UpdateDeleteResult with camelCase keys from wire converts to snake_case access" file="./spec/unit/models/update_delete_result_spec.rb" time="0.000481"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_since_epoch with numeric accepts integers" file="./spec/unit/modules/conversions_spec.rb" time="0.000530"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_since_epoch with numeric converts to integer" file="./spec/unit/modules/conversions_spec.rb" time="0.000597"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_since_epoch with time converts to milliseconds by default" file="./spec/unit/modules/conversions_spec.rb" time="0.000509"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_since_epoch with time converted to seconds" file="./spec/unit/modules/conversions_spec.rb" time="0.000606"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_since_epoch with any other object raises an exception" file="./spec/unit/modules/conversions_spec.rb" time="0.000594"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_time_from_epoch with numeric converts to Time from seconds" file="./spec/unit/modules/conversions_spec.rb" time="0.000562"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_time_from_epoch with numeric converts to Time from milliseconds by default" file="./spec/unit/modules/conversions_spec.rb" time="0.000555"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_time_from_epoch with any other object raises an exception" file="./spec/unit/modules/conversions_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.modules.conversions_spec" name="Ably::Modules::Conversions#as_time_from_epoch with Time leaves intact" file="./spec/unit/modules/conversions_spec.rb" time="0.000497"></testcase>
<testcase classname="spec.unit.realtime.websocket_transport_spec" name="Ably::Realtime::Connection::WebsocketTransport behaves like an incoming protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub supports valid ProtocolMessage messages" file="./spec/unit/realtime/websocket_transport_spec.rb" time="0.001111"></testcase>
<testcase classname="spec.unit.realtime.websocket_transport_spec" name="Ably::Realtime::Connection::WebsocketTransport behaves like an incoming protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub fail with unacceptable STATE event names" file="./spec/unit/realtime/websocket_transport_spec.rb" time="0.000972"></testcase>
<testcase classname="spec.unit.realtime.websocket_transport_spec" name="Ably::Realtime::Connection::WebsocketTransport behaves like an outgoing protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub fail with unacceptable STATE event names" file="./spec/unit/realtime/websocket_transport_spec.rb" time="0.000909"></testcase>
<testcase classname="spec.unit.realtime.websocket_transport_spec" name="Ably::Realtime::Connection::WebsocketTransport behaves like an outgoing protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub supports valid ProtocolMessage messages" file="./spec/unit/realtime/websocket_transport_spec.rb" time="0.000989"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#channel and #channel= rejects non string or nil values" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000624"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#channel and #channel= setter accepts a string value and getter returns the new value" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000671"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#channel and #channel= setter accepts nil" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#device_id and #device_id= setter accepts nil" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000699"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#device_id and #device_id= rejects non string or nil values" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000679"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#device_id and #device_id= setter accepts a string value and getter returns the new value" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000685"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription conversion method PushChannelSubscription accepts a PushChannelSubscription object" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000633"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#for_client_id constructor with an invalid valid object accepts a Hash object" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000649"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#for_client_id constructor with a valid object accepts a Hash object" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#client_id and #client_id= setter accepts a string value and getter returns the new value" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#client_id and #client_id= setter accepts nil" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000650"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription#client_id and #client_id= rejects non string or nil values" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000668"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription camelCase constructor attributes are generated when the object is serialised to JSON" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000670"></testcase>
<testcase classname="spec.unit.models.push_channel_subscription_spec" name="Ably::Models::PushChannelSubscription camelCase constructor attributes are rubyfied and exposed as underscore case" file="./spec/unit/models/push_channel_subscription_spec.rb" time="0.000600"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with event specified does not remove other blocks after it is called" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000551"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with event specified calls the block the first time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000549"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with event specified catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000856"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with no event specified does not remove other blocks after it is called" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000506"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with no event specified catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000813"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#once (#RTE4) with no event specified calls the block the first time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000546"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_off with on subscribers does not deregister them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_off with unsafe_on subscribers deregisters them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000624"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_off with unsafe_once subscribers deregister them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000664"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_off with once subscribers does not deregister them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000689"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out sends only messages to matching event names" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out should emit an event for any number of subscribers" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000710"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out without coercion only matches event names on type matches" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000605"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out #on subscribe to multiple events with the same block" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000621"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out with coercion calls the provided proc to coerce the event name" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000600"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out event callback changes within the callback block when callbacks are removed is unaffected and processes the prior event callbacks once (#RTE6b)" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000740"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out event callback changes within the callback block when callbacks are removed removes them for the next emitted event (#RTE6b)" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000755"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out event callback changes within the callback block when new event callbacks are added adds them for the next emitted event (#RTE6b)" file="./spec/unit/modules/event_emitter_spec.rb" time="0.002761"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#emit event fan out event callback changes within the callback block when new event callbacks are added is unaffected and processes the prior event callbacks once (#RTE6b)" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000875"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_once calls the block the first time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000542"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_once does not catch exceptions in provided blocks" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000746"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#on (#RTE3) with event specified calls the block every time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000638"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#on (#RTE3) with event specified catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000921"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#on (#RTE3) with no event specified calls the block every time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000688"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#on (#RTE3) with no event specified catches exceptions in the provided block, logs the error and continues" file="./spec/unit/modules/event_emitter_spec.rb" time="0.001111"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_on calls the block every time an event is emitted only" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000753"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#unsafe_on does not catch exceptions in provided blocks" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000797"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with unsafe_once subscribers does not deregister them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000835"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with unsafe_on subscribers does not deregister them" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000674"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off when on callback is configured for all events without any event names deletes all callbacks if not block given" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000710"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off when on callback is configured for all events without any event names deletes all matching callbacks" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000740"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off when on callback is configured for all events with event names as arguments does not remove the all events callback when a block is provided" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000784"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off when on callback is configured for all events with event names as arguments does not remove the all events callback when a block is not provided" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000730"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off when on callback is configured for all events with event names as arguments does not remove the all events callback when the block does not match" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with event specified in on handler without any event names deletes all matching callbacks" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000683"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with event specified in on handler without any event names deletes all callbacks if not block given" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000719"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with event specified in on handler with event names as arguments deletes all matching callbacks when a block is not provided" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000684"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with event specified in on handler with event names as arguments deletes matching callbacks when a block is provided" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.modules.event_emitter_spec" name="Ably::Modules::EventEmitter#off with event specified in on handler with event names as arguments continues if the block does not exist" file="./spec/unit/modules/event_emitter_spec.rb" time="0.000682"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#attributes prevents modification" file="./spec/unit/models/publish_result_spec.rb" time="0.000657"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#attributes returns the underlying attributes" file="./spec/unit/models/publish_result_spec.rb" time="0.000609"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#serials (#RSL1n) with nullable entries preserves nil entries" file="./spec/unit/models/publish_result_spec.rb" time="0.000512"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#serials (#RSL1n) when not provided returns empty array" file="./spec/unit/models/publish_result_spec.rb" time="0.000505"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#serials (#RSL1n) when nil returns empty array" file="./spec/unit/models/publish_result_spec.rb" time="0.000612"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#serials (#RSL1n) when empty array returns empty array" file="./spec/unit/models/publish_result_spec.rb" time="0.000539"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult#serials (#RSL1n) when present returns the serials array" file="./spec/unit/models/publish_result_spec.rb" time="0.000498"></testcase>
<testcase classname="spec.unit.models.publish_result_spec" name="Ably::Models::PublishResult truthiness is truthy for backward compatibility with boolean publish returns" file="./spec/unit/models/publish_result_spec.rb" time="0.000539"></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.001173"></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.000704"></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.000535"></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.000561"></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.000645"></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.000624"></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.000612"></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.000595"></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.000585"></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.000984"></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.000609"></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.000579"></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.000553"></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.000677"></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.000616"></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.000556"></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.000625"></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.000644"></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.000536"></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.000578"></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.000626"></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.000565"></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.000662"></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.000712"></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.000899"></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.000633"></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.000570"></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.000777"></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.000659"></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.000625"></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.000673"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #res (#TR4s) with multiple entries returns all entries" file="./spec/unit/models/protocol_message_spec.rb" time="0.000988"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #res (#TR4s) when absent returns nil" file="./spec/unit/models/protocol_message_spec.rb" time="0.000831"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #res (#TR4s) when present contains publish result entries with serials" file="./spec/unit/models/protocol_message_spec.rb" time="0.000923"></testcase>
<testcase classname="spec.unit.models.protocol_message_spec" name="Ably::Models::ProtocolMessage attributes #res (#TR4s) when present returns the res array" file="./spec/unit/models/protocol_message_spec.rb" time="0.000674"></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.000665"></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.000614"></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.000676"></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.000733"></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.002959"></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.000716"></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.000663"></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.000686"></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.000679"></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.000608"></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.000670"></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.000614"></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.000627"></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.000571"></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.000634"></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.001149"></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.001252"></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.001349"></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.000751"></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.000731"></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.000591"></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.000672"></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.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.000643"></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.000552"></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.000659"></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.001037"></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.000649"></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.000587"></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.000690"></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.000714"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection callbacks fail with unacceptable STATE event names" file="./spec/unit/realtime/connection_spec.rb" time="0.001217"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection callbacks are supported for valid STATE events" file="./spec/unit/realtime/connection_spec.rb" time="0.001040"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection behaves like an outgoing protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub supports valid ProtocolMessage messages" file="./spec/unit/realtime/connection_spec.rb" time="0.001018"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection behaves like an outgoing protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub fail with unacceptable STATE event names" file="./spec/unit/realtime/connection_spec.rb" time="0.001039"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection behaves like an incoming protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub fail with unacceptable STATE event names" file="./spec/unit/realtime/connection_spec.rb" time="0.001003"></testcase>
<testcase classname="spec.unit.realtime.connection_spec" name="Ably::Realtime::Connection behaves like an incoming protocol message bus behaves like a protocol message bus __protocol_msgbus__ PubSub supports valid ProtocolMessage messages" file="./spec/unit/realtime/connection_spec.rb" time="0.001094"></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.001403"></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.001276"></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.000811"></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.001109"></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.000840"></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.000819"></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.000716"></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.000584"></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.000645"></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.000592"></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.000633"></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.000868"></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.000696"></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.000578"></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.000669"></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.000733"></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.000744"></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.000739"></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.000802"></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.000763"></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.000620"></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.000850"></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.000810"></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.000646"></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.000733"></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.000594"></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.000559"></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.003116"></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.000677"></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.000616"></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.000777"></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.000879"></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.000832"></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.000736"></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.000552"></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.000867"></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.000734"></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.000777"></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.000544"></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.000622"></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.000666"></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.000568"></testcase>
<testcase classname="spec.unit.realtime.recovery_key_context_spec" name="Ably::Realtime::RecoveryKeyContext connection recovery key should decode recovery key - RTN16i, RTN16f, RTN16j" file="./spec/unit/realtime/recovery_key_context_spec.rb" time="0.000517"></testcase>
<testcase classname="spec.unit.realtime.recovery_key_context_spec" name="Ably::Realtime::RecoveryKeyContext connection recovery key should return nil for invalid recovery key - RTN16i, RTN16f, RTN16j" file="./spec/unit/realtime/recovery_key_context_spec.rb" time="0.000679"></testcase>
<testcase classname="spec.unit.realtime.recovery_key_context_spec" name="Ably::Realtime::RecoveryKeyContext connection recovery key should encode recovery key - RTN16i, RTN16f, RTN16j" file="./spec/unit/realtime/recovery_key_context_spec.rb" time="0.000538"></testcase>
</testsuite>
