From 301bb7265f56626cd6fb43afb4f18ae3f1514486 Mon Sep 17 00:00:00 2001 From: Vadym Markov Date: Tue, 22 Dec 2015 15:28:41 +0100 Subject: [PATCH 1/2] Add test for URL with no slash --- Tests/TestCompass.swift | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/Tests/TestCompass.swift b/Tests/TestCompass.swift index 3ae50a9..64ae626 100644 --- a/Tests/TestCompass.swift +++ b/Tests/TestCompass.swift @@ -94,9 +94,26 @@ class TestCompass: XCTestCase { self.waitForExpectationsWithTimeout(4.0, handler:nil) } + func testParseRegularURLWithSlashQuery() { + let expectation = self.expectationWithDescription("Parse URL with slash query") + let url = NSURL(string: "compassTests://callback/?access_token=Yo0OMrVZbRWNmgA6BT99hyuTUTNRGvqEEAQyeN1eslclzhFD0M8AidB4Z7Vs2NU8WoSNW0vYb961O38l&token_type=Bearer&expires_in=3600")! + + Compass.parse(url) { route, arguments in + XCTAssertEqual(route, "callback") + XCTAssertEqual(arguments.count, 3) + XCTAssertEqual(arguments["access_token"], "Yo0OMrVZbRWNmgA6BT99hyuTUTNRGvqEEAQyeN1eslclzhFD0M8AidB4Z7Vs2NU8WoSNW0vYb961O38l") + XCTAssertEqual(arguments["expires_in"], "3600") + XCTAssertEqual(arguments["token_type"], "Bearer") + + expectation.fulfill() + } + + self.waitForExpectationsWithTimeout(4.0, handler:nil) + } + func testParseRegularURLWithQuery() { let expectation = self.expectationWithDescription("Parse URL with query") - let url = NSURL(string: "compassTests://callback/?access_token=Yo0OMrVZbRWNmgA6BT99hyuTUTNRGvqEEAQyeN1eslclzhFD0M8AidB4Z7Vs2NU8WoSNW0vYb961O38l&token_type=Bearer&expires_in=3600")! + let url = NSURL(string: "compassTests://callback?access_token=Yo0OMrVZbRWNmgA6BT99hyuTUTNRGvqEEAQyeN1eslclzhFD0M8AidB4Z7Vs2NU8WoSNW0vYb961O38l&token_type=Bearer&expires_in=3600")! Compass.parse(url) { route, arguments in XCTAssertEqual(route, "callback") From e2759d7b52fe83cea0ef0080679071e306a5cae6 Mon Sep 17 00:00:00 2001 From: Vadym Markov Date: Tue, 22 Dec 2015 15:28:52 +0100 Subject: [PATCH 2/2] Update condition --- Source/Compass.swift | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/Compass.swift b/Source/Compass.swift index cc30fc5..c816e31 100644 --- a/Source/Compass.swift +++ b/Source/Compass.swift @@ -17,7 +17,7 @@ public struct Compass { var result = false let query = url.absoluteString.substringFromIndex(scheme.endIndex) - guard !(query.containsString("/?") || query.containsString("/#")) + guard !(query.containsString("?") || query.containsString("#")) else { return parseAsURL(url, completion: completion) } for route in routes.sort({ $0 < $1 }) {