SignInWithProviderTests.swift 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. // Copyright 2020 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 Combine
  15. import FirebaseAuth
  16. import Foundation
  17. import XCTest
  18. class SignInWithProviderTests: XCTestCase {
  19. override class func setUp() {
  20. FirebaseApp.configureForTests()
  21. }
  22. override class func tearDown() {
  23. FirebaseApp.app()?.delete { success in
  24. if success {
  25. print("Shut down app successfully.")
  26. } else {
  27. print("💥 There was a problem when shutting down the app..")
  28. }
  29. }
  30. }
  31. override func setUp() {
  32. do {
  33. try Auth.auth().signOut()
  34. } catch {}
  35. }
  36. static let apiKey = Credentials.apiKey
  37. static let accessTokenTimeToLive: TimeInterval = 60 * 60
  38. static let refreshToken = "REFRESH_TOKEN"
  39. static let accessToken = "ACCESS_TOKEN"
  40. static let email = "johnnyappleseed@apple.com"
  41. static let password = "secret"
  42. static let localID = "LOCAL_ID"
  43. static let displayName = "Johnny Appleseed"
  44. static let passwordHash = "UkVEQUNURUQ="
  45. static let oAuthSessionID = "sessionID"
  46. static let oAuthRequestURI = "requestURI"
  47. static let googleID = "GOOGLE_ID"
  48. static let googleDisplayName = "Google Doe"
  49. static let googleEmail = "user@gmail.com"
  50. class MockAuthProvider: OAuthProvider {
  51. static func provider(with providerID: String) -> OAuthProvider {
  52. super.init(providerID: providerID)
  53. }
  54. override func getCredentialWith(_ UIDelegate: AuthUIDelegate?,
  55. completion: ((AuthCredential?, Error?) -> Void)? = nil) {
  56. guard let completion = completion else { return }
  57. let credential = OAuthCredential(providerID: GoogleAuthProvider.id,
  58. sessionID: SignInWithProviderTests.oAuthSessionID,
  59. oAuthResponseURLString: SignInWithProviderTests
  60. .oAuthRequestURI)
  61. completion(credential, nil)
  62. }
  63. }
  64. class MockVerifyAssertionResponse: FIRVerifyAssertionResponse {
  65. override var federatedID: String? { return SignInWithProviderTests.googleID }
  66. override var providerID: String? { return GoogleAuthProvider.id }
  67. override var localID: String? { return SignInWithProviderTests.localID }
  68. override var displayName: String? { return SignInWithProviderTests.displayName }
  69. override var idToken: String { return EmailPasswordAuthTests.accessToken }
  70. override var refreshToken: String { return EmailPasswordAuthTests.refreshToken }
  71. override var approximateExpirationDate: Date {
  72. Date(timeIntervalSinceNow: EmailPasswordAuthTests.accessTokenTimeToLive)
  73. }
  74. }
  75. class MockGetAccountInfoResponseProviderUserInfo: FIRGetAccountInfoResponseProviderUserInfo {
  76. override var providerID: String? { return GoogleAuthProvider.id }
  77. override var displayName: String? { return SignInWithProviderTests.googleDisplayName }
  78. override var federatedID: String? { return SignInWithProviderTests.googleID }
  79. override var email: String? { return SignInWithProviderTests.googleEmail }
  80. }
  81. class MockGetAccountInfoResponseUser: FIRGetAccountInfoResponseUser {
  82. override var localID: String? { return SignInWithProviderTests.localID }
  83. override var displayName: String { return SignInWithProviderTests.displayName }
  84. override var providerUserInfo: [FIRGetAccountInfoResponseProviderUserInfo]? {
  85. return [MockGetAccountInfoResponseProviderUserInfo(dictionary: [:])]
  86. }
  87. }
  88. class MockGetAccountInfoResponse: FIRGetAccountInfoResponse {
  89. override var users: [FIRGetAccountInfoResponseUser] {
  90. return [MockGetAccountInfoResponseUser(dictionary: [:])]
  91. }
  92. }
  93. class MockAuthBackend: AuthBackendImplementationMock {
  94. override func verifyAssertion(_ request: FIRVerifyAssertionRequest,
  95. callback: @escaping FIRVerifyAssertionResponseCallback) {
  96. XCTAssertEqual(request.apiKey, EmailPasswordAuthTests.apiKey)
  97. XCTAssertEqual(request.providerID, GoogleAuthProvider.id)
  98. XCTAssertTrue(request.returnSecureToken)
  99. let response = MockVerifyAssertionResponse()
  100. callback(response, nil)
  101. }
  102. override func getAccountInfo(_ request: FIRGetAccountInfoRequest,
  103. callback: @escaping FIRGetAccountInfoResponseCallback) {
  104. XCTAssertEqual(request.apiKey, SignInWithProviderTests.apiKey)
  105. XCTAssertEqual(request.accessToken, SignInWithProviderTests.accessToken)
  106. let response = MockGetAccountInfoResponse()
  107. callback(response, nil)
  108. }
  109. }
  110. func testSignInUserWithEmailAndPassword() {
  111. // given
  112. FIRAuthBackend.setBackendImplementation(MockAuthBackend())
  113. let authProvider = MockAuthProvider.provider(with: "mockProvider")
  114. var cancellables = Set<AnyCancellable>()
  115. let userSignInExpectation = expectation(description: "User signed in")
  116. // when
  117. Auth.auth()
  118. .signIn(with: authProvider, uiDelegate: nil)
  119. .sink { completion in
  120. switch completion {
  121. case .finished:
  122. print("Finished")
  123. case let .failure(error):
  124. XCTFail("💥 Something went wrong: \(error)")
  125. }
  126. } receiveValue: { authDataResult in
  127. let user = authDataResult.user
  128. XCTAssertNotNil(user)
  129. XCTAssertEqual(user.uid, SignInWithProviderTests.localID)
  130. XCTAssertEqual(user.displayName, SignInWithProviderTests.displayName)
  131. XCTAssertEqual(user.providerData.count, 1)
  132. let userInfo = user.providerData[0]
  133. XCTAssertEqual(userInfo.providerID, GoogleAuthProvider.id)
  134. XCTAssertEqual(userInfo.uid, SignInWithProviderTests.googleID)
  135. XCTAssertEqual(userInfo.displayName, SignInWithProviderTests.googleDisplayName)
  136. XCTAssertEqual(userInfo.email, SignInWithProviderTests.googleEmail)
  137. userSignInExpectation.fulfill()
  138. }
  139. .store(in: &cancellables)
  140. // then
  141. wait(for: [userSignInExpectation], timeout: expectationTimeout)
  142. }
  143. }