|
| 1 | +import XCTest |
| 2 | + |
| 3 | +@testable import BitwardenShared |
| 4 | + |
| 5 | +class FlightRecorderDataTests: BitwardenTestCase { |
| 6 | + // MARK: Tests |
| 7 | + |
| 8 | + /// `allLogs` returns a list of all logs when there are no logs. |
| 9 | + func test_allLogs_empty() { |
| 10 | + let subject = FlightRecorderData() |
| 11 | + XCTAssertEqual(subject.allLogs, []) |
| 12 | + } |
| 13 | + |
| 14 | + /// `allLogs` returns a list of all logs when there's active and archived logs. |
| 15 | + func test_allLogs_activeAndArchivedLogs() { |
| 16 | + let activeLog = FlightRecorderData.LogMetadata(duration: .eightHours, startDate: .now) |
| 17 | + let archivedLogs = [ |
| 18 | + FlightRecorderData.LogMetadata(duration: .oneHour, startDate: .now), |
| 19 | + FlightRecorderData.LogMetadata(duration: .oneWeek, startDate: .now), |
| 20 | + ] |
| 21 | + let subject = FlightRecorderData(activeLog: activeLog, archivedLogs: archivedLogs) |
| 22 | + XCTAssertEqual(subject.allLogs, [activeLog] + archivedLogs) |
| 23 | + } |
| 24 | + |
| 25 | + /// `allLogs` returns a list of all logs when there's an active log. |
| 26 | + func test_allLogs_activeLog() { |
| 27 | + let log = FlightRecorderData.LogMetadata(duration: .eightHours, startDate: .now) |
| 28 | + let subject = FlightRecorderData(activeLog: log) |
| 29 | + XCTAssertEqual(subject.allLogs, [log]) |
| 30 | + } |
| 31 | + |
| 32 | + /// `allLogs` returns a list of all logs when there are archived logs. |
| 33 | + func test_allLogs_archivedLogs() { |
| 34 | + let logs = [ |
| 35 | + FlightRecorderData.LogMetadata(duration: .eightHours, startDate: .now), |
| 36 | + FlightRecorderData.LogMetadata(duration: .oneHour, startDate: .now), |
| 37 | + FlightRecorderData.LogMetadata(duration: .oneWeek, startDate: .now), |
| 38 | + ] |
| 39 | + let subject = FlightRecorderData(archivedLogs: logs) |
| 40 | + XCTAssertEqual(subject.allLogs, logs) |
| 41 | + } |
| 42 | + |
| 43 | + /// `activeLog` sets the active log. |
| 44 | + func test_setActiveLog() { |
| 45 | + var subject = FlightRecorderData() |
| 46 | + let log = FlightRecorderData.LogMetadata(duration: .eightHours, startDate: .now) |
| 47 | + subject.activeLog = log |
| 48 | + |
| 49 | + XCTAssertEqual(subject, FlightRecorderData(activeLog: log)) |
| 50 | + } |
| 51 | + |
| 52 | + /// `activeLog` sets the active log, archiving an existing log if there's already one active. |
| 53 | + func test_setActiveLog_existingLog() { |
| 54 | + let log1 = FlightRecorderData.LogMetadata(duration: .eightHours, startDate: .now) |
| 55 | + var subject = FlightRecorderData(activeLog: log1) |
| 56 | + |
| 57 | + let log2 = FlightRecorderData.LogMetadata(duration: .oneWeek, startDate: .now) |
| 58 | + subject.activeLog = log2 |
| 59 | + |
| 60 | + XCTAssertEqual(subject, FlightRecorderData(activeLog: log2, archivedLogs: [log1])) |
| 61 | + } |
| 62 | + |
| 63 | + // MARK: FlightRecorderData.LogMetadata Tests |
| 64 | + |
| 65 | + /// `id` returns the log's file name as a unique identifier. |
| 66 | + func test_logMetadata_id() { |
| 67 | + let log1 = FlightRecorderData.LogMetadata(duration: .oneHour, startDate: .now) |
| 68 | + XCTAssertEqual(log1.id, log1.fileName) |
| 69 | + |
| 70 | + let log2 = FlightRecorderData.LogMetadata(duration: .oneWeek, startDate: .now) |
| 71 | + XCTAssertEqual(log2.id, log2.fileName) |
| 72 | + } |
| 73 | + |
| 74 | + /// `init(duration:startDate:)` creates a file name for the log based on the start date. |
| 75 | + func test_logMetadata_init_fileName() { |
| 76 | + let log1 = FlightRecorderData.LogMetadata( |
| 77 | + duration: .oneHour, |
| 78 | + startDate: Date(year: 2025, month: 4, day: 11, hour: 10, minute: 30, second: 20) |
| 79 | + ) |
| 80 | + XCTAssertEqual(log1.fileName, "flight_recorder_2025-04-11-10-30-20.txt") |
| 81 | + |
| 82 | + let log2 = FlightRecorderData.LogMetadata( |
| 83 | + duration: .oneWeek, |
| 84 | + startDate: Date(year: 2025, month: 1, day: 2, hour: 3, minute: 4, second: 5) |
| 85 | + ) |
| 86 | + XCTAssertEqual(log2.fileName, "flight_recorder_2025-01-02-03-04-05.txt") |
| 87 | + } |
| 88 | +} |
0 commit comments