| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- //
- // Copyright 2022 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 XCTest
- @testable import FirebaseSessions
- class IdentifiersTests: XCTestCase {
- var identifiers: Identifiers!
- override func setUp() {
- // Clear all UserDefaults
- if let appDomain = Bundle.main.bundleIdentifier {
- UserDefaults.standard.removePersistentDomain(forName: appDomain)
- }
- identifiers = Identifiers()
- }
- func isValidSessionID(_ sessionID: String) -> Bool {
- if sessionID.count != 32 {
- assertionFailure("Session ID isn't 32 characters long")
- return false
- }
- if sessionID.contains("-") {
- assertionFailure("Session ID contains a dash")
- return false
- }
- if sessionID.lowercased().compare(sessionID) != ComparisonResult.orderedSame {
- assertionFailure("Session ID is not lowercase")
- return false
- }
- return true
- }
- // This test case isn't important behavior. When Crash and Perf integrate
- // with the Sessions SDK, we may want to move to a lazy solution where
- // sessionID can never be empty
- func test_sessionID_beforeGenerateReturnsNothing() throws {
- XCTAssert(identifiers.sessionID.count == 0)
- XCTAssertNil(identifiers.previousSessionID)
- }
- func test_generateNewSessionID_generatesValidID() throws {
- identifiers.generateNewSessionID()
- XCTAssert(isValidSessionID(identifiers.sessionID))
- XCTAssertNil(identifiers.previousSessionID)
- }
- /// Ensures that generating a Session ID multiple times results in the last Session ID being set in the previousSessionID field
- func test_generateNewSessionID_rotatesPreviousID() throws {
- identifiers.generateNewSessionID()
- let firstSessionID = identifiers.sessionID
- XCTAssert(isValidSessionID(identifiers.sessionID))
- XCTAssertNil(identifiers.previousSessionID)
- identifiers.generateNewSessionID()
- XCTAssert(isValidSessionID(identifiers.sessionID))
- XCTAssert(isValidSessionID(identifiers.previousSessionID!))
- // Ensure the new lastSessionID is equal to the sessionID from earlier
- XCTAssertEqual(identifiers.previousSessionID, firstSessionID)
- }
- }
|