| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283 |
- //
- // SessionManagerTests.swift
- //
- // Copyright (c) 2014-2016 Alamofire Software Foundation (http://alamofire.org/)
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- //
- @testable import Alamofire
- import Foundation
- import XCTest
- class SessionManagerTestCase: BaseTestCase {
- // MARK: Initialization Tests
- func testInitializerWithDefaultArguments() {
- // Given, When
- let manager = SessionManager()
- // Then
- XCTAssertNotNil(manager.session.delegate, "session delegate should not be nil")
- XCTAssertTrue(manager.delegate === manager.session.delegate, "manager delegate should equal session delegate")
- XCTAssertNil(manager.session.serverTrustPolicyManager, "session server trust policy manager should be nil")
- }
- func testInitializerWithSpecifiedArguments() {
- // Given
- let configuration = URLSessionConfiguration.default
- let delegate = SessionDelegate()
- let serverTrustPolicyManager = ServerTrustPolicyManager(policies: [:])
- // When
- let manager = SessionManager(
- configuration: configuration,
- delegate: delegate,
- serverTrustPolicyManager: serverTrustPolicyManager
- )
- // Then
- XCTAssertNotNil(manager.session.delegate, "session delegate should not be nil")
- XCTAssertTrue(manager.delegate === manager.session.delegate, "manager delegate should equal session delegate")
- XCTAssertNotNil(manager.session.serverTrustPolicyManager, "session server trust policy manager should not be nil")
- }
- func testThatFailableInitializerSucceedsWithDefaultArguments() {
- // Given
- let delegate = SessionDelegate()
- let session: URLSession = {
- let configuration = URLSessionConfiguration.default
- return URLSession(configuration: configuration, delegate: delegate, delegateQueue: nil)
- }()
- // When
- let manager = SessionManager(session: session, delegate: delegate)
- // Then
- if let manager = manager {
- XCTAssertTrue(manager.delegate === manager.session.delegate, "manager delegate should equal session delegate")
- XCTAssertNil(manager.session.serverTrustPolicyManager, "session server trust policy manager should be nil")
- } else {
- XCTFail("manager should not be nil")
- }
- }
- func testThatFailableInitializerSucceedsWithSpecifiedArguments() {
- // Given
- let delegate = SessionDelegate()
- let session: URLSession = {
- let configuration = URLSessionConfiguration.default
- return URLSession(configuration: configuration, delegate: delegate, delegateQueue: nil)
- }()
- let serverTrustPolicyManager = ServerTrustPolicyManager(policies: [:])
- // When
- let manager = SessionManager(session: session, delegate: delegate, serverTrustPolicyManager: serverTrustPolicyManager)
- // Then
- if let manager = manager {
- XCTAssertTrue(manager.delegate === manager.session.delegate, "manager delegate should equal session delegate")
- XCTAssertNotNil(manager.session.serverTrustPolicyManager, "session server trust policy manager should not be nil")
- } else {
- XCTFail("manager should not be nil")
- }
- }
- func testThatFailableInitializerFailsWithWhenDelegateDoesNotEqualSessionDelegate() {
- // Given
- let delegate = SessionDelegate()
- let session: URLSession = {
- let configuration = URLSessionConfiguration.default
- return URLSession(configuration: configuration, delegate: SessionDelegate(), delegateQueue: nil)
- }()
- // When
- let manager = SessionManager(session: session, delegate: delegate)
- // Then
- XCTAssertNil(manager, "manager should be nil")
- }
- func testThatFailableInitializerFailsWhenSessionDelegateIsNil() {
- // Given
- let delegate = SessionDelegate()
- let session: URLSession = {
- let configuration = URLSessionConfiguration.default
- return URLSession(configuration: configuration, delegate: nil, delegateQueue: nil)
- }()
- // When
- let manager = SessionManager(session: session, delegate: delegate)
- // Then
- XCTAssertNil(manager, "manager should be nil")
- }
- // MARK: Start Requests Immediately Tests
- func testSetStartRequestsImmediatelyToFalseAndResumeRequest() {
- // Given
- let manager = SessionManager()
- manager.startRequestsImmediately = false
- let url = URL(string: "https://httpbin.org/get")!
- let urlRequest = URLRequest(url: url)
- let expectation = self.expectation(description: "\(url)")
- var response: HTTPURLResponse?
- // When
- manager.request(urlRequest)
- .response { _, responseResponse, _, _ in
- response = responseResponse
- expectation.fulfill()
- }
- .resume()
- waitForExpectations(timeout: timeout, handler: nil)
- // Then
- XCTAssertNotNil(response, "response should not be nil")
- XCTAssertTrue(response?.statusCode == 200, "response status code should be 200")
- }
- // MARK: Deinitialization Tests
- func testReleasingManagerWithPendingRequestDeinitializesSuccessfully() {
- // Given
- var manager: SessionManager? = SessionManager()
- manager?.startRequestsImmediately = false
- let url = URL(string: "https://httpbin.org/get")!
- let urlRequest = URLRequest(url: url)
- // When
- let request = manager?.request(urlRequest)
- manager = nil
- // Then
- XCTAssertTrue(request?.task.state == .suspended, "request task state should be '.Suspended'")
- XCTAssertNil(manager, "manager should be nil")
- }
- func testReleasingManagerWithPendingCanceledRequestDeinitializesSuccessfully() {
- // Given
- var manager: SessionManager? = SessionManager()
- manager!.startRequestsImmediately = false
- let url = URL(string: "https://httpbin.org/get")!
- let urlRequest = URLRequest(url: url)
- // When
- let request = manager!.request(urlRequest)
- request.cancel()
- manager = nil
- // Then
- let state = request.task.state
- XCTAssertTrue(state == .canceling || state == .completed, "state should be .Canceling or .Completed")
- XCTAssertNil(manager, "manager should be nil")
- }
- }
- // MARK: -
- class ManagerConfigurationHeadersTestCase: BaseTestCase {
- enum ConfigurationType {
- case `default`, ephemeral, background
- }
- func testThatDefaultConfigurationHeadersAreSentWithRequest() {
- // Given, When, Then
- executeAuthorizationHeaderTest(for: .default)
- }
- func testThatEphemeralConfigurationHeadersAreSentWithRequest() {
- // Given, When, Then
- executeAuthorizationHeaderTest(for: .ephemeral)
- }
- // ⚠️ This test has been removed as a result of rdar://26870455 in Xcode 8 Seed 1
- // func testThatBackgroundConfigurationHeadersAreSentWithRequest() {
- // // Given, When, Then
- // executeAuthorizationHeaderTestForConfigurationType(.background)
- // }
- private func executeAuthorizationHeaderTest(for type: ConfigurationType) {
- // Given
- let manager: SessionManager = {
- let configuration: URLSessionConfiguration = {
- let configuration: URLSessionConfiguration
- switch type {
- case .default:
- configuration = .default
- case .ephemeral:
- configuration = .ephemeral
- case .background:
- let identifier = "org.alamofire.test.manager-configuration-tests"
- configuration = .background(withIdentifier: identifier)
- }
- var headers = SessionManager.defaultHTTPHeaders
- headers["Authorization"] = "Bearer 123456"
- configuration.httpAdditionalHeaders = headers
- return configuration
- }()
- return SessionManager(configuration: configuration)
- }()
- let expectation = self.expectation(description: "request should complete successfully")
- var response: Response<AnyObject, NSError>?
- // When
- manager.request("https://httpbin.org/headers", withMethod: .get)
- .responseJSON { closureResponse in
- response = closureResponse
- expectation.fulfill()
- }
- waitForExpectations(timeout: timeout, handler: nil)
- // Then
- if let response = response {
- XCTAssertNotNil(response.request, "request should not be nil")
- XCTAssertNotNil(response.response, "response should not be nil")
- XCTAssertNotNil(response.data, "data should not be nil")
- XCTAssertTrue(response.result.isSuccess, "result should be a success")
- if
- let headers = response.result.value?["headers" as NSString] as? [String: String],
- let authorization = headers["Authorization"]
- {
- XCTAssertEqual(authorization, "Bearer 123456", "authorization header value does not match")
- } else {
- XCTFail("failed to extract authorization header value")
- }
- } else {
- XCTFail("response should not be nil")
- }
- }
- }
|