| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992 |
- // Copyright 2018 Google
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- #import "FIRTestCase.h"
- #import "GTMHTTPServer.h"
- #import <FirebaseCore/FIRNetwork.h>
- #import <FirebaseCore/FIRReachabilityChecker.h>
- #import <GoogleToolboxForMac/GTMNSData+zlib.h>
- @interface FIRNetwork ()
- - (void)reachability:(FIRReachabilityChecker *)reachability
- statusChanged:(FIRReachabilityStatus)status;
- @end
- @interface FIRNetworkURLSession ()
- - (void)maybeRemoveTempFilesAtURL:(NSURL *)tempFile expiringTime:(NSTimeInterval)expiringTime;
- @end
- @interface FIRNetworkTest : FIRTestCase <FIRNetworkReachabilityDelegate>
- @end
- @implementation FIRNetworkTest {
- dispatch_queue_t _backgroundQueue;
- FIRNetwork *_network;
- /// Fake Server.
- GTMHTTPServer *_httpServer;
- GTMHTTPRequestMessage *_request;
- int _statusCode;
- // For network reachability test.
- BOOL _fakeNetworkIsReachable;
- BOOL _currentNetworkStatus;
- FIRReachabilityStatus _fakeReachabilityStatus;
- }
- #pragma mark - Setup and teardown
- - (void)setUp {
- [super setUp];
- _fakeNetworkIsReachable = YES;
- _statusCode = 200;
- _request = nil;
- _httpServer = [[GTMHTTPServer alloc] initWithDelegate:self];
- // Start the server.
- NSError *error = nil;
- XCTAssertTrue([_httpServer start:&error], @"Failed to start HTTP server: %@", error);
- _network = [[FIRNetwork alloc] init];
- _backgroundQueue = dispatch_queue_create("Test queue", DISPATCH_QUEUE_SERIAL);
- _request = nil;
- }
- - (void)tearDown {
- _network = nil;
- _backgroundQueue = nil;
- _request = nil;
- [_httpServer stop];
- _httpServer = nil;
- [super tearDown];
- }
- #pragma mark - Test reachability
- - (void)testReachability {
- _network.reachabilityDelegate = self;
- id reachability = [_network valueForKey:@"_reachability"];
- XCTAssertNotNil(reachability);
- id reachabilityMock = OCMPartialMock(reachability);
- [[[reachabilityMock stub] andCall:@selector(reachabilityStatus) onObject:self]
- reachabilityStatus];
- // Fake scenario with connectivity.
- _fakeNetworkIsReachable = YES;
- _fakeReachabilityStatus = kFIRReachabilityViaWifi;
- [_network reachability:reachabilityMock statusChanged:[reachabilityMock reachabilityStatus]];
- XCTAssertTrue([_network isNetworkConnected]);
- XCTAssertEqual(_currentNetworkStatus, _fakeNetworkIsReachable);
- // Fake scenario without connectivity.
- _fakeNetworkIsReachable = NO;
- _fakeReachabilityStatus = kFIRReachabilityNotReachable;
- [_network reachability:reachabilityMock statusChanged:[reachabilityMock reachabilityStatus]];
- XCTAssertFalse([_network isNetworkConnected]);
- XCTAssertEqual(_currentNetworkStatus, _fakeNetworkIsReachable);
- [reachabilityMock stopMocking];
- reachabilityMock = nil;
- }
- #pragma mark - Test POST Foreground
- - (void)testSessionNetwork_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testSessionNetworkShouldReturnError_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 500;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(((NSHTTPURLResponse *)response).statusCode, 500);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilURLNSURLSession_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- _statusCode = 200;
- [_network postURL:nil
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyURLNSURLSession_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- _statusCode = 200;
- [_network postURL:[NSURL URLWithString:@""]
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyPayloadNSURLSession_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [[NSData alloc] init];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNil(error);
- XCTAssertNotNil(_request);
- XCTAssertEqualObjects([_request.URL absoluteString], [url absoluteString]);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilQueueNSURLSession_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/1", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:nil
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- [expectation fulfill];
- }];
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHasRequestPendingNSURLSession_POST_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/hasRequestPending",
- _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- XCTAssertFalse(_network.hasUploadInProgress, @"hasUploadInProgress must be false");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, @"hasUploadInProgress must be true");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- #pragma mark - Test POST Background
- - (void)testSessionNetwork_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testSessionNetworkShouldReturnError_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 500;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(((NSHTTPURLResponse *)response).statusCode, 500);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilURLNSURLSession_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- _statusCode = 200;
- [_network postURL:nil
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyURLNSURLSession_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- _statusCode = 200;
- [_network postURL:[NSURL URLWithString:@""]
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyPayloadNSURLSession_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [[NSData alloc] init];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNil(error);
- XCTAssertNotNil(_request);
- XCTAssertEqualObjects([_request.URL absoluteString], [url absoluteString]);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilQueueNSURLSession_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/1", _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:nil
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- [expectation fulfill];
- }];
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHasRequestPendingNSURLSession_POST_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSData *uncompressedData = [@"Google" dataUsingEncoding:NSUTF8StringEncoding];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/hasRequestPending",
- _httpServer.port]];
- _statusCode = 200;
- [_network postURL:url
- payload:uncompressedData
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- [self verifyResponse:response error:error];
- [self verifyRequest];
- XCTAssertFalse(_network.hasUploadInProgress, @"hasUploadInProgress must be false");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, @"hasUploadInProgress must be true");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- #pragma mark - GET Methods Foreground
- - (void)testSessionNetworkAsync_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testSessionNetworkShouldReturnError_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 500;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(((NSHTTPURLResponse *)response).statusCode, 500);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilURLNSURLSession_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- _statusCode = 200;
- [_network getURL:nil
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyURLNSURLSession_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- _statusCode = 200;
- [_network getURL:[NSURL URLWithString:@""]
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilQueueNSURLSession_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/1", _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:nil
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHasRequestPendingNSURLSession_GET_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/hasRequestPending",
- _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, @"hasUploadInProgress must be false");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, @"hasUploadInProgress must be true");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHeaders_foreground {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 200;
- NSDictionary *headers = @{@"Version" : @"123"};
- [_network getURL:url
- headers:headers
- queue:_backgroundQueue
- usingBackgroundSession:NO
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- NSString *version = [_request.allHeaderFieldValues valueForKey:@"Version"];
- XCTAssertEqualObjects(version, @"123");
- [expectation fulfill];
- }];
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- #pragma mark - GET Methods Background
- - (void)testSessionNetworkAsync_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/2", _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testSessionNetworkShouldReturnError_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 500;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(((NSHTTPURLResponse *)response).statusCode, 500);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilURLNSURLSession_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- _statusCode = 200;
- [_network getURL:nil
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testEmptyURLNSURLSession_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- _statusCode = 200;
- [_network getURL:[NSURL URLWithString:@""]
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertEqual(error.code, FIRErrorCodeNetworkInvalidURL);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testNilQueueNSURLSession_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/1", _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:nil
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, "There must be no pending request");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, "There must be a pending request");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHasRequestPendingNSURLSession_GET_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/hasRequestPending",
- _httpServer.port]];
- _statusCode = 200;
- [_network getURL:url
- headers:nil
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- XCTAssertFalse(_network.hasUploadInProgress, @"hasUploadInProgress must be false");
- [expectation fulfill];
- }];
- XCTAssertTrue(_network.hasUploadInProgress, @"hasUploadInProgress must be true");
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- - (void)testHeaders_background {
- XCTestExpectation *expectation = [self expectationWithDescription:@"Expect block is called"];
- NSURL *url =
- [NSURL URLWithString:[NSString stringWithFormat:@"http://localhost:%d/3", _httpServer.port]];
- _statusCode = 200;
- NSDictionary *headers = @{@"Version" : @"123"};
- [_network getURL:url
- headers:headers
- queue:_backgroundQueue
- usingBackgroundSession:YES
- completionHandler:^(NSHTTPURLResponse *response, NSData *data, NSError *error) {
- XCTAssertNotNil(data);
- NSString *responseBody =
- [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(responseBody, @"<html><body>Hello, World!</body></html>");
- XCTAssertNil(error);
- NSString *version = [_request.allHeaderFieldValues valueForKey:@"Version"];
- XCTAssertEqualObjects(version, @"123");
- [expectation fulfill];
- }];
- // Wait a little bit so the server has enough time to respond.
- [self waitForExpectationsWithTimeout:10
- handler:^(NSError *error) {
- if (error) {
- XCTFail(@"Timeout Error: %@", error);
- }
- }];
- }
- #pragma mark - Test clean up files
- - (void)testRemoveExpiredFiles {
- NSError *writeError = nil;
- NSFileManager *fileManager = [NSFileManager defaultManager];
- FIRNetworkURLSession *session = [[FIRNetworkURLSession alloc]
- initWithNetworkLoggerDelegate:(id<FIRNetworkLoggerDelegate>)_network];
- NSArray *paths =
- NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, YES);
- NSString *applicationSupportDirectory = paths.firstObject;
- NSArray *tempPathComponents = @[
- applicationSupportDirectory, kFIRNetworkApplicationSupportSubdirectory,
- @"FIRNetworkTemporaryDirectory"
- ];
- NSURL *folderURL = [NSURL fileURLWithPathComponents:tempPathComponents];
- [fileManager createDirectoryAtURL:folderURL
- withIntermediateDirectories:YES
- attributes:nil
- error:&writeError];
- NSURL *tempFile1 = [folderURL URLByAppendingPathComponent:@"FIRUpload_temp_123"];
- [self createTempFileAtURL:tempFile1];
- NSURL *tempFile2 = [folderURL URLByAppendingPathComponent:@"FIRUpload_temp_456"];
- [self createTempFileAtURL:tempFile2];
- XCTAssertTrue([fileManager fileExistsAtPath:tempFile1.path]);
- XCTAssertTrue([fileManager fileExistsAtPath:tempFile2.path]);
- NSDate *now =
- [[NSDate date] dateByAddingTimeInterval:1]; // Start mocking the clock to avoid flakiness.
- id mockDate = OCMStrictClassMock([NSDate class]);
- [[[mockDate stub] andReturn:now] date];
- // The file should not be removed since it is not expired yet.
- [session maybeRemoveTempFilesAtURL:folderURL expiringTime:20];
- XCTAssertTrue([fileManager fileExistsAtPath:tempFile1.path]);
- XCTAssertTrue([fileManager fileExistsAtPath:tempFile2.path]);
- [mockDate stopMocking];
- mockDate = nil;
- now = [[NSDate date] dateByAddingTimeInterval:100]; // Move forward in time 100s.
- mockDate = OCMStrictClassMock([NSDate class]);
- [[[mockDate stub] andReturn:now] date];
- [session maybeRemoveTempFilesAtURL:folderURL expiringTime:20];
- XCTAssertFalse([fileManager fileExistsAtPath:tempFile1.path]);
- XCTAssertFalse([fileManager fileExistsAtPath:tempFile2.path]);
- [mockDate stopMocking];
- mockDate = nil;
- }
- #pragma mark - Internal Methods
- - (void)createTempFileAtURL:(NSURL *)fileURL {
- // Create a dictionary and write it to file.
- NSDictionary *someContent = @{@"object" : @"key"};
- [someContent writeToURL:fileURL atomically:YES];
- }
- - (void)verifyResponse:(NSHTTPURLResponse *)response error:(NSError *)error {
- XCTAssertNil(error, @"Error is not expected");
- XCTAssertNotNil(response, @"Error is not expected");
- }
- - (void)verifyRequest {
- XCTAssertNotNil(_request, @"Request cannot be nil");
- // Test whether the request is compressed correctly.
- NSData *requestBody = [_request body];
- NSData *decompressedRequestData = [NSData gtm_dataByInflatingData:requestBody error:NULL];
- NSString *requestString =
- [[NSString alloc] initWithData:decompressedRequestData encoding:NSUTF8StringEncoding];
- XCTAssertEqualObjects(requestString, @"Google", @"Request is not compressed correctly.");
- // The request has to be a POST.
- XCTAssertEqualObjects([_request method], @"POST", @"Request method has to be POST");
- // Content length has to be set correctly.
- NSString *contentLength = [_request.allHeaderFieldValues valueForKey:@"Content-Length"];
- XCTAssertEqualObjects(contentLength, @"26", @"Content Length is incorrect");
- NSString *contentEncoding = [_request.allHeaderFieldValues valueForKey:@"Content-Encoding"];
- XCTAssertEqualObjects(contentEncoding, @"gzip", @"Content Encoding is incorrect");
- }
- #pragma mark - Helper Methods
- - (GTMHTTPResponseMessage *)httpServer:(GTMHTTPServer *)server
- handleRequest:(GTMHTTPRequestMessage *)request {
- _request = request;
- NSData *html =
- [@"<html><body>Hello, World!</body></html>" dataUsingEncoding:NSUTF8StringEncoding];
- return [GTMHTTPResponseMessage responseWithBody:html
- contentType:@"text/html; charset=UTF-8"
- statusCode:_statusCode];
- }
- - (BOOL)isReachable {
- return _fakeNetworkIsReachable;
- }
- - (FIRReachabilityStatus)reachabilityStatus {
- return _fakeReachabilityStatus;
- }
- #pragma mark - FIRReachabilityDelegate
- - (void)reachabilityDidChange {
- _currentNetworkStatus = _fakeNetworkIsReachable;
- }
- @end
|