SendVerificationCodeTests.swift 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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 SendVerificationCodeTests: RPCBaseTests {
  19. private let kTestSecret = "secret"
  20. private let kTestReceipt = "receipt"
  21. private let kTestReCAPTCHAToken = "reCAPTCHAToken"
  22. private let kPhoneNumberKey = "phoneNumber"
  23. private let kReceiptKey = "iosReceipt"
  24. private let kSecretKey = "iosSecret"
  25. private let kExpectedAPIURL =
  26. "https://www.googleapis.com/identitytoolkit/v3/relyingparty/sendVerificationCode?key=APIKey"
  27. /** @fn testSendVerificationCodeRequest
  28. @brief Tests the sendVerificationCode request with a ReCAPTCHA token.
  29. */
  30. func testSendVerificationCodeRequestReCAPTCHA() async throws {
  31. let request = makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken))
  32. XCTAssertEqual(request.phoneNumber, kTestPhoneNumber)
  33. switch request.codeIdentity {
  34. case let .recaptcha(token):
  35. XCTAssertEqual(token, kTestReCAPTCHAToken)
  36. default:
  37. XCTFail("Should be a reCAPTCHA")
  38. }
  39. try await checkRequest(
  40. request: request,
  41. expected: kExpectedAPIURL,
  42. key: kPhoneNumberKey,
  43. value: kTestPhoneNumber
  44. )
  45. let requestDictionary = try XCTUnwrap(rpcIssuer.decodedRequest as? [String: AnyHashable])
  46. XCTAssertEqual(requestDictionary["recaptchaToken"], kTestReCAPTCHAToken)
  47. }
  48. /** @fn testSendVerificationCodeRequest
  49. @brief Tests the sendVerificationCode request with an App Credential
  50. */
  51. func testSendVerificationCodeRequestCredential() async throws {
  52. let credential = AuthAppCredential(receipt: kTestReceipt, secret: kTestSecret)
  53. let request = makeSendVerificationCodeRequest(CodeIdentity.credential(credential))
  54. XCTAssertEqual(request.phoneNumber, kTestPhoneNumber)
  55. switch request.codeIdentity {
  56. case let .credential(credential):
  57. XCTAssertEqual(credential.secret, kTestSecret)
  58. XCTAssertEqual(credential.receipt, kTestReceipt)
  59. default:
  60. XCTFail("Should be a credential")
  61. }
  62. try await checkRequest(
  63. request: request,
  64. expected: kExpectedAPIURL,
  65. key: kPhoneNumberKey,
  66. value: kTestPhoneNumber
  67. )
  68. let requestDictionary = try XCTUnwrap(rpcIssuer.decodedRequest as? [String: AnyHashable])
  69. XCTAssertEqual(requestDictionary[kReceiptKey], kTestReceipt)
  70. XCTAssertEqual(requestDictionary[kSecretKey], kTestSecret)
  71. }
  72. func testSendVerificationCodeRequestErrors() async throws {
  73. let kInvalidPhoneNumberErrorMessage = "INVALID_PHONE_NUMBER"
  74. let kQuotaExceededErrorMessage = "QUOTA_EXCEEDED"
  75. let kAppNotVerifiedErrorMessage = "APP_NOT_VERIFIED"
  76. let kCaptchaCheckFailedErrorMessage = "CAPTCHA_CHECK_FAILED"
  77. try await checkBackendError(
  78. request: makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken)),
  79. message: kInvalidPhoneNumberErrorMessage,
  80. errorCode: AuthErrorCode.invalidPhoneNumber
  81. )
  82. try await checkBackendError(
  83. request: makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken)),
  84. message: kQuotaExceededErrorMessage,
  85. errorCode: AuthErrorCode.quotaExceeded
  86. )
  87. try await checkBackendError(
  88. request: makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken)),
  89. message: kAppNotVerifiedErrorMessage,
  90. errorCode: AuthErrorCode.appNotVerified
  91. )
  92. try await checkBackendError(
  93. request: makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken)),
  94. message: kCaptchaCheckFailedErrorMessage,
  95. errorCode: AuthErrorCode.captchaCheckFailed
  96. )
  97. }
  98. /** @fn testSuccessfulSendVerificationCodeResponse
  99. @brief This test simulates a successful verify CustomToken flow.
  100. */
  101. func testSuccessfulSendVerificationCodeResponse() async throws {
  102. let kVerificationIDKey = "sessionInfo"
  103. let kFakeVerificationID = "testVerificationID"
  104. rpcIssuer.respondBlock = {
  105. try self.rpcIssuer?.respond(withJSON: [kVerificationIDKey: kFakeVerificationID])
  106. }
  107. let rpcResponse = try await AuthBackend.call(with:
  108. makeSendVerificationCodeRequest(CodeIdentity.recaptcha(kTestReCAPTCHAToken)))
  109. XCTAssertNotNil(rpcResponse)
  110. XCTAssertEqual(rpcResponse.verificationID, kFakeVerificationID)
  111. }
  112. private func makeSendVerificationCodeRequest(_ codeIdentity: CodeIdentity)
  113. -> SendVerificationCodeRequest {
  114. return SendVerificationCodeRequest(phoneNumber: kTestPhoneNumber,
  115. codeIdentity: codeIdentity,
  116. requestConfiguration: makeRequestConfiguration())
  117. }
  118. }