<testsuites tests='1064' failures='0' skipped='0' time='844.95141'>
  <testsuite name='Ably-iOS-Tests' time='844.95141' tests='1064' failures='0' skipped='0'>
    <testsuite name='ARTArchiveTests' time='0.012' tests='1' failures='0' skipped='0'>
      <testcase name='test_art_unarchivedObjectOfClass_for_state_machine_states' classname='ARTArchiveTests' time='0.012'/>
    </testsuite>
    <testsuite name='ARTDefaultTests' time='0.00064' tests='1' failures='0' skipped='0'>
      <testcase name='testVersions()' classname='ARTDefaultTests' time='0.00064'/>
    </testsuite>
    <testsuite name='ARTInternalLogTests' time='0.00278' tests='6' failures='0' skipped='0'>
      <testcase name='test_ARTLogDebug' classname='ARTInternalLogTests' time='0.00065'/>
      <testcase name='test_ARTLogError' classname='ARTInternalLogTests' time='0.00061'/>
      <testcase name='test_ARTLogInfo' classname='ARTInternalLogTests' time='0.00042'/>
      <testcase name='test_ARTLogVerbose' classname='ARTInternalLogTests' time='0.00038'/>
      <testcase name='test_ARTLogWarn' classname='ARTInternalLogTests' time='0.00037'/>
      <testcase name='test_classMethodLogger' classname='ARTInternalLogTests' time='0.00035'/>
    </testsuite>
    <testsuite name='AttachRetryStateTests' time='0.00196' tests='3' failures='0' skipped='0'>
      <testcase name='test_addRetryAttempt()' classname='AttachRetryStateTests' time='0.00087'/>
      <testcase name='test_transitionToAttachingOrSuspendedStateDoesNotResetRetrySequence()' classname='AttachRetryStateTests' time='0.00055'/>
      <testcase name='test_transitionToNonAttachingOrSuspendedStateResetsRetrySequence()' classname='AttachRetryStateTests' time='0.00054'/>
    </testsuite>
    <testsuite name='AuthTests' time='80.36621' tests='157' failures='0' skipped='0'>
      <testcase name='test__001__should_not_force_token_auth_when_clientId_is_set()' classname='AuthTests' time='4.0'/>
      <testcase name='test__002__should_accept_authURL_response_with_timestamp_argument_as_string()' classname='AuthTests' time='0.34'/>
      <testcase name='test__003__Basic__should_work_over_HTTPS_only()' classname='AuthTests' time='0.0073'/>
      <testcase name='test__004__Basic__should_send_the_API_key_in_the_Authorization_header()' classname='AuthTests' time='0.18'/>
      <testcase name='test__005__Basic__should_be_default_when_an_API_key_is_set()' classname='AuthTests' time='0.0006'/>
      <testcase name='test__006__Token__TTL_should_default_to_be_omitted()' classname='AuthTests' time='0.00073'/>
      <testcase name='test__007__Token__should_URL_query_be_correctly_encoded()' classname='AuthTests' time='0.0037'/>
      <testcase name='test__008__Token__should_omit_capability_field_if_it_is_not_specified()' classname='AuthTests' time='0.16'/>
      <testcase name='test__009__Token__should_add_capability_field_if_the_user_specifies_it()' classname='AuthTests' time='0.19'/>
      <testcase name='test__010__Token__token_auth__should_work_over_HTTP()' classname='AuthTests' time='0.28'/>
      <testcase name='test__011__Token__token_auth__should_work_over_HTTPS()' classname='AuthTests' time='0.36'/>
      <testcase name='test__012__Token__token_auth__for_REST_requests__should_send_the_token_in_the_Authorization_header()' classname='AuthTests' time='0.37'/>
      <testcase name='test__013__Token__token_auth__for_Realtime_connections__should_send_the_token_in_the_querystring_as_a_param_named_accessToken()' classname='AuthTests' time='0.17'/>
      <testcase name='test__014__Token__authentication_method__should_be_default_auth_method_when_options__useTokenAuth_is_set()' classname='AuthTests' time='0.0006'/>
      <testcase name='test__015__Token__authentication_method__should_be_default_auth_method_when_options__authUrl_is_set()' classname='AuthTests' time='0.00045'/>
      <testcase name='test__016__Token__authentication_method__should_be_default_auth_method_when_options__authCallback_is_set()' classname='AuthTests' time='0.00063'/>
      <testcase name='test__017__Token__authentication_method__should_be_default_auth_method_when_options__tokenDetails_is_set()' classname='AuthTests' time='0.00043'/>
      <testcase name='test__018__Token__authentication_method__should_be_default_auth_method_when_options__token_is_set()' classname='AuthTests' time='0.00042'/>
      <testcase name='test__019__Token__authentication_method__should_be_default_auth_method_when_options__key_is_set()' classname='AuthTests' time='0.00053'/>
      <testcase name='test__020__Token__authentication_method__should_indicate_an_error_and_not_retry_the_request_when_the_server_responds_with_a_token_error_and_there_is_no_way_to_renew_the_token()' classname='AuthTests' time='0.19'/>
      <testcase name='test__021__Token__authentication_method__should_transition_the_connection_to_the_FAILED_state_when_the_server_responds_with_a_token_error_and_there_is_no_way_to_renew_the_token()' classname='AuthTests' time='3.0'/>
      <testcase name='test__022__Token__authentication_method__on_token_error__reissues_token_and_retries_REST_requests()' classname='AuthTests' time='5.0'/>
      <testcase name='test__023__Token__authentication_method__in_REST__if_the_token_creation_failed_or_the_subsequent_request_with_the_new_token_failed_due_to_a_token_error__then_the_request_should_result_in_an_error()' classname='AuthTests' time='0.007'/>
      <testcase name='test__024__Token__authentication_method__in_Realtime__if_the_token_creation_failed_then_the_connection_should_move_to_the_DISCONNECTED_state_and_reports_the_error()' classname='AuthTests' time='0.33'/>
      <testcase name='test__025__Token__authentication_method__in_Realtime__if_the_connection_fails_due_to_a_terminal_token_error__then_the_connection_should_move_to_the_FAILED_state_and_reports_the_error()' classname='AuthTests' time='1.0'/>
      <testcase name='test__026__Token__authentication_method__if_a_request_by_a_realtime_client_to_an_authUrl_results_in_an_HTTP_403_the_client_library_should_transition_to_the_FAILED_state()' classname='AuthTests' time='0.3'/>
      <testcase name='test__027__Token__authentication_method__if_an_authCallback_results_in_an_HTTP_403_the_client_library_should_transition_to_the_FAILED_state()' classname='AuthTests' time='0.0028'/>
      <testcase name='test__028__Token__authentication_method__local_token_validity_check__should_be_done_if_queryTime_is_true_and_local_time_is_in_sync_with_server()' classname='AuthTests' time='7.0'/>
      <testcase name='test__029__Token__authentication_method__local_token_validity_check__should_NOT_be_done_if_queryTime_is_false_and_local_time_is_NOT_in_sync_with_server()' classname='AuthTests' time='6.0'/>
      <testcase name='test__030__Token__options__should_stop_client_when_useTokenAuth_and_no_key_occurs()' classname='AuthTests' time='0.0061'/>
      <testcase name='test__031__Token__options__should_stop_client_when_authCallback_and_authUrl_occurs()' classname='AuthTests' time='0.00082'/>
      <testcase name='test__032__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_request_to_authUrl_fails__if_the_connection_is_CONNECTING__then_the_connection_attempt_should_be_treated_as_unsuccessful()' classname='AuthTests' time='0.15'/>
      <testcase name='test__033__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_request_to_authUrl_fails__if_the_connection_is_CONNECTED__then_the_connection_should_remain_CONNECTED()' classname='AuthTests' time='0.7'/>
      <testcase name='test__034__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_request_to_authCallback_fails__if_the_connection_is_CONNECTING__then_the_connection_attempt_should_be_treated_as_unsuccessful()' classname='AuthTests' time='0.018'/>
      <testcase name='test__035__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_request_to_authCallback_fails__if_the_connection_is_CONNECTED__then_the_connection_should_remain_CONNECTED()' classname='AuthTests' time='0.47'/>
      <testcase name='test__036__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_provided_token_is_in_an_invalid_format__if_the_connection_is_CONNECTING__then_the_connection_attempt_should_be_treated_as_unsuccessful()' classname='AuthTests' time='0.17'/>
      <testcase name='test__037__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_provided_token_is_in_an_invalid_format__if_the_connection_is_CONNECTED__then_the_connection_should_remain_CONNECTED()' classname='AuthTests' time='0.73'/>
      <testcase name='test__038__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_attempt_times_out_after_realtimeRequestTimeout__if_the_connection_is_CONNECTING__then_the_connection_attempt_should_be_treated_as_unsuccessful()' classname='AuthTests' time='0.52'/>
      <testcase name='test__039__Token__options__if_an_attempt_by_the_realtime_client_library_to_authenticate_is_made_using_the_authUrl_or_authCallback__the_attempt_times_out_after_realtimeRequestTimeout__if_the_connection_is_CONNECTED__then_the_connection_should_remain_CONNECTED()' classname='AuthTests' time='2.0'/>
      <testcase name='test__040__Token__token_auth_and_clientId__should_permit_to_be_unauthenticated()' classname='AuthTests' time='0.33'/>
      <testcase name='test__041__Token__token_auth_and_clientId__should_check_clientId_consistency__on_rest()' classname='AuthTests' time='0.18'/>
      <testcase name='test__042__Token__token_auth_and_clientId__should_check_clientId_consistency__on_realtime()' classname='AuthTests' time='0.44'/>
      <testcase name='test__043__Token__token_auth_and_clientId__should_check_clientId_consistency__with_wildcard()' classname='AuthTests' time='0.0015'/>
      <testcase name='test__044__Token__token_auth_and_clientId__Incompatible_client__with_Realtime__it_should_change_the_connection_state_to_FAILED_and_emit_an_error()' classname='AuthTests' time='0.71'/>
      <testcase name='test__045__Token__token_auth_and_clientId__Incompatible_client__with_Rest__it_should_result_in_an_appropriate_error_response()' classname='AuthTests' time='0.2'/>
      <testcase name='test__046__Token__clientId_and_authenticated_clients__should_not_pass_clientId_with_published_message()' classname='AuthTests' time='0.18'/>
      <testcase name='test__047__Token__clientId_and_authenticated_clients__should_obtain_a_token_if_clientId_is_assigned()' classname='AuthTests' time='0.23'/>
      <testcase name='test__048__Token__clientId_and_authenticated_clients__should_convenience_clientId_return_a_string()' classname='AuthTests' time='0.0012'/>
      <testcase name='test__049__Token__clientId_and_authenticated_clients__ClientOptions_clientId_takes_precendence_when_a_clientId_value_is_provided_in_both_ClientOptions_clientId_and_ClientOptions_defaultTokenParams()' classname='AuthTests' time='0.66'/>
      <testcase name='test__050__Token__clientId_and_authenticated_clients__should_clientId_be_null_or_string()' classname='AuthTests' time='0.0014'/>
      <testcase name='test__051__Token__clientId_and_authenticated_clients__Auth_clientId_attribute_is_null__identity_should_be_anonymous_for_all_operations()' classname='AuthTests' time='0.32'/>
      <testcase name='test__052__Token__clientId_and_authenticated_clients__Auth_clientId_attribute_is_null__identity_may_change_and_become_identified()' classname='AuthTests' time='0.57'/>
      <testcase name='test__053__Token__clientId_and_authenticated_clients__auth_clientId_not_null__when_clientId_attribute_is_assigned_on_client_options()' classname='AuthTests' time='0.00077'/>
      <testcase name='test__054__Token__clientId_and_authenticated_clients__auth_clientId_not_null__when_tokenRequest_or_tokenDetails_has_clientId_not_null_or_wildcard_string()' classname='AuthTests' time='0.18'/>
      <testcase name='test__055__Token__clientId_and_authenticated_clients__auth_clientId_not_null__should_CONNECTED_ProtocolMessages_contain_a_clientId()' classname='AuthTests' time='0.51'/>
      <testcase name='test__056__Token__clientId_and_authenticated_clients__auth_clientId_not_null__client_does_not_have_an_identity_when_a_wildcard_string_____is_present()' classname='AuthTests' time='0.49'/>
      <testcase name='test__057__requestToken__implicitly_creates_a_TokenRequest_and_requests_a_token()' classname='AuthTests' time='0.21'/>
      <testcase name='test__058__requestToken__ensure_the_message_published_does_not_have_a_clientId()' classname='AuthTests' time='0.44'/>
      <testcase name='test__059__requestToken__ensure_that_the_message_is_rejected()' classname='AuthTests' time='0.35'/>
      <testcase name='test__060__requestToken__ensure_the_message_published_with_a_wildcard_____does_not_have_a_clientId()' classname='AuthTests' time='0.4'/>
      <testcase name='test__061__requestToken__ensure_the_message_published_with_a_wildcard_____has_the_provided_clientId()' classname='AuthTests' time='0.44'/>
      <testcase name='test__062__requestToken__arguments__should_not_merge_with_the_configured_params_and_options_but_instead_replace_all_corresponding_values__even_when__null_()' classname='AuthTests' time='0.35'/>
      <testcase name='test__063__requestToken__arguments__should_use_configured_defaults_if_the_object_arguments_are_omitted()' classname='AuthTests' time='0.4'/>
      <testcase name='test__064__requestToken__authUrl__query_will_provide_a_token_string()' classname='AuthTests' time='0.41'/>
      <testcase name='test__065__requestToken__authUrl__query_will_provide_a_TokenDetails()' classname='AuthTests' time='0.37'/>
      <testcase name='test__066__requestToken__authUrl__query_will_provide_a_TokenRequest()' classname='AuthTests' time='0.34'/>
      <testcase name='test__067__requestToken__authUrl__TokenParams_should_take_precedence_over_any_configured_authParams_when_a_name_conflict_occurs()' classname='AuthTests' time='0.042'/>
      <testcase name='test__068__requestToken__authUrl__should_override_previously_configured_parameters()' classname='AuthTests' time='0.00086'/>
      <testcase name='test__069__requestToken__authUrl__parameters__should_be_added_to_the_URL_when_auth_method_is_GET()' classname='AuthTests' time='0.0043'/>
      <testcase name='test__070__requestToken__authUrl__parameters__should_added_on_the_body_request_when_auth_method_is_POST()' classname='AuthTests' time='0.012'/>
      <testcase name='test__071__requestToken__should_support_all_TokenParams__using_defaults()' classname='AuthTests' time='0.22'/>
      <testcase name='test__072__requestToken__should_support_all_TokenParams__overriding_defaults()' classname='AuthTests' time='0.18'/>
      <testcase name='test__073__requestToken__When_authCallback_option_is_set__it_will_invoke_the_callback__with_a_token_string()' classname='AuthTests' time='0.012'/>
      <testcase name='test__074__requestToken__When_authCallback_option_is_set__it_will_invoke_the_callback__with_a_TokenDetails()' classname='AuthTests' time='0.0089'/>
      <testcase name='test__075__requestToken__When_authCallback_option_is_set__it_will_invoke_the_callback__with_a_TokenRequest()' classname='AuthTests' time='0.17'/>
      <testcase name='test__076__createTokenRequest__should_not_merge_with_the_configured_params_and_options_but_instead_replace_all_corresponding_values__even_when__null_()' classname='AuthTests' time='0.32'/>
      <testcase name='test__077__createTokenRequest__should_override_defaults_if_AuthOptions_provided()' classname='AuthTests' time='0.19'/>
      <testcase name='test__078__createTokenRequest__should_use_defaults_if_no_AuthOptions_is_provided()' classname='AuthTests' time='0.23'/>
      <testcase name='test__079__createTokenRequest__should_replace_defaults_if__nil__option_s_field_passed()' classname='AuthTests' time='0.0098'/>
      <testcase name='test__080__createTokenRequest__should_use_configured_defaults_if_the_object_arguments_are_omitted()' classname='AuthTests' time='0.25'/>
      <testcase name='test__081__createTokenRequest__should_create_and_sign_a_TokenRequest()' classname='AuthTests' time='0.022'/>
      <testcase name='test__082__createTokenRequest__should_support_AuthOptions()' classname='AuthTests' time='0.012'/>
      <testcase name='test__083__createTokenRequest__should_generate_a_unique_16_plus_character_nonce_if_none_is_provided()' classname='AuthTests' time='0.0011'/>
      <testcase name='test__084__createTokenRequest__should_provide_capability_has_json_text()' classname='AuthTests' time='0.00077'/>
      <testcase name='test__085__createTokenRequest__should_generate_a_valid_HMAC()' classname='AuthTests' time='0.00083'/>
      <testcase name='test__086__createTokenRequest__should_respect_all_requirements()' classname='AuthTests' time='0.26'/>
      <testcase name='test__087__createTokenRequest__should_generate_a_timestamp__from_current_time_if_not_provided()' classname='AuthTests' time='0.0027'/>
      <testcase name='test__088__createTokenRequest__should_generate_a_timestamp__will_retrieve_the_server_time_if_queryTime_is_true()' classname='AuthTests' time='0.22'/>
      <testcase name='test__089__createTokenRequest__TTL__should_be_optional()' classname='AuthTests' time='0.022'/>
      <testcase name='test__090__createTokenRequest__TTL__should_be_specified_in_milliseconds()' classname='AuthTests' time='0.019'/>
      <testcase name='test__091__createTokenRequest__TTL__should_be_valid_to_request_a_token_for_24_hours()' classname='AuthTests' time='0.2'/>
      <testcase name='test__092__authorize__should_always_create_a_token()' classname='AuthTests' time='0.59'/>
      <testcase name='test__093__authorize__should_create_a_new_token_if_one_already_exist_and_ensure_Token_Auth_is_used_for_all_future_requests()' classname='AuthTests' time='0.66'/>
      <testcase name='test__094__authorize__should_create_a_token_immediately_and_ensures_Token_Auth_is_used_for_all_future_requests()' classname='AuthTests' time='0.36'/>
      <testcase name='test__095__authorize__should_supports_all_TokenParams_and_AuthOptions()' classname='AuthTests' time='0.0074'/>
      <testcase name='test__096__authorize__should_use_the_requestToken_implementation()' classname='AuthTests' time='0.18'/>
      <testcase name='test__097__authorize__should_return_TokenDetails_with_valid_token_metadata()' classname='AuthTests' time='0.24'/>
      <testcase name='test__098__authorize__should_use_the_configured_Auth_clientId__if_not_null__by_default()' classname='AuthTests' time='0.36'/>
      <testcase name='test__099__authorize__on_subsequent_authorisations__should_store_the_AuthOptions_with_authUrl()' classname='AuthTests' time='0.51'/>
      <testcase name='test__100__authorize__on_subsequent_authorisations__should_store_the_AuthOptions_with_authCallback()' classname='AuthTests' time='0.0017'/>
      <testcase name='test__101__authorize__on_subsequent_authorisations__should_not_store_queryTime()' classname='AuthTests' time='0.4'/>
      <testcase name='test__102__authorize__on_subsequent_authorisations__should_store_the_TokenParams()' classname='AuthTests' time='2.0'/>
      <testcase name='test__103__authorize__on_subsequent_authorisations__should_use_configured_defaults_if_the_object_arguments_are_omitted()' classname='AuthTests' time='0.58'/>
      <testcase name='test__104__authorize__should_adhere_to_all_requirements_relating_to__TokenParams()' classname='AuthTests' time='0.21'/>
      <testcase name='test__105__authorize__should_adhere_to_all_requirements_relating_to__authCallback()' classname='AuthTests' time='0.2'/>
      <testcase name='test__106__authorize__should_adhere_to_all_requirements_relating_to__authUrl()' classname='AuthTests' time='0.2'/>
      <testcase name='test__107__authorize__should_adhere_to_all_requirements_relating_to__authUrl_with_json()' classname='AuthTests' time='0.5'/>
      <testcase name='test__108__authorize__should_adhere_to_all_requirements_relating_to__authUrl_returning_TokenRequest_decodes_TTL_as_expected()' classname='AuthTests' time='0.4'/>
      <testcase name='test__109__authorize__should_adhere_to_all_requirements_relating_to__authUrl_with_plain_text()' classname='AuthTests' time='0.52'/>
      <testcase name='test__110__authorize__when_TokenParams_and_AuthOptions_are_provided__should_supersede_configured_AuthOptions__using_key__even_if_arguments_objects_are_empty()' classname='AuthTests' time='1.0'/>
      <testcase name='test__111__authorize__when_TokenParams_and_AuthOptions_are_provided__should_supersede_configured_AuthOptions__using_authUrl__even_if_arguments_objects_are_empty()' classname='AuthTests' time='0.58'/>
      <testcase name='test__112__authorize__when_TokenParams_and_AuthOptions_are_provided__should_supersede_configured_AuthOptions__using_authCallback__even_if_arguments_objects_are_empty()' classname='AuthTests' time='0.0028'/>
      <testcase name='test__113__authorize__when_TokenParams_and_AuthOptions_are_provided__should_supersede_configured_params_and_options_even_if_arguments_objects_are_empty()' classname='AuthTests' time='0.83'/>
      <testcase name='test__114__authorize__when_TokenParams_and_AuthOptions_are_provided__example__if_a_client_is_initialised_with_TokenParams_ttl_configured_with_a_custom_value__and_a_TokenParams_object_is_passed_in_as_an_argument_to__authorize_with_a_null_value_for_ttl__then_the_ttl_used_for_every_subsequent_authorization_will_be_null()' classname='AuthTests' time='0.38'/>
      <testcase name='test__115__authorize__server_time_offset__should_obtain_server_time_once_and_persist_the_offset_from_the_local_clock()' classname='AuthTests' time='0.3'/>
      <testcase name='test__116__authorize__server_time_offset__should_be_consistent_the_timestamp_request_with_the_server_time()' classname='AuthTests' time='0.15'/>
      <testcase name='test__117__authorize__server_time_offset__should_be_possible_by_lib_Client_to_discard_the_cached_local_clock_offset()' classname='AuthTests' time='0.34'/>
      <testcase name='test__118__authorize__server_time_offset__should_use_the_local_clock_offset_to_calculate_the_server_time()' classname='AuthTests' time='0.021'/>
      <testcase name='test__119__authorize__server_time_offset__should_request_server_time_when_queryTime_is_true_even_if_the_time_offset_is_assigned()' classname='AuthTests' time='0.25'/>
      <testcase name='test__120__authorize__server_time_offset__should_discard_the_time_offset_in_situations_in_which_it_may_have_been_invalidated()' classname='AuthTests' time='0.0028'/>
      <testcase name='test__121__authorize__two_consecutive_authorizations__using_REST__should_call_each_authorize_callback()' classname='AuthTests' time='0.16'/>
      <testcase name='test__122__authorize__two_consecutive_authorizations__using_Realtime_and_connection_is_CONNECTING__should_call_each_Realtime_authorize_callback()' classname='AuthTests' time='0.78'/>
      <testcase name='test__123__authorize__two_consecutive_authorizations__using_Realtime_and_connection_is_CONNECTED__should_call_each_Realtime_authorize_callback()' classname='AuthTests' time='0.69'/>
      <testcase name='test__124__TokenParams__timestamp__if_explicitly_set__should_be_returned_by_the_getter()' classname='AuthTests' time='0.00059'/>
      <testcase name='test__125__TokenParams__timestamp__if_explicitly_set__the_value_should_stick()' classname='AuthTests' time='0.27'/>
      <testcase name='test__126__TokenParams__timestamp__object_has_no_timestamp_value_unless_explicitly_set()' classname='AuthTests' time='0.00065'/>
      <testcase name='test__127__Reauth__should_use_authorize__force__true___to_reauth_with_a_token_with_a_different_set_of_capabilities()' classname='AuthTests' time='1.0'/>
      <testcase name='test__128__Reauth__for_a_token_change_that_fails_due_to_an_incompatible_token__which_should_result_in_the_connection_entering_the_FAILED_state()' classname='AuthTests' time='0.85'/>
      <testcase name='test__129__TokenParams__timestamp_should_not_be_a_member_of_any_default_token_params()' classname='AuthTests' time='0.17'/>
      <testcase name='test__130__TokenRequest__fromJson__rejects_invalid_JSON()' classname='AuthTests' time='0.0084'/>
      <testcase name='test__131__TokenRequest__fromJson__rejects_non_object_JSON()' classname='AuthTests' time='0.00049'/>
      <testcase name='test__132__TokenRequest__fromJson__with_TTL__accepts_a_string__which_should_be_interpreted_as_JSON()' classname='AuthTests' time='0.00075'/>
      <testcase name='test__133__TokenRequest__fromJson__with_TTL__accepts_a_NSDictionary()' classname='AuthTests' time='0.00045'/>
      <testcase name='test__134__TokenRequest__fromJson__without_TTL__accepts_a_string__which_should_be_interpreted_as_JSON()' classname='AuthTests' time='0.0005'/>
      <testcase name='test__135__TokenRequest__fromJson__without_TTL__accepts_a_NSDictionary()' classname='AuthTests' time='0.00037'/>
      <testcase name='test__136__TokenDetails__fromJson__accepts_a_string__which_should_be_interpreted_as_JSON()' classname='AuthTests' time='0.00044'/>
      <testcase name='test__137__TokenDetails__fromJson__accepts_a_NSDictionary()' classname='AuthTests' time='0.00049'/>
      <testcase name='test__138__TokenDetails__fromJson__rejects_invalid_JSON()' classname='AuthTests' time='0.00069'/>
      <testcase name='test__139__TokenDetails__fromJson__rejects_non_object_JSON()' classname='AuthTests' time='0.00046'/>
      <testcase name='test__140__JWT_and_realtime__client_initialized_with_a_JWT_token_in_ClientOptions__with_valid_credentials__pulls_stats_successfully()' classname='AuthTests' time='0.5'/>
      <testcase name='test__141__JWT_and_realtime__client_initialized_with_a_JWT_token_in_ClientOptions__with_invalid_credentials__fails_to_connect_with_reason__invalid_signature_()' classname='AuthTests' time='0.67'/>
      <testcase name='test__142__JWT_and_realtime__when_using_authUrl__with_valid_credentials__fetches_a_channels_and_posts_a_message()' classname='AuthTests' time='0.65'/>
      <testcase name='test__143__JWT_and_realtime__when_using_authUrl__with_wrong_credentials__fails_to_connect_with_reason__invalid_signature_()' classname='AuthTests' time='1.0'/>
      <testcase name='test__144__JWT_and_realtime__when_using_authUrl__when_token_expires__receives_a_40142_error_from_the_server()' classname='AuthTests' time='4.0'/>
      <testcase name='test__145__JWT_and_realtime__when_using_authUrl__when_the_server_sends_and_AUTH_protocol_message__client_reauths_correctly_without_going_through_a_disconnection()' classname='AuthTests' time='5.0'/>
      <testcase name='test__146__JWT_and_realtime__when_using_authCallback__with_valid_credentials__pulls_stats_successfully()' classname='AuthTests' time='0.52'/>
      <testcase name='test__147__JWT_and_realtime__when_using_authCallback__with_invalid_credentials__fails_to_connect()' classname='AuthTests' time='1.0'/>
      <testcase name='test__148__JWT_and_realtime__when_token_expires_and_has_a_means_to_renew__reconnects_using_authCallback_and_obtains_a_new_token()' classname='AuthTests' time='3.0'/>
      <testcase name='test__149__JWT_and_realtime__when_the_token_request_includes_a_clientId__the_clientId_is_the_same_specified_in_the_JWT_token_request()' classname='AuthTests' time='0.69'/>
      <testcase name='test__150__JWT_and_realtime__when_the_token_request_includes_subscribe_only_capabilities__fails_to_publish_to_a_channel_with_subscribe_only_capability()' classname='AuthTests' time='0.72'/>
      <testcase name='test__151__currentTokenDetails__should_hold_a__TokenDetails__instance_in_which_only_the__token__attribute_is_populated_with_that_token_string()' classname='AuthTests' time='0.18'/>
      <testcase name='test__152__currentTokenDetails__should_be_set_with_the_current_token__if_applicable__on_instantiation_and_each_time_it_is_replaced()' classname='AuthTests' time='0.18'/>
      <testcase name='test__153__currentTokenDetails__should_be_empty_if_there_is_no_current_token()' classname='AuthTests' time='0.00099'/>
      <testcase name='test__154__JWT_and_rest__when_the_JWT_token_embeds_an_Ably_token__pulls_stats_successfully()' classname='AuthTests' time='0.5'/>
      <testcase name='test__155__JWT_and_rest__when_the_JWT_token_embeds_an_Ably_token_and_it_is_requested_as_encrypted__pulls_stats_successfully()' classname='AuthTests' time='0.49'/>
      <testcase name='test__156__JWT_and_rest__when_the_JWT_token_is_returned_with_application_jwt_content_type__the_client_successfully_connects_and_pulls_stats()' classname='AuthTests' time='0.38'/>
      <testcase name='test__157__JWT_and_rest__when_the_JWT_token_is_returned_with_application_jwt_content_type__the_client_can_request_a_new_token_to_initilize_another_client_that_connects_and_pulls_stats()' classname='AuthTests' time='0.39'/>
    </testsuite>
    <testsuite name='BackoffRetryDelayCalculatorTests' time='0.029' tests='1' failures='0' skipped='0'>
      <testcase name='test_delay()' classname='BackoffRetryDelayCalculatorTests' time='0.029'/>
    </testsuite>
    <testsuite name='ChannelOptionsTests' time='0.00538' tests='4' failures='0' skipped='0'>
      <testcase name='test_copyChannelOptions()' classname='ChannelOptionsTests' time='0.003'/>
      <testcase name='test_copyingFrozenChannelOptions_createsUnfrozenCopy()' classname='ChannelOptionsTests' time='0.00061'/>
      <testcase name='test_copyingFrozenRealtimeChannelOptions_createsUnfrozenCopy()' classname='ChannelOptionsTests' time='0.00047'/>
      <testcase name='test_copyRealtimeChannelOptions()' classname='ChannelOptionsTests' time='0.0013'/>
    </testsuite>
    <testsuite name='ClientInformationTests' time='0.00791' tests='3' failures='0' skipped='0'>
      <testcase name='testAgentIdentifierWithAdditionalAgents_withNilAdditionalAgents()' classname='ClientInformationTests' time='0.0045'/>
      <testcase name='testAgentIdentifierWithAdditionalAgents_withNonNilAdditionalAgents()' classname='ClientInformationTests' time='0.0029'/>
      <testcase name='testAgents()' classname='ClientInformationTests' time='0.00051'/>
    </testsuite>
    <testsuite name='ConnectRetryStateTests' time='0.00331' tests='3' failures='0' skipped='0'>
      <testcase name='test_addRetryAttempt()' classname='ConnectRetryStateTests' time='0.0013'/>
      <testcase name='test_transitionToConnectingOrDisconnectedStateDoesNotResetRetrySequence()' classname='ConnectRetryStateTests' time='0.0014'/>
      <testcase name='test_transitionToNonConnectingOrDisconnectedStateResetsRetrySequence()' classname='ConnectRetryStateTests' time='0.00061'/>
    </testsuite>
    <testsuite name='ContinuousClockTests' time='0.76' tests='2' failures='0' skipped='0'>
      <testcase name='test_advancedBy()' classname='ContinuousClockTests' time='0.51'/>
      <testcase name='test_isAfter()' classname='ContinuousClockTests' time='0.25'/>
    </testsuite>
    <testsuite name='CryptoTest' time='0.0017' tests='1' failures='0' skipped='0'>
      <testcase name='testEncryptAndDecrypt' classname='CryptoTest' time='0.0017'/>
    </testsuite>
    <testsuite name='CryptoTests' time='0.09748' tests='16' failures='0' skipped='0'>
      <testcase name='test__001__Crypto__getDefaultParams__returns_a_complete_CipherParams_instance__using_the_default_values_for_any_field_not_supplied()' classname='CryptoTests' time='0.013'/>
      <testcase name='test__002__Crypto__getDefaultParams__calculates_a_keyLength_from_the_key__its_size_in_bits_()' classname='CryptoTests' time='0.0011'/>
      <testcase name='test__003__Crypto__getDefaultParams__should_check_that_keyLength_is_valid_for_algorithm()' classname='CryptoTests' time='0.00073'/>
      <testcase name='test__004__Crypto__getDefaultParams__key_parameter__can_be_a_binary()' classname='CryptoTests' time='0.00047'/>
      <testcase name='test__005__Crypto__getDefaultParams__key_parameter__can_be_a_base64_encoded_string_with_standard_encoding()' classname='CryptoTests' time='0.00056'/>
      <testcase name='test__006__Crypto__getDefaultParams__key_parameter__can_be_a_base64_encoded_string_with_URL_encoding()' classname='CryptoTests' time='0.00051'/>
      <testcase name='test__007__Crypto__generateRandomKey__takes_a_single_length_argument_and_returns_a_binary()' classname='CryptoTests' time='0.00048'/>
      <testcase name='test__008__Crypto__generateRandomKey__takes_no_arguments_and_returns_the_default_algorithm_s_default_length()' classname='CryptoTests' time='0.00046'/>
      <testcase name='test__009__Crypto__generateHashSHA256__takes_data_and_returns_a_SHA256_digest()' classname='CryptoTests' time='0.0072'/>
      <testcase name='test__010__Crypto__encrypt__should_generate_a_new_IV_every_time_it_s_called__and_should_be_the_first_block_encrypted()' classname='CryptoTests' time='0.011'/>
      <testcase name='test__011__Crypto__with_fixtures_from_crypto_data_128_json__should_encrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.011'/>
      <testcase name='test__012__Crypto__with_fixtures_from_crypto_data_128_json__should_decrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.00097'/>
      <testcase name='test__013__Crypto__with_fixtures_from_crypto_data_256_json__should_encrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.0052'/>
      <testcase name='test__014__Crypto__with_fixtures_from_crypto_data_256_json__should_decrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.032'/>
      <testcase name='test__015__Crypto__with_fixtures_from_crypto_data_128_json__manual_decrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.0037'/>
      <testcase name='test__016__Crypto__with_fixtures_from_crypto_data_256_json__manual_decrypt_messages_as_expected_in_the_fixtures()' classname='CryptoTests' time='0.0091'/>
    </testsuite>
    <testsuite name='DefaultErrorCheckerTests' time='0.0047599999999999995' tests='4' failures='0' skipped='0'>
      <testcase name='test_isTokenError_statusCode401AndCodeBetween40140And40150()' classname='DefaultErrorCheckerTests' time='0.00055'/>
      <testcase name='test_isTokenError_statusCode401ButCodeGreaterThanOrEqualTo40150()' classname='DefaultErrorCheckerTests' time='0.00041'/>
      <testcase name='test_isTokenError_statusCode401ButCodeLessThan40140()' classname='DefaultErrorCheckerTests' time='0.0034'/>
      <testcase name='test_isTokenError_statusCodeNot401()' classname='DefaultErrorCheckerTests' time='0.0004'/>
    </testsuite>
    <testsuite name='DefaultInternalLogCoreTests' time='0.00777' tests='5' failures='0' skipped='0'>
      <testcase name='test_initWithClientOptions_whenClientOptionsLogLevelIsNone()' classname='DefaultInternalLogCoreTests' time='0.00089'/>
      <testcase name='test_initWithClientOptions_whenClientOptionsLogLevelIsNotNone()' classname='DefaultInternalLogCoreTests' time='0.0045'/>
      <testcase name='test_logLevel()' classname='DefaultInternalLogCoreTests' time='0.00075'/>
      <testcase name='test_logMessage()' classname='DefaultInternalLogCoreTests' time='0.00092'/>
      <testcase name='test_setLogLevel()' classname='DefaultInternalLogCoreTests' time='0.00071'/>
    </testsuite>
    <testsuite name='DefaultJitterCoefficientGeneratorTests' time='0.00229' tests='2' failures='0' skipped='0'>
      <testcase name='test_generatesAVarietyOfValues()' classname='DefaultJitterCoefficientGeneratorTests' time='0.0018'/>
      <testcase name='test_generatesValuesInExpectedRange()' classname='DefaultJitterCoefficientGeneratorTests' time='0.00049'/>
    </testsuite>
    <testsuite name='DeltaCodecTests' time='1.8699999999999999' tests='3' failures='0' skipped='0'>
      <testcase name='test__001__DeltaCodec__decoding__should_decode_vcdiff_encoded_messages()' classname='DeltaCodecTests' time='0.59'/>
      <testcase name='test__002__DeltaCodec__decoding__should_fail_and_recover_when_the_vcdiff_messages_are_out_of_order()' classname='DeltaCodecTests' time='0.59'/>
      <testcase name='test__003__DeltaCodec__decoding__should_recover_when_the_vcdiff_message_decoding_fails()' classname='DeltaCodecTests' time='0.69'/>
    </testsuite>
    <testsuite name='GCDTests' time='0.00084' tests='1' failures='0' skipped='0'>
      <testcase name='testScheduledBlockHandleDerefsBlockAfterInvoke()' classname='GCDTests' time='0.00084'/>
    </testsuite>
    <testsuite name='LogAdapterTests' time='0.00165' tests='3' failures='0' skipped='0'>
      <testcase name='test_logLevel()' classname='LogAdapterTests' time='0.00056'/>
      <testcase name='test_logMessage()' classname='LogAdapterTests' time='0.00052'/>
      <testcase name='test_setLogLevel()' classname='LogAdapterTests' time='0.00057'/>
    </testsuite>
    <testsuite name='ObjcppTest' time='0.00054' tests='1' failures='0' skipped='0'>
      <testcase name='testPrintVersionInfo' classname='ObjcppTest' time='0.00054'/>
    </testsuite>
    <testsuite name='ObjectLifetimesTests' time='1.0449' tests='5' failures='0' skipped='0'>
      <testcase name='test__001__ObjectLifetimes__user_code_releases_public_object__the_object_s_internal_child_s_back_reference_is_released_too()' classname='ObjectLifetimesTests' time='0.0022'/>
      <testcase name='test__002__ObjectLifetimes__user_code_holds_only_reference_to_public_object_s_public_child__still_can_access_parent_s_internal_object()' classname='ObjectLifetimesTests' time='0.0019'/>
      <testcase name='test__003__ObjectLifetimes__user_code_holds_only_reference_to_public_object_s_public_child__when_it_s_released__schedules_async_release_of_parent_s_internal_object_in_internal_queue()' classname='ObjectLifetimesTests' time='0.0008'/>
      <testcase name='test__004__ObjectLifetimes__when_user_leaves_Realtime_open__still_works()' classname='ObjectLifetimesTests' time='0.58'/>
      <testcase name='test__005__ObjectLifetimes__when_Realtime_is_closed_and_user_loses_its_reference__channels_don_t_leak()' classname='ObjectLifetimesTests' time='0.46'/>
    </testsuite>
    <testsuite name='PushActivationStateMachineTests' time='0.27984' tests='55' failures='0' skipped='0'>
      <testcase name='test__001__should_remove_identityTokenDetails_from_cache_and_storage()' classname='PushActivationStateMachineTests' time='0.0031'/>
      <testcase name='test__002__Activation_state_machine__should_set_NotActivated_state_as_current_state_when_disk_is_empty()' classname='PushActivationStateMachineTests' time='0.0031'/>
      <testcase name='test__003__Activation_state_machine__should_read_the_current_state_from_disk()' classname='PushActivationStateMachineTests' time='0.0028'/>
      <testcase name='test__004__Activation_state_machine__AfterRegistrationUpdateFailed_state_from_persistence_gets_migrated_to_AfterRegistrationSyncFailed()' classname='PushActivationStateMachineTests' time='0.0044'/>
      <testcase name='test__005__Activation_state_machine__should_queue_event_that_has_no_transition_defined_for_it()' classname='PushActivationStateMachineTests' time='0.016'/>
      <testcase name='test__006__Activation_state_machine__event_handling_sould_be_atomic_and_sequential()' classname='PushActivationStateMachineTests' time='0.094'/>
      <testcase name='test__007__Activation_state_machine__State_NotActivated__on_Event_CalledDeactivate__should_transition_to_NotActivated()' classname='PushActivationStateMachineTests' time='0.0044'/>
      <testcase name='test__008__Activation_state_machine__State_NotActivated__on_Event_GotPushDeviceDetails()' classname='PushActivationStateMachineTests' time='0.00098'/>
      <testcase name='test__009__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__if_the_local_device_has_the_necessary_push_details_should_send_event_GotPushDeviceDetails()' classname='PushActivationStateMachineTests' time='0.0017'/>
      <testcase name='test__010__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__none_of_them_then_should_transition_to_WaitingForPushDeviceDetails()' classname='PushActivationStateMachineTests' time='0.017'/>
      <testcase name='test__011__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__emits_a_SyncRegistrationFailed_event_with_code_61002_if_client_IDs_don_t_match()' classname='PushActivationStateMachineTests' time='0.0038'/>
      <testcase name='test__012__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__calls_registerCallback__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.0091'/>
      <testcase name='test__013__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__PUTs_device_registration__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.0017'/>
      <testcase name='test__014__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__local_device__should_have_a_generated_id()' classname='PushActivationStateMachineTests' time='0.0015'/>
      <testcase name='test__015__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__local_device__should_have_a_generated_secret()' classname='PushActivationStateMachineTests' time='0.0013'/>
      <testcase name='test__016__Activation_state_machine__State_NotActivated__on_Event_CalledActivate__local_device__should_have_a_clientID_if_the_client_is_identified()' classname='PushActivationStateMachineTests' time='0.00099'/>
      <testcase name='test__017__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_CalledActivate()' classname='PushActivationStateMachineTests' time='0.00093'/>
      <testcase name='test__018__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_CalledDeactivate()' classname='PushActivationStateMachineTests' time='0.0092'/>
      <testcase name='test__019__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GettingPushDeviceDetailsFailed()' classname='PushActivationStateMachineTests' time='0.0016'/>
      <testcase name='test__020__Activation_state_machine__State_WaitingForPushDeviceDetails__when_initializing_from_persistent_state_with_a_deviceToken__GotPushDeviceDetails_should_be_re_emitted()' classname='PushActivationStateMachineTests' time='0.0041'/>
      <testcase name='test__022__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GotPushDeviceDetails__should_use_custom_registerCallback_and_fire_GotDeviceRegistration_event()' classname='PushActivationStateMachineTests' time='0.0054'/>
      <testcase name='test__023__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GotPushDeviceDetails__should_use_custom_registerCallback_and_fire_GettingDeviceRegistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0056'/>
      <testcase name='test__024__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GotPushDeviceDetails__should_fire_GotDeviceRegistration_event()' classname='PushActivationStateMachineTests' time='0.0033'/>
      <testcase name='test__025__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GotPushDeviceDetails__should_fire_GettingDeviceRegistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0057'/>
      <testcase name='test__026__Activation_state_machine__State_WaitingForPushDeviceDetails__on_Event_GotPushDeviceDetails__should_transition_to_WaitingForDeviceRegistration()' classname='PushActivationStateMachineTests' time='0.0012'/>
      <testcase name='test__027__Activation_state_machine__State_WaitingForDeviceRegistration__on_Event_CalledActivate()' classname='PushActivationStateMachineTests' time='0.00084'/>
      <testcase name='test__028__Activation_state_machine__State_WaitingForDeviceRegistration__on_Event_GotDeviceRegistration()' classname='PushActivationStateMachineTests' time='0.0028'/>
      <testcase name='test__029__Activation_state_machine__State_WaitingForDeviceRegistration__on_Event_GettingDeviceRegistrationFailed()' classname='PushActivationStateMachineTests' time='0.0011'/>
      <testcase name='test__030__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledActivate()' classname='PushActivationStateMachineTests' time='0.0028'/>
      <testcase name='test__031__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledDeactivate__should_use_custom_deregisterCallback_and_fire_Deregistered_event()' classname='PushActivationStateMachineTests' time='0.003'/>
      <testcase name='test__032__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledDeactivate__should_use_custom_deregisterCallback_and_fire_DeregistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0042'/>
      <testcase name='test__033__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledDeactivate__should_fire_Deregistered_event_and_include_DeviceSecret_HTTP_header()' classname='PushActivationStateMachineTests' time='0.0014'/>
      <testcase name='test__034__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledDeactivate__should_fire_Deregistered_event_and_include_DeviceIdentityToken_HTTP_header()' classname='PushActivationStateMachineTests' time='0.0018'/>
      <testcase name='test__035__Activation_state_machine__State_WaitingForNewPushDeviceDetails__on_Event_CalledDeactivate__should_fire_DeregistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0011'/>
      <testcase name='test__036__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventCalledActivate__on_Event_CalledActivate()' classname='PushActivationStateMachineTests' time='0.0007'/>
      <testcase name='test__037__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventCalledActivate__on_Event_RegistrationSynced()' classname='PushActivationStateMachineTests' time='0.00096'/>
      <testcase name='test__038__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventCalledActivate__on_Event_SyncRegistrationFailed()' classname='PushActivationStateMachineTests' time='0.00087'/>
      <testcase name='test__039__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventGotPushDeviceDetails__on_Event_CalledActivate()' classname='PushActivationStateMachineTests' time='0.00073'/>
      <testcase name='test__040__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventGotPushDeviceDetails__on_Event_RegistrationSynced()' classname='PushActivationStateMachineTests' time='0.001'/>
      <testcase name='test__041__Activation_state_machine__State_WaitingForRegistrationSync_through_ARTPushActivationEventGotPushDeviceDetails__on_Event_SyncRegistrationFailed()' classname='PushActivationStateMachineTests' time='0.00096'/>
      <testcase name='test__042__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__emits_a_SyncRegistrationFailed_event_with_code_61002_if_client_IDs_don_t_match()' classname='PushActivationStateMachineTests' time='0.003'/>
      <testcase name='test__043__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__calls_registerCallback__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.0099'/>
      <testcase name='test__044__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledActivate__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__PUTs_device_registration__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.0022'/>
      <testcase name='test__045__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_GotPushDeviceDetails__the_local_device_has_id_and_deviceIdentityToken__emits_a_SyncRegistrationFailed_event_with_code_61002_if_client_IDs_don_t_match()' classname='PushActivationStateMachineTests' time='0.0056'/>
      <testcase name='test__046__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_GotPushDeviceDetails__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__calls_registerCallback__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.002'/>
      <testcase name='test__047__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_GotPushDeviceDetails__the_local_device_has_id_and_deviceIdentityToken__the_local_DeviceDetails_matches_the_instance_s_client_ID__PUTs_device_registration__transitions_to_WaitingForRegistrationSync()' classname='PushActivationStateMachineTests' time='0.0011'/>
      <testcase name='test__048__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledDeactivate__should_use_custom_deregisterCallback_and_fire_Deregistered_event()' classname='PushActivationStateMachineTests' time='0.016'/>
      <testcase name='test__049__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledDeactivate__should_use_custom_deregisterCallback_and_fire_DeregistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0011'/>
      <testcase name='test__050__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledDeactivate__should_fire_Deregistered_event_and_include_DeviceSecret_HTTP_header()' classname='PushActivationStateMachineTests' time='0.0013'/>
      <testcase name='test__051__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledDeactivate__should_fire_Deregistered_event_and_include_DeviceIdentityToken_HTTP_header()' classname='PushActivationStateMachineTests' time='0.0029'/>
      <testcase name='test__052__Activation_state_machine__State_AfterRegistrationSyncFailed__on_Event_CalledDeactivate__should_fire_DeregistrationFailed_event()' classname='PushActivationStateMachineTests' time='0.0017'/>
      <testcase name='test__053__Activation_state_machine__State_WaitingForDeregistration__on_Event_CalledDeactivate()' classname='PushActivationStateMachineTests' time='0.00069'/>
      <testcase name='test__054__Activation_state_machine__State_WaitingForDeregistration__on_Event_Deregistered()' classname='PushActivationStateMachineTests' time='0.0031'/>
      <testcase name='test__055__Activation_state_machine__State_WaitingForDeregistration__on_Event_DeregistrationFailed()' classname='PushActivationStateMachineTests' time='0.00069'/>
      <testcase name='test__056__Activation_state_machine__should_be_possible_to_activate_and_deactivate_and_then_activate_again_with_different_clientId()' classname='PushActivationStateMachineTests' time='0.0014'/>
    </testsuite>
    <testsuite name='PushAdminTests' time='8.7271' tests='33' failures='0' skipped='0'>
      <testcase name='test__001__publish__should_perform_an_HTTP_request_to__push_publish()' classname='PushAdminTests' time='0.0023'/>
      <testcase name='test__002__publish__should_publish_successfully()' classname='PushAdminTests' time='0.6'/>
      <testcase name='test__003__publish__should_fail_with_a_bad_recipient()' classname='PushAdminTests' time='0.61'/>
      <testcase name='test__004__publish__should_fail_with_an_empty_recipient()' classname='PushAdminTests' time='0.39'/>
      <testcase name='test__005__publish__should_fail_with_an_empty_payload()' classname='PushAdminTests' time='0.4'/>
      <testcase name='test__006__Device_Registrations__get__should_return_a_device()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__007__Device_Registrations__get__should_not_return_a_device_if_it_doesnt_exist()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__008__Device_Registrations__get__push_device_authentication__should_include_DeviceIdentityToken_HTTP_header()' classname='PushAdminTests' time='0.0022'/>
      <testcase name='test__009__Device_Registrations__get__push_device_authentication__should_include_DeviceSecret_HTTP_header()' classname='PushAdminTests' time='0.0054'/>
      <testcase name='test__010__Device_Registrations__list__should_list_devices_by_id()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__011__Device_Registrations__list__should_list_devices_by_client_id()' classname='PushAdminTests' time='0.18'/>
      <testcase name='test__012__Device_Registrations__list__should_list_devices_sorted()' classname='PushAdminTests' time='0.19'/>
      <testcase name='test__013__Device_Registrations__list__should_return_an_empty_list_when_id_does_not_exist()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__014__Device_Registrations__remove__should_unregister_a_device()' classname='PushAdminTests' time='0.0019'/>
      <testcase name='test__015__Device_Registrations__save__should_register_a_device()' classname='PushAdminTests' time='0.0029'/>
      <testcase name='test__016__Device_Registrations__save__push_device_authentication__should_include_DeviceIdentityToken_HTTP_header()' classname='PushAdminTests' time='0.0064'/>
      <testcase name='test__017__Device_Registrations__save__push_device_authentication__should_include_DeviceSecret_HTTP_header()' classname='PushAdminTests' time='0.0029'/>
      <testcase name='test__018__Device_Registrations__removeWhere__should_unregister_a_device()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__019__Channel_Subscriptions__save__should_add_a_subscription()' classname='PushAdminTests' time='0.53'/>
      <testcase name='test__020__Channel_Subscriptions__save__should_update_a_subscription()' classname='PushAdminTests' time='0.54'/>
      <testcase name='test__021__Channel_Subscriptions__save__should_fail_with_a_bad_recipient()' classname='PushAdminTests' time='0.19'/>
      <testcase name='test__022__Channel_Subscriptions__save__push_device_authentication__should_include_DeviceIdentityToken_HTTP_header()' classname='PushAdminTests' time='0.0019'/>
      <testcase name='test__023__Channel_Subscriptions__save__push_device_authentication__should_include_DeviceSecret_HTTP_header()' classname='PushAdminTests' time='0.004'/>
      <testcase name='test__024__Channel_Subscriptions__list__should_receive_a_list_of_subscriptions()' classname='PushAdminTests' time='0.25'/>
      <testcase name='test__025__Channel_Subscriptions__listChannels__should_receive_a_list_of_subscriptions()' classname='PushAdminTests' time='0.17'/>
      <testcase name='test__026__Channel_Subscriptions__remove__should_remove_a_subscription()' classname='PushAdminTests' time='0.5'/>
      <testcase name='test__027__Channel_Subscriptions__remove__push_device_authentication__should_include_DeviceIdentityToken_HTTP_header()' classname='PushAdminTests' time='0.0025'/>
      <testcase name='test__028__Channel_Subscriptions__remove__push_device_authentication__should_include_DeviceSecret_HTTP_header()' classname='PushAdminTests' time='0.0039'/>
      <testcase name='test__029__Channel_Subscriptions__removeWhere__should_remove_by_cliendId()' classname='PushAdminTests' time='1.0'/>
      <testcase name='test__030__Channel_Subscriptions__removeWhere__should_remove_by_cliendId_and_channel()' classname='PushAdminTests' time='0.68'/>
      <testcase name='test__031__Channel_Subscriptions__removeWhere__should_remove_by_deviceId()' classname='PushAdminTests' time='1.0'/>
      <testcase name='test__032__Channel_Subscriptions__removeWhere__should_not_remove_by_inexistent_deviceId()' classname='PushAdminTests' time='0.61'/>
      <testcase name='test__033__local_device__should_include_an_id_and_a_secret()' classname='PushAdminTests' time='0.0008'/>
    </testsuite>
    <testsuite name='PushChannelTests' time='0.6683' tests='13' failures='0' skipped='0'>
      <testcase name='test__001__Push_Channel__subscribeDevice__should_fail_if_the_LocalDevice_doesn_t_have_an_deviceIdentityToken()' classname='PushChannelTests' time='0.012'/>
      <testcase name='test__002__Push_Channel__subscribeDevice__should_do_a_POST_request_to__push_channelSubscriptions_and_include_device_authentication()' classname='PushChannelTests' time='0.0071'/>
      <testcase name='test__003__Push_Channel__subscribeClient__should_fail_if_the_LocalDevice_doesn_t_have_a_clientId()' classname='PushChannelTests' time='0.0054'/>
      <testcase name='test__004__Push_Channel__subscribeClient__should_do_a_POST_request_to__push_channelSubscriptions()' classname='PushChannelTests' time='0.0041'/>
      <testcase name='test__005__Push_Channel__unsubscribeDevice__should_fail_if_the_LocalDevice_doesn_t_have_a_deviceIdentityToken()' classname='PushChannelTests' time='0.0037'/>
      <testcase name='test__006__Push_Channel__unsubscribeDevice__should_do_a_DELETE_request_to__push_channelSubscriptions_and_include_device_authentication()' classname='PushChannelTests' time='0.0056'/>
      <testcase name='test__007__Push_Channel__unsubscribeClient__should_fail_if_the_LocalDevice_doesn_t_have_a_clientId()' classname='PushChannelTests' time='0.005'/>
      <testcase name='test__008__Push_Channel__unsubscribeClient__should_do_a_DELETE_request_to__push_channelSubscriptions()' classname='PushChannelTests' time='0.0033'/>
      <testcase name='test__009__Push_Channel__listSubscriptions__should_return_a_paginated_result_with_PushChannelSubscription_filtered_by_channel_and_device()' classname='PushChannelTests' time='0.005'/>
      <testcase name='test__010__Push_Channel__listSubscriptions__should_return_a_paginated_result_with_PushChannelSubscription_filtered_by_channel_and_client()' classname='PushChannelTests' time='0.0095'/>
      <testcase name='test__011__Push_Channel__listSubscriptions__should_not_accept_null_deviceId_and_null_clientId()' classname='PushChannelTests' time='0.0062'/>
      <testcase name='test__012__Push_Channel__listSubscriptions__should_not_accept_both_deviceId_and_clientId_params_at_the_same_time()' classname='PushChannelTests' time='0.0014'/>
      <testcase name='test__013__Push_Channel__listSubscriptions__should_return_a_paginated_result_with_PushChannelSubscription()' classname='PushChannelTests' time='0.6'/>
    </testsuite>
    <testsuite name='PushTests' time='3.8305000000000002' tests='18' failures='0' skipped='0'>
      <testcase name='test__001__activation__activate_method_should_send_a_CalledActivate_event_to_the_state_machine()' classname='PushTests' time='0.0021'/>
      <testcase name='test__002__activation__deactivate_method_should_send_a_CalledDeactivate_event_to_the_state_machine()' classname='PushTests' time='0.0022'/>
      <testcase name='test__003__activation__should_handle_GotPushDeviceDetails_event_when_platform_s_APIs_sends_the_details_for_push_notifications()' classname='PushTests' time='0.0069'/>
      <testcase name='test__004__activation__sends_GettingPushDeviceDetailsFailed_when_push_registration_fails()' classname='PushTests' time='0.0025'/>
      <testcase name='test__005__activation__should_update_LocalDevice_clientId_when_it_s_null_with_auth_clientId()' classname='PushTests' time='0.16'/>
      <testcase name='test__006__activation__should_store_the_device_token_data_as_string()' classname='PushTests' time='0.0021'/>
      <testcase name='test__007__activation__should_not_sync_the_local_device_dispatched_in_internal_queue()' classname='PushTests' time='0.0054'/>
      <testcase name='test__008__LocalDevice__has_a_device_method_that_returns_a_LocalDevice()' classname='PushTests' time='0.0052'/>
      <testcase name='test__009__LocalDevice__the_device_is_lazily_populated_from_the_persisted_state()' classname='PushTests' time='0.0029'/>
      <testcase name='test__010__LocalDevice__authentication_on_registered_device_sends_a_GotPushDeviceDetails_with_new_clientID()' classname='PushTests' time='3.0'/>
      <testcase name='test__011__LocalDevice__sets_device_s_client_ID_from_registration_response()' classname='PushTests' time='0.0039'/>
      <testcase name='test__012__LocalDevice__when_using_token_authentication__new_clientID_is_set()' classname='PushTests' time='0.45'/>
      <testcase name='test__013__LocalDevice__when_getting_a_client_ID_from_CONNECTED_message__new_clientID_is_set()' classname='PushTests' time='0.0034'/>
      <testcase name='test__014__Registerer_Delegate_option__a_successful_activation_should_call_the_correct_registerer_delegate_method()' classname='PushTests' time='0.16'/>
      <testcase name='test__015__Registerer_Delegate_option__registerer_delegate_should_not_hold_a_strong_instance_reference()' classname='PushTests' time='0.0052'/>
      <testcase name='test__016__activate_should_call_registerForAPNS_while_transition_from_not_activated()' classname='PushTests' time='0.0042'/>
      <testcase name='test__017__LocalDevice__must_verify_the_validity_of_saved_push_details_and_update_if_needed_on_the_Ably_server_by_triggering_GotPushDeviceDetails()' classname='PushTests' time='0.0079'/>
      <testcase name='test__018__LocalDevice__when_alternative_device_token_available_update_push_details_on_the_Ably_server_by_triggering_GotPushDeviceDetails()' classname='PushTests' time='0.0066'/>
    </testsuite>
    <testsuite name='ReadmeExamplesTests' time='1.5487' tests='16' failures='0' skipped='0'>
      <testcase name='test__001__testMakeKeyInstance()' classname='ReadmeExamplesTests' time='0.0058'/>
      <testcase name='test__002__testMakeTokenInstance()' classname='ReadmeExamplesTests' time='0.0034'/>
      <testcase name='test__003__testListenToConnectionStateChanges()' classname='ReadmeExamplesTests' time='0.16'/>
      <testcase name='test__004__testNoAutoConnect()' classname='ReadmeExamplesTests' time='0.0014'/>
      <testcase name='test__005__testSubscribeAndPublishingToChannel()' classname='ReadmeExamplesTests' time='0.18'/>
      <testcase name='test__006__testQueryingTheHistory()' classname='ReadmeExamplesTests' time='0.18'/>
      <testcase name='test__007__testPresenceOnAChannel()' classname='ReadmeExamplesTests' time='0.17'/>
      <testcase name='test__008__testQueryingThePresenceHistory()' classname='ReadmeExamplesTests' time='0.18'/>
      <testcase name='test__009__testMakeRestClientAndChannel()' classname='ReadmeExamplesTests' time='0.001'/>
      <testcase name='test__010__testRestPublishMessage()' classname='ReadmeExamplesTests' time='0.16'/>
      <testcase name='test__011__testRestQueryingTheHistory()' classname='ReadmeExamplesTests' time='0.16'/>
      <testcase name='test__012__testRestPresenceOnAChannel()' classname='ReadmeExamplesTests' time='0.18'/>
      <testcase name='test__013__testRestQueryingThePresenceHistory()' classname='ReadmeExamplesTests' time='0.16'/>
      <testcase name='test__014__testGenerateToken()' classname='ReadmeExamplesTests' time='0.001'/>
      <testcase name='test__015__testFetchingStats()' classname='ReadmeExamplesTests' time='0.0018'/>
      <testcase name='test__016__testFetchingTime()' classname='ReadmeExamplesTests' time='0.0043'/>
    </testsuite>
    <testsuite name='RealtimeClientChannelTests' time='111.37883' tests='143' failures='0' skipped='0'>
      <testcase name='test__001__Channel__should_process_all_incoming_messages_and_presence_messages_as_soon_as_a_Channel_becomes_attached()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__002__Channel__should_not_crash_when_an_ATTACH_request_is_responded_with_a_DETACHED()' classname='RealtimeClientChannelTests' time='0.39'/>
      <testcase name='test__003__Channel__EventEmitter__channel_states_and_events__should_implement_the_EventEmitter_and_emit_events_for_state_changes()' classname='RealtimeClientChannelTests' time='0.46'/>
      <testcase name='test__004__Channel__EventEmitter__channel_states_and_events__should_implement_the_EventEmitter_and_emit_events_for_FAILED_state_changes()' classname='RealtimeClientChannelTests' time='0.57'/>
      <testcase name='test__005__Channel__EventEmitter__channel_states_and_events__should_implement_the_EventEmitter_and_emit_events_for_SUSPENDED_state_changes()' classname='RealtimeClientChannelTests' time='0.39'/>
      <testcase name='test__006__Channel__EventEmitter__channel_states_and_events__can_emit_an_UPDATE_event()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__007__Channel__EventEmitter__channel_states_and_events__should_not_emit_detached_event_on_an_already_detached_channel()' classname='RealtimeClientChannelTests' time='0.57'/>
      <testcase name='test__008__Channel__EventEmitter__channel_states_and_events__state_attribute_should_be_the_current_state_of_the_channel()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__009__Channel__EventEmitter__channel_states_and_events__should_contain_an_ErrorInfo_object_with_details_when_an_error_occurs()' classname='RealtimeClientChannelTests' time='0.0035'/>
      <testcase name='test__010__Channel__EventEmitter__channel_states_and_events__a_ChannelStateChange_is_emitted_as_the_first_argument_for_every_channel_state_change()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__011a__Channel__EventEmitter__channel_states_and_events__ChannelStateChange_will_contain_a_resumed_boolean_attribute_with_value__true__if_the_bit_flag_RESUMED_was_included()' classname='RealtimeClientChannelTests' time='5.0'/>
      <testcase name='test__011b__Channel__EventEmitter__channel_states_and_events__ChannelStateChange_will_contain_a_resumed_boolean_attribute_with_value__true__if_the_bit_flag_RESUMED_was_included_for_recovered_connection()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__013__Channel__connection_state__if_the_connection_state_enters_the_CONNECTED_state__then_a_SUSPENDED_channel_will_transition_to_ATTACHING_and_goes_back_to_SUSPNDED_on_timeout()' classname='RealtimeClientChannelTests' time='4.0'/>
      <testcase name='test__015__Channel__connection_state__should_attach_successfully_and_remain_attached_after_the_connection_goes_from_SUSPENDED_to_CONNECTED()' classname='RealtimeClientChannelTests' time='8.0'/>
      <testcase name='test__016__Channel__connection_state__if_the_connection_state_enters_the_DISCONNECTED_state__it_will_have_no_effect_on_the_channel_states()' classname='RealtimeClientChannelTests' time='4.0'/>
      <testcase name='test__017__Channel__connection_state__changes_to_FAILED__ATTACHING_channel_should_transition_to_FAILED()' classname='RealtimeClientChannelTests' time='0.0051'/>
      <testcase name='test__018__Channel__connection_state__changes_to_FAILED__ATTACHED_channel_should_transition_to_FAILED()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__019__Channel__connection_state__changes_to_FAILED__channel_being_released_waiting_for_DETACH_shouldn_t_crash__issue__918_()' classname='RealtimeClientChannelTests' time='0.014'/>
      <testcase name='test__020__Channel__connection_state__changes_to_FAILED__should_immediately_fail_if_not_in_the_connected_state()' classname='RealtimeClientChannelTests' time='0.003'/>
      <testcase name='test__021__Channel__connection_state__changes_to_FAILED__should_keep_the_channels_attached_when_client_reconnected_successfully_and_queue_messages_is_disabled()' classname='RealtimeClientChannelTests' time='0.9'/>
      <testcase name='test__022__Channel__connection_state__changes_to_CLOSED__ATTACHING_channel_should_transition_to_DETACHED()' classname='RealtimeClientChannelTests' time='0.5'/>
      <testcase name='test__023__Channel__connection_state__changes_to_CLOSED__ATTACHED_channel_should_transition_to_DETACHED()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__024__Channel__connection_state__changes_to_SUSPENDED__ATTACHING_channel_should_transition_to_SUSPENDED()' classname='RealtimeClientChannelTests' time='0.37'/>
      <testcase name='test__025__Channel__connection_state__changes_to_SUSPENDED__ATTACHED_channel_should_transition_to_SUSPENDED()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__026__Channel__connection_state__changes_to_SUSPENDED__channel_being_released_waiting_for_DETACH_shouldn_t_crash__issue__918_()' classname='RealtimeClientChannelTests' time='0.044'/>
      <testcase name='test__027__Channel__attach__if_already_ATTACHED_or_ATTACHING_nothing_is_done()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__028__Channel__attach__if_the_user_does_not_have_sufficient_permissions_to_attach__then_the_channel_will_transition_to_FAILED_and_set_the_errorReason()' classname='RealtimeClientChannelTests' time='0.56'/>
      <testcase name='test__029__Channel__attach__if_the_channel_is_in_the_FAILED_state__the_attach_request_sets_its_errorReason_to_null__and_proceeds_with_a_channel_attach()' classname='RealtimeClientChannelTests' time='0.46'/>
      <testcase name='test__030__Channel__attach__should_send_an_ATTACH_ProtocolMessage__change_state_to_ATTACHING_and_change_state_to_ATTACHED_after_confirmation()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__031__Channel__attach__should_transition_the_channel_state_to_FAILED_if_the_user_does_not_have_sufficient_permissions()' classname='RealtimeClientChannelTests' time='0.58'/>
      <testcase name='test__032__Channel__attach__should_transition_the_channel_state_to_SUSPENDED_if_ATTACHED_ProtocolMessage_is_not_received()' classname='RealtimeClientChannelTests' time='2.0'/>
      <testcase name='test__033__Channel__attach__if_called_with_a_callback_should_call_it_once_attached()' classname='RealtimeClientChannelTests' time='0.45'/>
      <testcase name='test__034__Channel__attach__if_called_with_a_callback_and_already_attaching_should_call_the_callback_once_attached()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__035__Channel__attach__if_called_with_a_callback_and_already_attached_should_call_the_callback_with_nil_error()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__036__Channel__attach__if_the_channel_is_in_a_pending_state_ATTACHING__do_the_attach_operation_after_the_completion_of_the_pending_request()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__037__Channel__attach__if_the_channel_is_in_a_pending_state_DETACHING__do_the_attach_operation_after_the_completion_of_the_pending_request()' classname='RealtimeClientChannelTests' time='0.59'/>
      <testcase name='test__038__Channel__attach__a_channel_in_DETACHING_can_actually_move_back_to_ATTACHED_if_it_fails_to_detach()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__039__Channel__attach__results_in_an_error_if_the_connection_state_is__CLOSING()' classname='RealtimeClientChannelTests' time='0.34'/>
      <testcase name='test__040__Channel__attach__results_in_an_error_if_the_connection_state_is__CLOSED()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__041__Channel__attach__results_in_an_error_if_the_connection_state_is__SUSPENDED()' classname='RealtimeClientChannelTests' time='0.0036'/>
      <testcase name='test__042__Channel__attach__results_in_an_error_if_the_connection_state_is__FAILED()' classname='RealtimeClientChannelTests' time='0.0045'/>
      <testcase name='test__043__Channel__attach__happens_when_connection_is_CONNECTED_if_it_s_currently__INITIALIZED()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__044__Channel__attach__happens_when_connection_is_CONNECTED_if_it_s_currently__CONNECTING()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__045__Channel__attach__happens_when_connection_is_CONNECTED_if_it_s_currently__DISCONNECTED()' classname='RealtimeClientChannelTests' time='0.91'/>
      <testcase name='test__046__Channel__attach__attach_resume__should_pass_attach_resume_flag_in_attach_message()' classname='RealtimeClientChannelTests' time='0.59'/>
      <testcase name='test__047__Channel__attach__attach_resume__should_have_correct_AttachResume_value()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__048__Channel__attach__attach_resume__should_encode_correctly_the_AttachResume_flag()' classname='RealtimeClientChannelTests' time='2.0'/>
      <testcase name='test__049__Channel__detach__if_state_is_INITIALIZED_or_DETACHED_nothing_is_done()' classname='RealtimeClientChannelTests' time='0.52'/>
      <testcase name='test__050__Channel__detach__if_the_channel_is_in_a_pending_state_DETACHING__do_the_detach_operation_after_the_completion_of_the_pending_request()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__051__Channel__detach__if_the_channel_is_in_a_pending_state_ATTACHING__do_the_detach_operation_after_the_completion_of_the_pending_request()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__052__Channel__detach__results_in_an_error_if_the_connection_state_is_FAILED()' classname='RealtimeClientChannelTests' time='0.0022'/>
      <testcase name='test__053__Channel__detach__should_send_a_DETACH_ProtocolMessage__change_state_to_DETACHING_and_change_state_to_DETACHED_after_confirmation()' classname='RealtimeClientChannelTests' time='0.49'/>
      <testcase name='test__054__Channel__detach__if_called_with_a_callback_should_call_it_once_detached()' classname='RealtimeClientChannelTests' time='0.49'/>
      <testcase name='test__055__Channel__detach__if_called_with_a_callback_and_already_detaching_should_call_the_callback_once_detached()' classname='RealtimeClientChannelTests' time='0.5'/>
      <testcase name='test__056__Channel__detach__if_called_with_a_callback_and_already_detached_should_should_call_the_callback_with_nil_error()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__057__Channel__detach__if_a_DETACHED_is_not_received_within_the_default_realtime_request_timeout__the_detach_request_should_be_treated_as_though_it_has_failed_and_the_channel_will_return_to_its_previous_state()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__058__Channel__detach__if_the_channel_state_is_SUSPENDED__the__detach__request_transitions_the_channel_immediately_to_the_DETACHED_state()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__059__Channel__detach__results_in_an_error_if_the_connection_state_is__CLOSING()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__060__Channel__detach__results_in_an_error_if_the_connection_state_is__FAILED()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__061__Channel__detach__happens_when_channel_is_ATTACHED_if_connection_is_currently__INITIALIZED()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__062__Channel__detach__happens_when_channel_is_ATTACHED_if_connection_is_currently__CONNECTING()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__063__Channel__detach__happens_when_channel_is_ATTACHED_if_connection_is_currently__DISCONNECTED()' classname='RealtimeClientChannelTests' time='0.96'/>
      <testcase name='test__064__Channel__publish__should_encode_messages_in_the_same_way_as_the_RestChannel()' classname='RealtimeClientChannelTests' time='0.72'/>
      <testcase name='test__065__Channel__publish__Message_connectionId_should_match_the_current_Connection_id_for_all_published_messages()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__066__Channel__publish__should_provide_an_optional_argument_that_allows_the_clientId_value_to_be_specified()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__067__Channel__publish__should_invoke_callback__when_the_message_is_successfully_delivered()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__068__Channel__publish__should_invoke_callback__upon_failure()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__069__Channel__publish__should_invoke_callback__for_all_messages_published()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__070__Channel__publish__Connection_state_conditions__publish_should_not_trigger_an_implicit_attach()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__071__Channel__publish__Connection_state_conditions__if_the_connection_is_CONNECTED_and_the_channel_is__ATTACHED_then_the_messages_should_be_published_immediately()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__072__Channel__publish__Connection_state_conditions__if_the_connection_is_CONNECTED_and_the_channel_is__INITIALIZED_then_the_messages_should_be_published_immediately()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__073__Channel__publish__Connection_state_conditions__if_the_connection_is_CONNECTED_and_the_channel_is__DETACHED_then_the_messages_should_be_published_immediately()' classname='RealtimeClientChannelTests' time='0.59'/>
      <testcase name='test__074__Channel__publish__Connection_state_conditions__if_the_connection_is_CONNECTED_and_the_channel_is__ATTACHING_then_the_messages_should_be_published_immediately()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__075__Channel__publish__Connection_state_conditions__if_the_connection_is_CONNECTED_and_the_channel_is__DETACHING_then_the_messages_should_be_published_immediately()' classname='RealtimeClientChannelTests' time='0.57'/>
      <testcase name='test__076__Channel__publish__Connection_state_conditions__the_message__should_be_queued_and_delivered_as_soon_as_the_connection_state_returns_to_CONNECTED_if_the_connection_is__INITIALIZED()' classname='RealtimeClientChannelTests' time='0.58'/>
      <testcase name='test__077__Channel__publish__Connection_state_conditions__the_message__should_be_queued_and_delivered_as_soon_as_the_connection_state_returns_to_CONNECTED_if_the_connection_is__CONNECTING()' classname='RealtimeClientChannelTests' time='0.58'/>
      <testcase name='test__078__Channel__publish__Connection_state_conditions__the_message__should_be_queued_and_delivered_as_soon_as_the_connection_state_returns_to_CONNECTED_if_the_connection_is__DISCONNECTED()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__082__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__connection_is_SUSPENDED()' classname='RealtimeClientChannelTests' time='0.37'/>
      <testcase name='test__083__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__connection_is_CLOSING()' classname='RealtimeClientChannelTests' time='0.32'/>
      <testcase name='test__084__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__connection_is_CLOSED()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__085__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__connection_is_FAILED()' classname='RealtimeClientChannelTests' time='0.36'/>
      <testcase name='test__086__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__channel_is_SUSPENDED()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__087__Channel__publish__Connection_state_conditions__will_result_in_an_error_if_the__channel_is_FAILED()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__088__Channel__publish__message_bundling__Messages_are_delivered_using_a_single_ProtocolMessage_where_possible_by_bundling_in_all_messages_for_that_channel()' classname='RealtimeClientChannelTests' time='0.9'/>
      <testcase name='test__089__Channel__publish__message_bundling__The_resulting_ProtocolMessage_must_not_exceed_the_maxMessageSize()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__090__Channel__publish__message_bundling__should_only_bundle_messages_when_it_respects_all_of_the_constraints()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__091__Channel__publish__message_bundling__should_publish_only_once_on_multiple_explicit_publish_requests_for_a_given_message_with_client_supplied_ids()' classname='RealtimeClientChannelTests' time='0.54'/>
      <testcase name='test__092__Channel__publish__message_bundling__Messages_with_differing_clientId_values_must_not_be_bundled_together__messages_with_different__non_empty__clientIds_are_posted_via_different_protocol_messages()' classname='RealtimeClientChannelTests' time='0.9'/>
      <testcase name='test__093__Channel__publish__message_bundling__Messages_with_differing_clientId_values_must_not_be_bundled_together__messages_with_mixed_empty_non_empty_clientIds_are_posted_via_different_protocol_messages()' classname='RealtimeClientChannelTests' time='0.99'/>
      <testcase name='test__094__Channel__publish__message_bundling__Messages_with_differing_clientId_values_must_not_be_bundled_together__messages_bundled_by_the_user_are_posted_in_a_single_protocol_message_even_if_they_have_mixed_clientIds()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__095__Channel__publish__Unidentified_clients_using_Basic_Auth__should_have_the_provided_clientId_on_received_message_when_it_was_published_with_clientId()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__096__Channel__publish__expect_either__an_array_of_Message_objects()' classname='RealtimeClientChannelTests' time='0.5'/>
      <testcase name='test__097__Channel__publish__expect_either__a_name_string_and_data_payload()' classname='RealtimeClientChannelTests' time='0.45'/>
      <testcase name='test__098__Channel__publish__expect_either__allows_name_to_be_null()' classname='RealtimeClientChannelTests' time='0.45'/>
      <testcase name='test__099__Channel__publish__expect_either__allows_data_to_be_null()' classname='RealtimeClientChannelTests' time='0.45'/>
      <testcase name='test__100__Channel__publish__expect_either__allows_name_and_data_to_be_assigned()' classname='RealtimeClientChannelTests' time='0.42'/>
      <testcase name='test__101__Channel__publish__Identified_clients_with_clientId__when_publishing_a_Message_with_the_clientId_attribute_value_set_to_the_identified_client_s_clientId()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__102__Channel__publish__Identified_clients_with_clientId__when_publishing_a_Message_with_a_different_clientId_attribute_value_from_the_identified_client_s_clientId__it_should_reject_that_publish_operation_immediately()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__103__Channel__publish__Identified_clients_with_clientId__message_should_be_published_following_authentication_and_received_back_with_the_clientId_intact()' classname='RealtimeClientChannelTests' time='0.67'/>
      <testcase name='test__104__Channel__publish__Identified_clients_with_clientId__message_should_be_rejected_by_the_Ably_service_and_the_message_error_should_contain_the_server_error()' classname='RealtimeClientChannelTests' time='0.57'/>
      <testcase name='test__105__Channel__publish__Identified_clients_with_clientId__When_publishing_a_Message_with_clientId_set_to_null__should_be_unnecessary_to_set_clientId_of_the_Message_before_publishing_and_have_clientId_value_set_for_the_Message_when_received()' classname='RealtimeClientChannelTests' time='0.45'/>
      <testcase name='test__106__Channel__subscribe__with_no_arguments_subscribes_a_listener_to_all_messages()' classname='RealtimeClientChannelTests' time='0.5'/>
      <testcase name='test__107__Channel__subscribe__with_a_single_name_argument_subscribes_a_listener_to_only_messages_whose_name_member_matches_the_string_name()' classname='RealtimeClientChannelTests' time='0.5'/>
      <testcase name='test__108__Channel__subscribe__with_a_attach_callback_should_subscribe_and_call_the_callback_when_attached()' classname='RealtimeClientChannelTests' time='0.49'/>
      <testcase name='test__109__Channel__subscribe__should_implicitly_attach_the_channel_if_options_attachOnSubscribe_is_true()' classname='RealtimeClientChannelTests' time='0.72'/>
      <testcase name='test__109b__Channel__subscribe__should_not_implicitly_attach_the_channel_if_options_attachOnSubscribe_is_false()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__110__Channel__subscribe__should_result_in_an_error_if_channel_is_in_the_FAILED_state_and_options_attachOnSubscribe_is_true()' classname='RealtimeClientChannelTests' time='0.029'/>
      <testcase name='test__110b__Channel__subscribe__should_not_result_in_an_error_if_channel_is_in_the_FAILED_state_and_options_attachOnSubscribe_is_false()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__111__Channel__subscribe__should_exist_ensuring_published_messages_are_not_echoed_back_to_the_subscriber_when_echoMessages_is_false()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__112__Channel__subscribe__should_deliver_the_message_even_if_there_is_an_error_while_decoding__using_crypto_data_128()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__113__Channel__subscribe__should_deliver_the_message_even_if_there_is_an_error_while_decoding__using_crypto_data_256()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__114__Channel__subscribe__message_cannot_be_decoded_or_decrypted__should_deliver_with_encoding_attribute_set_indicating_the_residual_encoding_and_error_should_be_emitted()' classname='RealtimeClientChannelTests' time='0.46'/>
      <testcase name='test__115__Channel__unsubscribe__with_no_arguments_unsubscribes_the_provided_listener_to_all_messages_if_subscribed()' classname='RealtimeClientChannelTests' time='0.43'/>
      <testcase name='test__116__Channel__unsubscribe__with_a_single_name_argument_unsubscribes_the_provided_listener_if_previously_subscribed_with_a_name_specific_subscription()' classname='RealtimeClientChannelTests' time='0.48'/>
      <testcase name='test__117__Channel__history__should_support_all_the_same_params_as_Rest()' classname='RealtimeClientChannelTests' time='0.52'/>
      <testcase name='test__118__Channel__history__should_return_a_PaginatedResult_page()' classname='RealtimeClientChannelTests' time='0.65'/>
      <testcase name='test__119__Channel__history__should_retrieve_all_available_messages()' classname='RealtimeClientChannelTests' time='0.81'/>
      <testcase name='test__120__Channel__history__attached_channel_may_receive_an_additional_ATTACHED_ProtocolMessage()' classname='RealtimeClientChannelTests' time='0.39'/>
      <testcase name='test__121__Channel__history__If_an_ERROR_ProtocolMessage_is_received_for_this_channel_then_the_channel_should_immediately_transition_to_the_FAILED_state__the_errorReason_should_be_set_and_an_error_should_be_emitted_on_the_channel()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__122__Channel__history__should_not_emit_messages_to_subscribers_if_the_channel_is_in_any_state_other_than_ATTACHED()' classname='RealtimeClientChannelTests' time='3.0'/>
      <testcase name='test__123__Channel__history__supports_the_param_untilAttach__should_be_false_as_default()' classname='RealtimeClientChannelTests' time='0.00073'/>
      <testcase name='test__124__Channel__history__supports_the_param_untilAttach__should_invoke_an_error_when_the_untilAttach_is_specified_and_the_channel_is_not_attached()' classname='RealtimeClientChannelTests' time='0.0065'/>
      <testcase name='test__125__Channel__history__supports_the_param_untilAttach__where_value_is_true__should_pass_the_querystring_param_fromSerial_with_the_serial_number_assigned_to_the_channel()' classname='RealtimeClientChannelTests' time='0.59'/>
      <testcase name='test__126__Channel__history__supports_the_param_untilAttach__where_value_is_false__should_pass_the_querystring_param_fromSerial_with_the_serial_number_assigned_to_the_channel()' classname='RealtimeClientChannelTests' time='0.6'/>
      <testcase name='test__127__Channel__history__supports_the_param_untilAttach__should_retrieve_messages_prior_to_the_moment_that_the_channel_was_attached()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__128__Channel__history__if_the_channel_receives_a_server_initiated_DETACHED_message_when__the_channel_is_in_the_ATTACHED_states__an_attempt_to_reattach_the_channel_should_be_made_immediately_by_sending_a_new_ATTACH_message_and_the_channel_should_transition_to_the_ATTACHING_state_with_the_error_emitted_in_the_ChannelStateChange_event()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__129__Channel__history__if_the_channel_receives_a_server_initiated_DETACHED_message_when__the_channel_is_in_the_SUSPENDED_state__an_attempt_to_reattach_the_channel_should_be_made_immediately_by_sending_a_new_ATTACH_message_and_the_channel_should_transition_to_the_ATTACHING_state_with_the_error_emitted_in_the_ChannelStateChange_event()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__130__Channel__history__if_the_channel_receives_a_server_initiated_DETACHED_message_when__if_the_attempt_to_re_attach_fails_the_channel_will_transition_to_the_SUSPENDED_state_and_the_error_will_be_emitted_in_the_ChannelStateChange_event()' classname='RealtimeClientChannelTests' time='2.0'/>
      <testcase name='test__131__Channel__history__if_the_channel_receives_a_server_initiated_DETACHED_message_when__if_the_channel_was_already_in_the_ATTACHING_state__the_channel_will_transition_to_the_SUSPENDED_state_and_the_error_will_be_emitted_in_the_ChannelStateChange_event()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__131b__Channel__if_the_channel_receives_a_server_initiated_DETACHED_message_and_if_the_attempt_to_reattach_fails_then_the_channel_will_transition_to_SUSPENDED_state_with_periodic_reattach_with_channelRetryTimeout()' classname='RealtimeClientChannelTests' time='12.0'/>
      <testcase name='test__132__Channel__history__if_the_channel_receives_a_server_initiated_DETACHED_message_when__if_the_connection_is_no_longer_CONNECTED__then_the_automatic_attempts_to_re_attach_the_channel_must_be_cancelled()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__133__Channel__history__Channel_options__setOptions__should_send_an_ATTACH_message_with_params___modes_if_the_channel_is_attached()' classname='RealtimeClientChannelTests' time='0.47'/>
      <testcase name='test__134__Channel__history__Channel_options__setOptions__should_send_an_ATTACH_message_with_params___modes_if_the_channel_is_attaching()' classname='RealtimeClientChannelTests' time='0.44'/>
      <testcase name='test__135__Channel__history__Channel_options__setOptions__should_success_immediately_if_channel_is_not_attaching_or_attached()' classname='RealtimeClientChannelTests' time='0.0017'/>
      <testcase name='test__136__Channel__history__Channel_options__setOptions__should_fail_if_the_attach_moves_to_FAILED()' classname='RealtimeClientChannelTests' time='0.59'/>
      <testcase name='test__137__Channel__history__Channel_options__setOptions__should_fail_if_the_attach_moves_to_DETACHED()' classname='RealtimeClientChannelTests' time='0.41'/>
      <testcase name='test__138__Channel__crypto__if_configured_for_encryption__channels_encrypt_and_decrypt_messages__data()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__139__message_attributes__if_the_message_does_not_contain_an_id__it_should_be_set_to_protocolMsgId_index()' classname='RealtimeClientChannelTests' time='0.4'/>
      <testcase name='test__140__ChannelOptions__options_provided_when_instantiating_a_channel_should_be_frozen()' classname='RealtimeClientChannelTests' time='0.011'/>
      <testcase name='test__200__channel_serial_is_updated_whenever_a_protocol_message_with_either_message_presence_or_attached_actions_is_received_in_a_channel()' classname='RealtimeClientChannelTests' time='0.6'/>
      <testcase name='test__201__channel_serial_is_cleared_whenever_a_channel_entered_into_detached_suspended_or_failed_state()' classname='RealtimeClientChannelTests' time='0.65'/>
      <testcase name='test__202__Channel__attach__protocol_message_channelSerial_must_be_set_to_channelSerial_of_the_most_recent_protocol_message_or_omitted_if_no_previous_protocol_message_received()' classname='RealtimeClientChannelTests' time='1.0'/>
      <testcase name='test__Channel_options__setOptions__shouldUpdateOptionsOfRestChannel()' classname='RealtimeClientChannelTests' time='0.33'/>
    </testsuite>
    <testsuite name='RealtimeClientChannelsTests' time='1.0143' tests='5' failures='0' skipped='0'>
      <testcase name='test__001__Channels__should_exist_methods_to_check_if_a_channel_exists_or_iterate_through_the_existing_channels()' classname='RealtimeClientChannelsTests' time='0.0031'/>
      <testcase name='test__002__Channels__get__should_create_a_new_Channel_if_none_exists_or_return_the_existing_one()' classname='RealtimeClientChannelsTests' time='0.0034'/>
      <testcase name='test__003__Channels__get__should_be_possible_to_specify_a_ChannelOptions()' classname='RealtimeClientChannelsTests' time='0.0057'/>
      <testcase name='test__004__Channels__get__accessing_an_existing_Channel_with_options_should_update_the_options_and_then_return_the_object()' classname='RealtimeClientChannelsTests' time='0.0021'/>
      <testcase name='test__005__Channels__release__should_release_a_channel()' classname='RealtimeClientChannelsTests' time='1.0'/>
    </testsuite>
    <testsuite name='RealtimeClientConnectionTests' time='184.4342' tests='129' failures='0' skipped='0'>
      <testcase name='test__001__Connection__should_connect_automatically()' classname='RealtimeClientConnectionTests' time='0.35'/>
      <testcase name='test__002__Connection__should_connect_manually()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__003__Connection__API_version_param_must_be_included_in_all_connections()' classname='RealtimeClientConnectionTests' time='0.0056'/>
      <testcase name='test__004__Connection__Library_and_version_param__agent__should_include_the__Ably_Agent__header_value()' classname='RealtimeClientConnectionTests' time='0.36'/>
      <testcase name='test__005__Connection__basic_operations_should_work_simultaneously()' classname='RealtimeClientConnectionTests' time='0.91'/>
      <testcase name='test__006__Connection__should_have_an_opened_websocket_connection_and_received_a_CONNECTED_ProtocolMessage()' classname='RealtimeClientConnectionTests' time='0.34'/>
      <testcase name='test__007__Connection__should_make_a_new_connection_with_a_new_transport_instance_if_the_state_is_CLOSING()' classname='RealtimeClientConnectionTests' time='0.66'/>
      <testcase name='test__008__Connection__it_should_make_sure_that__when_the_CLOSED_ProtocolMessage_arrives_for_the_old_connection__it_doesn_t_affect_the_new_one()' classname='RealtimeClientConnectionTests' time='0.67'/>
      <testcase name='test__009__Connection__should_enter_FAILED_state_when_API_key_is_invalid()' classname='RealtimeClientConnectionTests' time='0.36'/>
      <testcase name='test__010__Connection__attributes_within_ConnectionDetails_should_be_used_as_defaults()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__011__Connection__should_disconnect_the_transport_when_no_activity_exist()' classname='RealtimeClientConnectionTests' time='5.0'/>
      <testcase name='test__012__Connection__the_client_may_receive_a_CONNECTED_ProtocolMessage_from_Ably_at_any_point_and_should_emit_an_UPDATE_event()' classname='RealtimeClientConnectionTests' time='0.89'/>
      <testcase name='test__013__Connection__should_set_the_Connection_reason_attribute_based_on_the_Error_member_of_the_CONNECTED_ProtocolMessage()' classname='RealtimeClientConnectionTests' time='0.53'/>
      <testcase name='test__014__Connection__should_not_move_to_FAILED_if_received_DISCONNECT_with_an_error()' classname='RealtimeClientConnectionTests' time='0.35'/>
      <testcase name='test__015__Connection__should_abort_reconnection_with_new_token_if_the_server_has_requested_it_to_authorize_and_after_it_the_connection_has_been_closed()' classname='RealtimeClientConnectionTests' time='0.43'/>
      <testcase name='test__016__Connection__ConnectionDetails__maxMessageSize_overrides_the_default_maxMessageSize()' classname='RealtimeClientConnectionTests' time='0.32'/>
      <testcase name='test__017__Connection__url__should_connect_to_the_default_host()' classname='RealtimeClientConnectionTests' time='0.0029'/>
      <testcase name='test__018__Connection__url__should_connect_with_query_string_params()' classname='RealtimeClientConnectionTests' time='0.34'/>
      <testcase name='test__019__Connection__url__should_connect_with_query_string_params_including_clientId()' classname='RealtimeClientConnectionTests' time='0.5'/>
      <testcase name='test__020__Connection__event_emitter__should_emit_events_for_state_changes()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__021__Connection__event_emitter__should_never_emit_a_ConnectionState_event_for_a_state_equal_to_the_previous_state()' classname='RealtimeClientConnectionTests' time='0.66'/>
      <testcase name='test__021b__Connection__event_emitter__should_never_emit_a_ConnectionState_event_for_a_state_equal_to_the_previous_state_CONNECTING()' classname='RealtimeClientConnectionTests' time='0.37'/>
      <testcase name='test__022__Connection__event_emitter__should_emit_states_on_a_new_connection()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__023__Connection__event_emitter__should_emit_states_when_connection_is_closed()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__024__Connection__event_emitter__should_have_the_current_state()' classname='RealtimeClientConnectionTests' time='0.34'/>
      <testcase name='test__025__Connection__event_emitter__should_have_a_ConnectionStateChange_as_first_argument_for_every_connection_state_change()' classname='RealtimeClientConnectionTests' time='0.32'/>
      <testcase name='test__026__Connection__event_emitter__should_have_the_reason_which_contains_an_ErrorInfo()' classname='RealtimeClientConnectionTests' time='0.32'/>
      <testcase name='test__027__Connection__event_emitter__any_state_change_triggered_by_a_ProtocolMessage_that_contains_an_Error_member_should_populate_the_Reason_property()' classname='RealtimeClientConnectionTests' time='0.53'/>
      <testcase name='test__028__Connection__ACK_and_NACK__should_expect_either_an_ACK_or_NACK_to_confirm__successful_receipt_and_acceptance_of_message()' classname='RealtimeClientConnectionTests' time='0.49'/>
      <testcase name='test__029__Connection__ACK_and_NACK__should_expect_either_an_ACK_or_NACK_to_confirm__successful_receipt_and_acceptance_of_presence()' classname='RealtimeClientConnectionTests' time='0.47'/>
      <testcase name='test__030__Connection__ACK_and_NACK__should_expect_either_an_ACK_or_NACK_to_confirm__message_failure()' classname='RealtimeClientConnectionTests' time='0.98'/>
      <testcase name='test__031__Connection__ACK_and_NACK__should_expect_either_an_ACK_or_NACK_to_confirm__presence_failure()' classname='RealtimeClientConnectionTests' time='0.47'/>
      <testcase name='test__032__Connection__ACK_and_NACK__ProtocolMessage__should_contain_unique_serially_incrementing_msgSerial_along_with_the_count()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__033__Connection__ACK_and_NACK__ProtocolMessage__should_continue_incrementing_msgSerial_serially_if_the_connection_resumes_successfully()' classname='RealtimeClientConnectionTests' time='6.0'/>
      <testcase name='test__034__Connection__ACK_and_NACK__ProtocolMessage__should_reset_msgSerial_serially_if_the_connection_does_not_resume()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__035__Connection__ACK_and_NACK__should_trigger_the_failure_callback_for_the_remaining_pending_messages_if__connection_is_closed()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__036__Connection__ACK_and_NACK__should_trigger_the_failure_callback_for_the_remaining_pending_messages_if__connection_state_enters_FAILED()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__038__Connection__connection_id__should_be_null_until_connected()' classname='RealtimeClientConnectionTests' time='0.35'/>
      <testcase name='test__039__Connection__connection_id__should_have_unique_IDs()' classname='RealtimeClientConnectionTests' time='0.5'/>
      <testcase name='test__040__Connection__connection_key__should_be_null_until_connected()' classname='RealtimeClientConnectionTests' time='0.34'/>
      <testcase name='test__041__Connection__connection_key__should_have_unique_connection_keys()' classname='RealtimeClientConnectionTests' time='0.58'/>
      <testcase name='test__045__Connection__close__if_CONNECTING__do_the_operation_once_CONNECTED()' classname='RealtimeClientConnectionTests' time='0.44'/>
      <testcase name='test__046__Connection__close__if_CONNECTED__should_send_a_CLOSE_action__change_state_to_CLOSING_and_receive_a_CLOSED_action()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__047__Connection__close__should_transition_to_CLOSED_action_when_the_close_process_timeouts()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__048__Connection__close__transitions_to_the_CLOSING_state_and_then_to_the_CLOSED_state_if_the_transport_is_abruptly_closed()' classname='RealtimeClientConnectionTests' time='0.43'/>
      <testcase name='test__049__Connection__close__if_DISCONNECTED__aborts_the_retry_and_moves_immediately_to_CLOSED()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__050__Connection__close__if_SUSPENDED__aborts_the_retry_and_moves_immediately_to_CLOSED()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__051__Connection__ping__fails_if_in_the_INITIALIZED__SUSPENDED__CLOSING__CLOSED_or_FAILED_state()' classname='RealtimeClientConnectionTests' time='0.86'/>
      <testcase name='test__052__Connection__ping__should_send_a_ProtocolMessage_with_action_HEARTBEAT_and_expects_a_HEARTBEAT_message_in_response()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__053__Connection__ping__should_fail_if_a_HEARTBEAT_ProtocolMessage_is_not_received_within_the_default_realtime_request_timeout()' classname='RealtimeClientConnectionTests' time='3.0'/>
      <testcase name='test__054__Connection__connection_request_fails__on_DISCONNECTED_after_CONNECTED__should_not_emit_error_with_a_renewable_token()' classname='RealtimeClientConnectionTests' time='3.0'/>
      <testcase name='test__055__Connection__connection_request_fails__on_token_error_while_CONNECTING__reissues_token_and_reconnects()' classname='RealtimeClientConnectionTests' time='5.0'/>
      <testcase name='test__056__Connection__connection_request_fails__should_transition_to_disconnected_when_the_token_renewal_fails()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__057__Connection__connection_request_fails__should_transition_to_Failed_state_because_the_token_is_invalid_and_not_renewable()' classname='RealtimeClientConnectionTests' time='3.0'/>
      <testcase name='test__058__Connection__connection_request_fails__connection_attempt_should_fail_if_not_connected_within_the_default_realtime_request_timeout()' classname='RealtimeClientConnectionTests' time='0.51'/>
      <testcase name='test__059__Connection__connection_request_fails__connection_attempt_fails_for_any_recoverable_reason__for_example_a_timeout()' classname='RealtimeClientConnectionTests' time='13.0'/>
      <testcase name='test__059b__Connection__connection_request_fails__connection_attempt_fails_for_any_recoverable_reason__for_example_an_hostUnreachable_transport_error()' classname='RealtimeClientConnectionTests' time='19.0'/>
      <testcase name='test__060__Connection__connection_request_fails__connection_state_has_been_in_the_DISCONNECTED_state_for_more_than_the_default_connectionStateTtl_should_change_the_state_to_SUSPENDED()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__061__Connection__connection_request_fails__should_change_the_state_to_SUSPENDED_when_the_connection_state_has_been_in_the_DISCONNECTED_state_for_more_than_the_connectionStateTtl()' classname='RealtimeClientConnectionTests' time='13.0'/>
      <testcase name='test__062__Connection__connection_request_fails__on_CLOSE_the_connection_should_stop_connection_retries()' classname='RealtimeClientConnectionTests' time='4.0'/>
      <testcase name='test__064__Connection__connection_failures_once_CONNECTED__if_a_Connection_transport_is_disconnected_unexpectedly_or_if_a_token_expires__then_the_Connection_manager_will_immediately_attempt_to_reconnect()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__065__Connection__connection_failures_once_CONNECTED__should_recover_from_disconnection_and_messages_should_be_delivered_once_the_connection_is_resumed()' classname='RealtimeClientConnectionTests' time='0.97'/>
      <testcase name='test__066__Connection__connection_failures_once_CONNECTED__ACK_and_NACK_responses_for_published_messages_can_only_ever_be_received_on_the_transport_connection_on_which_those_messages_were_sent()' classname='RealtimeClientConnectionTests' time='0.84'/>
      <testcase name='test__067__Connection__connection_failures_once_CONNECTED__reconnects_to_the_websocket_endpoint_with_additional_querystring_params__resume_is_the_private_connection_key_from_the_most_recent_CONNECTED_ProtocolMessage_received()' classname='RealtimeClientConnectionTests' time='0.77'/>
      <testcase name='test__068a__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__CONNECTED_ProtocolMessage_with_the_same_connectionId_as_the_current_client__and_no_error()' classname='RealtimeClientConnectionTests' time='0.75'/>
      <testcase name='test__068b__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__CONNECTED_ProtocolMessage_with_the_same_connectionId_as_the_current_client__and_no_error()' classname='RealtimeClientConnectionTests' time='0.91'/>
      <testcase name='test__068c__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__CONNECTED_ProtocolMessage_with_the_same_connectionId_as_the_current_client__and_no_error()' classname='RealtimeClientConnectionTests' time='10.0'/>
      <testcase name='test__069__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__CONNECTED_ProtocolMessage_with_the_different_connectionId_than_the_current_client_and_an_non_fatal_error()' classname='RealtimeClientConnectionTests' time='0.86'/>
      <testcase name='test__071__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__ERROR_ProtocolMessage_indicating_a_fatal_error_in_the_connection()' classname='RealtimeClientConnectionTests' time='0.44'/>
      <testcase name='test__072__Connection__connection_failures_once_CONNECTED__System_s_response_to_a_resume_request__should_resume_the_connection_after_an_auth_renewal()' classname='RealtimeClientConnectionTests' time='5.0'/>
      <testcase name='test__073__Connection__connection_failures_once_CONNECTED__when_a_connection_is_resumed__the_connection_key_may_change_and_will_be_provided_in_the_first_CONNECTED_ProtocolMessage_connectionDetails()' classname='RealtimeClientConnectionTests' time='0.87'/>
      <testcase name='test__074__Connection__connection_failures_once_CONNECTED__when_connection__ttl_plus_idle_interval__period_has_passed_since_last_activity__uses_a_new_connection()' classname='RealtimeClientConnectionTests' time='6.0'/>
      <testcase name='test__075__Connection__connection_failures_once_CONNECTED__when_connection__ttl_plus_idle_interval__period_has_passed_since_last_activity__reattaches_to_the_same_channels_after_a_new_connection_has_been_established()' classname='RealtimeClientConnectionTests' time='6.0'/>
      <testcase name='test__076__Connection__connection_failures_once_CONNECTED__when_connection__ttl_plus_idle_interval__period_has_NOT_passed_since_last_activity__uses_the_same_connection()' classname='RealtimeClientConnectionTests' time='0.78'/>
      <testcase name='test__077__Connection__connection_failures_once_CONNECTED__DISCONNECTED_message_contains_a_token_error__if_the_token_is_renewable_then_error_should_not_be_emitted()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__078__Connection__connection_failures_once_CONNECTED__DISCONNECTED_message_contains_a_token_error__and_the_library_does_not_have_a_means_to_renew_the_token__the_connection_will_transition_to_the_FAILED_state()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__079__Connection__connection_failures_once_CONNECTED__DISCONNECTED_message_contains_a_token_error__should_transition_to_disconnected_when_the_token_renewal_fails_and_the_error_should_be_emitted()' classname='RealtimeClientConnectionTests' time='3.0'/>
      <testcase name='test__080__Connection__Connection_recovery__connection_state_should_recover_explicitly_with_a_recover_key()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__082__Connection__Connection_recovery__when_a_connection_is_successfully_recovered__Connection_id_will_be_identical_to_the_id_of_the_connection_that_was_recovered_and_Connection_key_will_always_be_updated_to_the_ConnectionDetails_connectionKey_provided_in_the_first_CONNECTED_ProtocolMessage()' classname='RealtimeClientConnectionTests' time='0.69'/>
      <testcase name='test__085__Connection__Connection_recovery__should_set_internal_message_serial_to_component_in_recovery_key()' classname='RealtimeClientConnectionTests' time='0.52'/>
      <testcase name='test__086__Connection__Connection_recovery__library_should_create_channel_with_corresponding_serial_in_given_recovery_key()' classname='RealtimeClientConnectionTests' time='0.77'/>
      <testcase name='test__086a__Connection__Host_Fallback__failing_connections_with_custom_endpoint_should_result_in_an_error_immediately()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__086b__Connection__Host_Fallback__failing_connections_with_custom_port_should_result_in_an_error_immediately()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__086c__Connection__Host_Fallback__failing_connections_with_custom_tlsPort_should_result_in_an_error_immediately()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__087__Connection__Host_Fallback__failing_connections_with_custom_endpoint_should_result_in_time_outs()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__089__Connection__Host_Fallback__applies_when_an_array_of_ClientOptions_fallbackHosts_is_provided()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__089b__Connection__Host_Fallback__applies_when_deprecated_fallbackHostsUseDefault_option_is_set_to_true()' classname='RealtimeClientConnectionTests' time='0.38'/>
      <testcase name='test__090__Connection__Connection_recovery__library_provides_additional_querystring_when_recover_is_provided()' classname='RealtimeClientConnectionTests' time='0.77'/>
      <testcase name='test__090__Connection__Host_Fallback__should_not_use_an_alternative_host_when_the_client_receives_a_bad_request()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__091__Connection__Host_Fallback__every_connection_is_first_attempted_to_the_primary_host_realtime_ably_io_prod()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__091__Connection__Host_Fallback__every_connection_is_first_attempted_to_the_primary_host_realtime_ably_io_sandbox()' classname='RealtimeClientConnectionTests' time='0.74'/>
      <testcase name='test__092__Connection__Host_Fallback__should_retry_hosts_in_random_order_after_checkin_if_an_internet_connection_is_available_prod()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__092__Connection__Host_Fallback__should_retry_hosts_in_random_order_after_checkin_if_an_internet_connection_is_available_sandbox()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__093__Connection__Host_Fallback__doesn_t_try_fallback_host_if_Internet_connection_check_fails()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__094__Connection__Host_Fallback__should_retry_custom_fallback_hosts_in_random_order_after_checkin_if_an_internet_connection_is_available()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__095__Connection__Host_Fallback__won_t_use_fallback_hosts_feature_if_an_empty_array_is_provided()' classname='RealtimeClientConnectionTests' time='0.11'/>
      <testcase name='test__096__Connection__Host_Fallback__client_is_connected_to_a_fallback_host_endpoint_should_do_HTTP_requests_to_the_same_data_centre()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__097__Connection__Host_Fallback__should_use_an_alternative_host_when___hostUnreachable()' classname='RealtimeClientConnectionTests' time='0.37'/>
      <testcase name='test__098__Connection__Host_Fallback__should_use_an_alternative_host_when___requestTimeout()' classname='RealtimeClientConnectionTests' time='0.57'/>
      <testcase name='test__099__Connection__Host_Fallback__should_use_an_alternative_host_when___hostInternalError_code__501()' classname='RealtimeClientConnectionTests' time='0.37'/>
      <testcase name='test__100__Connection__Host_Fallback__should_move_to_disconnected_when_there_s_no_internet__with_NSPOSIXErrorDomain_with_code_57()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__101__Connection__Host_Fallback__should_move_to_disconnected_when_there_s_no_internet__with_NSPOSIXErrorDomain_with_code_50()' classname='RealtimeClientConnectionTests' time='0.36'/>
      <testcase name='test__102__Connection__Host_Fallback__should_move_to_disconnected_when_there_s_no_internet__with_any_kCFErrorDomainCFNetwork()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__103a__Connection__Transport_disconnected_side_effects__should_resend_any_ProtocolMessage_by_processing_connection_wide_pending_messages()' classname='RealtimeClientConnectionTests' time='0.96'/>
      <testcase name='test__103b__Connection__Transport_disconnected_side_effects_message_serial_for_pending_message_must_remain_the_same_that_is_awaiting_a_ACK_NACK()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__103c__Connection__Transport_disconnected_side_effects_message_must_be_assigned_a_new_msgSerial_from_the_internal_msgSerial()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__104__Connection__Transport_disconnected_side_effects__should_resend_the_ATTACH_message_if_there_are_any_pending_channels()' classname='RealtimeClientConnectionTests' time='0.84'/>
      <testcase name='test__106__Connection__Operating_System_events_for_network_internet_connectivity_changes__should_immediately_attempt_to_connect_if_the_operating_system_indicates_that_the_underlying_internet_connection_is_now_available_when_DISCONNECTED_or_SUSPENDED()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__106_b__Connection__Operating_System_events_for_network_internet_connectivity_changes__should_restart_the_pending_connection_attempt_if_the_operating_system_indicates_that_the_underlying_internet_connection_is_now_available_when_CONNECTING()' classname='RealtimeClientConnectionTests' time='0.7'/>
      <testcase name='test__107__Connection__Operating_System_events_for_network_internet_connectivity_changes__Ably_can_request_that_a_connected_client_re_authenticates_by_sending_the_client_an_AUTH_ProtocolMessage()' classname='RealtimeClientConnectionTests' time='0.94'/>
      <testcase name='test__108__Connection__Operating_System_events_for_network_internet_connectivity_changes__re_authenticate_and_resume_the_connection_when_the_client_is_forcibly_disconnected_following_a_DISCONNECTED_message_containing_an_error_code_greater_than_or_equal_to_40140_and_less_than_40150()' classname='RealtimeClientConnectionTests' time='5.0'/>
      <testcase name='test__109__Connection__Operating_System_events_for_network_internet_connectivity_changes__should_immediately_change_the_state_to_DISCONNECTED_if_the_operating_system_indicates_that_the_underlying_internet_connection_is_no_longer_available__when_CONNECTING()' classname='RealtimeClientConnectionTests' time='0.0057'/>
      <testcase name='test__110__Connection__Connection_recovery__connection_recovery_key_is_correctly_constructed_from_defined_parts()' classname='RealtimeClientConnectionTests' time='0.58'/>
      <testcase name='test__110__Connection__Operating_System_events_for_network_internet_connectivity_changes__should_immediately_change_the_state_to_DISCONNECTED_if_the_operating_system_indicates_that_the_underlying_internet_connection_is_no_longer_available__when_CONNECTED()' classname='RealtimeClientConnectionTests' time='0.37'/>
      <testcase name='test__111__Connection__Connection_recovery__connection_recovery_key_is_properly_serializing_any_unicode_channel_name()' classname='RealtimeClientConnectionTests' time='0.52'/>
      <testcase name='test__111__Connection__with_fixture_messages__should_encode_and_decode_fixture_messages_as_expected()' classname='RealtimeClientConnectionTests' time='2.0'/>
      <testcase name='test__112__Connection__Connection_recovery__connection_recovery_key_is_null_when_connection_is_in_invalid_state()' classname='RealtimeClientConnectionTests' time='0.4'/>
      <testcase name='test__112__Connection__with_fixture_messages__should_send_messages_through_raw_JSON_POST_and_retrieve_equal_messages_through_MsgPack_and_JSON()' classname='RealtimeClientConnectionTests' time='0.93'/>
      <testcase name='test__113__Connection__Connection_recovery__connection_recovery_key_is_null_when_connection_is_in_suspended_state()' classname='RealtimeClientConnectionTests' time='0.36'/>
      <testcase name='test__113__Connection__with_fixture_messages__should_send_messages_through_MsgPack_and_JSON_and_retrieve_equal_messages_through_raw_JSON_GET()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__114__Connection__Connection_recovery__connection_recovery_key_is_null_when_connection_is_in_failed_state()' classname='RealtimeClientConnectionTests' time='0.36'/>
      <testcase name='test__139__Connection__connection_id_and_key__should_be_nil_when_sdk_is_in_CLOSING_and_CLOSED_states()' classname='RealtimeClientConnectionTests' time='0.39'/>
      <testcase name='test__140__Connection__connection_id_and_key__should_be_nil_when_sdk_is_in_SUSPENDED_state()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__141__Connection__connection_id_and_key__should_be_nil_when_sdk_is_in_FAILED_state()' classname='RealtimeClientConnectionTests' time='0.33'/>
      <testcase name='test__200a__Connection__Connection_recovery__failures_system_response_to_unrecoverable_token_error()' classname='RealtimeClientConnectionTests' time='0.83'/>
      <testcase name='test__200b__Connection__Connection_recovery__failures_system_response_to_unrecoverable_token_error()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__200c__Connection__Connection_recovery__failures_system_response_to_unrecoverable_token_error()' classname='RealtimeClientConnectionTests' time='1.0'/>
      <testcase name='test__201__Connection__Connection_recovery__failures_once_CONNECTED__System_s_response_to_a_resume_request__CONNECTED_ProtocolMessage_with_the_different_connectionId_than_the_current_client_and_an_non_fatal_error()' classname='RealtimeClientConnectionTests' time='0.71'/>
      <testcase name='test__202__Connection__Connection_recovery__failures_with_any_other_fatal_error_in_the_connection()' classname='RealtimeClientConnectionTests' time='0.86'/>
    </testsuite>
    <testsuite name='RealtimeClientPresenceTests' time='293.98821' tests='113' failures='0' skipped='0'>
      <testcase name='test__002__Presence__should_receive_all_250_members()' classname='RealtimeClientPresenceTests' time='2.0'/>
      <testcase name='test__003__Presence__should_be_used_a_PresenceMap_to_maintain_a_list_of_members()' classname='RealtimeClientPresenceTests' time='50.0'/>
      <testcase name='test__004__Presence__callback_can_be_provided_that_will_be_called_upon_success()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__005__Presence__callback_can_be_provided_that_will_be_called_upon_failure()' classname='RealtimeClientPresenceTests' time='0.66'/>
      <testcase name='test__006__Presence__should_also_ensure_that_using_updateClient_has_no_side_effects_on_a_client_that_has_entered_normally_using_Presence_enter()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__007__Presence__should_indicate_an_error_if_the_client_is_identified_and_has_a_valid_clientId_and_the_clientId_argument_does_not_match_the_client_s_clientId()' classname='RealtimeClientPresenceTests' time='0.54'/>
      <testcase name='test__008__Presence__Presence_syncComplete_returns_true_if_the_initial_SYNC_operation_has_completed()' classname='RealtimeClientPresenceTests' time='2.0'/>
      <testcase name='test__010__Presence__ProtocolMessage_bit_flag__when_members_are_present()' classname='RealtimeClientPresenceTests' time='2.0'/>
      <testcase name='test__011__Presence__realtime_system_reserves_the_right_to_initiate_a_sync_of_the_presence_members_at_any_point_once_a_channel_is_attached__should_do_a_new_sync_whenever_a_SYNC_ProtocolMessage_is_received_with_a_channel_attribute_and_a_new_sync_sequence_identifier_in_the_channelSerial_attribute()' classname='RealtimeClientPresenceTests' time='0.98'/>
      <testcase name='test__012__Presence__realtime_system_reserves_the_right_to_initiate_a_sync_of_the_presence_members_at_any_point_once_a_channel_is_attached__when_a_SYNC_is_sent_with_no_channelSerial_attribute_then_the_sync_data_is_entirely_contained_within_that_ProtocolMessage()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__013__Presence__PresenceMap_has_existing_members_when_a_SYNC_is_started__should_ensure_that_members_no_longer_present_on_the_channel_are_removed_from_the_local_PresenceMap_once_the_sync_is_complete()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__014__Presence__PresenceMap_has_existing_members_when_a_SYNC_is_started__should_emit_a_LEAVE_event_for_each_existing_member_if_the_PresenceMap_has_existing_members_when_an_ATTACHED_message_is_received_without_a_HAS_PRESENCE_flag()' classname='RealtimeClientPresenceTests' time='0.51'/>
      <testcase name='test__015__Presence__subscribe__with_no_arguments_should_subscribe_a_listener_to_all_presence_messages()' classname='RealtimeClientPresenceTests' time='2.0'/>
      <testcase name='test__016__Presence__unsubscribe__with_no_arguments_unsubscribes_the_listener_if_previously_subscribed_with_an_action_specific_subscription()' classname='RealtimeClientPresenceTests' time='0.0014'/>
      <testcase name='test__017__Presence__Channel_state_change_side_effects__if_a_channel_enters_the_ATTACHED_state_then_all_queued_presence_messages_will_be_sent_immediately_and_a_presence_SYNC_may_be_initiated()' classname='RealtimeClientPresenceTests' time='0.95'/>
      <testcase name='test__018__Presence__Channel_state_change_side_effects__if_the_channel_enters_the_FAILED_state__all_queued_presence_messages_should_fail_immediately()' classname='RealtimeClientPresenceTests' time='0.0017'/>
      <testcase name='test__019__Presence__Channel_state_change_side_effects__if_the_channel_enters_the_FAILED_state__should_clear_the_PresenceMap_including_local_members_and_does_not_emit_any_presence_events()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__020__Presence__Channel_state_change_side_effects__if_the_channel_enters_the_DETACHED_state__all_queued_presence_messages_should_fail_immediately()' classname='RealtimeClientPresenceTests' time='0.0026'/>
      <testcase name='test__021__Presence__Channel_state_change_side_effects__if_the_channel_enters_the_DETACHED_state__should_clear_the_PresenceMap_including_local_members_and_does_not_emit_any_presence_events()' classname='RealtimeClientPresenceTests' time='0.59'/>
      <testcase name='test__022__Presence__Channel_state_change_side_effects__channel_enters_the_SUSPENDED_state__all_queued_presence_messages_should_fail_immediately()' classname='RealtimeClientPresenceTests' time='0.0017'/>
      <testcase name='test__023__Presence__Channel_state_change_side_effects__channel_enters_the_SUSPENDED_state__members_map_is_preserved_and_only_members_that_changed_between_ATTACHED_states_should_result_in_presence_events()' classname='RealtimeClientPresenceTests' time='4.0'/>
      <testcase name='test__024__Presence__enter__should_enter_the_current_client__optionally_with_the_data_provided()' classname='RealtimeClientPresenceTests' time='0.6'/>
      <testcase name='test__025__Presence__unsubscribe__with_a_single_action_argument_unsubscribes_the_provided_listener_to_all_presence_messages_for_that_action()' classname='RealtimeClientPresenceTests' time='0.0056'/>
      <testcase name='test__026__Presence__subscribe__should_implicitly_attach_the_channel_if_options_attachOnSubscribe_is_true()' classname='RealtimeClientPresenceTests' time='0.69'/>
      <testcase name='test__026b__Presence__subscribe__should_not_implicitly_attach_the_channel_if_options_attachOnSubscribe_is_false()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__027__Presence__subscribe__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state_and_options_attachOnSubscribe_is_true()' classname='RealtimeClientPresenceTests' time='0.012'/>
      <testcase name='test__027b__Presence__subscribe__should_not_result_in_an_error_if_the_channel_is_in_the_FAILED_state_and_options_attachOnSubscribe_is_false()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__028__Presence__subscribe__should_result_in_an_error_if_the_channel_moves_to_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0029'/>
      <testcase name='test__029__Presence__subscribe__with_a_single_action_argument()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__030__Presence__enter__optionally_a_callback_can_be_provided_that_is_called_for_success()' classname='RealtimeClientPresenceTests' time='0.48'/>
      <testcase name='test__031__Presence__enter__optionally_a_callback_can_be_provided_that_is_called_for_failure()' classname='RealtimeClientPresenceTests' time='0.44'/>
      <testcase name='test__032__Presence__enter__entering_without_an_explicit_PresenceMessage_clientId_should_implicitly_use_the_clientId_of_the_current_connection()' classname='RealtimeClientPresenceTests' time='0.54'/>
      <testcase name='test__033__Presence__enter__should_result_in_an_error_immediately_if_the_connection_state_is_connected_and_the_client_is_anonymous()' classname='RealtimeClientPresenceTests' time='0.32'/>
      <testcase name='test__033__Presence__enter__should_result_in_an_error_immediately_if_the_connection_state_is_connected_and_the_client_is_wildcard()' classname='RealtimeClientPresenceTests' time='0.31'/>
      <testcase name='test__034__Presence__enter__should_result_in_an_error_immediately_if_the_channel_is_DETACHED()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__035__Presence__enter__should_result_in_an_error_immediately_if_the_channel_is_FAILED()' classname='RealtimeClientPresenceTests' time='0.0028'/>
      <testcase name='test__036__Presence__enter__should_result_in_an_error_if_Ably_service_determines_that_the_client_is_unidentified()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__037__Presence__update__should_update_the_data_for_the_present_member_with_a_value()' classname='RealtimeClientPresenceTests' time='0.68'/>
      <testcase name='test__038__Presence__update__should_update_the_data_for_the_present_member_with_null()' classname='RealtimeClientPresenceTests' time='0.56'/>
      <testcase name='test__039__Presence__update__should_enter_current_client_into_the_channel_if_the_client_was_not_already_entered()' classname='RealtimeClientPresenceTests' time='0.48'/>
      <testcase name='test__040__Presence__update__optionally_a_callback_can_be_provided_that_is_called_for_success()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__041__Presence__update__optionally_a_callback_can_be_provided_that_is_called_for_failure()' classname='RealtimeClientPresenceTests' time='0.0058'/>
      <testcase name='test__042__Presence__update__update_without_an_explicit_PresenceMessage_clientId_should_implicitly_use_the_clientId_of_the_current_connection()' classname='RealtimeClientPresenceTests' time='0.97'/>
      <testcase name='test__043__Presence__leave__should_leave_the_current_client_from_the_channel_and_the_data_will_be_updated_with_the_value_provided()' classname='RealtimeClientPresenceTests' time='0.53'/>
      <testcase name='test__044__Presence__leave__should_leave_the_current_client_with_no_data()' classname='RealtimeClientPresenceTests' time='0.53'/>
      <testcase name='test__045__Presence__PresenceMap__all_incoming_presence_messages_must_be_compared_for_newness_with_the_matching_member_already_in_the_PresenceMap()' classname='RealtimeClientPresenceTests' time='0.98'/>
      <testcase name='test__047__Presence__PresenceMap__if_action_of_UPDATE_arrives__it_should_be_added_to_the_presence_map_with_the_action_set_to_PRESENT()' classname='RealtimeClientPresenceTests' time='0.98'/>
      <testcase name='test__048__Presence__PresenceMap__if_action_of_PRESENT_arrives__it_should_be_added_to_the_presence_map_with_the_action_set_to_PRESENT()' classname='RealtimeClientPresenceTests' time='0.91'/>
      <testcase name='test__049__Presence__PresenceMap__if_a_SYNC_is_not_in_progress__then_when_a_presence_message_with_an_action_of_LEAVE_arrives__that_memberKey_should_be_deleted_from_the_presence_map__if_present()' classname='RealtimeClientPresenceTests' time='10.0'/>
      <testcase name='test__050__Presence__PresenceMap__if_a_SYNC_is_in_progress__then_when_a_presence_message_with_an_action_of_LEAVE_arrives__it_should_be_stored_in_the_presence_map_with_the_action_set_to_ABSENT()' classname='RealtimeClientPresenceTests' time='10.0'/>
      <testcase name='test__051__Presence__PresenceMap__any_incoming_presence_message_that_passes_the_newness_check_should_be_emitted_on_the_Presence_object__with_an_event_name_set_to_its_original_action()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__052__Presence__PresenceMap__compare_for_newness__split_the_id_of_both_presence_messages()' classname='RealtimeClientPresenceTests' time='51.0'/>
      <testcase name='test__053__Presence__PresenceMap__compare_for_newness__presence_message_has_a_connectionId_which_is_not_an_initial_substring_of_its_id__compares_them_by_timestamp_numerically()' classname='RealtimeClientPresenceTests' time='51.0'/>
      <testcase name='test__054__Presence__PresenceMap__all_presence_messages_from_a_SYNC_must_also_be_compared_for_newness_in_the_same_way_as_they_would_from_a_PRESENCE__discard_members_where_messages_have_arrived_before_the_SYNC()' classname='RealtimeClientPresenceTests' time='10.0'/>
      <testcase name='test__056__Presence__enter__should_result_in_an_error_if_the_client_does_not_have_required_presence_permission()' classname='RealtimeClientPresenceTests' time='0.59'/>
      <testcase name='test__057__Presence__update__should_result_in_an_error_immediately_if_the_client_is_anonymous()' classname='RealtimeClientPresenceTests' time='0.51'/>
      <testcase name='test__058__Presence__update__should_result_in_an_error_immediately_if_the_channel_is_DETACHED()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__059__Presence__update__should_result_in_an_error_immediately_if_the_channel_is_FAILED()' classname='RealtimeClientPresenceTests' time='0.0021'/>
      <testcase name='test__060__Presence__update__should_result_in_an_error_if_the_client_does_not_have_required_presence_permission()' classname='RealtimeClientPresenceTests' time='0.55'/>
      <testcase name='test__061__Presence__update__should_result_in_an_error_if_Ably_service_determines_that_the_client_is_unidentified()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__062__Presence__leave__optionally_a_callback_can_be_provided_that_is_called_for_success()' classname='RealtimeClientPresenceTests' time='0.96'/>
      <testcase name='test__063__Presence__leave__optionally_a_callback_can_be_provided_that_is_called_for_failure()' classname='RealtimeClientPresenceTests' time='0.57'/>
      <testcase name='test__064__Presence__leave__should_raise_an_error_if_client_is_not_present()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__065__Presence__leave__entering_without_an_explicit_PresenceMessage_clientId_should_implicitly_use_the_clientId_of_the_current_connection()' classname='RealtimeClientPresenceTests' time='0.96'/>
      <testcase name='test__066__Presence__leave__if_the_client_is_not_currently_ENTERED__Ably_will_respond_with_an_ACK_and_the_request_will_succeed()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__067__Presence__enter__implicitly_attaches_the_Channel()' classname='RealtimeClientPresenceTests' time='0.5'/>
      <testcase name='test__068__Presence__enter__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0016'/>
      <testcase name='test__069__Presence__enter__should_result_in_an_error_if_the_channel_is_in_the_DETACHED_state()' classname='RealtimeClientPresenceTests' time='0.45'/>
      <testcase name='test__070__Presence__leave__should_result_in_an_error_immediately_if_the_client_is_anonymous()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__071__Presence__leave__should_result_in_an_error_immediately_if_the_channel_is_DETACHED()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__072__Presence__leave__should_result_in_an_error_immediately_if_the_channel_is_FAILED()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__073__Presence__leave__should_result_in_an_error_if_the_client_does_not_have_required_presence_permission()' classname='RealtimeClientPresenceTests' time='0.55'/>
      <testcase name='test__074__Presence__leave__should_result_in_an_error_if_Ably_service_determines_that_the_client_is_unidentified()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__078__Presence__enter__optional_data_can_be_included_when_entering_a_channel()' classname='RealtimeClientPresenceTests' time='0.92'/>
      <testcase name='test__079__Presence__enter__should_emit_the_data_attribute_in_the_LEAVE_event_when_data_is_provided_when_entering_but_no_data_is_provided_when_leaving()' classname='RealtimeClientPresenceTests' time='0.97'/>
      <testcase name='test__080__Presence__private_and_internal_PresenceMap_containing_only_members_that_match_the_current_connectionId__any_ENTER__PRESENT__UPDATE_or_LEAVE_event_that_matches_the_current_connectionId_should_be_applied_to_this_object()' classname='RealtimeClientPresenceTests' time='0.74'/>
      <testcase name='test__081__Presence__private_and_internal_PresenceMap_containing_only_members_that_match_the_current_connectionId__all_members_belonging_to_the_current_connection_are_published_as_a_PresenceMessage_on_the_Channel_by_the_server_irrespective_of_whether_the_client_has_permission_to_subscribe_or_the_Channel_is_configured_to_publish_presence_events()' classname='RealtimeClientPresenceTests' time='0.61'/>
      <testcase name='test__084__Presence__enterClient__should_implicitly_attach_the_Channel()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__085__Presence__enterClient__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0022'/>
      <testcase name='test__086__Presence__enterClient__should_result_in_an_error_if_the_channel_moves_to_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0029'/>
      <testcase name='test__087__Presence__updateClient__should_implicitly_attach_the_Channel()' classname='RealtimeClientPresenceTests' time='0.51'/>
      <testcase name='test__088__Presence__updateClient__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0017'/>
      <testcase name='test__089__Presence__updateClient__should_result_in_an_error_if_the_channel_moves_to_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0018'/>
      <testcase name='test__090__Presence__leaveClient__should_implicitly_attach_the_Channel()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__091__Presence__leaveClient__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0017'/>
      <testcase name='test__092__Presence__leaveClient__should_result_in_an_error_if_the_channel_moves_to_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0024'/>
      <testcase name='test__093__Presence__Connection_state_conditions__all_presence_messages_are_published_immediately_if_the_connection_is_CONNECTED()' classname='RealtimeClientPresenceTests' time='0.45'/>
      <testcase name='test__094__Presence__Connection_state_conditions__all_presence_messages_will_be_queued_and_delivered_as_soon_as_the_connection_state_returns_to_CONNECTED()' classname='RealtimeClientPresenceTests' time='0.92'/>
      <testcase name='test__095__Presence__Connection_state_conditions__all_presence_messages_will_be_lost_if_queueMessages_has_been_explicitly_set_to_false()' classname='RealtimeClientPresenceTests' time='0.4'/>
      <testcase name='test__096__Presence__Connection_state_conditions__should_result_in_an_error_if_the_connection_state_is_INITIALIZED_and_queueMessages_has_been_explicitly_set_to_false()' classname='RealtimeClientPresenceTests' time='0.0015'/>
      <testcase name='test__097__Presence__Connection_state_conditions__should_result_in_an_error_if_the_connection_state_is__suspended()' classname='RealtimeClientPresenceTests' time='0.42'/>
      <testcase name='test__098__Presence__Connection_state_conditions__should_result_in_an_error_if_the_connection_state_is__closed()' classname='RealtimeClientPresenceTests' time='0.51'/>
      <testcase name='test__099__Presence__Connection_state_conditions__should_result_in_an_error_if_the_connection_state_is__failed()' classname='RealtimeClientPresenceTests' time='0.39'/>
      <testcase name='test__100__Presence__get__should_return_a_list_of_current_members_on_the_channel()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__101__Presence__get__should_implicitly_attach_the_channel()' classname='RealtimeClientPresenceTests' time='0.47'/>
      <testcase name='test__102__Presence__get__should_result_in_an_error_if_the_channel_is_in_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0023'/>
      <testcase name='test__103__Presence__get__should_result_in_an_error_if_the_channel_moves_to_the_FAILED_state()' classname='RealtimeClientPresenceTests' time='0.0022'/>
      <testcase name='test__104__Presence__get__should_result_in_an_error_if_the_channel_is_in_the_DETACHED_state()' classname='RealtimeClientPresenceTests' time='0.46'/>
      <testcase name='test__105__Presence__get__should_result_in_an_error_if_the_channel_moves_to_the_DETACHED_state()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__106__Presence__get__query__waitForSync_should_be_true_by_default()' classname='RealtimeClientPresenceTests' time='0.00061'/>
      <testcase name='test__107__Presence__get__If_the_Channel_is_in_the_SUSPENDED_state_then__by_default__results_in_an_error()' classname='RealtimeClientPresenceTests' time='0.002'/>
      <testcase name='test__108__Presence__get__If_the_Channel_is_in_the_SUSPENDED_state_then__if_waitForSync_is_true__results_in_an_error()' classname='RealtimeClientPresenceTests' time='0.0024'/>
      <testcase name='test__109__Presence__get__If_the_Channel_is_in_the_SUSPENDED_state_then__if_waitForSync_is_false__returns_the_members_in_the_current_PresenceMap()' classname='RealtimeClientPresenceTests' time='0.0043'/>
      <testcase name='test__110__Presence__get__Query__set_of_params___waitForSync_is_true__should_wait_until_SYNC_is_complete_before_returning_a_list_of_members()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__111__Presence__get__Query__set_of_params___waitForSync_is_false__should_return_immediately_the_known_set_of_presence_members()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__112__Presence__get__Query__set_of_params___should_return_members_filtered_by_clientId()' classname='RealtimeClientPresenceTests' time='0.5'/>
      <testcase name='test__113__Presence__get__Query__set_of_params___should_return_members_filtered_by_connectionId()' classname='RealtimeClientPresenceTests' time='50.0'/>
      <testcase name='test__114__Presence__history__should_support_all_the_same_params_as_Rest()' classname='RealtimeClientPresenceTests' time='0.45'/>
      <testcase name='test__115__Presence__history__should_return_a_PaginatedResult_page()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__116__Presence__enterClient__enters_into_presence_on_a_channel_on_behalf_of_another_clientId()' classname='RealtimeClientPresenceTests' time='0.58'/>
      <testcase name='test__117__Presence__enterClient__should_be_present_all_the_registered_members_on_a_presence_channel()' classname='RealtimeClientPresenceTests' time='1.0'/>
      <testcase name='test__118__Presence__presence_message_attributes__if_the_presence_message_does_not_contain_an_id__it_should_be_set_to_protocolMsgId_index()' classname='RealtimeClientPresenceTests' time='0.32'/>
      <testcase name='test__200__Presence__PresenceMap_should_perform_re_entry_whenever_a_channel_moves_into_the_attached_state_and_presence_message_consists_of_enter_action_with_client_id_and_data()' classname='RealtimeClientPresenceTests' time='1.0'/>
    </testsuite>
    <testsuite name='RealtimeClientTests' time='27.92795' tests='46' failures='0' skipped='0'>
      <testcase name='test__001__RealtimeClient__All_WebSocket_connections_should_include_the_current_API_version()' classname='RealtimeClientTests' time='0.41'/>
      <testcase name='test__002__RealtimeClient__should_have_access_to_the_underlying_Connection_object()' classname='RealtimeClientTests' time='0.0024'/>
      <testcase name='test__003__RealtimeClient__should_provide_access_to_the_underlying_Channels_object()' classname='RealtimeClientTests' time='0.002'/>
      <testcase name='test__004__RealtimeClient__should_use_the_configured_timeouts_specified()' classname='RealtimeClientTests' time='6.0'/>
      <testcase name='test__005__RealtimeClient__background_behaviour()' classname='RealtimeClientTests' time='0.69'/>
      <testcase name='test__006__RealtimeClient__should_accept_acks_with_different_order()' classname='RealtimeClientTests' time='0.99'/>
      <testcase name='test__007__RealtimeClient__transport_should_guarantee_the_incoming_message_order()' classname='RealtimeClientTests' time='0.33'/>
      <testcase name='test__008__RealtimeClient__subscriber_should_receive_messages_in_the_same_order_in_which_they_have_been_sent()' classname='RealtimeClientTests' time='0.53'/>
      <testcase name='test__009__RealtimeClient__should_dispatch_in_user_queue_when_removing_an_observer()' classname='RealtimeClientTests' time='0.009'/>
      <testcase name='test__010__RealtimeClient__should_never_register_any_connection_listeners_for_internal_use_with_the_public_EventEmitter()' classname='RealtimeClientTests' time='0.39'/>
      <testcase name='test__011__RealtimeClient__should_never_register_any_message_and_channel_listeners_for_internal_use_with_the_public_EventEmitter()' classname='RealtimeClientTests' time='0.84'/>
      <testcase name='test__012__RealtimeClient__moves_to_DISCONNECTED_on_an_unexpected_normal_WebSocket_close()' classname='RealtimeClientTests' time='1.0'/>
      <testcase name='test__013__RealtimeClient__options__should_support_the_same_options_as_the_Rest_client()' classname='RealtimeClientTests' time='0.36'/>
      <testcase name='test__014__RealtimeClient__options__should_echoMessages_option_be_true_by_default()' classname='RealtimeClientTests' time='0.00057'/>
      <testcase name='test__015__RealtimeClient__options__should_autoConnect_option_be_true_by_default()' classname='RealtimeClientTests' time='0.00058'/>
      <testcase name='test__016__RealtimeClient__options__should_attempt_to_recover_the_connection_state_if_recover_string_is_assigned()' classname='RealtimeClientTests' time='0.67'/>
      <testcase name='test__017__RealtimeClient__options__should_modify_the_realtime_endpoint_host_if_realtimeHost_is_assigned()' classname='RealtimeClientTests' time='0.014'/>
      <testcase name='test__018__RealtimeClient__options__should_modify_both_the_REST_and_realtime_endpoint_if_environment_string_is_assigned()' classname='RealtimeClientTests' time='0.0013'/>
      <testcase name='test__019__RealtimeClient__options__url_should_contains_transport_params()' classname='RealtimeClientTests' time='0.0043'/>
      <testcase name='test__020__RealtimeClient__Auth_object__should_provide_access_to_the_Auth_object()' classname='RealtimeClientTests' time='0.0038'/>
      <testcase name='test__021__RealtimeClient__Auth_object__clientId_may_be_populated_when_the_connection_is_established()' classname='RealtimeClientTests' time='0.35'/>
      <testcase name='test__022__RealtimeClient__stats__should_present_an_async_interface()' classname='RealtimeClientTests' time='0.25'/>
      <testcase name='test__023__RealtimeClient__stats__should_accept_all_the_same_params_as_RestClient()' classname='RealtimeClientTests' time='0.69'/>
      <testcase name='test__024__RealtimeClient__time__should_present_an_async_interface()' classname='RealtimeClientTests' time='0.17'/>
      <testcase name='test__025__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__in_the_CONNECTED_state_and_auth_authorize_is_called__the_client_must_obtain_a_new_token__send_an_AUTH_ProtocolMessage_with_an_auth_attribute()' classname='RealtimeClientTests' time='0.83'/>
      <testcase name='test__026__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_authentication_token_change_is_successful__then_the_client_should_receive_a_new_CONNECTED_ProtocolMessage()' classname='RealtimeClientTests' time='0.75'/>
      <testcase name='test__027__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__performs_an_upgrade_of_capabilities_without_any_loss_of_continuity_or_connectivity_during_the_upgrade_process()' classname='RealtimeClientTests' time='0.87'/>
      <testcase name='test__028__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_capabilities_are_downgraded__client_should_receive_an_ERROR_ProtocolMessage_with_a_channel_property()' classname='RealtimeClientTests' time='0.82'/>
      <testcase name='test__029__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_authentication_token_change_fails__client_should_receive_an_ERROR_ProtocolMessage_triggering_the_connection_to_transition_to_the_FAILED_state()' classname='RealtimeClientTests' time='0.58'/>
      <testcase name='test__030__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_complete_with_an_error_if_the_request_fails()' classname='RealtimeClientTests' time='0.5'/>
      <testcase name='test__031__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_be_indicated_as_completed_with_the_new_token_or_error_only_once_realtime_has_responded_to_the_AUTH_with_either_a_CONNECTED_or_ERROR_respectively()' classname='RealtimeClientTests' time='0.63'/>
      <testcase name='test__032__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_connection_is_CONNECTING__all_current_connection_attempts_should_be_halted__and_after_obtaining_a_new_token_the_library_should_immediately_initiate_a_connection_attempt_using_the_new_token()' classname='RealtimeClientTests' time='0.83'/>
      <testcase name='test__033__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_complete_with_the_new_token_once_the_connection_has_moved_to_the_CONNECTED_state()' classname='RealtimeClientTests' time='0.65'/>
      <testcase name='test__034__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_complete_with_an_error_if_the_connection_moves_to_the_FAILED_state()' classname='RealtimeClientTests' time='0.54'/>
      <testcase name='test__035__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_complete_with_an_error_if_the_connection_moves_to_the_SUSPENDED_state()' classname='RealtimeClientTests' time='0.54'/>
      <testcase name='test__036__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__authorize_call_should_complete_with_an_error_if_the_connection_moves_to_the_CLOSED_state()' classname='RealtimeClientTests' time='0.61'/>
      <testcase name='test__037__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_connection_is_in_the_SUSPENDED_state_when_auth_authorize_is_called__after_obtaining_a_token_the_library_should_move_to_the_CONNECTING_state_and_initiate_a_connection_attempt_using_the_new_token()' classname='RealtimeClientTests' time='1.0'/>
      <testcase name='test__038__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_connection_is_in_the_CLOSED_state_when_auth_authorize_is_called__after_obtaining_a_token_the_library_should_move_to_the_CONNECTING_state_and_initiate_a_connection_attempt_using_the_new_token()' classname='RealtimeClientTests' time='1.0'/>
      <testcase name='test__039__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_connection_is_in_the_DISCONNECTED_state_when_auth_authorize_is_called__after_obtaining_a_token_the_library_should_move_to_the_CONNECTING_state_and_initiate_a_connection_attempt_using_the_new_token()' classname='RealtimeClientTests' time='1.0'/>
      <testcase name='test__040__RealtimeClient__Auth_authorize_should_upgrade_the_connection_with_current_token__when_the_connection_is_in_the_FAILED_state_when_auth_authorize_is_called__after_obtaining_a_token_the_library_should_move_to_the_CONNECTING_state_and_initiate_a_connection_attempt_using_the_new_token()' classname='RealtimeClientTests' time='1.0'/>
      <testcase name='test__041__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_the_publish_and_indicate_an_error()' classname='RealtimeClientTests' time='0.37'/>
      <testcase name='test__042__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_also_presence_messages__enter_()' classname='RealtimeClientTests' time='0.35'/>
      <testcase name='test__043__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_also_presence_messages__leave_()' classname='RealtimeClientTests' time='0.35'/>
      <testcase name='test__044__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_also_presence_messages__update_()' classname='RealtimeClientTests' time='0.35'/>
      <testcase name='test__045__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_also_presence_messages__updateClient_()' classname='RealtimeClientTests' time='0.33'/>
      <testcase name='test__046__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_also_presence_messages__leaveClient_()' classname='RealtimeClientTests' time='0.32'/>
    </testsuite>
    <testsuite name='RestClientChannelTests' time='13.35127' tests='48' failures='0' skipped='0'>
      <testcase name='test__001__publish__should_not_fail_sending_a_message_with_no_clientId_in_the_client_options_and_credentials_that_can_assume_any_clientId()' classname='RestClientChannelTests' time='0.46'/>
      <testcase name='test__002__publish__should_provide_an_optional_argument_that_allows_the_clientId_value_to_be_specified()' classname='RestClientChannelTests' time='0.0026'/>
      <testcase name='test__003__publish__should_provide_an_optional_argument_that_allows_the_extras_value_to_be_specified()' classname='RestClientChannelTests' time='0.35'/>
      <testcase name='test__004__publish__should_include_attributes_supplied_by_the_caller_in_the_encoded_message()' classname='RestClientChannelTests' time='0.19'/>
      <testcase name='test__005__publish__with_name_and_data_arguments__publishes_the_message_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.25'/>
      <testcase name='test__006__publish__with_name_only__publishes_the_message_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.28'/>
      <testcase name='test__007__publish__with_data_only__publishes_the_message_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.29'/>
      <testcase name='test__008__publish__with_neither_name_nor_data__publishes_the_message_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.25'/>
      <testcase name='test__009__publish__with_a_Message_object__publishes_the_message_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.27'/>
      <testcase name='test__010__publish__with_an_array_of_Message_objects__publishes_the_messages_in_a_single_request_and_invokes_callback_with_success()' classname='RestClientChannelTests' time='0.4'/>
      <testcase name='test__011__publish__Unidentified_clients_using_Basic_Auth__should_publish_message_with_the_provided_clientId()' classname='RestClientChannelTests' time='0.24'/>
      <testcase name='test__012__publish__ClientOptions_clientId__should_include_the_clientId_as_a_querystring_parameter_in_realtime_connection_requests()' classname='RestClientChannelTests' time='0.46'/>
      <testcase name='test__013__publish__ClientOptions_clientId__should_include_an_X_Ably_ClientId_header_with_value_set_to_the_clientId_as_Base64_encoded_string_in_REST_connection_requests()' classname='RestClientChannelTests' time='0.17'/>
      <testcase name='test__014__publish__Message_clientId__publishing_with_no_clientId_when_the_clientId_is_set_to_some_value_in_the_client_options_should_result_in_a_message_received_with_the_clientId_property_set_to_that_value()' classname='RestClientChannelTests' time='0.6'/>
      <testcase name='test__015__publish__Message_clientId__publishing_with_a_clientId_set_to_the_same_value_as_the_clientId_in_the_client_options_should_result_in_a_message_received_with_the_clientId_property_set_to_that_value()' classname='RestClientChannelTests' time='0.62'/>
      <testcase name='test__016__publish__Message_clientId__publishing_with_a_clientId_set_to_a_value_from_an_unidentified_client_should_result_in_a_message_received_with_the_clientId_property_set_to_that_value()' classname='RestClientChannelTests' time='0.59'/>
      <testcase name='test__017__publish__Message_clientId__publishing_with_a_clientId_set_to_a_different_value_from_the_clientId_in_the_client_options_should_result_in_a_message_being_rejected_by_the_server()' classname='RestClientChannelTests' time='0.41'/>
      <testcase name='test__018__publish__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__the_client_library_should_reject_the_publish_and_indicate_an_error()' classname='RestClientChannelTests' time='0.023'/>
      <testcase name='test__019__publish__If_the_total_size_of_message_s__exceeds_the_maxMessageSize__also_when_using_publish_data_clientId_extras()' classname='RestClientChannelTests' time='0.0041'/>
      <testcase name='test__020__publish__idempotent_publishing__idempotentRestPublishing_option()' classname='RestClientChannelTests' time='0.00077'/>
      <testcase name='test__021__publish__idempotent_publishing__should_not_generate_for_message_with_a_non_empty_id()' classname='RestClientChannelTests' time='0.0023'/>
      <testcase name='test__022__publish__idempotent_publishing__should_generate_for_internal_message_that_is_created_in_publish_name_data___method()' classname='RestClientChannelTests' time='0.003'/>
      <testcase name='test__023__publish__idempotent_publishing__should_not_generate_for_multiple_messages_with_a_non_empty_id()' classname='RestClientChannelTests' time='0.0013'/>
      <testcase name='test__024__publish__idempotent_publishing__should_not_generate_when_idempotentRestPublishing_flag_is_off()' classname='RestClientChannelTests' time='0.0044'/>
      <testcase name='test__025__publish__idempotent_publishing__should_have_only_one_published_message()' classname='RestClientChannelTests' time='0.78'/>
      <testcase name='test__026__publish__idempotent_publishing__should_publish_a_message_with_implicit_Id_only_once()' classname='RestClientChannelTests' time='0.5'/>
      <testcase name='test__027__publish__idempotent_publishing__random_idempotent_publish_id__should_generate_for_one_message_with_empty_id()' classname='RestClientChannelTests' time='0.0038'/>
      <testcase name='test__028__publish__idempotent_publishing__random_idempotent_publish_id__should_generate_for_multiple_messages_with_empty_id()' classname='RestClientChannelTests' time='0.018'/>
      <testcase name='test__029__history__should_return_a_PaginatedResult_page_containing_the_first_page_of_messages()' classname='RestClientChannelTests' time='0.19'/>
      <testcase name='test__030__history__query_arguments__start_and_end_should_filter_messages_between_those_two_times()' classname='RestClientChannelTests' time='0.68'/>
      <testcase name='test__031__history__query_arguments__start_must_be_equal_to_or_less_than_end_and_is_unaffected_by_the_request_direction()' classname='RestClientChannelTests' time='0.01'/>
      <testcase name='test__032__history__query_arguments__direction_backwards_or_forwards()' classname='RestClientChannelTests' time='0.26'/>
      <testcase name='test__033__history__query_arguments__limit_items_result()' classname='RestClientChannelTests' time='0.26'/>
      <testcase name='test__034__history__query_arguments__limit_supports_up_to_1000_items()' classname='RestClientChannelTests' time='0.0053'/>
      <testcase name='test__035__presence__get__should_return_presence_fixture_data()' classname='RestClientChannelTests' time='0.19'/>
      <testcase name='test__036__message_encoding__payloads_should_be_binary__strings__or_objects_capable_of_JSON_representation()' classname='RestClientChannelTests' time='0.7'/>
      <testcase name='test__037__message_encoding__encoding_attribute_should_represent_the_encoding_s__applied_in_right_to_left()' classname='RestClientChannelTests' time='0.41'/>
      <testcase name='test__038__message_encoding__json__binary_payload_should_be_encoded_as_Base64_and_represented_as_a_JSON_string()' classname='RestClientChannelTests' time='0.19'/>
      <testcase name='test__039__message_encoding__json__string_payload_should_be_represented_as_a_JSON_string()' classname='RestClientChannelTests' time='0.2'/>
      <testcase name='test__040__message_encoding__json__messages_received_should_be_decoded_based_on_the_encoding_field()' classname='RestClientChannelTests' time='0.72'/>
      <testcase name='test__041__message_encoding__json__json_payload_should_be_stringified_either__as_a_JSON_Array()' classname='RestClientChannelTests' time='0.19'/>
      <testcase name='test__042__message_encoding__json__json_payload_should_be_stringified_either__as_a_JSON_Object()' classname='RestClientChannelTests' time='0.22'/>
      <testcase name='test__043__message_payload_encryption__should_support_AES_encryption__128_CBC_mode()' classname='RestClientChannelTests' time='0.25'/>
      <testcase name='test__044__message_payload_encryption__should_support_AES_encryption__256_CBC_mode()' classname='RestClientChannelTests' time='0.27'/>
      <testcase name='test__045__message_decoding__should_deliver_with_a_binary_payload_when_the_payload_was_successfully_decoded_but_it_could_not_be_decrypted()' classname='RestClientChannelTests' time='0.42'/>
      <testcase name='test__046__message_decoding__should_deliver_with_encoding_attribute_set_indicating_the_residual_encoding_and_error_should_be_emitted()' classname='RestClientChannelTests' time='0.31'/>
      <testcase name='test__047__status__with_subscribers__returns_a_channel_details_object_populated_with_channel_metrics()' classname='RestClientChannelTests' time='0.7'/>
      <testcase name='test__48__channel_name_can_contain_slash_character_which_is_url_encoded_in_the_rest_request_path()' classname='RestClientChannelTests' time='0.0027'/>
    </testsuite>
    <testsuite name='RestClientChannelsTests' time='0.012929999999999999' tests='8' failures='0' skipped='0'>
      <testcase name='test__001__RestClient__channels__should_return_collection_of_channels()' classname='RestClientChannelsTests' time='0.0021'/>
      <testcase name='test__002__RestClient__channels__should_be_enumerable()' classname='RestClientChannelsTests' time='0.0034'/>
      <testcase name='test__003__RestClient__channels__get__should_return_a_channel()' classname='RestClientChannelsTests' time='0.0012'/>
      <testcase name='test__004__RestClient__channels__get__should_return_a_channel_with_the_provided_options()' classname='RestClientChannelsTests' time='0.00063'/>
      <testcase name='test__005__RestClient__channels__get__should_not_replace_the_options_on_an_existing_channel_when_none_are_provided()' classname='RestClientChannelsTests' time='0.0006'/>
      <testcase name='test__006__RestClient__channels__get__should_replace_the_options_on_an_existing_channel_when_new_ones_are_provided()' classname='RestClientChannelsTests' time='0.0017'/>
      <testcase name='test__007__RestClient__channels__channelExists__should_check_if_a_channel_exists()' classname='RestClientChannelsTests' time='0.0017'/>
      <testcase name='test__008__RestClient__channels__releaseChannel__should_release_a_channel()' classname='RestClientChannelsTests' time='0.0016'/>
    </testsuite>
    <testsuite name='RestClientPresenceTests' time='37.3781' tests='11' failures='0' skipped='0'>
      <testcase name='test__001__Presence__presence_messages_retrieved_are_decoded_in_the_same_way_that_messages_are_decoded()' classname='RestClientPresenceTests' time='0.88'/>
      <testcase name='test__002__Presence__get__should_return_a_PaginatedResult_page_containing_the_first_page_of_members()' classname='RestClientPresenceTests' time='1.0'/>
      <testcase name='test__003__Presence__get__limit_should_support_up_to_1000_items()' classname='RestClientPresenceTests' time='0.0022'/>
      <testcase name='test__004__Presence__get__clientId_should_filter_members_by_the_provided_clientId()' classname='RestClientPresenceTests' time='0.78'/>
      <testcase name='test__005__Presence__get__connectionId_should_filter_members_by_the_provided_connectionId()' classname='RestClientPresenceTests' time='4.0'/>
      <testcase name='test__006__Presence__history__should_return_a_PaginatedResult_page_containing_the_first_page_of_members()' classname='RestClientPresenceTests' time='1.0'/>
      <testcase name='test__007__Presence__history__query_argument__direction_should_change_the_order_of_the_members()' classname='RestClientPresenceTests' time='5.0'/>
      <testcase name='test__008__Presence__history__connectionId_should_filter_members_by_the_provided_connectionId()' classname='RestClientPresenceTests' time='4.0'/>
      <testcase name='test__009__Presence__history__query_argument__limit_supports_up_to_1000_members()' classname='RestClientPresenceTests' time='0.71'/>
      <testcase name='test__010__Presence__history__query_argument__start_and_end_should_filter_members_between_those_two_times()' classname='RestClientPresenceTests' time='20.0'/>
      <testcase name='test__011__Presence__history__query_argument__start_must_be_equal_to_or_less_than_end_and_is_unaffected_by_the_request_direction()' classname='RestClientPresenceTests' time='0.0059'/>
    </testsuite>
    <testsuite name='RestClientStatsTests' time='39.0036' tests='13' failures='0' skipped='0'>
      <testcase name='test__001__RestClient__stats__result__should_match_minute_level_inbound_and_outbound_fixture_data__forwards_()' classname='RestClientStatsTests' time='4.0'/>
      <testcase name='test__002__RestClient__stats__result__should_match_hour_level_inbound_and_outbound_fixture_data__forwards_()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__003__RestClient__stats__result__should_match_day_level_inbound_and_outbound_fixture_data__forwards_()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__004__RestClient__stats__result__should_match_month_level_inbound_and_outbound_fixture_data__forwards_()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__005__RestClient__stats__result__should_contain_only_one_item_when_limit_is_1__backwards()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__006__RestClient__stats__result__should_contain_only_one_item_when_limit_is_1__forwards()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__007__RestClient__stats__result__should_be_paginated_according_to_the_limit__backwards()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__008__RestClient__stats__result__should_be_paginated_according_to_the_limit__fowards_()' classname='RestClientStatsTests' time='5.0'/>
      <testcase name='test__009__RestClient__stats__query__start__should_return_an_error_when_later_than_end()' classname='RestClientStatsTests' time='0.00098'/>
      <testcase name='test__010__RestClient__stats__query__direction__should_be_backwards_by_default()' classname='RestClientStatsTests' time='0.00053'/>
      <testcase name='test__011__RestClient__stats__query__limit__should_have_a_default_value_of_100()' classname='RestClientStatsTests' time='0.00058'/>
      <testcase name='test__012__RestClient__stats__query__limit__should_return_an_error_when_greater_than_1000()' classname='RestClientStatsTests' time='0.00081'/>
      <testcase name='test__013__RestClient__stats__query__unit__should_default_to_minute()' classname='RestClientStatsTests' time='0.0007'/>
    </testsuite>
    <testsuite name='RestClientTests' time='28.15142' tests='97' failures='0' skipped='0'>
      <testcase name='test__001__RestClient__All_REST_requests_should_include_the_current_API_version()' classname='RestClientTests' time='0.22'/>
      <testcase name='test__002__RestClient__should_provide_access_to_the_AuthOptions_object_passed_in_ClientOptions()' classname='RestClientTests' time='0.0017'/>
      <testcase name='test__003__RestClient__REST_endpoint_host_should_be_configurable_in_the_Client_constructor_with_the_option_restHost()' classname='RestClientTests' time='0.027'/>
      <testcase name='test__004__RestClient__should_send_requests_over_http_and_https()' classname='RestClientTests' time='0.44'/>
      <testcase name='test__005__RestClient__should_use_Auth_to_manage_authentication()' classname='RestClientTests' time='0.21'/>
      <testcase name='test__006__RestClient__should_request_another_token_after_current_one_is_no_longer_valid()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__007__RestClient__should_result_in_an_error_when_user_does_not_have_sufficient_permissions()' classname='RestClientTests' time='0.4'/>
      <testcase name='test__008__RestClient__should_use_MsgPack_binary_protocol()' classname='RestClientTests' time='0.64'/>
      <testcase name='test__009__RestClient__should_use_JSON_text_protocol()' classname='RestClientTests' time='0.66'/>
      <testcase name='test__010__RestClient__X_Ably_Version_must_be_included_in_all_REST_requests()' classname='RestClientTests' time='0.21'/>
      <testcase name='test__011__RestClient__The_Agent_library_identifier_is_composed_of_a_series_of_key__value__entries_joined_by_spaces()' classname='RestClientTests' time='0.17'/>
      <testcase name='test__012__RestClient__should_indicate_an_error_if_there_is_no_way_to_renew_the_token()' classname='RestClientTests' time='2.0'/>
      <testcase name='test__013__RestClient__background_behaviour()' classname='RestClientTests' time='0.58'/>
      <testcase name='test__014__RestClient__client_should_handle_error_messages_in_plaintext_and_HTML_format()' classname='RestClientTests' time='0.26'/>
      <testcase name='test__015__RestClient__initializer__should_accept_an_API_key()' classname='RestClientTests' time='0.00094'/>
      <testcase name='test__016__RestClient__initializer__should_throw_when_provided_an_invalid_key()' classname='RestClientTests' time='0.0065'/>
      <testcase name='test__017__RestClient__initializer__should_result_in_error_status_when_provided_a_bad_key()' classname='RestClientTests' time='0.3'/>
      <testcase name='test__018__RestClient__initializer__should_accept_a_token()' classname='RestClientTests' time='0.18'/>
      <testcase name='test__019__RestClient__initializer__should_accept_an_options_object()' classname='RestClientTests' time='0.0043'/>
      <testcase name='test__020__RestClient__initializer__should_accept_an_options_object_with_token_authentication()' classname='RestClientTests' time='0.18'/>
      <testcase name='test__021__RestClient__initializer__should_result_in_error_status_when_provided_a_bad_token()' classname='RestClientTests' time='0.24'/>
      <testcase name='test__022__RestClient__logging__should_output_to_the_system_log_and_the_log_level_should_be_Warn()' classname='RestClientTests' time='0.003'/>
      <testcase name='test__023__RestClient__logging__should_have_a_mutable_log_level()' classname='RestClientTests' time='0.0045'/>
      <testcase name='test__024__RestClient__logging__should_accept_a_custom_logger()' classname='RestClientTests' time='0.0016'/>
      <testcase name='test__025__RestClient__endpoint__should_accept_a_custom_host_and_send_requests_to_the_specified_host()' classname='RestClientTests' time='0.012'/>
      <testcase name='test__026__RestClient__endpoint__should_ignore_an_environment_when_restHost_is_customized()' classname='RestClientTests' time='0.014'/>
      <testcase name='test__027__RestClient__endpoint__should_accept_an_environment_when_restHost_is_left_unchanged()' classname='RestClientTests' time='0.012'/>
      <testcase name='test__028__RestClient__endpoint__should_default_to_https___rest_ably_io()' classname='RestClientTests' time='0.012'/>
      <testcase name='test__029__RestClient__endpoint__should_connect_over_plain_http____when_tls_is_off()' classname='RestClientTests' time='0.19'/>
      <testcase name='test__030__RestClient__endpoint__should_not_prepend_the_environment_if_environment_is_configured_as__production_()' classname='RestClientTests' time='0.00068'/>
      <testcase name='test__031__RestClient__should_use_the_the_connection_and_request_timeouts_specified__timeout_for_any_single_HTTP_request_and_response()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__032__RestClient__should_use_the_the_connection_and_request_timeouts_specified__max_number_of_fallback_hosts()' classname='RestClientTests' time='0.0035'/>
      <testcase name='test__033__RestClient__should_use_the_the_connection_and_request_timeouts_specified__max_elapsed_time_in_which_fallback_host_retries_for_HTTP_requests_will_be_attempted()' classname='RestClientTests' time='0.43'/>
      <testcase name='test__034__RestClient__time__should_return_server_time()' classname='RestClientTests' time='0.2'/>
      <testcase name='test__035__RestClient__Authentication__should_support_basic_authentication_when_an_API_key_is_provided_with_the_key_option()' classname='RestClientTests' time='0.2'/>
      <testcase name='test__036__RestClient__Authentication__should_error_when_expired_token_and_no_means_to_renew()' classname='RestClientTests' time='5.0'/>
      <testcase name='test__037__RestClient__Authentication__should_renew_the_token_when_it_has_expired()' classname='RestClientTests' time='5.0'/>
      <testcase name='test__038__RestClient__Authentication__basic_authentication_flag__should_be_true_when_initialized_with_a_key()' classname='RestClientTests' time='0.0029'/>
      <testcase name='test__039__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__useTokenAuth_is_set()' classname='RestClientTests' time='0.0028'/>
      <testcase name='test__040__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__authUrl_is_set()' classname='RestClientTests' time='0.0022'/>
      <testcase name='test__041__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__authCallback_is_set()' classname='RestClientTests' time='0.0021'/>
      <testcase name='test__042__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__tokenDetails_is_set()' classname='RestClientTests' time='0.0018'/>
      <testcase name='test__043__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__token_is_set()' classname='RestClientTests' time='0.0022'/>
      <testcase name='test__044__RestClient__Authentication__basic_authentication_flag__should_be_false_when_options__key_is_set()' classname='RestClientTests' time='0.0019'/>
      <testcase name='test__045__RestClient__Host_Fallback__failing_HTTP_requests_with_custom_endpoint_should_result_in_an_error_immediately()' classname='RestClientTests' time='0.0037'/>
      <testcase name='test__046__RestClient__Host_Fallback__applies_when_ClientOptions_fallbackHostsUseDefault_is_true()' classname='RestClientTests' time='0.0014'/>
      <testcase name='test__047__RestClient__Host_Fallback__won_t_apply_fallback_hosts_if_ClientOptions_fallbackHosts_array_is_empty()' classname='RestClientTests' time='0.025'/>
      <testcase name='test__048__RestClient__Host_Fallback__won_t_apply_custom_fallback_hosts_if_ClientOptions_fallbackHosts_and_ClientOptions_environment_are_not_set__use_defaults_instead()' classname='RestClientTests' time='0.0013'/>
      <testcase name='test__049__RestClient__Host_Fallback__every_new_HTTP_request_is_first_attempted_to_the_default_primary_host_rest_ably_io()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__050__RestClient__Host_Fallback__should_not_use_an_alternative_host_when_the_client_receives_an_bad_request()' classname='RestClientTests' time='0.0029'/>
      <testcase name='test__051__RestClient__Host_Fallback__fallbackHostsUseDefault_option__allows_the_default_fallback_hosts_to_be_used_when__environment__is_not_production()' classname='RestClientTests' time='0.0087'/>
      <testcase name='test__052__RestClient__Host_Fallback__fallbackHostsUseDefault_option__allows_the_default_fallback_hosts_to_be_used_when_a_custom_Realtime_or_REST_host_endpoint_is_being_used()' classname='RestClientTests' time='0.002'/>
      <testcase name='test__053__RestClient__Host_Fallback__fallbackHostsUseDefault_option__should_be_inactive_by_default()' classname='RestClientTests' time='0.002'/>
      <testcase name='test__054__RestClient__Host_Fallback__fallbackHostsUseDefault_option__should_never_accept_to_configure__fallbackHost__and_set__fallbackHostsUseDefault__to__true_()' classname='RestClientTests' time='0.0036'/>
      <testcase name='test__055__RestClient__Host_Fallback__Fallback_behavior__should_be_applied_when_restHost__port_and_tlsPort_has_not_been_set_to_an_explicit_value()' classname='RestClientTests' time='0.0014'/>
      <testcase name='test__056__RestClient__Host_Fallback__Fallback_behavior__should_NOT_be_applied_when_ClientOptions_restHost_has_been_set()' classname='RestClientTests' time='0.0013'/>
      <testcase name='test__057__RestClient__Host_Fallback__Fallback_behavior__should_NOT_be_applied_when_ClientOptions_port_has_been_set()' classname='RestClientTests' time='0.0032'/>
      <testcase name='test__058__RestClient__Host_Fallback__Fallback_behavior__should_NOT_be_applied_when_ClientOptions_tlsPort_has_been_set()' classname='RestClientTests' time='0.0011'/>
      <testcase name='test__059__RestClient__Host_Fallback__Fallback_behavior__should_be_applied_when_ClientOptions_fallbackHosts_is_provided()' classname='RestClientTests' time='0.0017'/>
      <testcase name='test__060__RestClient__Host_Fallback__Fallback_behavior__should_be_applied_when_ClientOptions_fallbackHosts_is_not_provided_and_deprecated_fallbackHostsUseDefault_is_on()' classname='RestClientTests' time='0.0012'/>
      <testcase name='test__061__RestClient__Host_Fallback__fallback_hosts_list_and_priorities__should_use_ClientOptions_fallbackHosts_when_list_is_provided()' classname='RestClientTests' time='0.0014'/>
      <testcase name='test__062__RestClient__Host_Fallback__fallback_hosts_list_and_priorities__should_use_environment_fallback_hosts_when_ClientOptions_environment_is_set_to_a_value_other_than__production__and_ClientOptions_fallbackHosts_is_not_set()' classname='RestClientTests' time='0.002'/>
      <testcase name='test__063__RestClient__Host_Fallback__fallback_hosts_list_and_priorities__should_NOT_use_environment_fallback_hosts_when_ClientOptions_environment_is_set_to__production_()' classname='RestClientTests' time='0.0057'/>
      <testcase name='test__064__RestClient__Host_Fallback__fallback_hosts_list_and_priorities__should_use_default_fallback_hosts_when_both_ClientOptions_fallbackHosts_and_ClientOptions_environment_are_not_set()' classname='RestClientTests' time='0.0026'/>
      <testcase name='test__065__RestClient__Host_Fallback__retry_hosts_in_random_order__default_fallback_hosts_should_match__a_e__ably_realtime_com()' classname='RestClientTests' time='0.012'/>
      <testcase name='test__066__RestClient__Host_Fallback__retry_hosts_in_random_order__environment_fallback_hosts_have_the_format__environment___a_e__fallback_ably_realtime_com()' classname='RestClientTests' time='0.00086'/>
      <testcase name='test__067__RestClient__Host_Fallback__retry_hosts_in_random_order__until_httpMaxRetryCount_has_been_reached()' classname='RestClientTests' time='0.0067'/>
      <testcase name='test__068__RestClient__Host_Fallback__retry_hosts_in_random_order__use_custom_fallback_hosts_if_set()' classname='RestClientTests' time='0.0035'/>
      <testcase name='test__069__RestClient__Host_Fallback__retry_hosts_in_random_order__until_all_fallback_hosts_have_been_tried()' classname='RestClientTests' time='0.019'/>
      <testcase name='test__070__RestClient__Host_Fallback__retry_hosts_in_random_order__until_httpMaxRetryCount_has_been_reached__if_custom_fallback_hosts_are_provided_in_ClientOptions_fallbackHosts__then_they_will_be_used_instead()' classname='RestClientTests' time='0.0016'/>
      <testcase name='test__071__RestClient__Host_Fallback__retry_hosts_in_random_order__until_all_fallback_hosts_have_been_tried__if_custom_fallback_hosts_are_provided_in_ClientOptions_fallbackHosts__then_they_will_be_used_instead()' classname='RestClientTests' time='0.0021'/>
      <testcase name='test__072__RestClient__Host_Fallback__retry_hosts_in_random_order__all_fallback_requests_headers_should_contain__Host__header_with_fallback_host_address()' classname='RestClientTests' time='0.0022'/>
      <testcase name='test__073__RestClient__Host_Fallback__retry_hosts_in_random_order__if_an_empty_array_of_fallback_hosts_is_provided__then_fallback_host_functionality_is_disabled()' classname='RestClientTests' time='0.0042'/>
      <testcase name='test__074__RestClient__Host_Fallback__should_use_an_alternative_host_when___hostUnreachable()' classname='RestClientTests' time='0.0012'/>
      <testcase name='test__075__RestClient__Host_Fallback__should_use_an_alternative_host_when___requestTimeout_timeout__0_1_()' classname='RestClientTests' time='0.11'/>
      <testcase name='test__076__RestClient__Host_Fallback__should_use_an_alternative_host_when___hostInternalError_code__501_()' classname='RestClientTests' time='0.0014'/>
      <testcase name='test__077__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host___hostUnreachable()' classname='RestClientTests' time='0.0012'/>
      <testcase name='test__078__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host___requestTimeout_timeout__0_1_()' classname='RestClientTests' time='0.11'/>
      <testcase name='test__079__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host___hostInternalError_code__501_()' classname='RestClientTests' time='0.0014'/>
      <testcase name='test__080__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_restore_default_primary_host_after_fallbackRetryTimeout_expired___hostUnreachable()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__081__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_restore_default_primary_host_after_fallbackRetryTimeout_expired___requestTimeout_timeout__0_1_()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__082__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_restore_default_primary_host_after_fallbackRetryTimeout_expired___hostInternalError_code__501_()' classname='RestClientTests' time='1.0'/>
      <testcase name='test__083__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_use_another_fallback_host_if_previous_fallback_request_failed_and_store_it_as_default_if_current_fallback_request_succseeded___hostUnreachable()' classname='RestClientTests' time='0.01'/>
      <testcase name='test__084__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_use_another_fallback_host_if_previous_fallback_request_failed_and_store_it_as_default_if_current_fallback_request_succseeded___requestTimeout_timeout__0_1_()' classname='RestClientTests' time='0.21'/>
      <testcase name='test__085__RestClient__Host_Fallback__should_store_successful_fallback_host_as_default_host__should_use_another_fallback_host_if_previous_fallback_request_failed_and_store_it_as_default_if_current_fallback_request_succseeded___hostInternalError_code__501_()' classname='RestClientTests' time='0.0028'/>
      <testcase name='test__086__RestClient__request__method_signature_and_arguments__should_add_query_parameters()' classname='RestClientTests' time='0.0017'/>
      <testcase name='test__087__RestClient__request__method_signature_and_arguments__should_add_a_HTTP_body()' classname='RestClientTests' time='0.0012'/>
      <testcase name='test__088__RestClient__request__method_signature_and_arguments__should_add_a_HTTP_header()' classname='RestClientTests' time='0.0018'/>
      <testcase name='test__089__RestClient__request__method_signature_and_arguments__should_error_if_method_is_invalid()' classname='RestClientTests' time='0.0027'/>
      <testcase name='test__090__RestClient__request__method_signature_and_arguments__should_error_if_path_is_invalid()' classname='RestClientTests' time='0.00084'/>
      <testcase name='test__091__RestClient__request__method_signature_and_arguments__should_error_if_body_is_not_a_Dictionary_or_an_Array()' classname='RestClientTests' time='0.0008'/>
      <testcase name='test__092__RestClient__request__method_signature_and_arguments__should_do_a_request_and_receive_a_valid_response()' classname='RestClientTests' time='0.36'/>
      <testcase name='test__093__RestClient__request__method_signature_and_arguments__should_handle_response_failures()' classname='RestClientTests' time='0.37'/>
      <testcase name='test__094__RestClient__if_in_the_course_of_a_REST_request_an_attempt_to_authenticate_using_authUrl_fails_due_to_a_timeout__the_request_should_result_in_an_error_with_code_40170__statusCode_401__and_a_suitable_error_message()' classname='RestClientTests' time='3.0'/>
      <testcase name='test__095__RestClient__request_IDs__should_add__request_id__query_parameter()' classname='RestClientTests' time='0.0018'/>
      <testcase name='test__096__RestClient__request_IDs__should_remain_the_same_if_a_request_is_retried_to_a_fallback_host()' classname='RestClientTests' time='0.007'/>
      <testcase name='test__097__RestClient__request_IDs__ErrorInfo_should_have__requestId__property()' classname='RestClientTests' time='0.0016'/>
    </testsuite>
    <testsuite name='RestPaginatedTests' time='0.00243' tests='2' failures='0' skipped='0'>
      <testcase name='test__001__RestPaginated__should_extract_links_from_the_response()' classname='RestPaginatedTests' time='0.0017'/>
      <testcase name='test__002__RestPaginated__should_create_next_first_last_request_from_extracted_link_path()' classname='RestPaginatedTests' time='0.00073'/>
    </testsuite>
    <testsuite name='RetrySequenceTests' time='0.0018' tests='1' failures='0' skipped='0'>
      <testcase name='test_addRetryAttempt()' classname='RetrySequenceTests' time='0.0018'/>
    </testsuite>
    <testsuite name='StatsTests' time='0.055510000000000004' tests='38' failures='0' skipped='0'>
      <testcase name='test__001__Stats__all__should_return_a_MessagesTypes_object()' classname='StatsTests' time='0.0032'/>
      <testcase name='test__002__Stats__all__should_return_value_for_message_counts()' classname='StatsTests' time='0.00077'/>
      <testcase name='test__003__Stats__all__should_return_value_for_all_data_transferred()' classname='StatsTests' time='0.002'/>
      <testcase name='test__004__Stats__all__should_return_zero_for_empty_values()' classname='StatsTests' time='0.00077'/>
      <testcase name='test__005__Stats__persisted__should_return_a_MessagesTypes_object()' classname='StatsTests' time='0.0019'/>
      <testcase name='test__006__Stats__persisted__should_return_value_for_message_counts()' classname='StatsTests' time='0.00059'/>
      <testcase name='test__007__Stats__persisted__should_return_value_for_all_data_transferred()' classname='StatsTests' time='0.00059'/>
      <testcase name='test__008__Stats__persisted__should_return_zero_for_empty_values()' classname='StatsTests' time='0.00058'/>
      <testcase name='test__009__Stats__inbound__should_return_a_MessageTraffic_object()' classname='StatsTests' time='0.007'/>
      <testcase name='test__010__Stats__inbound__should_return_value_for_realtime_message_counts()' classname='StatsTests' time='0.00058'/>
      <testcase name='test__011__Stats__inbound__should_return_value_for_all_presence_data()' classname='StatsTests' time='0.00055'/>
      <testcase name='test__012__Stats__outbound__should_return_a_MessageTraffic_object()' classname='StatsTests' time='0.00065'/>
      <testcase name='test__013__Stats__outbound__should_return_value_for_realtime_message_counts()' classname='StatsTests' time='0.00057'/>
      <testcase name='test__014__Stats__outbound__should_return_value_for_all_presence_data()' classname='StatsTests' time='0.00061'/>
      <testcase name='test__015__Stats__connections__should_return_a_ConnectionTypes_object()' classname='StatsTests' time='0.0018'/>
      <testcase name='test__016__Stats__connections__should_return_value_for_tls_opened_counts()' classname='StatsTests' time='0.00047'/>
      <testcase name='test__017__Stats__connections__should_return_value_for_all_peak_connections()' classname='StatsTests' time='0.00041'/>
      <testcase name='test__018__Stats__connections__should_return_zero_for_empty_values()' classname='StatsTests' time='0.0004'/>
      <testcase name='test__019__Stats__channels__should_return_a_ResourceCount_object()' classname='StatsTests' time='0.0097'/>
      <testcase name='test__020__Stats__channels__should_return_value_for_opened_counts()' classname='StatsTests' time='0.00059'/>
      <testcase name='test__021__Stats__channels__should_return_value_for_peak_channels()' classname='StatsTests' time='0.00044'/>
      <testcase name='test__022__Stats__channels__should_return_zero_for_empty_values()' classname='StatsTests' time='0.00039'/>
      <testcase name='test__023__Stats__apiRequests__should_return_a_RequestCount_object()' classname='StatsTests' time='0.002'/>
      <testcase name='test__024__Stats__apiRequests__should_return_value_for_succeeded()' classname='StatsTests' time='0.00067'/>
      <testcase name='test__025__Stats__apiRequests__should_return_value_for_failed()' classname='StatsTests' time='0.00058'/>
      <testcase name='test__026__Stats__tokenRequests__should_return_a_RequestCount_object()' classname='StatsTests' time='0.0018'/>
      <testcase name='test__027__Stats__tokenRequests__should_return_value_for_succeeded()' classname='StatsTests' time='0.00055'/>
      <testcase name='test__028__Stats__tokenRequests__should_return_value_for_failed()' classname='StatsTests' time='0.00045'/>
      <testcase name='test__029__Stats__interval__should_return_a_Date_object_representing_the_start_of_the_interval()' classname='StatsTests' time='0.0014'/>
      <testcase name='test__030__Stats__push__should_return_a_ARTStatsPushCount_object()' classname='StatsTests' time='0.0018'/>
      <testcase name='test__031__Stats__push__should_return_value_for_messages_count()' classname='StatsTests' time='0.00055'/>
      <testcase name='test__032__Stats__push__should_return_value_for_invalid_notifications()' classname='StatsTests' time='0.00046'/>
      <testcase name='test__033__Stats__push__should_return_value_for_attempted_notifications()' classname='StatsTests' time='0.00052'/>
      <testcase name='test__034__Stats__push__should_return_value_for_successful_notifications()' classname='StatsTests' time='0.0073'/>
      <testcase name='test__035__Stats__push__should_return_value_for_failed_notifications()' classname='StatsTests' time='0.00055'/>
      <testcase name='test__036__Stats__push__should_return_value_for_directPublishes()' classname='StatsTests' time='0.00052'/>
      <testcase name='test__037__Stats__inProgress__should_return_a_Date_object_representing_the_last_sub_interval_included_in_this_statistic()' classname='StatsTests' time='0.0013'/>
      <testcase name='test__038__Stats__count__should_return_value_for_number_of_lower_level_stats()' classname='StatsTests' time='0.0005'/>
    </testsuite>
    <testsuite name='StringifiableTests' time='0.01746' tests='9' failures='0' skipped='0'>
      <testcase name='test__001__Stringifiable__type_conversion__as_string()' classname='StringifiableTests' time='0.00059'/>
      <testcase name='test__002__Stringifiable__type_conversion__as_bool__true_()' classname='StringifiableTests' time='0.00068'/>
      <testcase name='test__003__Stringifiable__type_conversion__as_bool__false_()' classname='StringifiableTests' time='0.00045'/>
      <testcase name='test__004__Stringifiable__type_conversion__as_integer_that_is_not_treated_as_bool__false_()' classname='StringifiableTests' time='0.00042'/>
      <testcase name='test__005__Stringifiable__type_conversion__as_integer_that_is_not_treated_as_bool__true_()' classname='StringifiableTests' time='0.013'/>
      <testcase name='test__006__Stringifiable__type_conversion__as_number__Int_()' classname='StringifiableTests' time='0.00059'/>
      <testcase name='test__007__Stringifiable__type_conversion__as_number__Float_1_decimal_digit_()' classname='StringifiableTests' time='0.00058'/>
      <testcase name='test__008__Stringifiable__type_conversion__as_number__Float_2_decimal_digits_()' classname='StringifiableTests' time='0.00053'/>
      <testcase name='test__009__Stringifiable__type_conversion__as_number__Float_4_decimal_digits_()' classname='StringifiableTests' time='0.00062'/>
    </testsuite>
    <testsuite name='UtilitiesTests' time='2.05784' tests='26' failures='0' skipped='0'>
      <testcase name='test__001__Utilities__JSON_Encoder__should_decode_a_protocol_message_that_has_an_error_without_a_message()' classname='UtilitiesTests' time='0.00056'/>
      <testcase name='test__002__Utilities__JSON_Encoder__should_encode_a_protocol_message_that_has_invalid_data()' classname='UtilitiesTests' time='0.0027'/>
      <testcase name='test__003__Utilities__JSON_Encoder__should_decode_data_with_malformed_JSON()' classname='UtilitiesTests' time='0.00073'/>
      <testcase name='test__004__Utilities__JSON_Encoder__should_decode_data_with_malformed_MsgPack()' classname='UtilitiesTests' time='0.0054'/>
      <testcase name='test__005__Utilities__JSON_Encoder__in_Realtime__should_handle_and_emit_the_invalid_data_error()' classname='UtilitiesTests' time='0.0087'/>
      <testcase name='test__006__Utilities__JSON_Encoder__in_Realtime__should_ignore_invalid_transport_message()' classname='UtilitiesTests' time='0.43'/>
      <testcase name='test__007__Utilities__JSON_Encoder__in_Rest__should_handle_and_emit_the_invalid_data_error()' classname='UtilitiesTests' time='0.0029'/>
      <testcase name='test__008__Utilities__JSON_Encoder__in_Rest__should_ignore_invalid_response_payload()' classname='UtilitiesTests' time='0.0035'/>
      <testcase name='test__009__Utilities__EventEmitter__should_emit_events_to_all_relevant_listeners()' classname='UtilitiesTests' time='0.0024'/>
      <testcase name='test__010__Utilities__EventEmitter__should_only_call_once_listeners_once_for_its_event()' classname='UtilitiesTests' time='0.00065'/>
      <testcase name='test__011__Utilities__EventEmitter__calling_off_with_a_single_listener_argument__should_stop_receiving_events_when_calling_off_with_a_single_listener_argument()' classname='UtilitiesTests' time='0.0024'/>
      <testcase name='test__012__Utilities__EventEmitter__calling_off_with_a_single_listener_argument__should_remove_the_timeout()' classname='UtilitiesTests' time='0.31'/>
      <testcase name='test__013__Utilities__EventEmitter__calling_off_with_listener_and_event_arguments__should_still_receive_events_if_off_doesn_t_match_the_listener_s_criteria()' classname='UtilitiesTests' time='0.00061'/>
      <testcase name='test__014__Utilities__EventEmitter__calling_off_with_listener_and_event_arguments__should_stop_receive_events_if_off_matches_the_listener_s_criteria()' classname='UtilitiesTests' time='0.00052'/>
      <testcase name='test__015__Utilities__EventEmitter__calling_off_with_no_arguments__should_remove_all_listeners()' classname='UtilitiesTests' time='0.00067'/>
      <testcase name='test__016__Utilities__EventEmitter__calling_off_with_no_arguments__should_allow_listening_again()' classname='UtilitiesTests' time='0.0021'/>
      <testcase name='test__017__Utilities__EventEmitter__calling_off_with_no_arguments__should_remove_all_timeouts()' classname='UtilitiesTests' time='0.16'/>
      <testcase name='test__018__Utilities__EventEmitter__the_timed_method__should_not_call_onTimeout_if_the_deadline_isn_t_reached()' classname='UtilitiesTests' time='0.32'/>
      <testcase name='test__019__Utilities__EventEmitter__the_timed_method__should_call_onTimeout_and_off_the_listener_if_the_deadline_is_reached()' classname='UtilitiesTests' time='0.36'/>
      <testcase name='test__020__Utilities__EventEmitter__set_of_listeners__should_not_change_over_the_course_of_the_emit()' classname='UtilitiesTests' time='0.0007'/>
      <testcase name='test__021__Utilities__Logger__should_have_a_history_of_logs()' classname='UtilitiesTests' time='0.44'/>
      <testcase name='test__022__Utilities__maxMessageSize__calculates_maxMessageSize_of_a_Message_with_name_and_data()' classname='UtilitiesTests' time='0.00057'/>
      <testcase name='test__023__Utilities__maxMessageSize__calculates_maxMessageSize_of_a_Message_with_name__data_and_extras()' classname='UtilitiesTests' time='0.0008'/>
      <testcase name='test__024__Utilities__maxMessageSize__calculates_maxMessageSize_of_a_Message_with_name__data__clientId_and_extras()' classname='UtilitiesTests' time='0.00072'/>
      <testcase name='test__025_Utilities__message_received_with_action_create_does_not_contain_a_serial_takes_it_from_version()' classname='UtilitiesTests' time='0.00056'/>
      <testcase name='test__027_Utilities__message_received_with_action_create_does_not_contain_createdAt()' classname='UtilitiesTests' time='0.00065'/>
    </testsuite>
    <testsuite name='WrapperSDKProxyTests' time='6.9' tests='18' failures='0' skipped='0'>
      <testcase name='test_addsAgentChannelParam_whenFetchedWithChannelOptions()' classname='WrapperSDKProxyTests' time='0.39'/>
      <testcase name='test_addsAgentChannelParam_whenFetchedWithNoChannelOptions()' classname='WrapperSDKProxyTests' time='0.44'/>
      <testcase name='test_doesNotAddAgentParam_whenProxyClientCreatedWithoutAgents()' classname='WrapperSDKProxyTests' time='0.44'/>
      <testcase name='test_history_addsWrapperSDKAgentToRequest()' classname='WrapperSDKProxyTests' time='1.0'/>
      <testcase name='test_presenceHistory_addsWrapperSDKAgentToRequest()' classname='WrapperSDKProxyTests' time='0.28'/>
      <testcase name='test_pushAdmin_addsWrapperSDKAgentToRequests()' classname='WrapperSDKProxyTests' time='0.16'/>
      <testcase name='test_pushAdmin_channelSubscriptions_addsWrapperSDKAgentToRequests()' classname='WrapperSDKProxyTests' time='0.18'/>
      <testcase name='test_pushAdmin_deviceRegistrations_addsWrapperSDKAgentToRequests()' classname='WrapperSDKProxyTests' time='0.16'/>
      <testcase name='test_pushChannel_addsWrapperSDKAgentToRequests()' classname='WrapperSDKProxyTests' time='0.18'/>
      <testcase name='test_request_addsWrapperSDKAgentToHeader()' classname='WrapperSDKProxyTests' time='0.18'/>
      <testcase name='test_request_firstAndNext_addWrapperSDKAgentToHeader()' classname='WrapperSDKProxyTests' time='1.0'/>
      <testcase name='test_sharesChannelMessageSubscriptionsWithUnderlyingChannel()' classname='WrapperSDKProxyTests' time='0.48'/>
      <testcase name='test_sharesChannelStateSubscriptionsWithUnderlyingChannel()' classname='WrapperSDKProxyTests' time='0.39'/>
      <testcase name='test_sharesChannelStateWithUnderlyingChannel()' classname='WrapperSDKProxyTests' time='0.51'/>
      <testcase name='test_sharesConnectionStateWithUnderlyingClient()' classname='WrapperSDKProxyTests' time='0.42'/>
      <testcase name='test_sharesConnectionSubscriptionsWithUnderlyingRealtimeClient()' classname='WrapperSDKProxyTests' time='0.31'/>
      <testcase name='test_stats_addsWrapperSDKAgentToRequest()' classname='WrapperSDKProxyTests' time='0.2'/>
      <testcase name='test_time_addsWrapperSDKAgentToRequest()' classname='WrapperSDKProxyTests' time='0.18'/>
    </testsuite>
    <properties>
      <property name='Configuration' value='Configuration 1'/>
      <property name='device' value='iPhone 16 (18.4)'/>
    </properties>
  </testsuite>
</testsuites>