<testsuite name="rspec2" tests="628" skipped="2" failures="0" errors="0" time="12.470589" timestamp="2024-06-17T10:12:00+00:00" hostname="fv-az1538-923">
<properties>
<property name="seed" value="11813"/>
</properties>
<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.006276"></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.003211"></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.001097"></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.001167"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#is_active when occupancy is not active should return false" file="./spec/unit/models/channel_status_spec.rb" time="0.000594"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#is_active when occupancy is active should return true" file="./spec/unit/models/channel_status_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.channel_status_spec" name="Ably::Models::ChannelStatus#occupancy should return occupancy object" file="./spec/unit/models/channel_status_spec.rb" time="0.001043"></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.000560"></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.000889"></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.000568"></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.000626"></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.000680"></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.000571"></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.007322"></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.000626"></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.000900"></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.000865"></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.000734"></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.000518"></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.001540"></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.000805"></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.000802"></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.000668"></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.000559"></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.000911"></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.000850"></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.000892"></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.000705"></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.000626"></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.000946"></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.000886"></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.000887"></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.000865"></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.000748"></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.000659"></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.000640"></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.000666"></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.000577"></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.000699"></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.000786"></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.000686"></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.000815"></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.002079"></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.000653"></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.000839"></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.000893"></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.000956"></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.000874"></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.000727"></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.000572"></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.000542"></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.000799"></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.000595"></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.001668"></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.000661"></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.001374"></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.000627"></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.000771"></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.000554"></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.002366"></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.001018"></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.000924"></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.000839"></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.001073"></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.001068"></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.001167"></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.001104"></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.000887"></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.000690"></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.000760"></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.000813"></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.000856"></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.000825"></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.000823"></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.000779"></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.000871"></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.000769"></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.000681"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client push #device is not supported and raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000808"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client push #push returns a Push object" file="./spec/unit/rest/client_spec.rb" time="0.000743"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments key: &quot;invalid&quot; raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000757"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments empty hash raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000643"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments key: &quot;invalid:asdad&quot; raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments key and key_secret raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000588"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments key and key_name raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000633"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with invalid arguments nil raises an exception" file="./spec/unit/rest/client_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer delegators delegates :auth_options to .auth" file="./spec/unit/rest/client_spec.rb" time="0.000948"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer delegators delegates :client_id to .auth" file="./spec/unit/rest/client_spec.rb" time="0.000841"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments realtime_host when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="0.001423"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments realtime_host when set without custom fallback hosts configured sets the realtime_host option" file="./spec/unit/rest/client_spec.rb" time="0.000599"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with a string token key instead of options hash sets the token" file="./spec/unit/rest/client_spec.rb" time="0.001409"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with token_details sets the token" file="./spec/unit/rest/client_spec.rb" time="0.001035"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments key only connects to the Ably service" file="./spec/unit/rest/client_spec.rb" time="0.000592"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments key only uses basic auth" file="./spec/unit/rest/client_spec.rb" time="0.000604"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments custom TLS port when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="0.000642"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint defaults to production" file="./spec/unit/rest/client_spec.rb" time="0.000865"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint with realtime_host option uses an alternate endpoint for Realtime clients" file="./spec/unit/rest/client_spec.rb" time="0.000758"><skipped/></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint with rest_host option uses an alternate endpoint for REST clients" file="./spec/unit/rest/client_spec.rb" time="0.000733"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint with tls_port option and a TLS connection uses the custom port for TLS requests" file="./spec/unit/rest/client_spec.rb" time="0.002260"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint with port option and non-TLS connections uses the custom port for non-TLS requests" file="./spec/unit/rest/client_spec.rb" time="0.001030"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments endpoint with environment option uses an alternate endpoint" file="./spec/unit/rest/client_spec.rb" time="0.000969"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with token_params configures default_token_params" file="./spec/unit/rest/client_spec.rb" time="0.003158"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with token sets the token" file="./spec/unit/rest/client_spec.rb" time="0.001247"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key_name" file="./spec/unit/rest/client_spec.rb" time="0.000798"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key" file="./spec/unit/rest/client_spec.rb" time="0.000683"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with a string key instead of options hash sets the key_secret" file="./spec/unit/rest/client_spec.rb" time="0.000824"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments with a string key instead of options hash uses basic auth" file="./spec/unit/rest/client_spec.rb" time="0.000864"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments key_name and key_secret constructs a key" file="./spec/unit/rest/client_spec.rb" time="0.000594"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set with custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="4.603120"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set with custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/rest/client_spec.rb" time="0.000896"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="0.000837"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set without custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/rest/client_spec.rb" time="0.000605"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="0.000641"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured sets the custom_host attribute" file="./spec/unit/rest/client_spec.rb" time="0.000695"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments rest_host when set with environment and without custom fallback hosts configured sets the environment attribute" file="./spec/unit/rest/client_spec.rb" time="0.000671"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments tls defaults to TLS" file="./spec/unit/rest/client_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments tls set to false uses plain text" file="./spec/unit/rest/client_spec.rb" time="0.000627"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments tls set to false uses HTTP" file="./spec/unit/rest/client_spec.rb" time="0.000784"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments custom port when set without custom fallback hosts configured has no default fallback hosts" file="./spec/unit/rest/client_spec.rb" time="0.000692"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments logger with log_level :none silences all logging with a NilLogger" file="./spec/unit/rest/client_spec.rb" time="0.000704"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments logger default specifies Logger::WARN log level" file="./spec/unit/rest/client_spec.rb" time="0.000713"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments logger default uses Ruby Logger" file="./spec/unit/rest/client_spec.rb" time="0.000722"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments logger with custom logger and log_level sets the custom log level" file="./spec/unit/rest/client_spec.rb" time="0.000661"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments logger with custom logger and log_level uses the custom logger" file="./spec/unit/rest/client_spec.rb" time="0.000772"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set with fallback_hosts_use_default sets the environment attribute" file="./spec/unit/rest/client_spec.rb" time="0.000599"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set with fallback_hosts_use_default uses the production default fallback hosts (#RTN17b)" file="./spec/unit/rest/client_spec.rb" time="0.000603"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set without custom fallback hosts configured sets the environment attribute" file="./spec/unit/rest/client_spec.rb" time="0.000601"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set without custom fallback hosts configured uses the default fallback hosts (#TBC, see https://github.com/ably/wiki/issues/361)" file="./spec/unit/rest/client_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set with custom fallback hosts configured uses the custom provided fallback hosts (#RSC15a)" file="./spec/unit/rest/client_spec.rb" time="0.000684"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client behaves like a client initializer with valid arguments environment when set with custom fallback hosts configured sets the environment attribute" file="./spec/unit/rest/client_spec.rb" time="0.000609"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options fallback_retry_timeout (#RSC15f) when provided configures a new timeout" file="./spec/unit/rest/client_spec.rb" time="0.000582"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options fallback_retry_timeout (#RSC15f) default is set to 10 minutes" file="./spec/unit/rest/client_spec.rb" time="0.000643"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options TLS disabled fails for any operation with basic auth and attempting to send an API key over a non-secure connection (#RSA1)" file="./spec/unit/rest/client_spec.rb" time="0.001751"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options :use_token_auth set to false without a key fails as a key is required if not using token auth" file="./spec/unit/rest/client_spec.rb" time="0.000588"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options :use_token_auth set to false with a key and :tls =&gt; false fails for any operation with basic auth and attempting to send an API key over a non-secure connection" file="./spec/unit/rest/client_spec.rb" time="0.001203"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options :use_token_auth set to true without a key or token fails as a key is required to issue tokens" file="./spec/unit/rest/client_spec.rb" time="0.000602"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options max_message_size is nil should return default 65536 (#TO3l8)" file="./spec/unit/rest/client_spec.rb" time="0.000596"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options max_message_size is customized 131072 bytes should return 131072" file="./spec/unit/rest/client_spec.rb" time="0.000573"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options max_message_size is not present should return default 65536 (#TO3l8)" file="./spec/unit/rest/client_spec.rb" time="0.000514"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options use agent set agent to non-default value default agent should return default ably agent" file="./spec/unit/rest/client_spec.rb" time="0.000508"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client initializer options use agent set agent to non-default value custom agent should overwrite client.agent" file="./spec/unit/rest/client_spec.rb" time="0.002527"></testcase>
<testcase classname="spec.unit.rest.client_spec" name="Ably::Rest::Client request_id generation includes request_id in URL" file="./spec/unit/rest/client_spec.rb" time="0.000709"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams :key missing from constructor raises an exception" file="./spec/unit/models/cipher_params_spec.rb" time="0.000688"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor with an incompatible :key_length constructor param raises an exception" file="./spec/unit/models/cipher_params_spec.rb" time="0.000787"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor as a binary encoded string contains the binary string" file="./spec/unit/models/cipher_params_spec.rb" time="0.000791"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor with an unsupported :key_length for aes-cbc encryption raises an exception" file="./spec/unit/models/cipher_params_spec.rb" time="0.000718"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor as nil raises an exception" file="./spec/unit/models/cipher_params_spec.rb" time="0.000521"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor as a URL safe base64 encoded string is a binary representation of the URL safe base64 encoded string" file="./spec/unit/models/cipher_params_spec.rb" time="0.000612"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor as a base64 encoded string is a binary representation of the base64 encoded string" file="./spec/unit/models/cipher_params_spec.rb" time="0.000849"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams#key with :key in constructor with an invalid type raises an exception" file="./spec/unit/models/cipher_params_spec.rb" time="0.000562"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with combined param in the constructor #mode contains the mode" file="./spec/unit/models/cipher_params_spec.rb" time="0.000685"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with combined param in the constructor #algorithm contains the algorithm" file="./spec/unit/models/cipher_params_spec.rb" time="0.000665"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with combined param in the constructor #cipher_type contains the complete algorithm string as an upper case string" file="./spec/unit/models/cipher_params_spec.rb" time="0.000680"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with combined param in the constructor #key_length contains the key_length" file="./spec/unit/models/cipher_params_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with specified params in the constructor #key_length contains the key_length" file="./spec/unit/models/cipher_params_spec.rb" time="0.000635"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with specified params in the constructor #algorithm contains the algorithm" file="./spec/unit/models/cipher_params_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with specified params in the constructor #mode contains the mode" file="./spec/unit/models/cipher_params_spec.rb" time="0.000575"></testcase>
<testcase classname="spec.unit.models.cipher_params_spec" name="Ably::Models::CipherParams with specified params in the constructor #cipher_type contains the complete algorithm string as an upper case string" file="./spec/unit/models/cipher_params_spec.rb" time="0.000604"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails to_json with all attributes and values returns all attributes" file="./spec/unit/models/token_details_spec.rb" time="0.000632"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails to_json with only a token string returns populated attributes" file="./spec/unit/models/token_details_spec.rb" time="0.000544"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails TokenDetails conversion methods with a JSON object returns a new TokenDetails object from the JSON" file="./spec/unit/models/token_details_spec.rb" time="0.000558"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails TokenDetails conversion methods with a TokenDetails object returns the TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model is immutable prevents changes" file="./spec/unit/models/token_details_spec.rb" time="0.000627"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model is immutable dups options" file="./spec/unit/models/token_details_spec.rb" time="0.000575"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/token_details_spec.rb" time="0.000616"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #key_name retrieves attribute :key_name" file="./spec/unit/models/token_details_spec.rb" time="0.000555"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/token_details_spec.rb" time="0.000578"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/token_details_spec.rb" time="0.000584"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model attributes #token retrieves attribute :token" file="./spec/unit/models/token_details_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/token_details_spec.rb" time="0.000614"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/token_details_spec.rb" time="0.000575"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is true when attributes are the same" file="./spec/unit/models/token_details_spec.rb" time="0.000651"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #== is false when class type differs" file="./spec/unit/models/token_details_spec.rb" time="0.000578"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/token_details_spec.rb" time="0.000608"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is false when class type differs" file="./spec/unit/models/token_details_spec.rb" time="0.000547"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is false when attributes are not the same" file="./spec/unit/models/token_details_spec.rb" time="0.000616"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails == is true when attributes are the same" file="./spec/unit/models/token_details_spec.rb" time="0.001730"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? once grace period buffer has passed is true" file="./spec/unit/models/token_details_spec.rb" time="0.000707"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? within grace period buffer is false" file="./spec/unit/models/token_details_spec.rb" time="0.000630"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? when expires is not available (i.e. string tokens) is always false" file="./spec/unit/models/token_details_spec.rb" time="0.000625"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? with :from attribute is false" file="./spec/unit/models/token_details_spec.rb" time="0.000650"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #expired? with :from attribute is true" file="./spec/unit/models/token_details_spec.rb" time="0.000572"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes #capability retrieves attribute :capability as parsed JSON" file="./spec/unit/models/token_details_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires when converted to JSON is in milliseconds" file="./spec/unit/models/token_details_spec.rb" time="0.000616"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued when converted to JSON is in milliseconds" file="./spec/unit/models/token_details_spec.rb" time="0.000594"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued with :issued option as a Time in constructor retrieves attribute :issued as Time" file="./spec/unit/models/token_details_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires with :expires option as milliseconds in constructor retrieves attribute :expires as Time" file="./spec/unit/models/token_details_spec.rb" time="0.000590"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #issued with :issued option as milliseconds in constructor retrieves attribute :issued as Time" file="./spec/unit/models/token_details_spec.rb" time="0.000532"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails attributes  #expires with :expires option as a Time in constructor retrieves attribute :expires as Time" file="./spec/unit/models/token_details_spec.rb" time="0.000607"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with JSON string returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.001181"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with JSON-like object returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.000713"></testcase>
<testcase classname="spec.unit.models.token_details_spec" name="Ably::Models::TokenDetails from_json (#TD7) with Ruby idiomatic Hash object returns a valid TokenDetails object" file="./spec/unit/models/token_details_spec.rb" time="0.000680"></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.000908"></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.001247"></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.000768"></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.000772"></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.001072"></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.000699"></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.000561"></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.000612"></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.000642"></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.000648"></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.000626"></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.000546"></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.000544"></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.000589"></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.000679"></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.000611"></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.000596"></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.000565"></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.000546"></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.001625"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params with a base64-encoded :key param converts the key to binary" file="./spec/unit/util/crypto_spec.rb" time="0.000778"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params without a :key param raises an exception" file="./spec/unit/util/crypto_spec.rb" time="0.000612"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params with just a :key param uses the defaults" file="./spec/unit/util/crypto_spec.rb" time="0.000765"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params with just a :key param contains the provided key" file="./spec/unit/util/crypto_spec.rb" time="0.000714"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params with just a :key param returns a CipherParams object" file="./spec/unit/util/crypto_spec.rb" time="0.000621"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto get_default_params with provided params overrides the defaults" file="./spec/unit/util/crypto_spec.rb" time="0.000615"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto defaults match other client libraries" file="./spec/unit/util/crypto_spec.rb" time="0.000524"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto#encrypt &amp; #decrypt encrypts and decrypts an empty string" file="./spec/unit/util/crypto_spec.rb" time="0.000930"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto#encrypt &amp; #decrypt encrypts and decrypts a non-empty string" file="./spec/unit/util/crypto_spec.rb" time="0.000866"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto using shared client lib fixture data with AES-256-CBC behaves like an Ably encrypter and decrypter (#RTL7d) text payload encrypts exactly the same binary data as other client libraries" file="./spec/unit/util/crypto_spec.rb" time="0.001075"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto using shared client lib fixture data with AES-256-CBC behaves like an Ably encrypter and decrypter (#RTL7d) text payload decrypts exactly the same binary data as other client libraries" file="./spec/unit/util/crypto_spec.rb" time="0.000999"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto using shared client lib fixture data with AES-128-CBC behaves like an Ably encrypter and decrypter (#RTL7d) text payload encrypts exactly the same binary data as other client libraries" file="./spec/unit/util/crypto_spec.rb" time="0.000773"></testcase>
<testcase classname="spec.unit.util.crypto_spec" name="Ably::Util::Crypto using shared client lib fixture data with AES-128-CBC behaves like an Ably encrypter and decrypter (#RTL7d) text payload decrypts exactly the same binary data as other client libraries" file="./spec/unit/util/crypto_spec.rb" time="0.000775"></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.000815"></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.000798"></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.000729"></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.001024"></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.000739"></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.001051"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger uses the language provided Logger by default" file="./spec/unit/logger_spec.rb" time="0.000300"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals delegates to the default Logger object" file="./spec/unit/logger_spec.rb" time="0.000466"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter when debugging uses short time format" file="./spec/unit/logger_spec.rb" time="0.000447"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter when info -&gt; fatal uses long time format" file="./spec/unit/logger_spec.rb" time="0.000461"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter with Realtime client with Realtime disconnected client formats logs with an empty client ID" file="./spec/unit/logger_spec.rb" time="0.000982"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter with Realtime client with Realtime connected client formats logs with a client ID" file="./spec/unit/logger_spec.rb" time="0.000782"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter severity argument can be a string" file="./spec/unit/logger_spec.rb" time="0.000325"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter severity argument can be an Integer" file="./spec/unit/logger_spec.rb" time="0.000392"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger internals formatter with REST client formats logs without a client ID" file="./spec/unit/logger_spec.rb" time="0.000334"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger with blocks does not call the block unless the log level is met" file="./spec/unit/logger_spec.rb" time="0.000478"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger with blocks with an exception in the logger block catches the error and continues" file="./spec/unit/logger_spec.rb" time="0.000657"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger with a custom Logger with an invalid interface raises an exception" file="./spec/unit/logger_spec.rb" time="0.000387"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger with a custom Logger with a valid interface delegates log messages to logger" file="./spec/unit/logger_spec.rb" time="0.000465"></testcase>
<testcase classname="spec.unit.logger_spec" name="Ably::Logger with a custom Logger with a valid interface is used" file="./spec/unit/logger_spec.rb" time="0.000372"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats returns value for message counts" file="./spec/unit/models/stats_spec.rb" time="0.000634"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000630"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats returns a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.001819"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats returns zero for empty values" file="./spec/unit/models/stats_spec.rb" time="0.000618"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats returns value for all data transferred" file="./spec/unit/models/stats_spec.rb" time="0.000711"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats #presence is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000669"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats #all is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000653"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#all stats #messages is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000567"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#interval_time returns a Time object representing the start of the interval" file="./spec/unit/models/stats_spec.rb" time="0.000681"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#interval_granularity returns the granularity of the interval_id" file="./spec/unit/models/stats_spec.rb" time="0.000675"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats returns value for all presence data" file="./spec/unit/models/stats_spec.rb" time="0.000648"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats returns value for realtime message counts" file="./spec/unit/models/stats_spec.rb" time="0.000656"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats returns a MessageTraffic object" file="./spec/unit/models/stats_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000640"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats #all is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000600"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats #realtime is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000552"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats #rest is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000550"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#inbound stats #webhook is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000654"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats returns zero for empty values" file="./spec/unit/models/stats_spec.rb" time="0.000648"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats returns value for all peak connections" file="./spec/unit/models/stats_spec.rb" time="0.000646"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000613"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats returns value for tls opened counts" file="./spec/unit/models/stats_spec.rb" time="0.000654"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats returns a ConnectionTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000598"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats #all is a ResourceCount object" file="./spec/unit/models/stats_spec.rb" time="0.000553"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats #plain is a ResourceCount object" file="./spec/unit/models/stats_spec.rb" time="0.000545"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#connections stats #tls is a ResourceCount object" file="./spec/unit/models/stats_spec.rb" time="0.000627"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats returns value for message counts" file="./spec/unit/models/stats_spec.rb" time="0.000592"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats returns zero for empty values" file="./spec/unit/models/stats_spec.rb" time="0.000644"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats returns value for all data transferred" file="./spec/unit/models/stats_spec.rb" time="0.000658"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats returns a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000584"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats #all is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000614"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats #messages is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000620"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#persisted stats #presence is a MessageCount object" file="./spec/unit/models/stats_spec.rb" time="0.000611"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats returns value for succeeded" file="./spec/unit/models/stats_spec.rb" time="0.000569"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats returns a RequestCount object" file="./spec/unit/models/stats_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000634"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats returns value for failed" file="./spec/unit/models/stats_spec.rb" time="0.000575"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats #refused is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000615"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats #failed is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000644"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#token_requests stats #succeeded is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000622"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000529"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats returns a ResourceCount object" file="./spec/unit/models/stats_spec.rb" time="0.001301"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats returns value for peak channels" file="./spec/unit/models/stats_spec.rb" time="0.000589"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats returns value for opened counts" file="./spec/unit/models/stats_spec.rb" time="0.000695"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats returns zero for empty values" file="./spec/unit/models/stats_spec.rb" time="0.000657"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats #mean is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000634"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats #refused is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000591"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats #opened is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000509"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats #min is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000614"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#channels stats #peak is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000543"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats returns value for realtime message counts" file="./spec/unit/models/stats_spec.rb" time="0.000578"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats returns value for all presence data" file="./spec/unit/models/stats_spec.rb" time="0.000533"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000576"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats returns a MessageTraffic object" file="./spec/unit/models/stats_spec.rb" time="0.000553"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats #webhook is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000643"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats #realtime is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000563"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats #rest is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#outbound stats #all is a MessageTypes object" file="./spec/unit/models/stats_spec.rb" time="0.000606"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats returns a RequestCount object" file="./spec/unit/models/stats_spec.rb" time="0.000600"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats returns value for succeeded" file="./spec/unit/models/stats_spec.rb" time="0.000587"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats returns value for failed" file="./spec/unit/models/stats_spec.rb" time="0.000612"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats raises an exception for unknown attributes" file="./spec/unit/models/stats_spec.rb" time="0.000613"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats #failed is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000596"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats #refused is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000566"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats#api_requests stats #succeeded is a Integer object" file="./spec/unit/models/stats_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #granularity_from_interval_id returns a :month interval_id for 2014-02" file="./spec/unit/models/stats_spec.rb" time="0.000561"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #granularity_from_interval_id fails with an invalid interval_id 14-20" file="./spec/unit/models/stats_spec.rb" time="0.000580"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #granularity_from_interval_id returns a :minute interval_id for 2014-02-03:05:06" file="./spec/unit/models/stats_spec.rb" time="0.000611"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #granularity_from_interval_id returns a :hour interval_id for 2014-02-03:05" file="./spec/unit/models/stats_spec.rb" time="0.000607"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #granularity_from_interval_id returns a :day interval_id for 2014-02-03" file="./spec/unit/models/stats_spec.rb" time="0.000595"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #from_interval_id converts a month interval_id 2014-02 into a Time object in UTC 0" file="./spec/unit/models/stats_spec.rb" time="0.000560"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #from_interval_id converts an hour interval_id 2014-02-03:05 into a Time object in UTC 0" file="./spec/unit/models/stats_spec.rb" time="0.000571"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #from_interval_id converts a day interval_id 2014-02-03 into a Time object in UTC 0" file="./spec/unit/models/stats_spec.rb" time="0.000559"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #from_interval_id converts a minute interval_id 2014-02-03:05:06 into a Time object in UTC 0" file="./spec/unit/models/stats_spec.rb" time="0.000500"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #from_interval_id fails with an invalid interval_id 14-20" file="./spec/unit/models/stats_spec.rb" time="0.000526"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is +02:00 converts time 2014-02-03:06 with granularity :hour into 2014-02-03:04 at UTC +00:00" file="./spec/unit/models/stats_spec.rb" time="0.000535"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC converts time 2014-02-03:05:06 with granularity :day into 2014-02-03" file="./spec/unit/models/stats_spec.rb" time="0.000474"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC converts time 2014-02-03:05:06 with granularity :month into 2014-02" file="./spec/unit/models/stats_spec.rb" time="0.000513"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC fails with invalid time" file="./spec/unit/models/stats_spec.rb" time="0.000521"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC fails with invalid granularity" file="./spec/unit/models/stats_spec.rb" time="0.000482"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC converts time 2014-02-03:05:06 with granularity :minute into 2014-02-03:05:06" file="./spec/unit/models/stats_spec.rb" time="0.000517"></testcase>
<testcase classname="spec.unit.models.stats_spec" name="Ably::Models::Stats class methods #to_interval_id when time zone of time argument is UTC converts time 2014-02-03:05:06 with granularity :hour into 2014-02-03:05" file="./spec/unit/models/stats_spec.rb" time="0.001238"></testcase>
<testcase classname="spec.unit.models.channel_details_spec" name="Ably::Models::ChannelDetails#name should return name" file="./spec/unit/models/channel_details_spec.rb" time="0.000525"></testcase>
<testcase classname="spec.unit.models.channel_details_spec" name="Ably::Models::ChannelDetails#channel_id should return channel id" file="./spec/unit/models/channel_details_spec.rb" time="0.000498"></testcase>
<testcase classname="spec.unit.models.channel_details_spec" name="Ably::Models::ChannelDetails#status should return status" file="./spec/unit/models/channel_details_spec.rb" time="0.000826"></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.000694"></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.000772"></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.000712"></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.000755"></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.000846"></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.000982"></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.000707"></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.000672"></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.000624"></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.000583"></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.000652"></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.000558"></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.000667"></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.000618"></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.000521"></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.000685"></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.000724"></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.000765"></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.000692"></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.000585"></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.000716"></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.001254"></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.001050"></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.001082"></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.001014"></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.000662"></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.000625"></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.001790"></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.000680"></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.000611"></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.000667"></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.000615"></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.000630"></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.000656"></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.000632"></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.000571"></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.000669"></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.000643"></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.000618"></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.000573"></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.000643"></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.000717"></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.000646"></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.000635"></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.000821"></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.000815"></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.000728"></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.000706"></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.000778"></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.000653"></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.000571"></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.000595"></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.000637"></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.000631"></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.000642"></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.000657"></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.000604"></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.012932"></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.007102"></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.012076"></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.000776"></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.000577"></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.000596"></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.000607"></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.000590"></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.000517"></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.000515"></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.000710"></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.000685"></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.000579"></testcase>
<testcase classname="spec.unit.models.delta_extras_spec" name="Ably::Models::DeltaExtras should have `from` attribute" file="./spec/unit/models/delta_extras_spec.rb" time="0.000628"></testcase>
<testcase classname="spec.unit.models.delta_extras_spec" name="Ably::Models::DeltaExtras should have `format` attribute" file="./spec/unit/models/delta_extras_spec.rb" time="0.000646"></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.001287"></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.000997"></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.000972"></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.001030"></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.000997"></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.001026"></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.001247"></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.001290"></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.000786"></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.001041"></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.000923"></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.000836"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/rest/channel_spec.rb" time="0.001610"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/rest/channel_spec.rb" time="0.000814"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as frozen UTF_8 string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.000827"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as frozen UTF_8 string remains as UTF-8" file="./spec/unit/rest/channel_spec.rb" time="0.000725"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as UTF_8 string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.000709"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as UTF_8 string remains as UTF-8" file="./spec/unit/rest/channel_spec.rb" time="0.000810"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as Nil raises an argument error" file="./spec/unit/rest/channel_spec.rb" time="0.000749"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as Integer raises an argument error" file="./spec/unit/rest/channel_spec.rb" time="0.000801"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/rest/channel_spec.rb" time="0.002466"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#initializer as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/rest/channel_spec.rb" time="0.000948"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument as Integer raises an argument error" file="./spec/unit/rest/channel_spec.rb" time="0.000851"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument max message size exceeded when max_message_size is 10 bytes and a message size is 2 bytes should send a message" file="./spec/unit/rest/channel_spec.rb" time="0.001161"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument max message size exceeded when max_message_size is 10 bytes and a message size is 11 bytes should raise Ably::Exceptions::MaxMessageSizeExceeded" file="./spec/unit/rest/channel_spec.rb" time="0.001078"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument max message size exceeded when max_message_size is nil and a message size is 65537 bytes should raise Ably::Exceptions::MaxMessageSizeExceeded" file="./spec/unit/rest/channel_spec.rb" time="0.001035"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument max message size exceeded when max_message_size is 65536 bytes and a message size is 10 bytes should send a message" file="./spec/unit/rest/channel_spec.rb" time="0.001122"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument max message size exceeded when max_message_size is 65536 bytes and a message size is 65537 bytes should raise Ably::Exceptions::MaxMessageSizeExceeded" file="./spec/unit/rest/channel_spec.rb" time="0.001092"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument as frozen UTF_8 string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.001131"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument as UTF_8 string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.001211"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument as SHIFT_JIS string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.001126"></testcase>
<testcase classname="spec.unit.rest.channel_spec" name="Ably::Rest::Channel#publish name argument as ASCII_8BIT string is permitted" file="./spec/unit/rest/channel_spec.rb" time="0.001183"></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.000575"></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.000627"></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.000665"></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.000619"></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.000600"></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.000615"></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.000686"></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.000665"></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.000565"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth defaults should have no default capability" file="./spec/unit/auth_spec.rb" time="0.000541"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth defaults should have no default TTL" file="./spec/unit/auth_spec.rb" time="0.000574"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/auth_spec.rb" time="0.000696"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/auth_spec.rb" time="0.000592"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option with nil value is permitted" file="./spec/unit/auth_spec.rb" time="0.000629"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as Integer raises an argument error" file="./spec/unit/auth_spec.rb" time="0.000626"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as UTF_8 string remains as UTF-8" file="./spec/unit/auth_spec.rb" time="0.000635"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as UTF_8 string is permitted" file="./spec/unit/auth_spec.rb" time="0.000610"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/auth_spec.rb" time="0.000598"></testcase>
<testcase classname="spec.unit.auth_spec" name="Ably::Auth client_id option as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/auth_spec.rb" time="0.001510"></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.000627"></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.000678"><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.000614"></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.000637"></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.000642"></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.000631"></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.000571"></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.000614"></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.000619"></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.000516"></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.000548"></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.000649"></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.000624"></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.000545"></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.000613"></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.000621"></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.000534"></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.000515"></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.000560"></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.000540"></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.000459"></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.000513"></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.000516"></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.000481"></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.000526"></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.000595"></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.000525"></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.000626"></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.000855"></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.000553"></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.000637"></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.000602"></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.000604"></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 two similar Enums with shared symbol values provides compatability for the equivalent symbol values" file="./spec/unit/modules/enum_spec.rb" time="0.000532"></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.000615"></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.000629"></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.000581"></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.001561"></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.000678"></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.000638"></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.000583"></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.000769"></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.000636"></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.000606"></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.000552"></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.000616"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response supports pagination" file="./spec/unit/models/paginated_result_spec.rb" time="0.000894"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response is not the last page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000878"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response has next page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000893"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page returns nil when trying to access the last page when it is the last page" file="./spec/unit/models/paginated_result_spec.rb" time="0.001133"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page retrieves the next page of results" file="./spec/unit/models/paginated_result_spec.rb" time="0.001119"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page is the last page" file="./spec/unit/models/paginated_result_spec.rb" time="0.001095"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page does not have a next page" file="./spec/unit/models/paginated_result_spec.rb" time="0.001097"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page returns another PaginatedResult" file="./spec/unit/models/paginated_result_spec.rb" time="0.001071"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page and then first page returns a PaginatedResult" file="./spec/unit/models/paginated_result_spec.rb" time="0.001241"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with paged http response accessing next page and then first page retrieves the first page of results" file="./spec/unit/models/paginated_result_spec.rb" time="0.001249"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items #last gets the last item in page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000804"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items is Enumerable" file="./spec/unit/models/paginated_result_spec.rb" time="0.000747"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items #first gets the first item in page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000695"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items provides [] accessor method" file="./spec/unit/models/paginated_result_spec.rb" time="0.000750"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items is iterable" file="./spec/unit/models/paginated_result_spec.rb" time="0.000790"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items returns correct length from body" file="./spec/unit/models/paginated_result_spec.rb" time="0.000763"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items with coercion returns coerced objects" file="./spec/unit/models/paginated_result_spec.rb" time="0.000788"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items #each yields each item" file="./spec/unit/models/paginated_result_spec.rb" time="0.000848"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult#items #each returns an enumerator" file="./spec/unit/models/paginated_result_spec.rb" time="0.000868"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult paged transformations with option async_blocking_operations: true #first calls the errback callback when first page headers are missing" file="./spec/unit/models/paginated_result_spec.rb" time="0.011177"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult paged transformations with option async_blocking_operations: true #next allows a success callback block to be added" file="./spec/unit/models/paginated_result_spec.rb" time="0.003489"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult paged transformations with option async_blocking_operations: true #next returns a SafeDeferrable that catches exceptions in callbacks and logs them" file="./spec/unit/models/paginated_result_spec.rb" time="0.002265"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult paged transformations with each block calls the block for each result on second page after retrieving the results" file="./spec/unit/models/paginated_result_spec.rb" time="0.001025"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult paged transformations with each block calls the block for each result after retrieving the results" file="./spec/unit/models/paginated_result_spec.rb" time="0.000983"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with non paged http response is the last page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000814"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with non paged http response returns nil when accessing next page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000841"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with non paged http response does not have next page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000822"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with non paged http response does not support pagination" file="./spec/unit/models/paginated_result_spec.rb" time="0.000856"></testcase>
<testcase classname="spec.unit.models.paginated_result_spec" name="Ably::Models::PaginatedResult with non paged http response returns nil when accessing first page" file="./spec/unit/models/paginated_result_spec.rb" time="0.000805"></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.000588"></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.000472"></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.000553"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields with protocol message #timestamp prefers embedded timestamp" file="./spec/unit/models/message_spec.rb" time="0.000796"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields with protocol message #id prefers embedded ID" file="./spec/unit/models/message_spec.rb" time="0.000694"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields without protocol message #id uses embedded ID" file="./spec/unit/models/message_spec.rb" time="0.000679"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message from REST request with embedded fields without protocol message #timestamp uses embedded timestamp" file="./spec/unit/models/message_spec.rb" time="0.000804"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has a connectionId attribute with a protocol message with a different connectionId uses the model value" file="./spec/unit/models/message_spec.rb" time="0.000784"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has a connectionId attribute but no protocol message uses the model value" file="./spec/unit/models/message_spec.rb" time="0.000651"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has no connectionId attribute and no protocol message uses the model value" file="./spec/unit/models/message_spec.rb" time="0.000651"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#connection_id attribute when this model has no connectionId attribute with a protocol message with a connectionId uses the model value" file="./spec/unit/models/message_spec.rb" time="0.000728"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when no delta should return nil" file="./spec/unit/models/message_spec.rb" time="0.000696"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when delta should return vcdiff format" file="./spec/unit/models/message_spec.rb" time="0.000609"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#delta_extras (TM2i) when delta should return 1234-1234-5678-9009 message id" file="./spec/unit/models/message_spec.rb" time="0.000703"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#timestamp retrieves attribute :timestamp as Time object from ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000761"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a Hash contains a Hash Json object" file="./spec/unit/models/message_spec.rb" time="0.000686"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a string raises an exception" file="./spec/unit/models/message_spec.rb" time="0.000745"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when a Json Array contains a Json Array object" file="./spec/unit/models/message_spec.rb" time="0.000660"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#extras (#TM2i) when missing is nil" file="./spec/unit/models/message_spec.rb" time="0.000646"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is false when class type differs" file="./spec/unit/models/message_spec.rb" time="0.000641"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is false when attributes are not the same" file="./spec/unit/models/message_spec.rb" time="0.002148"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #== is true when attributes are the same" file="./spec/unit/models/message_spec.rb" time="0.000875"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #to_json returns a JSON string with Ably payload naming" file="./spec/unit/models/message_spec.rb" time="0.000814"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model is immutable prevents changes" file="./spec/unit/models/message_spec.rb" time="0.000764"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model is immutable dups options" file="./spec/unit/models/message_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model #to_msgpack returns a msgpack object with Ably payload naming" file="./spec/unit/models/message_spec.rb" time="0.000701"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #[] provides accessor method to #attributes" file="./spec/unit/models/message_spec.rb" time="0.000592"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #attributes provides access to #attributes" file="./spec/unit/models/message_spec.rb" time="0.000710"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #id retrieves attribute :id" file="./spec/unit/models/message_spec.rb" time="0.000674"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #name retrieves attribute :name" file="./spec/unit/models/message_spec.rb" time="0.000659"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #encoding retrieves attribute :encoding" file="./spec/unit/models/message_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #data retrieves attribute :data" file="./spec/unit/models/message_spec.rb" time="0.000650"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message serialization of the Message object (#RSL1j) behaves like a model attributes #client_id retrieves attribute :client_id" file="./spec/unit/models/message_spec.rb" time="0.000668"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with binary data adds Base64 encoding" file="./spec/unit/models/message_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with binary data encodes as Base64 so that it can be converted to UTF-8 automatically by JSON#dump" file="./spec/unit/models/message_spec.rb" time="0.000747"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#to_json with valid data converts the attribute back to Java mixedCase notation using string keys" file="./spec/unit/models/message_spec.rb" time="0.000743"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should not allow changes to the payload" file="./spec/unit/models/message_spec.rb" time="0.000901"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should generate a message ID from the index, serial and connection id" file="./spec/unit/models/message_spec.rb" time="0.000797"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage should not modify the data payload" file="./spec/unit/models/message_spec.rb" time="0.000746"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage with identical message objects recognises the index based on the object ID as opposed to message payload" file="./spec/unit/models/message_spec.rb" time="0.000915"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message part of ProtocolMessage with identical message objects provide a unique ID:index" file="./spec/unit/models/message_spec.rb" time="0.000869"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000658"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.000706"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000689"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000623"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.001423"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000715"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :encoding as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.000779"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.000721"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000725"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000702"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000736"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.000655"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000619"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000610"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :name as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000712"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as UTF_8 string is permitted" file="./spec/unit/models/message_spec.rb" time="0.000715"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as UTF_8 string remains as UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000712"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as ASCII_8BIT string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000684"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as ASCII_8BIT string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000724"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as Integer raises an argument error" file="./spec/unit/models/message_spec.rb" time="0.000629"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as SHIFT_JIS string gets converted to UTF-8" file="./spec/unit/models/message_spec.rb" time="0.000615"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as SHIFT_JIS string is compatible with original encoding" file="./spec/unit/models/message_spec.rb" time="0.000710"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message initialized with :client_id as Nil is permitted" file="./spec/unit/models/message_spec.rb" time="0.000684"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with an encoding returns a message object" file="./spec/unit/models/message_spec.rb" time="0.000908"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with no encoding returns a message object" file="./spec/unit/models/message_spec.rb" time="0.000856"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with no encoding with a block does not call the block" file="./spec/unit/models/message_spec.rb" time="0.000797"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with a custom encoding returns a message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/message_spec.rb" time="0.000894"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with invalid Cipher encoding with a block calls the block with the exception" file="./spec/unit/models/message_spec.rb" time="0.001131"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with invalid Cipher encoding without a block raises an exception" file="./spec/unit/models/message_spec.rb" time="0.001024"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded (#TM3) with a Cipher encoding returns a message object with the residual incompatible transforms left in the encoding property" file="./spec/unit/models/message_spec.rb" time="0.002165"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.000733"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000741"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000712"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message with ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.000666"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000629"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000731"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.000707"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with another Message without ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.000692"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage has no ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000631"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.000645"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.000669"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON without ProtocolMessage raises an exception when accessing ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000711"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage has a ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage provides access to ProtocolMessage" file="./spec/unit/models/message_spec.rb" time="0.000695"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage initializes with the JSON" file="./spec/unit/models/message_spec.rb" time="0.000723"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Message conversion method with JSON with ProtocolMessage returns a Message object" file="./spec/unit/models/message_spec.rb" time="0.000691"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#from_encoded_array (#TM3) with no encoding returns an Array of message objects" file="./spec/unit/models/message_spec.rb" time="0.001054"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message Java naming converts the attribute to ruby symbol naming convention" file="./spec/unit/models/message_spec.rb" time="0.000686"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size nil (#TO3l8e) should return 19 bytes" file="./spec/unit/models/message_spec.rb" time="0.000736"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size Array (#TO3l8b) should return 24 bytes" file="./spec/unit/models/message_spec.rb" time="0.000702"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size extras (#TO3l8d) should return 57 bytes" file="./spec/unit/models/message_spec.rb" time="0.000702"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size String (#TO3l8a) should return 33 bytes" file="./spec/unit/models/message_spec.rb" time="0.000694"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#size Object (#TO3l8b) should return 38 bytes" file="./spec/unit/models/message_spec.rb" time="0.000732"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#protocol_message_index (#RTL21) should return correct protocol_message_index" file="./spec/unit/models/message_spec.rb" time="0.000776"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#id (#RSL1j) exposes the #id attribute" file="./spec/unit/models/message_spec.rb" time="0.000678"></testcase>
<testcase classname="spec.unit.models.message_spec" name="Ably::Models::Message#id (#RSL1j) #as_json exposes the #id attribute" file="./spec/unit/models/message_spec.rb" time="0.001412"></testcase>
</testsuite>
