TwitterAuthProviderTests.swift 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. /** @class FIRTwitterAuthProviderTests
  18. @brief Tests for @c FIRTwitterAuthProvider
  19. */
  20. @available(iOS 13, tvOS 13, macOS 10.15, macCatalyst 13, watchOS 7, *)
  21. class TwitterAuthProviderTests: XCTestCase {
  22. /** @fn testCredentialWithToken
  23. @brief Tests the @c credentialWithToken method to make sure the credential it produces populates
  24. the appropriate fields in a verify assertion request.
  25. */
  26. func testCredentialWithToken() {
  27. let kTwitterToken = "Token"
  28. let kTwitterSecret = "Secret"
  29. let requestConfiguration = AuthRequestConfiguration(apiKey: "APIKey", appID: "appID")
  30. let credential = TwitterAuthProvider.credential(
  31. withToken: kTwitterToken,
  32. secret: kTwitterSecret
  33. )
  34. let request = VerifyAssertionRequest(providerID: TwitterAuthProvider.id,
  35. requestConfiguration: requestConfiguration)
  36. credential.prepare(request)
  37. XCTAssertEqual(kTwitterToken, request.providerAccessToken)
  38. XCTAssertEqual(kTwitterSecret, request.providerOAuthTokenSecret)
  39. }
  40. /** @fn testTwitterAuthCredentialCoding
  41. @brief Tests successful archiving and unarchiving of @c TwitterAuthCredential.
  42. */
  43. func testTwitterAuthCredentialCoding() throws {
  44. let kTwitterToken = "Token"
  45. let kTwitterSecret = "Secret"
  46. let credential = TwitterAuthProvider.credential(
  47. withToken: kTwitterToken,
  48. secret: kTwitterSecret
  49. )
  50. XCTAssertTrue(TwitterAuthCredential.supportsSecureCoding)
  51. let data = try NSKeyedArchiver.archivedData(
  52. withRootObject: credential,
  53. requiringSecureCoding: true
  54. )
  55. let unarchivedCredential = try XCTUnwrap(NSKeyedUnarchiver.unarchivedObject(
  56. ofClass: TwitterAuthCredential.self, from: data
  57. ))
  58. XCTAssertEqual(unarchivedCredential.token, kTwitterToken)
  59. XCTAssertEqual(unarchivedCredential.secret, kTwitterSecret)
  60. }
  61. }