diff --git a/Source/ARTAuth.m b/Source/ARTAuth.m index 969ed55c5..5170fd2a5 100644 --- a/Source/ARTAuth.m +++ b/Source/ARTAuth.m @@ -224,8 +224,10 @@ - (void)handleAuthUrlResponse:(NSHTTPURLResponse *)response withData:(NSData *)d ARTTokenRequest *tokenRequest = [_rest.encoders[@"application/json"] decodeTokenRequest:data error:&decodeError]; if (decodeError) { callback(nil, decodeError); - } else { + } else if (tokenRequest) { [tokenRequest toTokenDetails:self callback:callback]; + } else { + callback(nil, [ARTErrorInfo createWithCode:ARTStateAuthUrlIncompatibleContent message:@"content response cannot be used for token request"]); } } else { callback(tokenDetails, nil); diff --git a/Source/ARTRestPresence.m b/Source/ARTRestPresence.m index 5671dc01f..98e7c28ac 100644 --- a/Source/ARTRestPresence.m +++ b/Source/ARTRestPresence.m @@ -135,7 +135,15 @@ - (BOOL)history:(ARTDataQuery *)query callback:(void(^)(__GENERIC(ARTPaginatedRe ARTPaginatedResultResponseProcessor responseProcessor = ^(NSHTTPURLResponse *response, NSData *data) { id encoder = [_channel.rest.encoders objectForKey:response.MIMEType]; - return [encoder decodePresenceMessages:data]; + return [[encoder decodePresenceMessages:data] artMap:^(ARTPresenceMessage *message) { + NSError *error; + message = [message decodeWithEncoder:_channel.dataEncoder error:&error]; + if (error != nil) { + ARTErrorInfo *errorInfo = [ARTErrorInfo wrap:(ARTErrorInfo *)error.userInfo[NSLocalizedFailureReasonErrorKey] prepend:@"Failed to decode data: "]; + [_channel.logger error:@"RS:%p %@", _channel.rest, errorInfo.message]; + } + return message; + }]; }; [ARTPaginatedResult executePaginated:_channel.rest withRequest:request andResponseProcessor:responseProcessor callback:callback]; diff --git a/Source/ARTStatus.h b/Source/ARTStatus.h index 091a256b7..3f37407d9 100644 --- a/Source/ARTStatus.h +++ b/Source/ARTStatus.h @@ -26,6 +26,7 @@ typedef NS_ENUM(NSUInteger, ARTState) { ARTStateNoClientId, ARTStateMismatchedClientId, ARTStateRequestTokenFailed, + ARTStateAuthUrlIncompatibleContent, ARTStateBadConnectionState, ARTStateError = 99999 }; diff --git a/Spec/Auth.swift b/Spec/Auth.swift index 50a3ad339..6aa3582eb 100644 --- a/Spec/Auth.swift +++ b/Spec/Auth.swift @@ -160,7 +160,7 @@ class Auth : QuickSpec { options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } client.setTransportClass(TestProxyTransport.self) client.connect() @@ -1893,6 +1893,10 @@ class Auth : QuickSpec { // Invalid TokenDetails waitUntil(timeout: testTimeout) { done in ARTRest(options: options).auth.authorise(nil, options: nil) { tokenDetails, error in + guard let error = error else { + fail("Error is nil"); done(); return + } + expect(error.code).to(equal(Int(ARTState.AuthUrlIncompatibleContent.rawValue))) expect(tokenDetails).to(beNil()) done() } @@ -2030,7 +2034,7 @@ class Auth : QuickSpec { describe("Reauth") { // RTC8 - it("should use authorise({force: true}) to reauth with a token with a different set of capabilities") { + pending("should use authorise({force: true}) to reauth with a token with a different set of capabilities") { // init ARTRest let restOptions = AblyTests.setupOptions(AblyTests.jsonRestOptions) let rest = ARTRest(options: restOptions) @@ -2059,7 +2063,7 @@ class Auth : QuickSpec { realtimeOptions.clientId = "testClientId" let realtime = ARTRealtime(options:realtimeOptions) - defer { realtime.close() } + defer { realtime.dispose(); realtime.close() } // wait for connected state waitUntil(timeout: testTimeout) { done in diff --git a/Spec/RealtimeClient.swift b/Spec/RealtimeClient.swift index 1b63f220b..f93b0ae2d 100644 --- a/Spec/RealtimeClient.swift +++ b/Spec/RealtimeClient.swift @@ -30,7 +30,7 @@ class RealtimeClient: QuickSpec { // G4 it("All WebSocket connections should include the current API version") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in diff --git a/Spec/RealtimeClientChannel.swift b/Spec/RealtimeClientChannel.swift index b6bcd6f86..d60ec33fc 100644 --- a/Spec/RealtimeClientChannel.swift +++ b/Spec/RealtimeClientChannel.swift @@ -82,7 +82,7 @@ class RealtimeClientChannel: QuickSpec { // RTL2a it("should implement the EventEmitter and emit events for state changes") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.statesEventEmitter).to(beAKindOf(ARTEventEmitter.self)) @@ -141,7 +141,7 @@ class RealtimeClientChannel: QuickSpec { // RTL2b it("state attribute should be the current state of the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -154,7 +154,7 @@ class RealtimeClientChannel: QuickSpec { // RTL2c it("should contain an ErrorInfo object with details when an error occurs") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let error = AblyTests.newErrorProtocolMessage() @@ -183,7 +183,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -211,7 +211,7 @@ class RealtimeClientChannel: QuickSpec { it("ATTACHED channel should transition to FAILED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -245,7 +245,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -261,7 +261,7 @@ class RealtimeClientChannel: QuickSpec { it("ATTACHED channel should transition to DETACHED") { let options = AblyTests.commonAppSetup() let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -281,7 +281,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let channel = client.channels.get("test") @@ -299,7 +299,7 @@ class RealtimeClientChannel: QuickSpec { it("ATTACHED channel should transition to DETACHED") { let options = AblyTests.commonAppSetup() let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -321,7 +321,7 @@ class RealtimeClientChannel: QuickSpec { // RTL4a it("if already ATTACHED or ATTACHING nothing is done") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } var errorInfo: ARTErrorInfo? let channel = client.channels.get("test") @@ -351,7 +351,7 @@ class RealtimeClientChannel: QuickSpec { // RTL4e it("DETACHING") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -370,7 +370,7 @@ class RealtimeClientChannel: QuickSpec { // RTL4g it("FAILED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -400,7 +400,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -421,7 +421,7 @@ class RealtimeClientChannel: QuickSpec { it("CLOSED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -438,7 +438,7 @@ class RealtimeClientChannel: QuickSpec { it("SUSPENDED") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") client.onSuspended() @@ -453,7 +453,7 @@ class RealtimeClientChannel: QuickSpec { it("FAILED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") client.onError(AblyTests.newErrorProtocolMessage()) @@ -474,7 +474,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).to(equal(ARTRealtimeConnectionState.Initialized)) @@ -493,7 +493,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -513,7 +513,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.1 let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -539,7 +539,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -559,7 +559,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.clientOptions() options.token = getTestToken(capability: "{ \"main\":[\"subscribe\"] }") let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -583,7 +583,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -606,7 +606,7 @@ class RealtimeClientChannel: QuickSpec { it("if called with a callback should call it once attached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -621,7 +621,7 @@ class RealtimeClientChannel: QuickSpec { it("if called with a callback and already attaching should call the callback once attached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -638,7 +638,7 @@ class RealtimeClientChannel: QuickSpec { it("if called with a callback and already attached should call the callback with nil error") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -658,7 +658,7 @@ class RealtimeClientChannel: QuickSpec { // RTL5a it("if state is INITIALISED, DETACHED or DETACHING nothing is done") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } var errorInfo: ARTErrorInfo? let channel = client.channels.get("test") @@ -698,7 +698,7 @@ class RealtimeClientChannel: QuickSpec { // RTL5b it("results in an error if the connection state is FAILED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") client.onError(AblyTests.newErrorProtocolMessage()) @@ -719,7 +719,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -739,7 +739,7 @@ class RealtimeClientChannel: QuickSpec { // RTL5e it("if called with a callback should call it once detached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -758,7 +758,7 @@ class RealtimeClientChannel: QuickSpec { // RTL5e it("if called with a callback and already detaching should call the callback once detached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -779,7 +779,7 @@ class RealtimeClientChannel: QuickSpec { // RTL5e it("if called with a callback and already detached should should call the callback with nil error") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -806,7 +806,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -839,7 +839,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let transport = client.transport as! TestProxyTransport @@ -862,7 +862,7 @@ class RealtimeClientChannel: QuickSpec { it("FAILED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -886,7 +886,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -907,7 +907,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -928,7 +928,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.1 let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1004,7 +1004,7 @@ class RealtimeClientChannel: QuickSpec { it("when the message is successfully delivered") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -1031,7 +1031,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.token = getTestToken(key: options.key, capability: "{ \"\(ARTChannels_getChannelNamePrefix!())-test\":[\"subscribe\"] }") let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -1070,7 +1070,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.token = getTestToken(key: options.key, capability: "{ \"\(ARTChannels_getChannelNamePrefix!())-channelToSucceed\":[\"subscribe\", \"publish\"], \"\(ARTChannels_getChannelNamePrefix!())-channelToFail\":[\"subscribe\"] }") let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } TotalMessages.succeeded = 0 TotalMessages.failed = 0 @@ -1117,7 +1117,7 @@ class RealtimeClientChannel: QuickSpec { // RTL6c1 it("if the connection is CONNECTED and the channel is ATTACHED then the messages should be published immediately") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -1202,7 +1202,7 @@ class RealtimeClientChannel: QuickSpec { // RTL6c3 it("implicitly attaches the channel; if the channel is in or moves to the FAILED state before the operation succeeds, it should result in an error") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in let protocolError = AblyTests.newErrorProtocolMessage() @@ -1319,7 +1319,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") // Test that the initially queued messages are sent together. @@ -1374,7 +1374,7 @@ class RealtimeClientChannel: QuickSpec { // RTL6e1 it("should have the provided clientId on received message when it was published with clientId") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.auth.clientId).to(beNil()) @@ -1400,7 +1400,7 @@ class RealtimeClientChannel: QuickSpec { // RTL6f it("Message#connectionId should match the current Connection#id for all published messages") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1421,7 +1421,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") typealias JSONObject = NSDictionary @@ -1441,7 +1441,7 @@ class RealtimeClientChannel: QuickSpec { it("a name string and data payload") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let expectedResult = "string_data" @@ -1462,7 +1462,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1499,7 +1499,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1536,7 +1536,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1574,7 +1574,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let message = ARTMessage(name: nil, data: "message") @@ -1604,7 +1604,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let message = ARTMessage(name: nil, data: "message", clientId: options.clientId!) @@ -1625,7 +1625,7 @@ class RealtimeClientChannel: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1650,7 +1650,7 @@ class RealtimeClientChannel: QuickSpec { completion(getTestTokenDetails(clientId: "john"), nil) } let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let message = ARTMessage(name: nil, data: "message", clientId: "john") waitUntil(timeout: testTimeout) { done in @@ -1671,7 +1671,7 @@ class RealtimeClientChannel: QuickSpec { completion(getTestTokenDetails(clientId: "john"), nil) } let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let message = ARTMessage(name: nil, data: "message", clientId: "tester") waitUntil(timeout: testTimeout) { done in @@ -1688,7 +1688,7 @@ class RealtimeClientChannel: QuickSpec { // RTL6h it("should provide an optional argument that allows the clientId value to be specified") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1714,7 +1714,7 @@ class RealtimeClientChannel: QuickSpec { // RTL7a it("with no arguments subscribes a listener to all messages") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1738,7 +1738,7 @@ class RealtimeClientChannel: QuickSpec { // RTL7b it("with a single name argument subscribes a listener to only messages whose name member matches the string name") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1763,7 +1763,7 @@ class RealtimeClientChannel: QuickSpec { it("with a attach callback should subscribe and call the callback when attached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1789,7 +1789,7 @@ class RealtimeClientChannel: QuickSpec { // RTL7c it("should implicitly attach the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1801,7 +1801,7 @@ class RealtimeClientChannel: QuickSpec { // RTL7c it("should result in an error if channel is in the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -1830,7 +1830,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let (keyData, ivData, messages) = AblyTests.loadCryptoTestData(cryptoTest) let testMessage = messages[0] @@ -1897,7 +1897,7 @@ class RealtimeClientChannel: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channelOptions = ARTChannelOptions(cipher: ["key":ARTCrypto.generateRandomKey()]) let channel = client.channels.get("test", options: channelOptions) @@ -1975,7 +1975,7 @@ class RealtimeClientChannel: QuickSpec { // RTL8a it("with no arguments unsubscribes the provided listener to all messages if subscribed") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -1997,7 +1997,7 @@ class RealtimeClientChannel: QuickSpec { // RTL8b it("with a single name argument unsubscribes the provided listener if previously subscribed with a name-specific subscription") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") @@ -2072,7 +2072,7 @@ class RealtimeClientChannel: QuickSpec { it("should invoke an error when the untilAttach is specified and the channel is not attached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let query = ARTRealtimeHistoryQuery() @@ -2099,7 +2099,7 @@ class RealtimeClientChannel: QuickSpec { for caseItem in cases { it("where value is \(caseItem.untilAttach), should pass the querystring param fromSerial with the serial number assigned to the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let testHTTPExecutor = TestProxyHTTPExecutor() @@ -2272,7 +2272,7 @@ class RealtimeClientChannel: QuickSpec { // RTL12 it("attached channel may receive an additional ATTACHED ProtocolMessage") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in channel.attach() { error in diff --git a/Spec/RealtimeClientChannels.swift b/Spec/RealtimeClientChannels.swift index c4087b1b2..d9f60848a 100644 --- a/Spec/RealtimeClientChannels.swift +++ b/Spec/RealtimeClientChannels.swift @@ -24,7 +24,7 @@ class RealtimeClientChannels: QuickSpec { // RTS2 it("should exist methods to check if a channel exists or iterate through the existing channels") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } var disposable = [ARTRealtimeChannel]() disposable.append(client.channels.get("test1")) @@ -46,7 +46,7 @@ class RealtimeClientChannels: QuickSpec { // RTS3a it("should create a new Channel if none exists or return the existing one") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.channels.collection).to(haveCount(0)) let channel = client.channels.get("test") @@ -60,7 +60,7 @@ class RealtimeClientChannels: QuickSpec { // RTS3b it("should be possible to specify a ChannelOptions") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let options = ARTChannelOptions() let channel = client.channels.get("test", options: options) expect(channel.options).to(beIdenticalTo(options)) @@ -69,7 +69,7 @@ class RealtimeClientChannels: QuickSpec { // RTS3c it("accessing an existing Channel with options should update the options and then return the object") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.channels.get("test").options).toNot(beNil()) let options = ARTChannelOptions() let channel = client.channels.get("test", options: options) @@ -82,7 +82,7 @@ class RealtimeClientChannels: QuickSpec { context("release") { it("should release a channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.subscribe { _ in diff --git a/Spec/RealtimeClientConnection.swift b/Spec/RealtimeClientConnection.swift index 844b5a5fd..13c519888 100644 --- a/Spec/RealtimeClientConnection.swift +++ b/Spec/RealtimeClientConnection.swift @@ -32,7 +32,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } if let transport = client.transport as? TestProxyTransport, let url = transport.lastUrl { expect(url.host).to(equal("realtime.ably.io")) @@ -49,7 +49,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -87,7 +87,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -127,7 +127,7 @@ class RealtimeClientConnection: QuickSpec { expect(options.autoConnect).to(beTrue(), description: "autoConnect should be true by default") let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } // The only way to control this functionality is with the options flag client.connection.on { stateChange in let stateChange = stateChange! @@ -148,7 +148,7 @@ class RealtimeClientConnection: QuickSpec { options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } var waiting = true waitUntil(timeout: testTimeout) { done in @@ -178,7 +178,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.once(.Connecting) { _ in guard let webSocketTransport = client.transport as? ARTWebSocketTransport else { @@ -238,7 +238,7 @@ class RealtimeClientConnection: QuickSpec { options.disconnectedRetryTimeout = 0.0 let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let connection = client.connection var events: [ARTRealtimeConnectionState] = [] @@ -310,7 +310,7 @@ class RealtimeClientConnection: QuickSpec { options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let connection = client.connection var events: [ARTRealtimeConnectionState] = [] @@ -346,7 +346,7 @@ class RealtimeClientConnection: QuickSpec { it("should emit states when connection is closed") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) let connection = client.connection - defer { client.close() } + defer { client.dispose(); client.close() } var events: [ARTRealtimeConnectionState] = [] waitUntil(timeout: testTimeout) { done in @@ -383,7 +383,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let connection = client.connection expect(connection.state.rawValue).to(equal(ARTRealtimeConnectionState.Initialized.rawValue), description: "Missing INITIALIZED state") @@ -432,7 +432,7 @@ class RealtimeClientConnection: QuickSpec { it("should have the reason which contains an ErrorInfo") { let options = AblyTests.commonAppSetup() let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let connection = client.connection var errorInfo: ARTErrorInfo? @@ -571,7 +571,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in publishFirstTestMessage(client, completion: { error in @@ -600,7 +600,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -642,7 +642,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in publishFirstTestMessage(client, completion: { error in @@ -671,7 +671,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -724,7 +724,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("channel") channel.attach() @@ -789,7 +789,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("channel") let transport = client.transport as! TestProxyTransport @@ -819,7 +819,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("channel") let transport = client.transport as! TestProxyTransport @@ -1412,7 +1412,7 @@ class RealtimeClientConnection: QuickSpec { // RTN13a it("should send a ProtocolMessage with action HEARTBEAT and expects a HEARTBEAT message in response") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.ping() { error in expect(error).to(beNil()) @@ -1427,7 +1427,7 @@ class RealtimeClientConnection: QuickSpec { // RTN13c it("should fail if a HEARTBEAT ProtocolMessage is not received within the default realtime request timeout") { let client = AblyTests.newRealtime(AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in let start = NSDate() let transport = client.transport as! TestProxyTransport @@ -1658,7 +1658,7 @@ class RealtimeClientConnection: QuickSpec { ARTDefault.setRealtimeRequestTimeout(0.5) let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } var start, end: NSDate? waitUntil(timeout: testTimeout) { done in client.connection.on(.Disconnected) { stateChange in @@ -1743,7 +1743,7 @@ class RealtimeClientConnection: QuickSpec { ARTDefault.setRealtimeRequestTimeout(0.1) let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on(.Suspended) { stateChange in @@ -1828,7 +1828,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.1 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) let expectedConnectionKey = client.connection.key! @@ -1856,7 +1856,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 1.0 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1884,7 +1884,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 1.0 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1939,7 +1939,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 1.0 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -1970,7 +1970,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 1.0 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.connection.state).toEventually(equal(ARTRealtimeConnectionState.Connected), timeout: testTimeout) @@ -2051,7 +2051,7 @@ class RealtimeClientConnection: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport.self) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -2084,7 +2084,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.5 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") var resumed = false @@ -2122,7 +2122,7 @@ class RealtimeClientConnection: QuickSpec { options.disconnectedRetryTimeout = 1.0 let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -2350,7 +2350,7 @@ class RealtimeClientConnection: QuickSpec { it("Connection#recoveryKey should be composed with the connection key and latest serial received") { let options = AblyTests.commonAppSetup() let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in client.connection.once(.Connected) { _ in @@ -2407,7 +2407,7 @@ class RealtimeClientConnection: QuickSpec { it("Connection#recoveryKey should become becomes null when a connection is explicitly CLOSED or CLOSED") { let options = AblyTests.commonAppSetup() let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.once(.Connected) { _ in client.connection.once(.Closed) { _ in @@ -2431,7 +2431,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.recover = "99999!xxxxxx-xxxxxxxxx-xxxxxxxxx:-1" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.once(.Connected) { stateChange in expect(stateChange!.reason!.message).to(contain("Unable to recover connection")) @@ -2481,7 +2481,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2513,7 +2513,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2588,7 +2588,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2640,7 +2640,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2670,7 +2670,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2712,7 +2712,7 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: "message") { error in @@ -2756,7 +2756,6 @@ class RealtimeClientConnection: QuickSpec { } client.connect() - defer { client.close() } expect(urlConnections).toEventually(haveCount(2), timeout: testTimeout) @@ -2945,7 +2944,7 @@ class RealtimeClientConnection: QuickSpec { options.logLevel = .Debug options.disconnectedRetryTimeout = 0.1 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let transport = client.transport as! TestProxyTransport @@ -2977,7 +2976,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.1 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let transport = client.transport as! TestProxyTransport @@ -3006,7 +3005,7 @@ class RealtimeClientConnection: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 0.1 let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let transport = client.transport as! TestProxyTransport @@ -3051,6 +3050,7 @@ class RealtimeClientConnection: QuickSpec { } afterEach { + client.dispose() client.close() } @@ -3119,7 +3119,7 @@ class RealtimeClientConnection: QuickSpec { options.autoConnect = false client = ARTRealtime(options: options) client.setReachabilityClass(TestReachability.self) - defer { client.close() } + defer { client.dispose(); client.close() } waitUntil(timeout: testTimeout) { done in client.connection.on { stateChange in @@ -3200,7 +3200,7 @@ class RealtimeClientConnection: QuickSpec { it("should encode and decode fixture messages as expected") { let options = AblyTests.commonAppSetup() let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() diff --git a/Spec/RealtimeClientPresence.swift b/Spec/RealtimeClientPresence.swift index 561d632e0..e134df9ca 100644 --- a/Spec/RealtimeClientPresence.swift +++ b/Spec/RealtimeClientPresence.swift @@ -24,7 +24,7 @@ class RealtimeClientPresence: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -59,7 +59,7 @@ class RealtimeClientPresence: QuickSpec { let client = ARTRealtime(options: options) client.setTransportClass(TestProxyTransport) client.connect() - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -94,7 +94,7 @@ class RealtimeClientPresence: QuickSpec { } let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") var lastSyncSerial: String? @@ -214,7 +214,7 @@ class RealtimeClientPresence: QuickSpec { // RTP7a it("with no arguments unsubscribes the listener if previously subscribed with an action-specific subscription") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let listener = channel.presence.subscribe { _ in }! @@ -231,7 +231,7 @@ class RealtimeClientPresence: QuickSpec { // RTP5a it("all queued presence messages should fail immediately if the channel enters the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -248,7 +248,7 @@ class RealtimeClientPresence: QuickSpec { // RTP5a it("all queued presence messages should fail immediately if the channel enters the DETACHED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -270,7 +270,7 @@ class RealtimeClientPresence: QuickSpec { it("all queued presence messages will be sent immediately and a presence SYNC will be initiated implicitly if a channel enters the ATTACHED state") { let options = AblyTests.commonAppSetup() let client1 = AblyTests.newRealtime(options) - defer { client1.close() } + defer { client1.dispose(); client1.close() } let channel1 = client1.channels.get("room") waitUntil(timeout: testTimeout) { done in @@ -280,29 +280,37 @@ class RealtimeClientPresence: QuickSpec { } } + let client2 = AblyTests.newRealtime(options) + defer { client2.dispose(); client2.close() } + let channel2 = client2.channels.get(channel1.name) + waitUntil(timeout: testTimeout) { done in - delay(0.5) { + channel2.presence.enterClient("Client 2", data: nil) { error in + expect(error).to(beNil()) + expect(channel2.queuedMessages).to(haveCount(0)) + expect(channel2.state).to(equal(ARTRealtimeChannelState.Attached)) + + if channel2.presence.syncComplete { + expect(channel2.presenceMap.members).to(haveCount(2)) + } + else { + expect(channel2.presenceMap.members).to(haveCount(1)) + } + done() } - } - let client2 = AblyTests.newRealtime(options) - defer { client2.close() } - let channel2 = client2.channels.get(channel1.name) - - channel2.presence.enterClient("Client 2", data: nil) { error in - expect(error).to(beNil()) - expect(channel2.queuedMessages).to(haveCount(0)) - expect(channel2.state).to(equal(ARTRealtimeChannelState.Attached)) + expect(channel2.queuedMessages).to(haveCount(1)) + expect(channel2.presence.syncComplete).to(beFalse()) + expect(channel2.presenceMap.members).to(haveCount(0)) } - expect(channel2.queuedMessages).to(haveCount(1)) - expect(channel2.presence.syncComplete).to(beFalse()) + guard let transport = client2.transport as? TestProxyTransport else { + fail("Transport should be a test proxy"); return + } - expect(channel2.presenceMap.members).to(haveCount(0)) + expect(transport.protocolMessagesReceived.filter{ $0.action == .Sync }).to(haveCount(1)) - expect(channel2.state).toEventually(equal(ARTRealtimeChannelState.Attached), timeout: testTimeout) - expect(channel2.presence.syncComplete).toEventually(beTrue(), timeout: testTimeout) expect(channel2.presenceMap.members).to(haveCount(2)) } @@ -345,7 +353,7 @@ class RealtimeClientPresence: QuickSpec { // RTP7b it("with a single action argument unsubscribes the provided listener to all presence messages for that action") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let listener = channel.presence.subscribe(.Present) { _ in }! @@ -362,7 +370,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c it("should implicitly attach the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -381,7 +389,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c it("should result in an error if the channel is in the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -402,7 +410,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c it("should result in an error if the channel moves to the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -521,7 +529,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -549,7 +557,7 @@ class RealtimeClientPresence: QuickSpec { // RTP8f it("should result in an error immediately if the client is anonymous") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -570,7 +578,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -594,7 +602,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -617,7 +625,7 @@ class RealtimeClientPresence: QuickSpec { // RTP8i it("should result in an error if Ably service determines that the client is unidentified") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -638,7 +646,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -663,7 +671,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -693,7 +701,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.presenceMap.members).to(haveCount(0)) @@ -717,7 +725,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -733,7 +741,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -751,7 +759,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -787,7 +795,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -816,7 +824,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -851,7 +859,7 @@ class RealtimeClientPresence: QuickSpec { } let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") var user50LeaveTimestamp: NSDate? @@ -901,10 +909,10 @@ class RealtimeClientPresence: QuickSpec { // RTP8h it("should result in an error if the client does not have required presence permission") { let options = AblyTests.commonAppSetup() - options.token = getTestToken(capability: "{ \"cannotpresence:john\":[\"publish\"] }") + options.token = getTestToken(clientId: "john", capability: "{ \"cannotpresence:john\":[\"publish\"] }") options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("cannotpresence") waitUntil(timeout: testTimeout) { done in @@ -926,7 +934,7 @@ class RealtimeClientPresence: QuickSpec { // RTP9e it("should result in an error immediately if the client is anonymous") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -942,7 +950,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -961,7 +969,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -977,10 +985,10 @@ class RealtimeClientPresence: QuickSpec { // RTP9e it("should result in an error if the client does not have required presence permission") { let options = AblyTests.clientOptions() - options.token = getTestToken(capability: "{ \"cannotpresence:john\":[\"publish\"] }") + options.token = getTestToken(clientId: "john", capability: "{ \"cannotpresence:john\":[\"publish\"] }") options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("cannotpresence") waitUntil(timeout: testTimeout) { done in @@ -994,7 +1002,7 @@ class RealtimeClientPresence: QuickSpec { // RTP9e it("should result in an error if Ably service determines that the client is unidentified") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1014,7 +1022,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1037,7 +1045,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1064,7 +1072,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.presence.leave("offline")).to(raiseException()) } @@ -1074,7 +1082,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1112,7 +1120,7 @@ class RealtimeClientPresence: QuickSpec { options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -1132,7 +1140,7 @@ class RealtimeClientPresence: QuickSpec { options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -1154,7 +1162,7 @@ class RealtimeClientPresence: QuickSpec { // RTP10e it("should result in an error immediately if the client is anonymous") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1170,7 +1178,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1195,7 +1203,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1218,10 +1226,10 @@ class RealtimeClientPresence: QuickSpec { // RTP10e it("should result in an error if the client does not have required presence permission") { let options = AblyTests.clientOptions() - options.token = getTestToken(capability: "{ \"cannotpresence:other\":[\"publish\"] }") + options.token = getTestToken(clientId: "john", capability: "{ \"cannotpresence:other\":[\"publish\"] }") options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("cannotpresence") waitUntil(timeout: testTimeout) { done in @@ -1235,7 +1243,7 @@ class RealtimeClientPresence: QuickSpec { // RTP10e it("should result in an error if Ably service determines that the client is unidentified") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1254,7 +1262,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c it("should implicitly attach the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -1273,7 +1281,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c pending("should result in an error if the channel is in the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -1290,7 +1298,7 @@ class RealtimeClientPresence: QuickSpec { // RTP6c pending("should result in an error if the channel moves to the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1422,7 +1430,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1453,7 +1461,7 @@ class RealtimeClientPresence: QuickSpec { context(testCase) { it("should implicitly attach the Channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -1470,7 +1478,7 @@ class RealtimeClientPresence: QuickSpec { it("should result in an error if the channel is in the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -1486,7 +1494,7 @@ class RealtimeClientPresence: QuickSpec { it("should result in an error if the channel moves to the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1507,7 +1515,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.clientId = "john" let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1534,7 +1542,7 @@ class RealtimeClientPresence: QuickSpec { // RTP16a it("all presence messages are published immediately if the connection is CONNECTED") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1554,7 +1562,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.disconnectedRetryTimeout = 1.0 let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.options.queueMessages).to(beTrue()) @@ -1583,7 +1591,7 @@ class RealtimeClientPresence: QuickSpec { options.disconnectedRetryTimeout = 1.0 options.queueMessages = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.options.queueMessages).to(beFalse()) @@ -1610,7 +1618,7 @@ class RealtimeClientPresence: QuickSpec { let options = AblyTests.commonAppSetup() options.autoConnect = false let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.options.queueMessages).to(beTrue()) @@ -1635,7 +1643,7 @@ class RealtimeClientPresence: QuickSpec { for (connectionState, performMethod) in cases { it("should result in an error if the connection state is \(connectionState)") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(client.options.queueMessages).to(beTrue()) @@ -1689,7 +1697,7 @@ class RealtimeClientPresence: QuickSpec { } let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") var presenceQueryWasCreated = false @@ -1717,7 +1725,7 @@ class RealtimeClientPresence: QuickSpec { // RTP11b it("should implicitly attach the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.state).to(equal(ARTRealtimeChannelState.Initialized)) @@ -1735,7 +1743,7 @@ class RealtimeClientPresence: QuickSpec { // RTP11b it("should result in an error if the channel is in the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.onError(AblyTests.newErrorProtocolMessage()) @@ -1752,7 +1760,7 @@ class RealtimeClientPresence: QuickSpec { // RTP11b it("should result in an error if the channel moves to the FAILED state") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1782,7 +1790,7 @@ class RealtimeClientPresence: QuickSpec { } let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let query = ARTRealtimePresenceQuery() @@ -1820,7 +1828,7 @@ class RealtimeClientPresence: QuickSpec { } let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let query = ARTRealtimePresenceQuery() @@ -1913,7 +1921,7 @@ class RealtimeClientPresence: QuickSpec { } let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in @@ -1968,7 +1976,7 @@ class RealtimeClientPresence: QuickSpec { it("should invoke an error when the untilAttach is specified and the channel is not attached") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let query = ARTRealtimeHistoryQuery() @@ -1995,7 +2003,7 @@ class RealtimeClientPresence: QuickSpec { for caseItem in cases { it("where value is \(caseItem.untilAttach), should pass the querystring param fromSerial with the serial number assigned to the channel") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") let testHTTPExecutor = TestProxyHTTPExecutor() @@ -2042,7 +2050,7 @@ class RealtimeClientPresence: QuickSpec { } let client = ARTRealtime(options: options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") waitUntil(timeout: testTimeout) { done in channel.attach() { _ in @@ -2092,7 +2100,7 @@ class RealtimeClientPresence: QuickSpec { } let client = AblyTests.newRealtime(options) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") channel.attach() @@ -2116,7 +2124,7 @@ class RealtimeClientPresence: QuickSpec { // RTP14a, RTP14b, RTP14c, RTP14d it("enters into presence on a channel on behalf of another clientId") { let client = ARTRealtime(options: AblyTests.commonAppSetup()) - defer { client.close() } + defer { client.dispose(); client.close() } let channel = client.channels.get("test") expect(channel.presenceMap.members).to(haveCount(0)) diff --git a/Spec/RestClient.swift b/Spec/RestClient.swift index 3af4c32e1..241c9c38a 100644 --- a/Spec/RestClient.swift +++ b/Spec/RestClient.swift @@ -991,14 +991,16 @@ class RestClient: QuickSpec { options.token = getTestToken(ttl: 0.1) let client = ARTRest(options: options) waitUntil(timeout: testTimeout) { done in - client.channels.get("test").publish(nil, data: "message") { error in - guard let error = error else { - fail("Error is empty"); done() - return + delay(0.1) { + client.channels.get("test").publish(nil, data: "message") { error in + guard let error = error else { + fail("Error is empty"); done() + return + } + expect(error.code).to(equal(Int(ARTState.RequestTokenFailed.rawValue))) + expect(error.message).to(contain("no means to renew the token is provided")) + done() } - expect(error.code).to(equal(Int(ARTState.RequestTokenFailed.rawValue))) - expect(error.message).to(contain("no means to renew the token is provided")) - done() } } } diff --git a/Spec/RestClientChannel.swift b/Spec/RestClientChannel.swift index 7d00968f8..c1d611bcf 100644 --- a/Spec/RestClientChannel.swift +++ b/Spec/RestClientChannel.swift @@ -344,8 +344,8 @@ class RestClientChannel: QuickSpec { } } - delay(0.2) { - waitUntil(timeout: testTimeout) { done in + waitUntil(timeout: testTimeout) { done in + delay(0.2) { channel.publish(nil, data: "message3") { _ in done() } diff --git a/Spec/RestClientPresence.swift b/Spec/RestClientPresence.swift index 6d8f65d2c..3124f0ad0 100644 --- a/Spec/RestClientPresence.swift +++ b/Spec/RestClientPresence.swift @@ -477,18 +477,13 @@ class RestClientPresence: QuickSpec { let channel = client.channels.get("test") let expectedData = ["test":1] - var decodeNumberOfCalls = 0 - let hook = ARTBaseMessage.testSuite_injectIntoClassMethod(#selector(ARTBaseMessage.decodeWithEncoder(_:error:))) { - decodeNumberOfCalls += 1 - } - defer { hook?.remove() } waitUntil(timeout: testTimeout) { done in channel.publish(nil, data: expectedData) { _ in done() } } var realtime = ARTRealtime(options: options) - defer { realtime.close() } + defer { realtime.dispose(); realtime.close() } waitUntil(timeout: testTimeout) { done in realtime.channels.get("test").presence.enterClient("john", data: expectedData) { _ in done() } } @@ -503,6 +498,12 @@ class RestClientPresence: QuickSpec { } } + var decodeNumberOfCalls = 0 + let hook = ARTBaseMessage.testSuite_injectIntoClassMethod(#selector(ARTBaseMessage.decodeWithEncoder(_:error:))) { + decodeNumberOfCalls += 1 + } + defer { hook?.remove() } + waitUntil(timeout: testTimeout) { done in channel.history(checkReceivedMessage(done)) }