| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- // Copyright 2023 Google LLC
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- import Foundation
- import XCTest
- @testable import FirebaseAuth
- /** @class FIRTwitterAuthProviderTests
- @brief Tests for @c FIRTwitterAuthProvider
- */
- @available(iOS 13, tvOS 13, macOS 10.15, macCatalyst 13, watchOS 7, *)
- class TwitterAuthProviderTests: XCTestCase {
- /** @fn testCredentialWithToken
- @brief Tests the @c credentialWithToken method to make sure the credential it produces populates
- the appropriate fields in a verify assertion request.
- */
- func testCredentialWithToken() {
- let kTwitterToken = "Token"
- let kTwitterSecret = "Secret"
- let requestConfiguration = AuthRequestConfiguration(apiKey: "APIKey", appID: "appID")
- let credential = TwitterAuthProvider.credential(
- withToken: kTwitterToken,
- secret: kTwitterSecret
- )
- let request = VerifyAssertionRequest(providerID: TwitterAuthProvider.id,
- requestConfiguration: requestConfiguration)
- credential.prepare(request)
- XCTAssertEqual(kTwitterToken, request.providerAccessToken)
- XCTAssertEqual(kTwitterSecret, request.providerOAuthTokenSecret)
- }
- /** @fn testTwitterAuthCredentialCoding
- @brief Tests successful archiving and unarchiving of @c TwitterAuthCredential.
- */
- func testTwitterAuthCredentialCoding() throws {
- let kTwitterToken = "Token"
- let kTwitterSecret = "Secret"
- let credential = TwitterAuthProvider.credential(
- withToken: kTwitterToken,
- secret: kTwitterSecret
- )
- XCTAssertTrue(TwitterAuthCredential.supportsSecureCoding)
- let data = try NSKeyedArchiver.archivedData(
- withRootObject: credential,
- requiringSecureCoding: true
- )
- let unarchivedCredential = try XCTUnwrap(NSKeyedUnarchiver.unarchivedObject(
- ofClass: TwitterAuthCredential.self, from: data
- ))
- XCTAssertEqual(unarchivedCredential.token, kTwitterToken)
- XCTAssertEqual(unarchivedCredential.secret, kTwitterSecret)
- }
- }
|