diff --git a/Source/Session/Session.swift b/Source/Session/Session.swift index 3ed74cd..54accc1 100644 --- a/Source/Session/Session.swift +++ b/Source/Session/Session.swift @@ -14,9 +14,6 @@ public class Session: NSObject { private lazy var bridge = WebViewBridge(webView: webView) private var initialized = false private var refreshing = false - - /// Options behave differently if a response is provided. - private let visitOptionsHandler = VisitOptionsHandler() private var isShowingStaleContent = false private var isSnapshotCacheStale = false @@ -68,8 +65,7 @@ public class Session: NSObject { initialized = false } - let processedOptions = visitOptionsHandler.process(options) - let visit = makeVisit(for: visitable, options: processedOptions) + let visit = makeVisit(for: visitable, options: options ?? VisitOptions()) currentVisit?.cancel() currentVisit = visit diff --git a/Source/Session/VisitOptionsHandler.swift b/Source/Session/VisitOptionsHandler.swift deleted file mode 100644 index 303337a..0000000 --- a/Source/Session/VisitOptionsHandler.swift +++ /dev/null @@ -1,24 +0,0 @@ -import Foundation - -class VisitOptionsHandler { - - private var unhandledVisitOptions: VisitOptions? - - /// If a form submission provides a response HTML, save the options and pass them to the next visit proposal. - func process(_ options: VisitOptions?) -> VisitOptions { - - if let options, options.response?.responseHTML != nil { - /// A `responseHTML` is provided for the next visit. - unhandledVisitOptions = options - return options - } else if let unhandledVisitOptions { - /// Next visit is happening. Use the previous `responseHTML`. - self.unhandledVisitOptions = nil - return unhandledVisitOptions - } else { - /// No options are unhandled. - return options ?? VisitOptions() - } - } - -} diff --git a/Source/Visit/VisitResponse.swift b/Source/Visit/VisitResponse.swift index baa5ad5..7b90496 100644 --- a/Source/Visit/VisitResponse.swift +++ b/Source/Visit/VisitResponse.swift @@ -1,12 +1,14 @@ import Foundation public struct VisitResponse: Codable { + public let redirected: Bool public let statusCode: Int public let responseHTML: String? - public init(statusCode: Int, responseHTML: String? = nil) { + public init(statusCode: Int, responseHTML: String? = nil, redirected: Bool = false) { self.statusCode = statusCode self.responseHTML = responseHTML + self.redirected = redirected } public var isSuccessful: Bool { diff --git a/Tests/VisitOptionsTests.swift b/Tests/VisitOptionsTests.swift deleted file mode 100644 index ecd9a85..0000000 --- a/Tests/VisitOptionsTests.swift +++ /dev/null @@ -1,71 +0,0 @@ -@testable import Turbo -import XCTest - -class VisitOptionsTests: XCTestCase { - func test_Decodable_defaultsToAdvanceActionWhenNotProvided() throws { - let json = "{}".data(using: .utf8)! - - let options = try JSONDecoder().decode(VisitOptions.self, from: json) - XCTAssertEqual(options.action, .advance) - XCTAssertNil(options.response) - } - - func test_Decodable_usesProvidedActionWhenNotNil() throws { - let json = """ - {"action": "restore"} - """.data(using: .utf8)! - - let options = try JSONDecoder().decode(VisitOptions.self, from: json) - XCTAssertEqual(options.action, .restore) - XCTAssertNil(options.response) - } - - func test_Decodable_canBeInitializedWithResponse() throws { - _ = try validVisitVisitOptions(responseHTMLString: "") - } - - func test_visitOptionsArePreserved() throws { - let visitOptionsWithResponse = try validVisitVisitOptions(responseHTMLString: "") - let handler = VisitOptionsHandler() - - let processedOptions = handler.process(visitOptionsWithResponse) - XCTAssert(processedOptions == visitOptionsWithResponse) - - let nextVisitOptions = try validVisitVisitOptions(responseHTMLString: nil) - let savedOptions = handler.process(nextVisitOptions) - XCTAssert(savedOptions == visitOptionsWithResponse) - } -} - -extension VisitOptionsTests { - func validVisitVisitOptions(responseHTMLString: String?) throws -> VisitOptions { - var responseJSON = "" - if let responseHTMLString { - responseJSON = ", \"responseHTML\": \"\(responseHTMLString)\"" - } - - let json = """ - {"response": {"statusCode": 200\(responseJSON)}} - """.data(using: .utf8)! - - let options = try JSONDecoder().decode(VisitOptions.self, from: json) - XCTAssertEqual(options.action, .advance) - - let response = try XCTUnwrap(options.response) - XCTAssertEqual(response.statusCode, 200) - XCTAssertEqual(response.responseHTML, responseHTMLString) - return options - } -} - -extension VisitOptions : Equatable { - public static func == (lhs: VisitOptions, rhs: VisitOptions) -> Bool { - lhs.action == rhs.action && lhs.response == rhs.response - } -} - -extension VisitResponse : Equatable { - public static func == (lhs: VisitResponse, rhs: VisitResponse) -> Bool { - lhs.responseHTML == rhs.responseHTML && lhs.statusCode == rhs.statusCode - } -}