83 lines
2.7 KiB
Swift
83 lines
2.7 KiB
Swift
//
|
|
// TestTransport.swift
|
|
// AccountTests
|
|
//
|
|
// Created by Maurice Parker on 5/4/19.
|
|
// Copyright © 2019 Ranchero Software, LLC. All rights reserved.
|
|
//
|
|
|
|
import Foundation
|
|
import RSWeb
|
|
import XCTest
|
|
|
|
final class TestTransport: Transport {
|
|
|
|
enum TestTransportError: String, Error {
|
|
case invalidState = "The test wasn't set up correctly."
|
|
}
|
|
|
|
var testFiles = [String: String]()
|
|
var testStatusCodes = [String: Int]()
|
|
|
|
/// Allows tests to filter time sensitive state out to make matching against test data easier.
|
|
var blacklistedQueryItemNames = Set([
|
|
"newerThan", // Feedly: Mock data has a fixed date.
|
|
"unreadOnly", // Feedly: Mock data is read/unread by test expectation.
|
|
"count", // Feedly: Mock data is limited by test expectation.
|
|
])
|
|
|
|
private func httpResponse(for request: URLRequest, statusCode: Int = 200) -> HTTPURLResponse {
|
|
guard let url = request.url else {
|
|
fatalError("Attempting to mock a http response for a request without a URL \(request).")
|
|
}
|
|
return HTTPURLResponse(url: url, statusCode: statusCode, httpVersion: "HTTP/1.1", headerFields: nil)!
|
|
}
|
|
|
|
func send(request: URLRequest, completion: @escaping (Result<(HTTPURLResponse, Data?), Error>) -> Void) {
|
|
|
|
guard let url = request.url, var components = URLComponents(url: url, resolvingAgainstBaseURL: false) else {
|
|
completion(.failure(TestTransportError.invalidState))
|
|
return
|
|
}
|
|
|
|
components.queryItems = components
|
|
.queryItems?
|
|
.filter { !blacklistedQueryItemNames.contains($0.name) }
|
|
|
|
guard let urlString = components.url?.absoluteString else {
|
|
completion(.failure(TestTransportError.invalidState))
|
|
return
|
|
}
|
|
|
|
let response = httpResponse(for: request, statusCode: testStatusCodes[urlString] ?? 200)
|
|
|
|
var mockResponseFound = false
|
|
for (key, testFileName) in testFiles where urlString.contains(key) {
|
|
let testFileURL = Bundle(for: TestTransport.self).resourceURL!.appendingPathComponent(testFileName)
|
|
let data = try! Data(contentsOf: testFileURL)
|
|
DispatchQueue.global(qos: .background).async {
|
|
completion(.success((response, data)))
|
|
}
|
|
mockResponseFound = true
|
|
break
|
|
}
|
|
|
|
if !mockResponseFound {
|
|
// XCTFail("Missing mock response for: \(urlString)")
|
|
print("***\nWARNING: \(self) missing mock response for:\n\(urlString)\n***")
|
|
DispatchQueue.global(qos: .background).async {
|
|
completion(.success((response, nil)))
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
func send(request: URLRequest, method: String, completion: @escaping (Result<Void, Error>) -> Void) {
|
|
fatalError("Unimplemented.")
|
|
}
|
|
|
|
func send(request: URLRequest, method: String, payload: Data, completion: @escaping (Result<(HTTPURLResponse, Data?), Error>) -> Void) {
|
|
fatalError("Unimplemented.")
|
|
}
|
|
}
|