VerifyCustomTokenTests.swift 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. // Copyright 2023 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. import Foundation
  15. import XCTest
  16. @testable import FirebaseAuth
  17. @available(iOS 13, tvOS 13, macOS 10.15, macCatalyst 13, watchOS 7, *)
  18. class VerifyCustomTokenTests: RPCBaseTests {
  19. private let kTestTokenKey = "token"
  20. private let kTestToken = "test token"
  21. private let kReturnSecureTokenKey = "returnSecureToken"
  22. private let kExpectedAPIURL =
  23. "https://www.googleapis.com/identitytoolkit/v3/relyingparty/verifyCustomToken?key=APIKey"
  24. /** @fn testVerifyCustomTokenRequest
  25. @brief Tests the verify custom token request.
  26. */
  27. func testVerifyCustomTokenRequest() async throws {
  28. let request = makeVerifyCustomTokenRequest()
  29. request.returnSecureToken = false
  30. try await checkRequest(
  31. request: request,
  32. expected: kExpectedAPIURL,
  33. key: kTestTokenKey,
  34. value: kTestToken
  35. )
  36. let requestDictionary = try XCTUnwrap(rpcIssuer.decodedRequest as? [String: AnyHashable])
  37. XCTAssertNil(requestDictionary[kReturnSecureTokenKey])
  38. }
  39. /** @fn testVerifyCustomTokenRequestOptionalFields
  40. @brief Tests the verify custom token request with optional fields.
  41. */
  42. func testVerifyCustomTokenRequestOptionalFields() async throws {
  43. let request = makeVerifyCustomTokenRequest()
  44. try await checkRequest(
  45. request: request,
  46. expected: kExpectedAPIURL,
  47. key: kTestTokenKey,
  48. value: kTestToken
  49. )
  50. let requestDictionary = try XCTUnwrap(rpcIssuer.decodedRequest as? [String: AnyHashable])
  51. XCTAssertTrue(try XCTUnwrap(requestDictionary[kReturnSecureTokenKey] as? Bool))
  52. }
  53. func testVerifyCustomTokenRequestErrors() async throws {
  54. let kInvalidCustomTokenErrorMessage = "INVALID_CUSTOM_TOKEN"
  55. let kInvalidCustomTokenServerErrorMessage = "INVALID_CUSTOM_TOKEN : Detailed Error"
  56. let kInvalidCustomTokenEmptyServerErrorMessage = "INVALID_CUSTOM_TOKEN :"
  57. let kInvalidCustomTokenErrorDetails = "Detailed Error"
  58. let kCredentialMismatchErrorMessage = "CREDENTIAL_MISMATCH:"
  59. try await checkBackendError(
  60. request: makeVerifyCustomTokenRequest(),
  61. message: kInvalidCustomTokenErrorMessage,
  62. errorCode: AuthErrorCode.invalidCustomToken
  63. )
  64. try await checkBackendError(
  65. request: makeVerifyCustomTokenRequest(),
  66. message: kInvalidCustomTokenServerErrorMessage,
  67. errorCode: AuthErrorCode.invalidCustomToken,
  68. checkLocalizedDescription: kInvalidCustomTokenErrorDetails
  69. )
  70. try await checkBackendError(
  71. request: makeVerifyCustomTokenRequest(),
  72. message: kInvalidCustomTokenEmptyServerErrorMessage,
  73. errorCode: AuthErrorCode.invalidCustomToken,
  74. checkLocalizedDescription: "The custom token format is incorrect. Please check the documentation."
  75. )
  76. try await checkBackendError(
  77. request: makeVerifyCustomTokenRequest(),
  78. message: kCredentialMismatchErrorMessage,
  79. errorCode: AuthErrorCode.customTokenMismatch
  80. )
  81. }
  82. /** @fn testSuccessfulVerifyCustomTokenResponse
  83. @brief This test simulates a successful verify CustomToken flow.
  84. */
  85. func testSuccessfulVerifyCustomTokenResponse() async throws {
  86. let kIDTokenKey = "idToken"
  87. let kTestIDToken = "ID_TOKEN"
  88. let kTestExpiresIn = "12345"
  89. let kTestRefreshToken = "REFRESH_TOKEN"
  90. let kExpiresInKey = "expiresIn"
  91. let kRefreshTokenKey = "refreshToken"
  92. let kIsNewUserKey = "isNewUser"
  93. rpcIssuer.respondBlock = {
  94. try self.rpcIssuer.respond(withJSON: [
  95. kIDTokenKey: kTestIDToken,
  96. kExpiresInKey: kTestExpiresIn,
  97. kRefreshTokenKey: kTestRefreshToken,
  98. kIsNewUserKey: true,
  99. ])
  100. }
  101. let rpcResponse = try await authBackend.call(with: makeVerifyCustomTokenRequest())
  102. XCTAssertEqual(rpcResponse.idToken, kTestIDToken)
  103. XCTAssertEqual(rpcResponse.refreshToken, kTestRefreshToken)
  104. let expiresIn = try XCTUnwrap(rpcResponse.approximateExpirationDate?.timeIntervalSinceNow)
  105. XCTAssertEqual(expiresIn, 12345, accuracy: 0.1)
  106. XCTAssertTrue(rpcResponse.isNewUser)
  107. }
  108. private func makeVerifyCustomTokenRequest() -> VerifyCustomTokenRequest {
  109. return VerifyCustomTokenRequest(token: kTestToken,
  110. requestConfiguration: makeRequestConfiguration())
  111. }
  112. }