From 427ac6144db48b5e2a1ed88218a8fd19854f1e4f Mon Sep 17 00:00:00 2001 From: Tony Li Date: Wed, 21 Feb 2024 14:05:03 +1300 Subject: [PATCH 1/4] Update some WordPressComRestApi unit tests --- .../WordPressComRestApiTests+Locale.swift | 285 ++++-------------- .../WordPressComRestApiTests.swift | 14 +- 2 files changed, 66 insertions(+), 233 deletions(-) diff --git a/WordPressKitTests/WordPressComRestApiTests+Locale.swift b/WordPressKitTests/WordPressComRestApiTests+Locale.swift index 4ebb5dfbe..66643c3eb 100644 --- a/WordPressKitTests/WordPressComRestApiTests+Locale.swift +++ b/WordPressKitTests/WordPressComRestApiTests+Locale.swift @@ -1,272 +1,97 @@ import Foundation import XCTest +import OHHTTPStubs import WordPressShared @testable import WordPressKit extension WordPressComRestApiTests { - func testThatAppendingLocaleWorks() { - // Given - let path = "/path/path" - let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug + func testThatAppendingLocaleWorks() async throws { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) - // When let api = WordPressComRestApi() - let localeAppendedPath = api.buildRequestURLFor(path: path) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) - - let expectedPath = path - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNotNil(actualQueryItems) - - let expectedQueryItemCount = 1 - let actualQueryItemCount = actualQueryItems!.count - XCTAssertEqual(expectedQueryItemCount, actualQueryItemCount) - - let actualQueryItem = actualQueryItems!.first - XCTAssertNotNil(actualQueryItem!) - - let actualQueryItemKey = actualQueryItem!.name - let expectedQueryItemKey = WordPressComRestApi.LocaleKeyDefault - XCTAssertEqual(expectedQueryItemKey, actualQueryItemKey) + let _ = await api.perform(.get, URLString: "/path/path") - let actualQueryItemValue = actualQueryItem!.value - XCTAssertNotNil(actualQueryItemValue) - - let expectedQueryItemValue = preferredLanguageIdentifier - XCTAssertEqual(expectedQueryItemValue, actualQueryItemValue!) + let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug + try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("locale=\(preferredLanguageIdentifier)")) } - func testThatAppendingLocaleWorksWithExistingParams() { - // Given + func testThatAppendingLocaleWorksWithExistingParams() async { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) + let path = "/path/path" let params: [String: AnyObject] = [ "someKey": "value" as AnyObject ] - // When let api = WordPressComRestApi() - let localeAppendedPath = api.buildRequestURLFor(path: path, parameters: params) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) - - let expectedPath = "/path/path" - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNotNil(actualQueryItems) - - let expectedQueryItemCount = 1 - let actualQueryItemCount = actualQueryItems!.count - XCTAssertEqual(expectedQueryItemCount, actualQueryItemCount) - - let actualQueryString = actualURLComponents?.query - XCTAssertNotNil(actualQueryString) - - let queryStringIncludesLocale = actualQueryString!.contains(WordPressComRestApi.LocaleKeyDefault) - XCTAssertTrue(queryStringIncludesLocale) - } - - func testThatLocaleIsNotAppendedIfAlreadyIncludedInPath() { - // Given - let preferredLanguageIdentifier = "foo" - let path = "/path/path?locale=\(preferredLanguageIdentifier)" - - // When - let api = WordPressComRestApi() - let localeAppendedPath = api.buildRequestURLFor(path: path) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) - - let expectedPath = "/path/path" - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNotNil(actualQueryItems) - - let expectedQueryItemCount = 1 - let actualQueryItemCount = actualQueryItems!.count - XCTAssertEqual(expectedQueryItemCount, actualQueryItemCount) - - let actualQueryItem = actualQueryItems!.first - XCTAssertNotNil(actualQueryItem!) - - let actualQueryItemKey = actualQueryItem!.name - let expectedQueryItemKey = WordPressComRestApi.LocaleKeyDefault - XCTAssertEqual(expectedQueryItemKey, actualQueryItemKey) - - let actualQueryItemValue = actualQueryItem!.value - XCTAssertNotNil(actualQueryItemValue) - - let expectedQueryItemValue = preferredLanguageIdentifier - XCTAssertEqual(expectedQueryItemValue, actualQueryItemValue!) - } + let _ = await api.perform(.get, URLString: path, parameters: params) - func testThatAppendingLocaleIgnoresIfAlreadyIncludedInRequestParameters() { - // Given - let inputPath = "/path/path" - let expectedLocaleValue = "foo" - let params: [String: AnyObject] = [ - WordPressComRestApi.LocaleKeyDefault: expectedLocaleValue as AnyObject - ] - - // When - let requestURLString = WordPressComRestApi().buildRequestURLFor(path: inputPath, parameters: params) - - // Then let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug - XCTAssertFalse(requestURLString!.contains(preferredLanguageIdentifier)) + try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("locale=\(preferredLanguageIdentifier)")) + try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("someKey=value")) } - func testThatLocaleIsNotAppendedWhenDisabled() { - // Given - let path = "/path/path" + func testThatLocaleIsNotAppendedIfAlreadyIncludedInPath() async { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) - // When let api = WordPressComRestApi() - api.appendsPreferredLanguageLocale = false - let localeAppendedPath = api.buildRequestURLFor(path: path) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) - - let expectedPath = path - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNil(actualQueryItems) - } - - func testThatAlternateLocaleKeyIsHonoredWhenSpecified() { - // Given - let path = "/path/path" - let expectedKey = "foo" - - // When - let api = WordPressComRestApi(localeKey: expectedKey) - let localeAppendedPath = api.buildRequestURLFor(path: path) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) + let _ = await api.perform(.get, URLString: "/path?locale=foo") - let expectedPath = path - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNotNil(actualQueryItems) - - let expectedQueryItemCount = 1 - let actualQueryItemCount = actualQueryItems!.count - XCTAssertEqual(expectedQueryItemCount, actualQueryItemCount) - - let actualQueryItem = actualQueryItems!.first - XCTAssertNotNil(actualQueryItem!) - - let actualQueryItemKey = actualQueryItem!.name - XCTAssertEqual(expectedKey, actualQueryItemKey) + try XCTAssertEqual(XCTUnwrap(request?.url?.query), "locale=foo") } - func testThatAppendingLocaleWorksWhenPassingNilParameters() { - // Given - let path = "/path/path" - let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug + func testThatAppendingLocaleIgnoresIfAlreadyIncludedInRequestParameters() async throws { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) - // When let api = WordPressComRestApi() - let localeAppendedPath = WordPressComRestApi().buildRequestURLFor(path: path, parameters: nil) - - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) - - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) + let _ = await api.perform(.get, URLString: "/path", parameters: ["locale": "foo"] as [String: AnyObject]) - let expectedPath = path - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) - - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNotNil(actualQueryItems) - - let expectedQueryItemCount = 1 - let actualQueryItemCount = actualQueryItems!.count - XCTAssertEqual(expectedQueryItemCount, actualQueryItemCount) - - let actualQueryItem = actualQueryItems!.first - XCTAssertNotNil(actualQueryItem!) - - let actualQueryItemKey = actualQueryItem!.name - let expectedQueryItemKey = WordPressComRestApi.LocaleKeyDefault - XCTAssertEqual(expectedQueryItemKey, actualQueryItemKey) - - let actualQueryItemValue = actualQueryItem!.value - XCTAssertNotNil(actualQueryItemValue) - - let expectedQueryItemValue = preferredLanguageIdentifier - XCTAssertEqual(expectedQueryItemValue, actualQueryItemValue!) + try XCTAssertEqual(XCTUnwrap(request?.url?.query), "locale=foo") } - func testThatLocaleIsNotAppendedWhenDisabledAndParametersAreNil() { - // Given - let path = "/path/path" + func testThatLocaleIsNotAppendedWhenDisabled() async { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) - // When let api = WordPressComRestApi() api.appendsPreferredLanguageLocale = false - let localeAppendedPath = api.buildRequestURLFor(path: path, parameters: nil) + let _ = await api.perform(.get, URLString: "/path") - // Then - XCTAssertNotNil(localeAppendedPath) - let actualURL = URL(string: localeAppendedPath!, relativeTo: api.baseURL) - XCTAssertNotNil(actualURL) + XCTAssertNotNil(request?.url) + XCTAssertNil(request?.url?.query) + } - let actualURLComponents = URLComponents(url: actualURL!, resolvingAgainstBaseURL: false) - XCTAssertNotNil(actualURLComponents) + func testThatAlternateLocaleKeyIsHonoredWhenSpecified() async { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) - let expectedPath = path - let actualPath = actualURLComponents!.path - XCTAssertEqual(expectedPath, actualPath) + let api = WordPressComRestApi(localeKey: "foo") - let actualQueryItems = actualURLComponents!.queryItems - XCTAssertNil(actualQueryItems) + let _ = await api.perform(.get, URLString: "/path/path") + try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("foo=")) } } diff --git a/WordPressKitTests/WordPressComRestApiTests.swift b/WordPressKitTests/WordPressComRestApiTests.swift index 67ba520be..55a131044 100644 --- a/WordPressKitTests/WordPressComRestApiTests.swift +++ b/WordPressKitTests/WordPressComRestApiTests.swift @@ -130,14 +130,22 @@ class WordPressComRestApiTests: XCTestCase { self.waitForExpectations(timeout: 2, handler: nil) } - func testBaseUrl() { + func testBaseUrl() async throws { + var request: URLRequest? + stub(condition: { _ in true }, response: { + request = $0 + return HTTPStubsResponse(error: URLError(.networkConnectionLost)) + }) + let defaultApi = WordPressComRestApi() XCTAssertEqual(defaultApi.baseURL.absoluteString, "https://public-api.wordpress.com/") - XCTAssertTrue(defaultApi.buildRequestURLFor(path: "/path")!.hasPrefix("https://public-api.wordpress.com/path")) + let _ = await defaultApi.perform(.get, URLString: "/path") + try XCTAssertTrue(XCTUnwrap(request?.url?.absoluteString).hasPrefix("https://public-api.wordpress.com/path")) let localhostApi = WordPressComRestApi(baseURL: URL(string: "http://localhost:8080")!) XCTAssertEqual(localhostApi.baseURL.absoluteString, "http://localhost:8080") - XCTAssertTrue(localhostApi.buildRequestURLFor(path: "/path")!.hasPrefix("http://localhost:8080/path")) + let _ = await localhostApi.perform(.get, URLString: "/local") + try XCTAssertTrue(XCTUnwrap(request?.url?.absoluteString).hasPrefix("http://localhost:8080/local")) } func testURLStringWithQuery() async { From 2e67d20e276223f2511642ef8e2ea9655fe9878a Mon Sep 17 00:00:00 2001 From: Tony Li Date: Wed, 21 Feb 2024 14:06:19 +1300 Subject: [PATCH 2/4] Do not add default query if it exists in the original URL --- WordPressKit/HTTPRequestBuilder.swift | 3 ++- .../Utilities/HTTPRequestBuilderTests.swift | 9 +++++++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/WordPressKit/HTTPRequestBuilder.swift b/WordPressKit/HTTPRequestBuilder.swift index 885c88446..b84cd706b 100644 --- a/WordPressKit/HTTPRequestBuilder.swift +++ b/WordPressKit/HTTPRequestBuilder.swift @@ -153,8 +153,9 @@ final class HTTPRequestBuilder { // Add default query items if they don't exist in `appendedQuery`. var newQuery = appendedQuery if !defaultQuery.isEmpty { + let allQuery = (original.queryItems ?? []) + newQuery let toBeAdded = defaultQuery.filter { item in - !newQuery.contains(where: { $0.name == item.name}) + !allQuery.contains(where: { $0.name == item.name}) } newQuery.append(contentsOf: toBeAdded) } diff --git a/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift b/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift index 7b008c752..ca1beb2ad 100644 --- a/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift +++ b/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift @@ -205,6 +205,15 @@ class HTTPRequestBuilderTests: XCTestCase { try XCTAssertEqual(builder.query(name: "foo", value: "bar").build().url?.query, "locale=zh&foo=bar") } + func testDefaultQueryExistsInOriginalURL() throws { + let url = try HTTPRequestBuilder(url: URL(string: "https://wordpress.org/hello?locale=foo")!) + .query(defaults: [URLQueryItem(name: "locale", value: "en")]) + .build() + .url + + XCTAssertEqual(url?.query, "locale=foo") + } + func testJSONBody() throws { var request = try HTTPRequestBuilder(url: URL(string: "https://wordpress.org")!) .method(.post) From 0b64235979a2f2750bfad0fc610658472fa19c07 Mon Sep 17 00:00:00 2001 From: Tony Li Date: Wed, 21 Feb 2024 14:36:57 +1300 Subject: [PATCH 3/4] Use more strict assertions --- .../WordPressComRestApiTests+Locale.swift | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/WordPressKitTests/WordPressComRestApiTests+Locale.swift b/WordPressKitTests/WordPressComRestApiTests+Locale.swift index 66643c3eb..a37973aeb 100644 --- a/WordPressKitTests/WordPressComRestApiTests+Locale.swift +++ b/WordPressKitTests/WordPressComRestApiTests+Locale.swift @@ -18,10 +18,10 @@ extension WordPressComRestApiTests { let _ = await api.perform(.get, URLString: "/path/path") let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug - try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("locale=\(preferredLanguageIdentifier)")) + XCTAssertEqual(request?.url?.query, "locale=\(preferredLanguageIdentifier)") } - func testThatAppendingLocaleWorksWithExistingParams() async { + func testThatAppendingLocaleWorksWithExistingParams() async throws { var request: URLRequest? stub(condition: { _ in true }, response: { request = $0 @@ -37,8 +37,8 @@ extension WordPressComRestApiTests { let _ = await api.perform(.get, URLString: path, parameters: params) let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug - try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("locale=\(preferredLanguageIdentifier)")) - try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("someKey=value")) + let query = try XCTUnwrap(request?.url?.query?.split(separator: "&")) + XCTAssertEqual(Set(query), Set(["locale=\(preferredLanguageIdentifier)", "someKey=value"])) } func testThatLocaleIsNotAppendedIfAlreadyIncludedInPath() async { @@ -91,7 +91,8 @@ extension WordPressComRestApiTests { let api = WordPressComRestApi(localeKey: "foo") + let preferredLanguageIdentifier = WordPressComLanguageDatabase().deviceLanguage.slug let _ = await api.perform(.get, URLString: "/path/path") - try XCTAssertTrue(XCTUnwrap(request?.url?.query).contains("foo=")) + XCTAssertEqual(request?.url?.query, "foo=\(preferredLanguageIdentifier)") } } From 67cfbe24d87792a39e234326fd07029f49b11451 Mon Sep 17 00:00:00 2001 From: Tony Li Date: Thu, 22 Feb 2024 11:12:35 +1300 Subject: [PATCH 4/4] Change test functions names --- WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift | 2 +- WordPressKitTests/WordPressComRestApiTests+Locale.swift | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift b/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift index ca1beb2ad..966f127bd 100644 --- a/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift +++ b/WordPressKitTests/Utilities/HTTPRequestBuilderTests.swift @@ -205,7 +205,7 @@ class HTTPRequestBuilderTests: XCTestCase { try XCTAssertEqual(builder.query(name: "foo", value: "bar").build().url?.query, "locale=zh&foo=bar") } - func testDefaultQueryExistsInOriginalURL() throws { + func testDefaultQueryDoesNotOverriedQueryItemInOriginalURL() throws { let url = try HTTPRequestBuilder(url: URL(string: "https://wordpress.org/hello?locale=foo")!) .query(defaults: [URLQueryItem(name: "locale", value: "en")]) .build() diff --git a/WordPressKitTests/WordPressComRestApiTests+Locale.swift b/WordPressKitTests/WordPressComRestApiTests+Locale.swift index a37973aeb..2c5aa658c 100644 --- a/WordPressKitTests/WordPressComRestApiTests+Locale.swift +++ b/WordPressKitTests/WordPressComRestApiTests+Locale.swift @@ -7,7 +7,7 @@ import WordPressShared extension WordPressComRestApiTests { - func testThatAppendingLocaleWorks() async throws { + func testAddsLocaleToURLQueryByDefault() async throws { var request: URLRequest? stub(condition: { _ in true }, response: { request = $0 @@ -21,7 +21,7 @@ extension WordPressComRestApiTests { XCTAssertEqual(request?.url?.query, "locale=\(preferredLanguageIdentifier)") } - func testThatAppendingLocaleWorksWithExistingParams() async throws { + func testAddsLocaleToURLQueryByDefaultAndMaintainsInputParameters() async throws { var request: URLRequest? stub(condition: { _ in true }, response: { request = $0