๐Ÿงช Palace iOS Test Report

Generated: 2026-06-10 19:50:52 UTC | Commit: 4a81d7ae6a18 | Branch: fix/pp4542-regression-test-coverage

โŒ 1 TEST(S) FAILED

7151 tests completed in 17m 5s

7151
Total Tests
7047
Passed
1
Failed
103
Skipped
17m 5s
Duration
45.6%
Coverage

โŒ Failed Tests

โŒ TokenRefreshAndRetryQueueTests.First Run

Duration: 713ms

๐Ÿ“Š Tests by Class

Class Total Passed Failed Duration
โœ… AccessLintComplianceTests 11 11 0 23ms
โœ… AccessibilityAnnouncementCenterTests 20 20 0 1.63s
โœ… AccessibilityLabelTests 9 9 0 31ms
โœ… AccessibilityPreferencesTests 26 26 0 224ms
โœ… AccessibilityServiceTests 11 11 0 101ms
โœ… AccountAuthDocCarryoverTests 5 5 0 1.48s
โœ… AccountAuthSurfaceHostsTests 7 7 0 103ms
โœ… AccountAwareNetworkTests 10 10 0 264ms
โœ… AccountDetailCredentialStateTests 7 0 0 120ms
โœ… AccountDetailPINVisibilityTests 25 0 0 538ms
โœ… AccountDetailSignOutConfirmationTests 2 0 0 63ms
โœ… AccountDetailViewModelGapTests 1 1 0 109ms
โœ… AccountDetailViewModelTests 19 0 0 301ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests 10 10 0 84ms
โœ… AccountDetailsNeedsAuthAggregateTests 10 10 0 48ms
โœ… AccountDetailsURLTests 17 17 0 132ms
โœ… AccountModelGapTests 9 9 0 1.82s
โœ… AccountModelTests 20 20 0 4.28s
โœ… AccountProfileDocumentTests 3 3 0 23ms
โœ… AccountStateMachineTests 10 10 0 1.31s
โœ… AccountSwitchCleanupTests 8 8 0 310ms
โœ… AccountSwitchIntegrationTests 8 8 0 140ms
โœ… AccountSwitchLifecycleTests 9 0 0 177ms
โœ… AccountsManagerCacheTests 16 16 0 2.91s
โœ… AccountsManagerCancellationTests 5 5 0 596ms
โœ… AccountsManagerGapTests 3 3 0 19ms
โœ… AccountsManagerHelpersTests 12 12 0 31ms
โœ… AccountsManagerIsolationLintTests 2 2 0 1.11s
โœ… AccountsManagerStateMachineWiringTests 13 13 0 4.53s
โœ… AccountsManagerTests 51 50 0 1m 42s
โœ… ActiveSessionsViewModelTests 12 12 0 302ms
โœ… AdobeActivationTests 6 6 0 32ms
โœ… AdobeCertificateGapTests 7 7 0 38ms
โœ… AdobeDRMCharacterizationTests 21 21 0 72ms
โœ… AdobeDRMErrorGapTests 3 3 0 15ms
โœ… AdobeDRMHandlerTests 12 12 0 87ms
โœ… AdobeDRMServiceGapTests 2 2 0 5ms
โœ… AlertModelCoverageTests 6 6 0 24ms
โœ… AlertModelRetryTests 7 7 0 26ms
โœ… AlertModelTests 2 2 0 6ms
โœ… AlertUtilsTests 20 20 0 1.46s
โœ… AnnotationContractTests 3 3 0 31ms
โœ… AnnotationDeviceIDTests 2 2 0 16ms
โœ… AnnotationPostResponseContractTests 1 1 0 10ms
โœ… AnnouncementChainTests 5 5 0 118ms
โœ… AnnouncementTests 3 3 0 10ms
โœ… AnonymousBorrowBaselineFixtureTests 13 13 0 133ms
โœ… AnonymousBorrowCandidateFixtureTests 6 6 0 42ms
โœ… AnonymousBorrowDeltaTests 2 2 0 15ms
โœ… AppContainerAudiobookFactoryTests 3 3 0 7ms
โœ… AppContainerAuthCoordinatorRegistrationTests 3 3 0 7ms
โœ… AppContainerImageLoaderInjectionTests 4 4 0 75ms
โœ… AppContainerIsolationLintTests 5 5 0 2.00s
โœ… AppContainerResetTests 4 4 0 64ms
โœ… AppContainerTests 4 4 0 19ms
โœ… AppContainerWithSignInModalSheetPresenterTests 2 2 0 15ms
โœ… AppHealthViewModelTests 8 8 0 1.39s
โœ… AppLaunchTrackerExtendedTests 16 16 0 437ms
โœ… AppLaunchTrackerTests 10 10 0 391ms
โœ… AppRouteTests 5 5 0 20ms
โœ… AppTabHostMiniPlayerIntegrationTests 6 6 0 379ms
โœ… AppTabHostViewBadgeCountTests 10 10 0 116ms
โœ… AppTabRouterCoverageTests 4 4 0 14ms
โœ… AppTabRouterGapTests 3 3 0 12ms
โœ… ArrayExtensionsTests 6 6 0 22ms
โœ… AudioBookmarkGapTests 6 6 0 567ms
โœ… AudioEngineWrapperTests 8 8 0 213ms
โœ… AudioInterruptionLogicTests 6 6 0 39ms
โœ… AudiobookAccessibilityTests 7 7 0 56ms
โœ… AudiobookBackgroundAudioTests 2 2 0 41ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests 6 6 0 1m 11s
โœ… AudiobookBookmarkBusinessLogicTests 21 21 0 4.23s
โœ… AudiobookChapterTOCNormalizationTests 6 6 0 17ms
โœ… AudiobookCrossVendorSmokeTests 4 4 0 143ms
โœ… AudiobookDataManagerEmptyQueueTests 1 1 0 13ms
โœ… AudiobookDataManagerErrorHandlingTests 5 5 0 10.40s
โœ… AudiobookDataManagerModelsTests 20 20 0 107ms
โœ… AudiobookDataManagerNetworkSyncTests 5 5 0 5.22s
โœ… AudiobookDataManagerSaveTests 4 4 0 75ms
โœ… AudiobookDataManagerStoreRecoveryTests 5 5 0 2.38s
โœ… AudiobookFileLoggerTests 14 14 0 438ms
โœ… AudiobookFirstOpenHangTests 5 5 0 5.38s
โœ… AudiobookFullPlayerCoverContainerTests 9 9 0 174ms
โœ… AudiobookLoadFailureSAMLReauthTests 10 10 0 862ms
โœ… AudiobookLoaderDispatchTests 7 7 0 313ms
โœ… AudiobookLoaderFinalizeBuildTests 9 9 0 369ms
โœ… AudiobookLoaderOPDSShapeMatrixTests 5 5 0 171ms
โœ… AudiobookLoaderPredicateTests 11 11 0 95ms
โœ… AudiobookLoaderTests 2 2 0 179ms
โœ… AudiobookMiniPlayerViewTests 13 13 0 182ms
โœ… AudiobookNetworkValidationTests 3 3 0 20ms
โœ… AudiobookOpenStateRaceTests 3 3 0 557ms
โœ… AudiobookPhoneAlertContentTests 3 3 0 29ms
โœ… AudiobookPlaybackStateTests 3 3 0 84ms
โœ… AudiobookPlaybackTests 26 26 0 496ms
โœ… AudiobookPlaytimesLifecycleTests 6 6 0 1.96s
โœ… AudiobookPositionAdapterContractTests 3 3 0 136ms
โœ… AudiobookPositionPolicyValidatorTests 14 14 0 24ms
โœ… AudiobookPositionRestoreTests 11 11 0 1.56s
โœ… AudiobookSAMLReauthTests 6 6 0 108ms
โœ… AudiobookSessionErrorDescriptionTests 4 4 0 16ms
โœ… AudiobookSessionErrorExtTests 4 4 0 19ms
โœ… AudiobookSessionErrorTests 2 2 0 8ms
โœ… AudiobookSessionManagerErrorMappingTests 6 6 0 24ms
โœ… AudiobookSessionManagerFlagGatePresentationTests 4 4 0 6.20s
โœ… AudiobookSessionManagerPresenterMigrationTests 8 8 0 2.96s
โœ… AudiobookSessionManagerShutdownTests 8 8 0 207ms
โœ… AudiobookSessionPresenterTests 16 16 0 815ms
โœ… AudiobookSessionStateTests 6 6 0 57ms
โœ… AudiobookSessionStateTransitionTests 18 18 0 49.62s
โœ… AudiobookSleepTimerIntegrationTests 5 5 0 466ms
โœ… AudiobookStorageLocationTests 3 3 0 11ms
โœ… AudiobookTOCTests 18 18 0 2.57s
โœ… AudiobookTimeEntryTests 6 6 0 24ms
โœ… AudiobookTimeTrackerEdgeTests 8 8 0 148ms
โœ… AudiobookTimeTrackerLifecycleTests 5 5 0 1.09s
โœ… AudiobookTimeTrackerTests 9 9 0 163ms
โœ… AudiobookTrackCompletionTests 2 2 0 45ms
โœ… AudiobookTypeRoutingTests 5 5 0 870ms
โœ… AudiobookVendorAdapterTests 5 5 0 48ms
โœ… AudiobookmarkTests 4 4 0 25ms
โœ… AuthCoordinatorTelemetryTests 5 5 0 68ms
โœ… AuthDecisionEventEmissionTests 7 7 0 49ms
โœ… AuthDocumentContractTests 2 2 0 39ms
โœ… AuthDocumentVariantsContractTests 5 5 0 30ms
โœ… AuthErrorCategoryTests 12 12 0 39ms
โœ… AuthErrorProblemDocSeamTests 6 6 0 40ms
โœ… AuthFlowSecurityTests 3 0 0 392ms
โœ… AuthReducerTests 21 21 0 103ms
โœ… AuthTypeTests 7 7 0 48ms
โœ… AuthenticationTests 16 16 0 4.12s
โœ… BackgroundDownloadHandlerTests 28 28 0 228ms
โœ… BackgroundListenerTests 2 2 0 96ms
โœ… BackupExclusionMigrationTests 3 3 0 27ms
โœ… BadgeDefinitionTests 33 33 0 271ms
โœ… BadgeServiceTests 16 16 0 301ms
โœ… BadgesViewModelTests 14 14 0 323ms
โœ… BasicAuthEmptyCredentialTests 4 4 0 11ms
โœ… BearerTokenAdapterTests 5 4 0 67ms
โœ… BearerTokenFulfillFlowTests 4 4 0 39ms
โœ… BearerTokenRefreshTests 4 4 0 391ms
โœ… BearerTokenResponseDetectionTests 7 7 0 43ms
โœ… BeginningPositionPolicyTests 8 8 0 467ms
โœ… BookAvailabilityFormatterTests 18 18 0 76ms
โœ… BookButtonMapperHoldReadyTests 10 10 0 31ms
โœ… BookButtonMapperTests 21 21 0 118ms
โœ… BookButtonMapperViewModelTests 18 18 0 70ms
โœ… BookButtonStateTests 8 8 0 83ms
โœ… BookButtonTypeMetaTests 4 4 0 35ms
โœ… BookButtonTypeTests 13 13 0 100ms
โœ… BookCellModelActionTests 18 18 0 811ms
โœ… BookCellModelCacheInvalidationTests 8 8 0 96ms
โœ… BookCellModelCachePrefetchSafetyTests 9 9 0 485ms
โœ… BookCellModelCacheTests 22 22 0 30.11s
โœ… BookCellModelComputedPropertyTests 19 19 0 500ms
โœ… BookCellModelOfflineTests 9 9 0 421ms
โœ… BookCellModelRegistryBindingTests 4 4 0 354ms
โœ… BookCellModelStateTests 16 16 0 413ms
โœ… BookCellModelStreamingHTMLTests 2 2 0 135ms
โœ… BookCellStateComprehensiveTests 14 14 0 365ms
โœ… BookContentResetServiceTests 2 2 0 44ms
โœ… BookDetailMetadataHydrationTests 6 6 0 8.66s
โœ… BookDetailViewModelTests 87 87 0 1.65s
โœ… BookFileManagerTests 8 8 0 59ms
โœ… BookListViewAccessibilityTests 9 9 0 61ms
โœ… BookPreviewTests 4 4 0 19ms
โœ… BookRegistryStoreTests 26 26 0 914ms
โœ… BookRegistrySyncReadinessTests 3 2 0 619ms
โœ… BookRegistrySyncTests 24 22 0 397ms
โœ… BookReturnCleverReauthTests 1 1 0 18ms
โœ… BookReturnServiceAuthCoordinatorTests 3 3 0 927ms
โœ… BookReturnServiceContractTests 5 5 0 5.10s
โœ… BookReturnServiceTests 14 14 0 901ms
โœ… BookSignInRedirectHandlerTests 8 8 0 288ms
โœ… BookStateIntegrationTests 8 8 0 75ms
โœ… BookmarkBusinessLogicExtendedTests 6 6 0 778ms
โœ… BookmarkDeletionLogTests 3 3 0 640ms
โœ… BookmarkDeviceIdMatchingTests 3 3 0 294ms
โœ… BookmarkExistenceTests 4 4 0 422ms
โœ… BookmarkManagerTests 24 24 0 706ms
โœ… BookmarkSortingTests 1 1 0 192ms
โœ… BookmarkSyncTests 3 3 0 318ms
โœ… BorrowAndDownloadIntegrationTests 7 7 0 322ms
โœ… BorrowErrorMessageTests 13 13 0 77ms
โœ… BorrowErrorPresenterTests 6 6 0 535ms
โœ… BorrowOperationAuthCoordinatorTests 6 6 0 7.22s
โœ… BorrowOperationCleverReauthTests 2 2 0 347ms
โœ… BorrowOperationContractTests 6 6 0 511ms
โœ… BorrowOperationStreamingHTMLTests 3 3 0 1.55s
โœ… BorrowOperationTests 13 13 0 2.03s
โœ… BorrowOperationTimeoutTests 3 3 0 159ms
โœ… BorrowReducerContractTests 2 2 0 20ms
โœ… BorrowReducerTests 21 21 0 126ms
โœ… BundledRegistrySnapshotTests 5 5 0 625ms
โœ… ButtonStateTests 16 16 0 407ms
โœ… ButtonStyleTypeTests 2 2 0 6ms
โœ… C64ConversionTests 6 6 0 21ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests 2 2 0 216ms
โœ… CarPlayAuthHelperReadinessTests 3 3 0 1.19s
โœ… CarPlayChapterListTests 3 3 0 20ms
โœ… CarPlayIntegrationTests 2 2 0 15ms
โœ… CarPlayLibraryRefreshTests 3 3 0 18ms
โœ… CarPlayNowPlayingTemplateTests 4 4 0 529ms
โœ… CarPlayOpenAppAlertTests 4 4 0 12ms
โœ… CarPlayPlaybackErrorTests 8 8 0 33ms
โœ… CarPlayTests 12 12 0 1.92s
โœ… CarPlayTimeTrackingTests 3 3 0 112ms
โœ… CatalogAPIDedupeTests 3 3 0 449ms
โœ… CatalogAPIEntryPointTests 1 1 0 16ms
โœ… CatalogAccessibilityTests 8 8 0 21ms
โœ… CatalogCacheKeyAndIsolationTests 12 12 0 258ms
โœ… CatalogCacheMetadataExactBoundaryTests 4 4 0 25ms
โœ… CatalogCacheMetadataTests 21 21 0 76ms
โœ… CatalogFeedModelTests 4 4 0 103ms
โœ… CatalogFilterGroupModelTests 17 17 0 147ms
โœ… CatalogFilterModelTests 17 17 0 36ms
โœ… CatalogFilterServiceTests 29 29 0 88ms
โœ… CatalogFilterTests 1 1 0 3ms
โœ… CatalogLaneAssemblyTests 7 7 0 20ms
โœ… CatalogLaneModelStructTests 18 18 0 1.34s
โœ… CatalogLaneModelTests 1 1 0 3ms
โœ… CatalogLaneMoreFilterStateTests 8 8 0 87ms
โœ… CatalogLaneMoreViewModelTests 42 42 0 776ms
โœ… CatalogLaneRowViewAccessibilityTests 11 11 0 1.17s
โœ… CatalogLaneSortingTests 4 4 0 97ms
โœ… CatalogLoadIntegrationTests 6 6 0 60ms
โœ… CatalogOPDS2NegotiationTests 12 12 0 94ms
โœ… CatalogPreloaderTests 6 6 0 74ms
โœ… CatalogProblemDocumentTests 6 6 0 121ms
โœ… CatalogRepositoryCoreTests 9 9 0 349ms
โœ… CatalogRepositoryStaleWhileRevalidateTests 12 12 0 467ms
โœ… CatalogRepositoryTests 19 19 0 260ms
โœ… CatalogSearchViewModelRegistryUpdateTests 5 5 0 210ms
โœ… CatalogSearchViewModelTests 67 67 0 7.56s
โœ… CatalogSelectorsTests 2 2 0 16ms
โœ… CatalogSortServiceTests 14 14 0 143ms
โœ… CatalogStateTests 7 7 0 66ms
โœ… CatalogViewContinueRowsIntegrationTests 3 3 0 32ms
โœ… CatalogViewModelStateMachineTests 10 10 0 109ms
โœ… ChaosFaultInjectionTests 5 5 0 53ms
โœ… ChapterChangeDetectorTests 5 5 0 62ms
โœ… ChapterTOCNormalizerTests 7 7 0 49ms
โœ… CirculationAnalyticsTests 4 4 0 41ms
โœ… ColdStartResumeIntegrationTests 10 10 0 1.05s
โœ… ColorExtensionTests 5 5 0 27ms
โœ… ConcurrentBookStateTests 3 3 0 64ms
โœ… ConcurrentDownloadStateTests 3 3 0 65ms
โœ… ConcurrentTokenRefreshTests 2 2 0 97ms
โœ… ContinueRowSectionTests 6 6 0 60ms
โœ… ContinuousPlaybackTrackingTests 3 3 0 921ms
โœ… CookiePersistenceTests 10 10 0 965ms
โœ… CrawlStateTests 16 16 0 62ms
โœ… CrawlableFeedAnalysisTests 17 17 0 119ms
โœ… CrawlerFallbackTests 12 12 0 766ms
โœ… CredentialEdgeCaseTests 6 6 0 17ms
โœ… CredentialPrivacyTests 4 4 0 19ms
โœ… CredentialPromptCoordinatorTests 4 4 0 368ms
โœ… CrossDeviceBookmarkSyncTests 12 12 0 106ms
โœ… CrossDeviceSyncE2ETests 5 5 0 1.76s
โœ… CrossDomain401Tests 8 8 0 25ms
โœ… CrossFormatMappingTests 14 14 0 52ms
โœ… DPLAErrorTests 3 3 0 12ms
โœ… DRMAdversarialTests 4 1 0 153ms
โœ… DRMFulfilledPublicationTests 6 6 0 34ms
โœ… DataBase64Tests 3 3 0 14ms
โœ… DataReceptionComparisonTests 2 2 0 53ms
โœ… DateExtensionTests 9 9 0 26ms
โœ… DateFormattingTests 4 4 0 17ms
โœ… Date_NYPLAdditionsTests 7 7 0 520ms
โœ… DebugSettingsTests 27 27 0 167ms
โœ… DefaultCatalogAPITests 31 31 0 366ms
โœ… DefaultRecentlyReadingServiceTests 12 12 0 87ms
โœ… DeriveInitialStateTests 4 4 0 52ms
โœ… DeveloperSettingsTierTests 4 4 0 23ms
โœ… DeviceLogCollectorGapTests 2 2 0 12.77s
โœ… DeviceLogCollectorTests 9 9 0 47.85s
โœ… DeviceOrientationTests 7 7 0 29ms
โœ… DeviceSpecificErrorMonitorTests 11 11 0 219ms
โœ… DictionaryExtensionsTests 5 5 0 23ms
โœ… DiskBudgetManagerTests 7 7 0 35ms
โœ… DiskBudgetTests 2 2 0 22ms
โœ… DownloadAlertPresenterTests 8 8 0 767ms
โœ… DownloadAnnouncementServiceTests 12 12 0 135ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests 6 6 0 2.64s
โœ… DownloadAuthRetryHandlerTaskLifecycleTests 4 4 0 401ms
โœ… DownloadAuthRetryHandlerTests 17 17 0 2.49s
โœ… DownloadCancellationHandlerTests 5 5 0 297ms
โœ… DownloadCompletionParserTests 9 9 0 184ms
โœ… DownloadCoordinatorIntegrationTests 10 10 0 1.07s
โœ… DownloadCoordinatorTests 11 11 0 529ms
โœ… DownloadDiskSpaceTests 2 2 0 10ms
โœ… DownloadErrorInfoTests 3 3 0 50ms
โœ… DownloadErrorRecoveryPolicyTests 11 11 0 164ms
โœ… DownloadErrorRecoveryTests 3 3 0 27ms
โœ… DownloadFreeSpaceExhaustionTests 11 11 0 85ms
โœ… DownloadInfoTests 5 5 0 20ms
โœ… DownloadIntegrityTests 10 10 0 228ms
โœ… DownloadOnlyOnWiFiTests 10 10 0 77ms
โœ… DownloadPersistenceStoreTests 5 5 0 58ms
โœ… DownloadProgressPublisherCoreTests 19 19 0 732ms
โœ… DownloadProgressPublisherTests 2 2 0 14ms
โœ… DownloadQueueIntegrationTests 3 3 0 73ms
โœ… DownloadQueueOrchestratorTests 9 9 0 481ms
โœ… DownloadRMSDKHandoffTests 1 1 0 2ms
โœ… DownloadRedirectTests 7 7 0 24ms
โœ… DownloadResumeAfterKillTests 7 7 0 160ms
โœ… DownloadSlotManagementTests 5 5 0 2.37s
โœ… DownloadStartCoordinatorContractTests 5 5 0 129ms
โœ… DownloadStartCoordinatorTests 9 9 0 274ms
โœ… DownloadStartDispatcherTests 26 26 0 675ms
โœ… DownloadStateMachineIntegrationTests 15 15 0 164ms
โœ… DownloadStateMachineTests 5 5 0 30ms
โœ… DownloadStateManagerTests 16 16 0 151ms
โœ… DownloadTaskLifecycleServiceTests 9 9 0 2.38s
โœ… DownloadThrottlingServiceTests 10 10 0 478ms
โœ… DownloadWatchdogTests 3 3 0 200ms
โœ… EPUBKeyCommandsPP4289Tests 4 4 0 53ms
โœ… EPUBModuleTests 4 4 0 43ms
โœ… EPUBPositionTests 10 10 0 171ms
โœ… EPUBSearchViewModelTests 18 18 0 165ms
โœ… EPUBToolbarToggleTests 11 11 0 87ms
โœ… EmailAddressTests 16 16 0 123ms
โœ… EpubSampleFactoryTests 5 5 0 27ms
โœ… ErrorActivityTrackerTests 12 12 0 76ms
โœ… ErrorDetailTests 12 12 0 125ms
โœ… ErrorDetailViewControllerGapTests 3 3 0 227ms
โœ… ErrorDetailViewControllerTests 14 14 0 119ms
โœ… ErrorLogExporterTests 5 5 0 101ms
โœ… ExpiredLoanStringsTests 5 5 0 1.58s
โœ… FacetEnumTests 3 3 0 10ms
โœ… FacetToolbarAccessibilityTests 5 5 0 23ms
โœ… FacetViewModelLogoDelegateTests 4 4 0 23ms
โœ… FacetViewModelTests 18 18 0 15.11s
โœ… FetchManifestWithBearerTokenLCPSafetyTests 1 1 0 41ms
โœ… FetchManifestWithBearerTokenTests 9 9 0 158ms
โœ… FetchOpenAccessManifestLCPSafetyTests 4 4 0 17ms
โœ… FileURLGenerationTests 3 3 0 30ms
โœ… FindawayChapterStatusGuardTests 1 1 0 16ms
โœ… FloatTPPAdditionsTests 5 5 0 25ms
โœ… FocusIndicationTests 7 7 0 69ms
โœ… FontManagerTests 17 17 0 130ms
โœ… ForceResetTests 6 6 0 67ms
โœ… GeneralCacheTests 20 20 0 320ms
โœ… GroupEnumTests 1 1 0 29ms
โœ… HTMLTextViewTests 70 70 0 28.89s
โœ… HoldNotificationClassificationTests 2 2 0 7ms
โœ… HoldsBadgeCountTests 9 9 0 58ms
โœ… HoldsBookViewModelTests 8 8 0 192ms
โœ… HoldsReducerTests 11 11 0 202ms
โœ… HoldsSyncFailureTests 12 12 0 569ms
โœ… HoldsViewModelTests 23 23 0 1.30s
โœ… ImageCacheContinuationTests 1 1 0 242ms
โœ… ImageCacheTypeTests 1 1 0 4ms
โœ… ImageLoaderTests 11 11 0 211ms
โœ… IntExtensionsTests 4 4 0 40ms
โœ… IsReaderActiveTrackingModifierTests 4 4 0 589ms
โœ… KeyboardNavigationFKATests 11 11 0 114ms
โœ… KeyboardNavigationHandlerTests 16 16 0 114ms
โœ… KeyboardVoiceOverTests 5 5 0 30ms
โœ… LCPAcquisitionPredicateTests 4 4 0 24ms
โœ… LCPAdapterTests 8 8 0 118ms
โœ… LCPAudiobookURLSchemeTests 4 4 0 11ms
โœ… LCPAudiobooksTests 21 21 0 145ms
โœ… LCPBotanCRLGuardTests 5 5 0 62ms
โœ… LCPCharacterizationTests 31 31 0 193ms
โœ… LCPClientTests 8 8 0 45ms
โœ… LCPFulfillmentHandlerTests 8 8 0 749ms
โœ… LCPKeychainMigrationTests 3 3 0 50ms
โœ… LCPLibraryServiceTests 20 20 0 225ms
โœ… LCPLicenseDocumentDetectionTests 5 5 0 20ms
โœ… LCPLicenseFilePathTests 3 3 0 16ms
โœ… LCPOrphanedDownloadRegistryTests 4 4 0 36ms
โœ… LCPPDFAcquisitionPredicateTests 5 5 0 19ms
โœ… LCPPDFDiskExtractTests 5 5 0 89ms
โœ… LCPPDFOpenProgressTests 13 13 0 281ms
โœ… LCPPassphraseReadinessTests 2 2 0 12ms
โœ… LCPSessionIdentifierTests 3 3 0 33ms
โœ… LegacySAMLProblemDocumentPropagationTests 7 7 0 1.05s
โœ… LibrariesSectionViewModelTests 11 11 0 50ms
โœ… LibraryCatalogMergerTests 9 9 0 84ms
โœ… LibraryRegistryCrawlerTests 14 14 0 153ms
โœ… LicensesServiceTests 4 4 0 19ms
โœ… LiveCrawlableParsingTest 4 0 0 28ms
โœ… LocalBookContentServiceTests 7 7 0 221ms
โœ… LocalFileAdapterTests 6 5 0 85ms
โœ… LogTests 14 14 0 388ms
โœ… LoginKeyboardTests 8 8 0 148ms
โœ… MainActorHelpersTests 22 22 0 693ms
โœ… MappedCatalogBridgeTests 3 3 0 28ms
โœ… MappedCatalogModelTests 11 11 0 591ms
โœ… MockBackendExpiredCredentialsTests 3 3 0 330ms
โœ… MockBackendIntegrationTests 4 4 0 271ms
โœ… MockBackendLoanLimitTests 2 2 0 111ms
โœ… MockBackendRouteMatchingTests 4 4 0 27ms
โœ… MockBackendServerDownTests 1 1 0 25ms
โœ… MockIsolationLintTests 5 5 0 2.24s
โœ… MultiLibraryTokenIsolationTests 14 14 0 453ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests 6 6 0 115ms
โœ… MyBooksDownloadCenterAdeptGapTests 3 3 0 14ms
โœ… MyBooksDownloadCenterConcurrencyTests 21 21 0 530ms
โœ… MyBooksDownloadCenterEvictionTests 7 7 0 149ms
โœ… MyBooksDownloadCenterOfflineTests 8 8 0 732ms
โœ… MyBooksDownloadSessionInvalidationTests 3 3 0 18ms
โœ… MyBooksSimplifiedBearerTokenTests 17 17 0 164ms
โœ… MyBooksViewModelBooksPublisherTests 3 3 0 32ms
โœ… MyBooksViewModelConcurrencyTests 4 4 0 225ms
โœ… MyBooksViewModelDownloadStateTests 3 3 0 22ms
โœ… MyBooksViewModelEmptyArrayTests 3 3 0 13ms
โœ… MyBooksViewModelEmptyStateTests 4 4 0 37ms
โœ… MyBooksViewModelExtendedTests 15 15 0 24.78s
โœ… MyBooksViewModelFacetIntegrationTests 4 4 0 18ms
โœ… MyBooksViewModelFacetPublisherTests 3 3 0 31ms
โœ… MyBooksViewModelFilterSortInteractionTests 2 2 0 59ms
โœ… MyBooksViewModelFilterTests 9 9 0 185ms
โœ… MyBooksViewModelGuardConditionsTests 2 2 0 34ms
โœ… MyBooksViewModelLargeDatasetTests 2 2 0 331ms
โœ… MyBooksViewModelLoadAccountTests 2 2 0 245ms
โœ… MyBooksViewModelLoginStateTests 4 4 0 4.79s
โœ… MyBooksViewModelMultipleAuthorSortingTests 3 3 0 42ms
โœ… MyBooksViewModelNotificationTests 4 4 0 356ms
โœ… MyBooksViewModelOfflineFilteringTests 3 3 0 122ms
โœ… MyBooksViewModelPublisherTests 7 7 0 136ms
โœ… MyBooksViewModelSearchEdgeCaseTests 6 6 0 85ms
โœ… MyBooksViewModelSearchQueryTests 3 3 0 68ms
โœ… MyBooksViewModelSortPersistenceTests 3 3 0 2.96s
โœ… MyBooksViewModelSortingIntegrationTests 5 5 0 355ms
โœ… MyBooksViewModelSortingTests 6 6 0 79ms
โœ… MyBooksViewModelStateTransitionTests 3 3 0 410ms
โœ… MyBooksViewModelUIBindingTests 3 3 0 28ms
โœ… NSErrorAdditionsTests 7 7 0 51ms
โœ… NSNotificationTPPTests 3 3 0 49ms
โœ… NavigationCoordinatorTests 17 17 0 45ms
โœ… NavigationFreezePreventionTests 5 5 0 12ms
โœ… NetworkExecutorCredentialGuardTests 8 8 0 343ms
โœ… NetworkExecutorResponseRegressionTests 4 4 0 256ms
โœ… NetworkExecutorTaskTypeTests 3 3 0 55ms
โœ… NetworkOfflineDetectionTests 3 3 0 10ms
โœ… NetworkQueueTests 11 11 0 123ms
โœ… NetworkRequestQueueTests 2 2 0 10.23s
โœ… NetworkRetryLogicTests 7 7 0 496ms
โœ… NetworkTimeoutTests 2 2 0 4ms
โœ… NotificationEventTypeContractTests 7 7 0 29ms
โœ… NotificationPayloadContractTests 10 10 0 58ms
โœ… NotificationServiceStateMachineTests 9 9 0 1.59s
โœ… NotificationServiceTests 16 16 0 83ms
โœ… NotificationServiceTokenTests 13 13 0 46ms
โœ… NotificationSyncThrottleTests 5 5 0 12ms
โœ… NotificationTokenDataTests 4 4 0 12ms
โœ… NotificationTokenRegistrationTests 10 10 0 95ms
โœ… NowPlayingCoordinatorBackgroundTests 6 6 0 475ms
โœ… NowPlayingCoordinatorTests 19 19 0 368ms
โœ… OAuthSAMLRedirectRegressionTests 4 4 0 489ms
โœ… OIDCAuthDocumentParsingTests 4 4 0 262ms
โœ… OIDCAuthTypeTests 5 5 0 25ms
โœ… OIDCAuthenticationPropertyTests 8 8 0 978ms
โœ… OIDCCallbackEdgeCaseTests 9 9 0 1.01s
โœ… OIDCCallbackHandlingTests 5 5 0 6.47s
โœ… OIDCCallbackSchemeTests 3 3 0 8ms
โœ… OIDCIsolationRegressionTests 6 6 0 576ms
โœ… OIDCLoginRoutingTests 3 3 0 474ms
โœ… OIDCMakeRequestTests 3 3 0 247ms
โœ… OIDCNSCodingTests 1 1 0 132ms
โœ… OIDCNetworkLayer401Tests 5 5 0 455ms
โœ… OIDCReauthOnExpiredTokenTests 5 5 0 906ms
โœ… OIDCRedirectURIConstructionTests 6 6 0 726ms
โœ… OIDCRegressionTests 9 9 0 1.32s
โœ… OIDCSelectedAuthenticationTests 2 2 0 296ms
โœ… OIDCSignOutRegressionTests 6 6 0 784ms
โœ… OIDCTokenRefreshRegressionTests 6 6 0 684ms
โœ… OIDCUpdateUserAccountTests 5 5 0 550ms
โœ… OIDCViewModelRegressionTests 1 1 0 161ms
โœ… OIDCViewModelSignInTests 2 2 0 53ms
โœ… OPDS1BorrowEntryContractTests 4 4 0 70ms
โœ… OPDS1CatalogGroupedContractTests 3 3 0 36ms
โœ… OPDS1HoldEntriesContractTests 4 4 0 52ms
โœ… OPDS1LoansFeedContractTests 6 6 0 118ms
โœ… OPDS1ParsingTests 34 34 0 332ms
โœ… OPDS1RevokeResponseContractTests 2 2 0 12ms
โœ… OPDS2AuthenticationDocumentTests 18 18 0 126ms
โœ… OPDS2AvailabilityTests 4 4 0 380ms
โœ… OPDS2BookBridgeTests 44 44 0 357ms
โœ… OPDS2BorrowResponseContractTests 3 3 0 11ms
โœ… OPDS2CatalogWiringTests 17 17 0 160ms
โœ… OPDS2CatalogsFeedTests 3 3 0 389ms
โœ… OPDS2ContributorTests 2 2 0 31ms
โœ… OPDS2EmptyFeedContractTests 1 1 0 10ms
โœ… OPDS2FeedContractTests 4 4 0 37ms
โœ… OPDS2FeedParsingTests 11 11 0 738ms
โœ… OPDS2FeedTests 13 13 0 97ms
โœ… OPDS2FullMetadataTests 4 4 0 18ms
โœ… OPDS2FullPublicationTests 13 13 0 35ms
โœ… OPDS2IntegrationTests 18 18 0 252ms
โœ… OPDS2LinkArrayTests 5 5 0 222ms
โœ… OPDS2LinkComputedPropertyTests 20 20 0 59ms
โœ… OPDS2LinkRelTests 1 1 0 6ms
โœ… OPDS2LinkTests 2 2 0 175ms
โœ… OPDS2ParsingTests 38 38 0 383ms
โœ… OPDS2PublicationExtendedTests 53 53 0 161ms
โœ… OPDS2PublicationImageTests 6 6 0 24ms
โœ… OPDS2PublicationNarratorTests 3 3 0 2.21s
โœ… OPDS2PublicationTests 2 2 0 185ms
โœ… OPDS2SamlIDPTests 6 6 0 52ms
โœ… OPDS2SearchResultsContractTests 3 3 0 28ms
โœ… OPDS2SubjectTests 2 2 0 9ms
โœ… OPDS2SupportingTypesTests 5 5 0 36ms
โœ… OPDSAcquisitionPathExpandedTests 15 15 0 513ms
โœ… OPDSFeedCacheTests 14 14 0 215ms
โœ… OPDSFeedMigrationTests 11 11 0 25ms
โœ… OPDSFeedParsingTests 2 2 0 281ms
โœ… OPDSFeedServiceStateMachineTests 3 3 0 628ms
โœ… OPDSFeedServiceTests 2 2 0 10ms
โœ… OPDSFormatTests 13 13 0 527ms
โœ… OPDSParserCoreTests 4 4 0 13ms
โœ… OPDSParserTests 4 4 0 42ms
โœ… OPDSParsingTests 57 57 0 5.84s
โœ… OfflineActionTests 29 29 0 481ms
โœ… OfflineQueueServiceExtendedTests 13 13 0 5.41s
โœ… OfflineQueueServiceTests 17 17 0 7.15s
โœ… OpenAccessAdapterTests 6 6 0 4.08s
โœ… OverdriveDeferredFulfillmentTests 6 6 0 21ms
โœ… OverdriveDownloadHandlerTests 9 9 0 244ms
โœ… OverdriveFulfillmentTests 5 5 0 104ms
โœ… PDFExtensionsTests 20 20 0 114ms
โœ… PDFReaderTests 12 12 0 52ms
โœ… PP3596RegressionTests 3 3 0 98ms
โœ… Palace 2 2 0 <1ms
โœ… PalaceCheckPropertyTests 8 8 0 159ms
โœ… PalaceErrorCategoryTests 20 20 0 60ms
โœ… PalaceErrorExtendedTests 23 23 0 357ms
โœ… PalaceErrorTests 11 11 0 377ms
โœ… PalacePDFViewTests 12 12 0 225ms
โœ… PalaceTestSetupObservationTests 4 4 0 19ms
โœ… PalaceWiringTestCaseTests 4 4 0 36ms
โœ… ParserFuzzTests 4 4 0 51.16s
โœ… PatronProfileContractTests 4 4 0 77ms
โœ… PerformanceMonitorTests 14 14 0 152ms
โœ… PerformanceReportTests 14 14 0 70ms
โœ… PersistentLoggerTests 9 9 0 2.26s
โœ… PlaybackBootstrapperTests 8 8 0 600ms
โœ… PlaybackFailureRecordTests 5 5 0 11ms
โœ… PlaybackOpenPolicyTests 7 7 0 15ms
โœ… PlaybackRateTests 16 16 0 60ms
โœ… PlaybackTrackingRegressionTests 5 5 0 128ms
โœ… PositionPersistenceLogicTests 6 6 0 23ms
โœ… PositionPersistenceTests 2 2 0 6ms
โœ… PositionSyncServiceTests 13 13 0 556ms
โœ… PositionSyncTests 5 5 0 73ms
โœ… PositionWriterContractTests 6 6 0 85ms
โœ… PostUpdateMigrationTests 5 5 0 64ms
โœ… ProblemDocumentContractTests 4 4 0 22ms
โœ… ProblemDocumentLoanExpiryTests 5 5 0 18ms
โœ… ProblemDocumentTests 12 12 0 84ms
โœ… ProblemReportEmailTests 8 8 0 28ms
โœ… ReachabilityTests 10 10 0 40ms
โœ… Reader2BookmarkContractTests 3 3 0 36ms
โœ… Reader2PositionAdapterContractTests 4 3 0 1.73s
โœ… Reader2PositionResumeContractTests 3 3 0 414ms
โœ… ReaderAccessibilityTests 7 7 0 34ms
โœ… ReaderEditingActionsTests 5 5 0 27ms
โœ… ReaderErrorTests 5 5 0 61ms
โœ… ReaderNavBarVoiceOverTests 2 2 0 16ms
โœ… ReaderServiceSyncTests 3 3 0 51ms
โœ… ReaderThemeTests 24 24 0 233ms
โœ… ReadingPositionTests 22 22 0 458ms
โœ… ReadingSessionTrackerTests 13 13 0 350ms
โœ… ReadingStatsServiceTests 12 12 0 242ms
โœ… ReadingStatsStoreTests 9 9 0 120ms
โœ… RedirectHandlingIntegrationTests 4 4 0 11ms
โœ… RedirectPolicyTests 9 9 0 128ms
โœ… RemoteFeatureFlagsGapTests 4 4 0 42ms
โœ… RemoteFeatureFlagsTests 9 9 0 43ms
โœ… ResourcePropertiesLengthTests 3 3 0 8ms
โœ… RetryClassificationTests 17 17 0 37ms
โœ… ReturnFlowTests 1 1 0 25ms
โœ… RightsManagementDetectionTests 5 5 0 338ms
โœ… RightsManagementDispatcherTests 10 10 0 92ms
โœ… SAMLCookieSyncTests 5 5 0 15ms
โœ… SAMLLogoutCallbackDetectionTests 4 4 0 25ms
โœ… SAMLLogoutLinkParsingTests 5 5 0 108ms
โœ… SAMLLogoutURLTests 4 4 0 13ms
โœ… SAMLPlusBiblioBoardExpirationTests 8 8 0 1.29s
โœ… SEMigrationsTests 6 6 0 123ms
โœ… SafeDictionaryTests 21 21 0 295ms
โœ… SamplePlayerErrorTests 5 5 0 19ms
โœ… SampleTypeTests 8 8 0 78ms
โœ… SceneDelegateTests 1 1 0 6ms
โœ… ScopedResetTests 9 9 0 376ms
โœ… SearchAccessibilityTests 6 6 0 34ms
โœ… SearchFlowIntegrationTests 8 8 0 145ms
โœ… SettingsViewModelComputedPropertyTests 6 6 0 45ms
โœ… SettingsViewModelEdgeCaseTests 7 7 0 7.38s
โœ… SettingsViewModelGapTests 1 1 0 27ms
โœ… SettingsViewModelSyncTests 14 14 0 4.79s
โœ… SettingsViewModelTests 33 33 0 1.30s
โœ… SignInModalLifecycleTests 9 9 0 11.10s
โœ… SignInModalPredicateTests 3 3 0 10ms
โœ… SignInModalSAMLOIDCTests 6 6 0 21ms
โœ… SignInOAuthErrorPropagationTests 8 8 0 784ms
โœ… SignInToReadFlowIntegrationTests 5 5 0 640ms
โœ… SignInWebSheetIntegrationTests 3 3 0 7.31s
โœ… SignInWebSheetViewModelTests 31 31 0 307ms
โœ… SignOutCacheClearingTests 3 3 0 8ms
โœ… SingletonResetRegistryTests 5 5 0 134ms
โœ… StatsViewModelTests 10 10 0 270ms
โœ… StatusAnnouncementTests 22 22 0 168ms
โœ… StopPositionSaveTests 2 2 0 13ms
โœ… StoreTests 5 5 0 36ms
โœ… StreamingReaderPresentationContractTests 1 1 0 11ms
โœ… StreamingReaderProgressStoreTests 7 7 0 71ms
โœ… StreamingReaderViewControllerScrollRestoreTests 12 12 0 1.61s
โœ… StreamingReaderViewModelTests 9 9 0 118ms
โœ… StringExtensionTests 8 8 0 61ms
โœ… StringExtensionsTests 3 3 0 39ms
โœ… StringHTMLEntitiesTests 7 7 0 48ms
โœ… StringNYPLAdditionsTests 4 4 0 17ms
โœ… String_NYPLAdditionsTests 4 4 0 91ms
โœ… SupportSectionDecisionTests 5 5 0 409ms
โœ… SyncConflictResolutionTests 3 3 0 47ms
โœ… SyncDeletionGuardTests 5 5 0 130ms
โœ… SyncDeletionRatioTests 6 6 0 23ms
โœ… SyncPermissionTests 5 5 0 219ms
โœ… TPPAccountAuthStateEnumTests 5 5 0 38ms
โœ… TPPAccountListDataSourceTests 3 3 0 8ms
โœ… TPPAdobeActivationSkipTests 6 6 0 656ms
โœ… TPPAgeCheckCompletionTests 5 5 0 559ms
โœ… TPPAgeCheckIsValidTests 5 5 0 25ms
โœ… TPPAgeCheckStateMachineTests 4 4 0 515ms
โœ… TPPAgeCheckTests 6 6 0 1.58s
โœ… TPPAgeCheckVerifyDecisionTests 5 5 0 504ms
โœ… TPPAlertUtilsTests 45 45 0 838ms
โœ… TPPAnnotationsHermeticTests 15 15 0 143ms
โœ… TPPAnnotationsOverrideTests 4 4 0 271ms
โœ… TPPAnnotationsTests 29 29 0 5.80s
โœ… TPPAnnouncementManagerTests 3 3 0 31ms
โœ… TPPAuthDocumentContractTests 3 3 0 28ms
โœ… TPPBackgroundExecutorTests 3 3 0 27ms
โœ… TPPBadgeImageGapTests 2 2 0 17ms
โœ… TPPBaseReaderViewControllerInitialLocationTests 5 5 0 41ms
โœ… TPPBasicAuthTests 11 11 0 89ms
โœ… TPPBookAccessibilityLabelTests 8 8 0 39ms
โœ… TPPBookAuthorCoverageTests 3 3 0 8ms
โœ… TPPBookAuthorTests 6 6 0 86ms
โœ… TPPBookBearerTokenTests 9 8 0 133ms
โœ… TPPBookButtonsStateTests 7 7 0 26ms
โœ… TPPBookContentMetadataFilesHelperTests 9 9 0 33ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests 2 2 0 120ms
โœ… TPPBookContentTypeConverterTests 4 4 0 16ms
โœ… TPPBookContentTypeExtendedTests 4 4 0 48ms
โœ… TPPBookContentTypeTests 14 14 0 52ms
โœ… TPPBookCoverRegistryTests 14 14 0 689ms
โœ… TPPBookCreationTests 7 7 0 82ms
โœ… TPPBookExtensionsTests 21 21 0 104ms
โœ… TPPBookIsDRMProtectedTests 9 9 0 32ms
โœ… TPPBookLocationCoverageTests 7 7 0 51ms
โœ… TPPBookLocationEdgeCaseTests 27 27 0 75ms
โœ… TPPBookLocationKeyTests 3 3 0 20ms
โœ… TPPBookLocationTests 11 11 0 56ms
โœ… TPPBookModelGapTests 4 4 0 33ms
โœ… TPPBookRegistryAsyncReadinessTests 3 3 0 552ms
โœ… TPPBookRegistryAtomicWriteTests 7 7 0 1.14s
โœ… TPPBookRegistryBookRetrievalTests 7 7 0 162ms
โœ… TPPBookRegistryBookmarkTests 7 7 0 158ms
โœ… TPPBookRegistryCorruptedDataTests 5 5 0 34ms
โœ… TPPBookRegistryDataTests 4 4 0 29ms
โœ… TPPBookRegistryDependencyTests 4 4 0 73ms
โœ… TPPBookRegistryFulfillmentIdTests 4 4 0 56ms
โœ… TPPBookRegistryLargeCorpusTests 5 5 0 2m 24s
โœ… TPPBookRegistryLoadReentrancyTests 2 2 0 32ms
โœ… TPPBookRegistryLocationTests 4 4 0 79ms
โœ… TPPBookRegistryMigrationTests 16 16 0 1.83s
โœ… TPPBookRegistryPersistenceTests 10 10 0 1.93s
โœ… TPPBookRegistryProcessingTests 2 2 0 21ms
โœ… TPPBookRegistryPublisherTests 6 6 0 987ms
โœ… TPPBookRegistryRecordPersistenceTests 3 3 0 37ms
โœ… TPPBookRegistryRecordTests 10 10 0 42ms
โœ… TPPBookRegistryStateManagementTests 11 11 0 18.55s
โœ… TPPBookRegistryThreadSafetyTests 3 3 0 653ms
โœ… TPPBookRegistryUpdateAndRemoveTests 1 1 0 27ms
โœ… TPPBookRequiresAdobeDRMTests 6 6 0 31ms
โœ… TPPBookSerializationTests 13 13 0 111ms
โœ… TPPBookStateInitializationTests 4 4 0 13ms
โœ… TPPBookStateTests 4 4 0 32ms
โœ… TPPBookTests 93 93 0 428ms
โœ… TPPBookmarkDeletionLogTests 11 11 0 172ms
โœ… TPPBookmarkFactoryInitTests 2 2 0 11ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests 5 5 0 58ms
โœ… TPPBookmarkFactoryTests 15 15 0 84ms
โœ… TPPBookmarkR3ConversionTests 5 5 0 24ms
โœ… TPPBookmarkR3LocationTests 13 13 0 30ms
โœ… TPPBookmarkSpecTests 1 1 0 7ms
โœ… TPPCachingTests 3 3 0 21ms
โœ… TPPCapturedCredentialsTests 5 5 0 5.74s
โœ… TPPConfigurationTests 22 22 0 67ms
โœ… TPPContentTypeTests 9 9 0 32ms
โœ… TPPCredentialConcurrencyTests 3 3 0 14ms
โœ… TPPCredentialIsolationE2ETests 5 0 0 180ms
โœ… TPPCredentialPersistenceTests 6 6 0 588ms
โœ… TPPCredentialSnapshotCoherenceTests 3 0 0 2.36s
โœ… TPPCredentialSnapshotTests 8 8 0 22ms
โœ… TPPCredentialsCoverageTests 9 9 0 39ms
โœ… TPPCredentialsTests 26 26 0 161ms
โœ… TPPCrossLibrarySignOutTests 6 6 0 995ms
โœ… TPPDRMFailureCredentialPreservationTests 4 4 0 445ms
โœ… TPPErrorLoggerTests 27 27 0 436ms
โœ… TPPIdleSignOutRegressionTests 13 13 0 1.31s
โœ… TPPJWKConversionTest 1 1 0 23ms
โœ… TPPKeychainManagerTests 5 5 0 34ms
โœ… TPPLastReadPositionPosterTests 13 13 0 425ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests 5 5 0 44ms
โœ… TPPLastReadPositionSynchronizerTests 23 23 0 112ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests 5 5 0 29ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests 9 9 0 29ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests 3 3 0 23ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests 9 9 0 26ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests 10 10 0 44ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests 4 4 0 22ms
โœ… TPPLoginNoActivationTests 3 3 0 514ms
โœ… TPPMainThreadCheckerTests 4 4 0 65ms
โœ… TPPMigrationManagerTests 15 15 0 43ms
โœ… TPPNetworkExecutorAPITests 14 14 0 151ms
โœ… TPPNetworkExecutorStubbedTests 17 17 0 365ms
โœ… TPPNetworkExecutorTests 3 3 0 14ms
โœ… TPPNetworkResponderAuthCoordinatorTests 5 5 0 28ms
โœ… TPPNetworkResponderTests 12 12 0 218ms
โœ… TPPOPDSAcquisitionPathTests 5 5 0 47ms
โœ… TPPOPDSEntryTests 5 5 0 36ms
โœ… TPPOPDSFeedTests 3 3 0 431ms
โœ… TPPOPDSGroupSwiftTests 3 3 0 13ms
โœ… TPPOPDSLinkTests 7 7 0 46ms
โœ… TPPOpenSearchDescriptionExpandedTests 10 10 0 39ms
โœ… TPPOpenSearchDescriptionTests 1 1 0 5ms
โœ… TPPPDFDocumentMetadataTests 15 15 0 179ms
โœ… TPPPDFDocumentTests 8 8 0 20ms
โœ… TPPPDFLocationCoverageTests 7 7 0 42ms
โœ… TPPPDFLocationTests 10 10 0 90ms
โœ… TPPPDFPageBookmarkTests 9 9 0 53ms
โœ… TPPPDFPageTests 5 5 0 24ms
โœ… TPPPDFReaderModeTests 6 6 0 59ms
โœ… TPPPerAccountIsolationTests 8 0 0 255ms
โœ… TPPPreferredAuthSelectionTests 8 8 0 1.12s
โœ… TPPProblemDocumentCacheManagerTests 12 12 0 91ms
โœ… TPPProblemDocumentTests 21 21 0 104ms
โœ… TPPReaderAppearanceTests 4 4 0 13ms
โœ… TPPReaderBookmarksBusinessLogicTests 12 12 0 1.44s
โœ… TPPReaderBookmarksReadinessTests 2 2 0 206ms
โœ… TPPReaderFontTests 4 4 0 24ms
โœ… TPPReaderPreferencesLoadTests 3 3 0 26ms
โœ… TPPReaderSettingsTests 28 28 0 288ms
โœ… TPPReaderTOCBusinessLogicTests 15 15 0 3.24s
โœ… TPPReaderTOCFlattenTests 2 2 0 1.03s
โœ… TPPReadiumBookmarkLocationMatchingTests 5 5 0 40ms
โœ… TPPReadiumBookmarkTests 21 21 0 2.35s
โœ… TPPReauthenticatorMockTests 2 2 0 26ms
โœ… TPPReauthenticatorTests 4 4 0 26ms
โœ… TPPReturnPromptHelperTests 5 5 0 28ms
โœ… TPPSAMLCookieExpirationTests 7 7 0 31ms
โœ… TPPSAMLFlowTests 10 10 0 53ms
โœ… TPPSAMLReauthFlowTests 2 2 0 249ms
โœ… TPPSAMLRegressionTests 4 4 0 518ms
โœ… TPPSAMLSignInTests 26 26 0 3.80s
โœ… TPPSAMLStateIsolationTests 4 4 0 210ms
โœ… TPPSAMLStateMachineTests 6 6 0 569ms
โœ… TPPSettingsTests 6 6 0 3.34s
โœ… TPPSignInAdobeSkipTests 14 14 0 1.70s
โœ… TPPSignInAuthStateTransitionTests 3 3 0 297ms
โœ… TPPSignInBusinessLogicExtendedTests 58 58 0 9.48s
โœ… TPPSignInBusinessLogicOAuthTests 11 11 0 1.18s
โœ… TPPSignInBusinessLogicSignOutTests 11 11 0 1.46s
โœ… TPPSignInBusinessLogicStateMachineTests 9 9 0 955ms
โœ… TPPSignInBusinessLogicTests 18 18 0 2.48s
โœ… TPPSignInBusinessLogicTokenFlowTests 3 3 0 346ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests 2 2 0 301ms
โœ… TPPSignInErrorHandlingTests 2 2 0 170ms
โœ… TPPSignInProfileDocEdgeCaseTests 3 3 0 410ms
โœ… TPPSignedInStateProviderTests 3 3 0 12ms
โœ… TPPUserAccountAuthStateTests 6 6 0 22ms
โœ… TPPUserAccountGapTests 4 4 0 12ms
โœ… TPPUserAccountIsolationLintTests 3 3 0 797ms
โœ… TPPUserAccountTestFactoryTests 7 0 0 83ms
โœ… TPPUserFriendlyErrorTests 11 11 0 59ms
โœ… TPPUserNotificationsTests 10 10 0 154ms
โœ… TPPXMLSwiftTests 16 16 0 110ms
โœ… TPPXMLTests 3 3 0 28ms
โœ… TearDownRequiredLintTests 5 5 0 1.90s
โœ… TestAppContainerFactoryTests 5 5 0 92ms
โœ… TimeEntryTests 3 3 0 15ms
โŒ TokenRefreshAndRetryQueueTests 11 10 1 9.29s
โœ… TokenRefreshIntegrationTests 2 2 0 254ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests 8 8 0 4.53s
โœ… TokenRefreshInterceptorTests 24 24 0 6.73s
โœ… TokenRefreshOnForegroundTests 10 10 0 2.70s
โœ… TokenRefreshTests 25 25 0 102ms
โœ… TokenRequestCredentialGuardTests 13 13 0 173ms
โœ… TokenRequestTests 11 11 0 128ms
โœ… TokenResponseTests 21 21 0 59ms
โœ… TypographyPresetTests 21 21 0 669ms
โœ… TypographyServiceTests 31 31 0 1.30s
โœ… TypographySettingsViewModelTests 27 27 0 1.15s
โœ… UIAlertCACommitGuardTests 8 8 0 252ms
โœ… UIColor_NYPLAdditionsTests 1 1 0 3ms
โœ… URLBackupExclusionTests 3 3 0 18ms
โœ… URLExtensionTests 16 16 0 228ms
โœ… URLExtensionsTests 6 6 0 25ms
โœ… URLRequestExtensionsCoverageTests 3 3 0 8ms
โœ… URLRequestExtensionsTests 11 11 0 60ms
โœ… URLRequestNYPLAdditionsTests 11 11 0 87ms
โœ… URLRequest_NYPLTests 1 1 0 4ms
โœ… URLResponseAuthenticationTests 10 10 0 30ms
โœ… URLResponseNYPLTests 14 14 0 70ms
โœ… URLSessionCredentialStorageTests 3 3 0 49ms
โœ… URLSessionStubbingResetTests 2 2 0 12ms
โœ… URLTypeTests 2 2 0 8ms
โœ… URLValidationTests 5 5 0 10ms
โœ… UnifiedOPDSServiceStateMachineTests 2 2 0 501ms
โœ… UserAccountPublisherAuthStateTests 5 5 0 92ms
โœ… UserAccountPublisherTests 14 14 0 1.03s
โœ… UserAccountValidationTests 11 11 0 1.27s
โœ… UserDefaultsIsolationLintTests 2 2 0 764ms
โœ… UserProfileDocumentTests 7 7 0 58ms
โœ… UserRetryTrackerTests 10 10 0 195ms
โœ… XCTestCase_testUserDefaultsTests 3 3 0 44ms
โœ… iPadOnMacRMSDKGuardTests 1 1 0 6ms

๐Ÿ“ˆ Code Coverage

Target Coverage Lines
Palace.app
45.6%
40605 / 89022

๐Ÿ“‹ All Tests

Class Test Duration
โœ… AccessLintComplianceTests testAudiobookLabel_isDescriptive 2ms
โœ… AccessLintComplianceTests testBorrowAnnouncementStrings_areMeaningful 2ms
โœ… AccessLintComplianceTests testDownloadAnnouncementStrings_areMeaningful 2ms
โœ… AccessLintComplianceTests testExpandCollapseButton_labelsRoundTripOnStateFlip 2ms
โœ… AccessLintComplianceTests testPDFToolbarButton_fallbackLabel_isDistinctFromOkLabel 2ms
โœ… AccessLintComplianceTests testRetryAnnouncementStrings_areMeaningful 2ms
โœ… AccessLintComplianceTests testReturnAnnouncementStrings_areMeaningful 2ms
โœ… AccessLintComplianceTests testSearchAnnouncementStrings_areMeaningful 3ms
โœ… AccessLintComplianceTests testSortFilterLabels_areDescriptive 2ms
โœ… AccessLintComplianceTests testStatusAnnouncement_actionFailed_combinesTitleAndMessage 2ms
โœ… AccessLintComplianceTests testStatusAnnouncement_errorOccurred_passesThrough 2ms
โœ… AccessibilityAnnouncementCenterTests testPP3594_borrowAndReturnAnnouncements_postMessages 4ms
โœ… AccessibilityAnnouncementCenterTests testPP3594_downloadAnnouncements_respectVoiceOverDisabled 314ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_additionalResultsLoaded_announcesCount 4ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_additionalResultsLoaded_zeroCount_doesNotAnnounce 311ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_allAnnouncements_useAnnouncementNotificationType 4ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_announceError_postsMessage 12ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_announceMessage_postsArbitraryMessage 3ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_announceStatus_combinesTitleAndMessage 7ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_deduplication_allowsDifferentMessages 8ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_deduplication_allowsRepeatAfterWindowExpires 6ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_deduplication_crossMethod_sameText 6ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_deduplication_rapidFireSameMessage_onlyOneAnnouncement 5ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_deduplication_suppressesDuplicateWithinWindow 3ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_emptyMessage_isNotPosted 307ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_errorAnnouncements_respectVoiceOverDisabled 311ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_searchAnnouncements_respectVoiceOverDisabled 308ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_searchFailed_announcesFailure 5ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_searchNoResults_announcesNoResults 5ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_searchRerun_announcesUpdatedResults 5ms
โœ… AccessibilityAnnouncementCenterTests testPP3673_searchResults_announcesResultCountAndQuery 5ms
โœ… AccessibilityLabelTests testAccessibilityStrings_areNotEmpty 4ms
โœ… AccessibilityLabelTests testAccessibilityStrings_formatStringsWork 2ms
โœ… AccessibilityLabelTests testBookmarkLabels_existAndAreDifferent 4ms
โœ… AccessibilityLabelTests testChapterNavigationLabels_exist 3ms
โœ… AccessibilityLabelTests testExistingAccessibilityStrings_areNotEmpty 3ms
โœ… AccessibilityLabelTests testExpandCollapseLabels_areDifferent 5ms
โœ… AccessibilityLabelTests testFilterButtonLabel_changesWithCount 2ms
โœ… AccessibilityLabelTests testPlayPauseLabels_areDifferent 5ms
โœ… AccessibilityLabelTests testSortButtonLabel_changesWithSortOption 2ms
โœ… AccessibilityPreferencesTests testButtonShapesEnabled_WhenEnabled_RoundTripsThroughCodable 7ms
โœ… AccessibilityPreferencesTests testCodableRoundTrip_CustomPreferences 4ms
โœ… AccessibilityPreferencesTests testCodableRoundTrip_DefaultPreferences 3ms
โœ… AccessibilityPreferencesTests testCustomRotorActionsEnabled_Toggle 9ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_ButtonShapesOff 5ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_CustomRotorEnabled 4ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_HapticFeedbackOn 43ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_HasStandardVerbosity 4ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_HighContrastOff 27ms
โœ… AccessibilityPreferencesTests testDefaultPreferences_ReducedMotionOff 5ms
โœ… AccessibilityPreferencesTests testEquatable_DifferentValues 5ms
โœ… AccessibilityPreferencesTests testEquatable_SameValues 3ms
โœ… AccessibilityPreferencesTests testHapticFeedbackEnabled_Toggle 3ms
โœ… AccessibilityPreferencesTests testHighContrastBoost_WhenEnabled_MakesPrefsUnequalToDefault 4ms
โœ… AccessibilityPreferencesTests testPersistence_NoSavedData_ReturnsNil 7ms
โœ… AccessibilityPreferencesTests testPersistence_SaveAndLoad 17ms
โœ… AccessibilityPreferencesTests testReducedMotion_WhenEnabled_RoundTripsThroughCodable 6ms
โœ… AccessibilityPreferencesTests testStorageKey_IsCorrect 5ms
โœ… AccessibilityPreferencesTests testVerbosityMinimal_Description 4ms
โœ… AccessibilityPreferencesTests testVerbosityMinimal_DisplayName 21ms
โœ… AccessibilityPreferencesTests testVerbosityStandard_Description 3ms
โœ… AccessibilityPreferencesTests testVerbosityStandard_DisplayName 3ms
โœ… AccessibilityPreferencesTests testVerbosityVerbose_Description 22ms
โœ… AccessibilityPreferencesTests testVerbosityVerbose_DisplayName 3ms
โœ… AccessibilityPreferencesTests testVerbosity_AllCases 3ms
โœ… AccessibilityPreferencesTests testVerbosity_CodableRoundTrip 3ms
โœ… AccessibilityServiceTests testAccessibilityPreferencesCodable 12ms
โœ… AccessibilityServiceTests testDefaultPreferences 17ms
โœ… AccessibilityServiceTests testHapticDisabledWhenPreferenceOff 7ms
โœ… AccessibilityServiceTests testHapticDisabledWithReducedMotion 6ms
โœ… AccessibilityServiceTests testHighContrastEffective 6ms
โœ… AccessibilityServiceTests testPreferencesPersistAcrossInstances 6ms
โœ… AccessibilityServiceTests testPreferencesPublisher 9ms
โœ… AccessibilityServiceTests testReducedMotionEffective 6ms
โœ… AccessibilityServiceTests testUpdatePreferences 23ms
โœ… AccessibilityServiceTests testVerbosityDescriptions 7ms
โœ… AccessibilityServiceTests testVerbosityDisplayNames 2ms
โœ… AccountAuthDocCarryoverTests testAccount_authenticationDocumentDidSet_createsDetails 316ms
โœ… AccountAuthDocCarryoverTests testAccount_detailsPreserved_whenAuthDocCopiedToNewAccount 316ms
โœ… AccountAuthDocCarryoverTests testAccount_detailsSyncPermission_defaultsToTrue 166ms
โœ… AccountAuthDocCarryoverTests testAccount_multipleAccountsCarryover_matchesByUUID 432ms
โœ… AccountAuthDocCarryoverTests testAccount_replacementWithoutCarryover_losesDetails 249ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_includesAuthenticationDocumentUrlHost 6ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_includesCatalogUrlHost 4ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_includesHomePageUrlHost 81ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_lowercasesAtProducer 4ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_returnsEmptySetWhenAllURLsAbsent 3ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_skipsMalformedURLs 2ms
โœ… AccountAuthSurfaceHostsTests testAuthSurfaceHosts_unionsAllProvidedHosts 2ms
โœ… AccountAwareNetworkTests testCancelNonEssentialTasks_CancelsActiveTasks 20ms
โœ… AccountAwareNetworkTests testCancelNonEssentialTasks_DoesNotCrash_andLeavesExecutorFullyUsable 33ms
โœ… AccountAwareNetworkTests testExecuteTokenRefresh_AcceptsAccountId 48ms
โœ… AccountAwareNetworkTests testExecuteTokenRefresh_NilAccountId_BackwardCompatible 74ms
โœ… AccountAwareNetworkTests testRefreshTokenAndResume_AcceptsAccountIdParameter 10ms
โœ… AccountAwareNetworkTests testRefreshTokenAndResume_DefaultAccountId_BackwardCompatible 11ms
โœ… AccountAwareNetworkTests testRefreshTokenAndResume_NilAccountId_DoesNotCrash 9ms
โœ… AccountAwareNetworkTests testRequest_AccountIdParameter_AcceptsNil 18ms
โœ… AccountAwareNetworkTests testRequest_AccountIdParameter_AcceptsSpecificId 30ms
โœ… AccountAwareNetworkTests testRequest_CapturesCurrentAccountToken 12ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_OAuthRemainsSignedInWhenStateBecomesStale 50ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_SAMLUpdatesWhenStateBecomesStale 13ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_falseWhenSAMLCredentialsStale 10ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_trueWhenLoggedIn 8ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_trueWhenOAuthCredentialsStale 14ms
โŠ˜ AccountDetailCredentialStateTests testIsSignedIn_updatesAfterSAMLReauthentication 9ms
โŠ˜ AccountDetailCredentialStateTests testNeedsReauthentication_trueWhenCredentialsStale 15ms
โŠ˜ AccountDetailPINVisibilityTests testAccountDidChangeViaNotification_ClearsCredentialsOnLogout 14ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicDidCancelSignIn_ClearsLoadingAndSigningOut 46ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicDidCompleteSignIn_ClearsLoadingAndSigningOut 15ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicDidFinishDeauthorizing_ClearsLoadingAndSigningOut 18ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicDidReceiveCredentials_SetsLoadingTrue 16ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicSignOutError_401ShowsUnexpectedCredentialsAlert 19ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicSignOutError_WithErrorUsesLocalizedDescription 59ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicValidationError_CancelledErrorClearsPin 29ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicValidationError_ShowsAlertAndClearsLoading 15ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicWillSignIn_NonOAuth_SetsLoadingTrueAndClearsSigningOut 21ms
โŠ˜ AccountDetailPINVisibilityTests testBusinessLogicWillSignOut_SetsLoadingAndSigningOut 17ms
โŠ˜ AccountDetailPINVisibilityTests testCellType_HashableInSet 13ms
โŠ˜ AccountDetailPINVisibilityTests testCellType_InfoHeaderEqualityByText 15ms
โŠ˜ AccountDetailPINVisibilityTests testCellType_SimpleCasesEqual 42ms
โŠ˜ AccountDetailPINVisibilityTests testContext_ReturnsSettingsTab 17ms
โŠ˜ AccountDetailPINVisibilityTests testLibraryLogo_MatchesSelectedAccountLogo 14ms
โŠ˜ AccountDetailPINVisibilityTests testPINVisibility_DefaultsToHidden 21ms
โŠ˜ AccountDetailPINVisibilityTests testPINVisibility_IndependentOfCredentialChanges 14ms
โŠ˜ AccountDetailPINVisibilityTests testPINVisibility_ToggleMultipleTimes 28ms
โŠ˜ AccountDetailPINVisibilityTests testPinComputed_EmptyReturnsEmptyString 16ms
โŠ˜ AccountDetailPINVisibilityTests testRefreshSignInState_ReloadsTableWhenStateChanges 14ms
โŠ˜ AccountDetailPINVisibilityTests testSelectAuthMethod_ClearsIDPAndSetsSelectedAuth 23ms
โŠ˜ AccountDetailPINVisibilityTests testSignIn_WhenAlreadySignedIn_SetsIsSigningOutTrue 15ms
โŠ˜ AccountDetailPINVisibilityTests testUpdateSync_WritesToAccountDetails 17ms
โŠ˜ AccountDetailPINVisibilityTests testUsernameComputed_EmptyReturnsNil 19ms
โŠ˜ AccountDetailSignOutConfirmationTests testConfirmSignOut_WhenSignedIn_DoesNotImmediatelyDeauthorize 31ms
โŠ˜ AccountDetailSignOutConfirmationTests testMakeSignOutConfirmationAlert_HasDestructiveSignOutAndCancelActions 32ms
โœ… AccountDetailViewModelGapTests testAccountDetailViewModel_updateSync_setsPermission 109ms
โŠ˜ AccountDetailViewModelTests testAlertPropertiesUpdate 9ms
โŠ˜ AccountDetailViewModelTests testBusinessLogic_IsInitialized 13ms
โŠ˜ AccountDetailViewModelTests testCanSignInWithBothCredentials 33ms
โŠ˜ AccountDetailViewModelTests testCanSignInWithEmptyCredentials 7ms
โŠ˜ AccountDetailViewModelTests testCanSignInWithOnlyUsername 9ms
โŠ˜ AccountDetailViewModelTests testCanSignIn_WithSpecialCharacters 10ms
โŠ˜ AccountDetailViewModelTests testCanSignIn_WithWhitespaceOnlyUsername 6ms
โŠ˜ AccountDetailViewModelTests testClearCredentials_WorksIndependently 39ms
โŠ˜ AccountDetailViewModelTests testCredentialFields_AreIndependent 54ms
โŠ˜ AccountDetailViewModelTests testInitialPublishedPropertiesState 21ms
โŠ˜ AccountDetailViewModelTests testIsPINHiddenDefaultsToTrue 7ms
โŠ˜ AccountDetailViewModelTests testIsSyncEnabledToggle 10ms
โŠ˜ AccountDetailViewModelTests testLibraryNameReturnsAccountName 22ms
โŠ˜ AccountDetailViewModelTests testMultipleAlerts_CanBeShown 14ms
โŠ˜ AccountDetailViewModelTests testPinTextUpdate 6ms
โŠ˜ AccountDetailViewModelTests testSelectedAccountMatchesInitialized 9ms
โŠ˜ AccountDetailViewModelTests testShowBarcode_WhenEnabled_TriggerObjectWillChange 12ms
โŠ˜ AccountDetailViewModelTests testTogglePINVisibility 7ms
โŠ˜ AccountDetailViewModelTests testUsernameTextUpdate 15ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_anonymous_returnsFalse 5ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_basic_returnsFalse 21ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_coppa_returnsFalse 7ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_isStrictSupersetOf_isOauthOrIsOidc_forSaml 4ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_none_returnsFalse 3ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_oauthIntermediary_returnsTrue 20ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_oidc_returnsTrue 6ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_saml_returnsTrue 10ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_token_returnsFalse 2ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests testIsBrowserBased_vs_needsAuth_areDistinctPredicates 6ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_AnonymousMixedWithBasic_ReturnsTrue 5ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_AnonymousOnly_ReturnsFalse 4ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_BasicOnly_ReturnsTrue 9ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_CoppaOnly_ReturnsFalse 3ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_OAuthOnly_ReturnsTrue 3ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_OidcOnly_ReturnsTrue 3ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccountDetails_NeedsAuth_SamlOnly_ReturnsTrue 4ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccount_NeedsAuth_AnonymousDetailsLoaded_ReturnsFalse 4ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccount_NeedsAuth_BasicDetailsLoaded_ReturnsTrue 7ms
โœ… AccountDetailsNeedsAuthAggregateTests testAccount_NeedsAuth_BeforeAuthDocLoaded_ReturnsNil 5ms
โœ… AccountDetailsURLTests testDebugDescription_ReflectsSupportsSimplyESync_WhenUserProfileUrlPresent 3ms
โœ… AccountDetailsURLTests testDefaultAuth_WithOAuthAndBasic_PrefersBasicOverOAuth 13ms
โœ… AccountDetailsURLTests testEulaIsAccepted_DefaultIsFalse 4ms
โœ… AccountDetailsURLTests testEulaIsAccepted_RoundTrips_ThroughUserDefaults 7ms
โœ… AccountDetailsURLTests testGetLicenseURL_AfterSettingMultipleTypes_ReturnsCorrectURLs 18ms
โœ… AccountDetailsURLTests testGetLicenseURL_WhenNotSet_ReturnsNil 4ms
โœ… AccountDetailsURLTests testSetURL_ForAcknowledgements_StoresURL 7ms
โœ… AccountDetailsURLTests testSetURL_ForAnnotations_StoresURL 9ms
โœ… AccountDetailsURLTests testSetURL_ForContentLicenses_StoresURL 6ms
โœ… AccountDetailsURLTests testSetURL_ForEULA_StoresURL 6ms
โœ… AccountDetailsURLTests testSetURL_ForPrivacyPolicy_StoresURL 6ms
โœ… AccountDetailsURLTests testSetURL_OverwritesPreviousURL 7ms
โœ… AccountDetailsURLTests testSetURL_PersistsToUserDefaults 15ms
โœ… AccountDetailsURLTests testSyncPermissionGranted_DefaultIsTrue 6ms
โœ… AccountDetailsURLTests testSyncPermissionGranted_ToggleOffThenOn_PersistsViaUserDefaults 10ms
โœ… AccountDetailsURLTests testUserAboveAgeLimit_DefaultIsFalse 5ms
โœ… AccountDetailsURLTests testUserAboveAgeLimit_RoundTrips_ThroughUserDefaults 6ms
โœ… AccountModelGapTests testAccountDetails_defaultAuth_prefersNonOAuth 107ms
โœ… AccountModelGapTests testAccountDetails_eulaIsAccepted_persistsAcrossObjectRecreation 93ms
โœ… AccountModelGapTests testAccountDetails_initFromAuthDoc_populatesAuthMethods 219ms
โœ… AccountModelGapTests testAccountDetails_setAndGetLicenseURL_roundTrips 169ms
โœ… AccountModelGapTests testAccountDetails_syncPermissionGranted_persistsAcrossObjectRecreation 218ms
โœ… AccountModelGapTests testAccount_hasSupportOption_reflectsSupportAvailability 429ms
โœ… AccountModelGapTests testAccount_initFromPublication_mapsPropertiesCorrectly 116ms
โœ… AccountModelGapTests testAccount_loansUrl_delegatesToDetails 227ms
โœ… AccountModelGapTests testAuthentication_NSCoding_roundTrip 243ms
โœ… AccountModelTests testAccount_DebugDescription_ContainsName 2ms
โœ… AccountModelTests testAccount_InitFromPublication_DefaultLogo_IsPlaceholder 8ms
โœ… AccountModelTests testAccount_InitFromPublication_DetailsAreNil 4ms
โœ… AccountModelTests testAccount_InitFromPublication_DropsHelpLink_TrailingSlashAndPathInsensitive 3ms
โœ… AccountModelTests testAccount_InitFromPublication_DropsHelpLink_WhenItPointsAtAboutAppMarketingURL 824ms
โœ… AccountModelTests testAccount_InitFromPublication_DropsHelpLink_WhenItPointsAtAboutAppMarketingURL_HTTPSScheme 16ms
โœ… AccountModelTests testAccount_InitFromPublication_HasUpdatedToken_IsFalse 1.30s
โœ… AccountModelTests testAccount_InitFromPublication_KeepsHelpLink_WhenItPointsAtRealSupportPage 54ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsAuthDocUrl 2ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsCatalogUrl 6ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsHomePageUrl 2ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsName 2ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsSubtitle 2ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsSupportEmail 5ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsSupportURL 3ms
โœ… AccountModelTests testAccount_InitFromPublication_SetsUUID 29ms
โœ… AccountModelTests testLoadAuthenticationDocument_WithNilUrl_CompletesWithFalse 960ms
โœ… AccountModelTests testLoadLogo_WithCachedImage_UsesCachedImage 986ms
โœ… AccountModelTests testLoadLogo_WithNilLogoUrl_DoesNotCrash 69ms
โœ… AccountModelTests testLoansUrl_WhenDetailsNil_ReturnsNil 2ms
โœ… AccountProfileDocumentTests testGetProfileDocument_WhenUserAccountHasNoCredentials_CompletesWithNil_DoesNotFetch 14ms
โœ… AccountProfileDocumentTests testGetProfileDocument_WithDetailsButNilProfileUrl_CompletesWithNil 4ms
โœ… AccountProfileDocumentTests testGetProfileDocument_WithNilDetails_CompletesWithNil 6ms
โœ… AccountStateMachineTests testAwaitReady_blocksUntilTransition_thenResolves 4ms
โœ… AccountStateMachineTests testAwaitReady_cancellingOneAwaiter_doesNotAffectOthers 561ms
โœ… AccountStateMachineTests testAwaitReady_detailsEvictedArrivesViaStream_throwsEvictionError 81ms
โœ… AccountStateMachineTests testAwaitReady_multipleConcurrentAwaiters_allResolve 253ms
โœ… AccountStateMachineTests testAwaitReady_terminalDetailsFailed_throwsImmediately 3ms
โœ… AccountStateMachineTests testAwaitReady_terminalDetailsLoaded_returnsImmediately 5ms
โœ… AccountStateMachineTests testDetailsEvicted_libraryDeselected_throwsEvictionError_fromAwaitReady 6ms
โœ… AccountStateMachineTests testDetailsFailedAccountNotFound_meansHTTP404_throwsAuthLoadError_fromAwaitReady 3ms
โœ… AccountStateMachineTests testInitialState_freshUUID_isNotLoaded 391ms
โœ… AccountStateMachineTests testStateStream_emitsCurrentThenTransitions 6ms
โœ… AccountSwitchCleanupTests testBookCellModelCache_ClearsOnAccountChange 57ms
โœ… AccountSwitchCleanupTests testCancelNonEssentialTasks_CalledMultipleTimes_ExecutorIdempotent 15ms
โœ… AccountSwitchCleanupTests testCancelNonEssentialTasks_WithNoActiveTasks_ExecutorRemainsUsable 175ms
โœ… AccountSwitchCleanupTests testFactoryAccount_DefaultMintIsNamespaced 4ms
โœ… AccountSwitchCleanupTests testFactoryAccount_DistinctUUIDsRemainIsolated 24ms
โœ… AccountSwitchCleanupTests testFactoryAccount_RapidMintingDoesNotCrash 5ms
โœ… AccountSwitchCleanupTests testFactoryAccount_WithSpecificUUID_BindsUUIDAndIsIsolated 2ms
โœ… AccountSwitchCleanupTests testPauseAllTasks_AfterCancel_ResumeAcceptsNewRequests 27ms
โœ… AccountSwitchIntegrationTests testAccountSwitch_ClearsBookRegistry 4ms
โœ… AccountSwitchIntegrationTests testAccountSwitch_ClearsCachedCredentials 12ms
โœ… AccountSwitchIntegrationTests testAccountSwitch_InvalidatesCatalogCache 14ms
โœ… AccountSwitchIntegrationTests testAccountSwitch_PostsCurrentAccountDidChangeNotification 17ms
โœ… AccountSwitchIntegrationTests testAccountSwitch_StopsPendingNetworkRequests 72ms
โœ… AccountSwitchIntegrationTests testMultipleRapidSwitches_DoNotCorruptRegistry 11ms
โœ… AccountSwitchIntegrationTests testNewAccount_LoadsFreshCatalog 7ms
โœ… AccountSwitchIntegrationTests testSwitchToSameAccount_IsIdempotent 4ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_AToBAnonymous_NoBearerOnBRequest 9ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_ATokenNeverLeaksIntoBRequest 11ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_AtoB_AsRegistryFileIsUntouched 10ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_AtoB_LoadsBsPersistedRegistry 35ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_AtoBtoA_RestoresAsState 14ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_BsCredentialsDoNotOverwriteAs 10ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_CancelsInflightNonEssentialTasks 16ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_LiveTaskCount_DropsToZeroAfterCancel 46ms
โŠ˜ AccountSwitchLifecycleTests testSwitch_PerLibraryAccountCacheIsStable 26ms
โœ… AccountsManagerCacheTests testAccountMainFeedURL_NotOverwrittenWithNil_WhenCurrentAccountMissing 151ms
โœ… AccountsManagerCacheTests testCacheDataAndMetadata_AreWrittenTogether 103ms
โœ… AccountsManagerCacheTests testCacheExpiry_OldCacheIsNotUsed 8ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_Codable_EncodesAndDecodes 4ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsExpired_ReturnsFalseJustUnder24Hours 3ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsExpired_ReturnsFalseWhenRecent 3ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsExpired_ReturnsTrueAfter24Hours 2.47s
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsStale_ReturnsFalseJustUnder6Hours 4ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsStale_ReturnsFalseWhenFresh 5ms
โœ… AccountsManagerCacheTests testCatalogCacheMetadata_IsStale_ReturnsTrueAfter6Hours 3ms
โœ… AccountsManagerCacheTests testLoadCatalogs_WhenCacheExists_CompletesWithCachedData 115ms
โœ… AccountsManagerCacheTests testLoadCatalogs_WhenCacheExpired_ReturnsNil 19ms
โœ… AccountsManagerCacheTests testLoadCatalogs_WhenCacheStale_ReturnsDataButMarkedStale 6ms
โœ… AccountsManagerCacheTests testNotification_TPPCatalogDidLoad_IsDeliveredToObserver 9ms
โœ… AccountsManagerCacheTests testReadCacheMetadata_ReturnsNilWhenNotExists 4ms
โœ… AccountsManagerCacheTests testWriteAndReadCacheMetadata 5ms
โœ… AccountsManagerCancellationTests testCancelBackgroundWork_doesNotMutatePersistentAccountSets 9ms
โœ… AccountsManagerCancellationTests testCancelBackgroundWork_isIdempotent 10ms
โœ… AccountsManagerCancellationTests testCancelBackgroundWork_onLiveInstance_cancelsTheTask 22ms
โœ… AccountsManagerCancellationTests testCancelBackgroundWork_onOptOutInstance_isSafeNoOp 8ms
โœ… AccountsManagerCancellationTests testCancelBackgroundWork_whileFetchInFlight_doesNotCommitToAccountSets 548ms
โœ… AccountsManagerGapTests testAccountsManager_accountByUUID_returnsNilForUnknownUUID 9ms
โœ… AccountsManagerGapTests testAccountsManager_currentAccountId_persistsToUserDefaults 7ms
โœ… AccountsManagerGapTests testAccountsManager_tppAccountUUID_isNotEmpty 3ms
โœ… AccountsManagerHelpersTests test_isCacheStale_freshMetadata_returnsFalse 2ms
โœ… AccountsManagerHelpersTests test_isCacheStale_nilMetadata_returnsTrue 3ms
โœ… AccountsManagerHelpersTests test_isCacheStale_serverMaxAgeRespected 4ms
โœ… AccountsManagerHelpersTests test_isCacheStale_staleMetadata_returnsTrue 2ms
โœ… AccountsManagerHelpersTests test_shouldFinishSwitchingImmediately_bothNil_returnsTrue 2ms
โœ… AccountsManagerHelpersTests test_shouldFinishSwitchingImmediately_differentAccounts_returnsFalse 3ms
โœ… AccountsManagerHelpersTests test_shouldFinishSwitchingImmediately_newNilWithExistingPrevious_returnsFalse 3ms
โœ… AccountsManagerHelpersTests test_shouldFinishSwitchingImmediately_previousNil_returnsTrue 3ms
โœ… AccountsManagerHelpersTests test_shouldFinishSwitchingImmediately_sameAccount_returnsTrue 3ms
โœ… AccountsManagerHelpersTests test_shouldPopToRoot_onePath_returnsTrue 3ms
โœ… AccountsManagerHelpersTests test_shouldPopToRoot_threePath_returnsTrue 2ms
โœ… AccountsManagerHelpersTests test_shouldPopToRoot_zeroPath_returnsFalse 2ms
โœ… AccountsManagerIsolationLintTests testLintCatchesSyntheticViolator 3ms
โœ… AccountsManagerIsolationLintTests testNoBareAccountsManagerOutsideWhitelist 1.11s
โœ… AccountsManagerStateMachineWiringTests testDriveCurrentAccountAuthDoc_realAccountNotFound_doesNotRedrive 300ms
โœ… AccountsManagerStateMachineWiringTests testDriveCurrentAccountAuthDoc_staleEvictionMarker_redrives 788ms
โœ… AccountsManagerStateMachineWiringTests testDriveCurrentAccountAuthDoc_terminalState_isNoOp 370ms
โœ… AccountsManagerStateMachineWiringTests testLibraryReselect_priorAccount_terminatesWithLibraryDeselected 121ms
โœ… AccountsManagerStateMachineWiringTests testLibraryReselect_reentry_resetsState_andRedrives 122ms
โœ… AccountsManagerStateMachineWiringTests testLibrarySwitch_drivesNewCurrentAccountPastBasicInfoLoaded 433ms
โœ… AccountsManagerStateMachineWiringTests testLoadCatalogs_authDocFetchFails_drivesDetailsFailed 11ms
โœ… AccountsManagerStateMachineWiringTests testLoadCatalogs_currentAccountWithoutDetails_drivesDetailsLoading_thenLoaded 390ms
โœ… AccountsManagerStateMachineWiringTests testLoadCatalogs_warmPath_drivesCurrentAccountPastBasicInfoLoaded 323ms
โœ… AccountsManagerStateMachineWiringTests testPreload_drivesEachLoadedAccount_toBasicInfoLoaded 345ms
โœ… AccountsManagerStateMachineWiringTests testSingleFlight_twoConcurrentAwaiters_oneNetworkRequest 34ms
โœ… AccountsManagerStateMachineWiringTests testStartDownload_currentAccountIdRoundTrip_A_nil_A_B_eachCaptureIsPinned 971ms
โœ… AccountsManagerStateMachineWiringTests testStartDownload_endToEnd_capturedAccountIdReachesAuthorizationHeader 318ms
โœ… AccountsManagerTests testAccountChangeNotification_HasCorrectName 90ms
โœ… AccountsManagerTests testAccountDetails_DefaultAuth_ReturnsNonOAuthFirst 85ms
โœ… AccountsManagerTests testAccountDetails_NeedsAgeCheck_WhenCOPPAAuthExists 86ms
โœ… AccountsManagerTests testAccountDetails_SupportsReservations 84ms
โœ… AccountsManagerTests testAccountDetails_SupportsSimplyESync 110ms
โœ… AccountsManagerTests testAccountLookup_FromMultipleThreads_DoesNotCrash 248ms
โœ… AccountsManagerTests testAccount_AuthenticationDocumentUrl_IsValid 100ms
โœ… AccountsManagerTests testAccount_BarcodeAuthentication_IsBasic 89ms
โœ… AccountsManagerTests testAccount_CatalogUrl_IsValid 105ms
โœ… AccountsManagerTests testAccount_HasAuthenticationTypes 138ms
โœ… AccountsManagerTests testAccount_HasRequiredProperties 84ms
โœ… AccountsManagerTests testAccount_OAuthAuthentication_IsOAuth 144ms
โœ… AccountsManagerTests testAccount_SAMLAuthentication_IsSAML 94ms
โœ… AccountsManagerTests testAccount_WithEmptyUUID_ReturnsNil 87ms
โœ… AccountsManagerTests testAccount_WithExistingUUID_ReturnsAccount 103ms
โœ… AccountsManagerTests testAccount_WithNonExistentUUID_CreatesNewAccount 123ms
โœ… AccountsManagerTests testAccount_WithNonExistentUUID_ReturnsNil 120ms
โœ… AccountsManagerTests testAccount_WithValidUUID_ReturnsAccount 121ms
โœ… AccountsManagerTests testAccountsHaveLoaded_IsConsistentWithAccountsQuery 84ms
โœ… AccountsManagerTests testAccountsManager_ConformsToTPPLibraryAccountsProvider 79ms
โœ… AccountsManagerTests testAccountsManager_HasAgeCheck 114ms
โœ… AccountsManagerTests testAccountsManager_HasNYPLAccountUUID 167ms
โœ… AccountsManagerTests testAccountsManager_WithEmptyUUID_ReturnsNil 89ms
โœ… AccountsManagerTests testAccounts_FromMultipleThreads_DoesNotCrash 90ms
โŠ˜ AccountsManagerTests testAccounts_WithNilKey_ReturnsCurrentAccountSet 99ms
โœ… AccountsManagerTests testAccounts_WithNonExistentKey_ReturnsEmptyArray 89ms
โœ… AccountsManagerTests testAuthenticationType_Basic_DoesNotRequireCatalogAuthentication 84ms
โœ… AccountsManagerTests testAuthenticationType_Basic_NeedsAuth 111ms
โœ… AccountsManagerTests testAuthenticationType_OAuth_NeedsAuth 92ms
โœ… AccountsManagerTests testAuthenticationType_OAuth_RequiresCatalogAuthentication 122ms
โœ… AccountsManagerTests testAuthenticationType_SAML_NeedsAuth 84ms
โœ… AccountsManagerTests testCatalogDidLoadNotification_CanBeObservedWithCombine 127ms
โœ… AccountsManagerTests testCatalogDidLoad_NotificationExists 87ms
โœ… AccountsManagerTests testClearCache_DoesNotThrow 79ms
โœ… AccountsManagerTests testCreateOPDS2Publication_ReturnsValidPublication 121ms
โœ… AccountsManagerTests testCurrentAccountId_AfterExplicitClear_ReturnsNilFromDefaults 101ms
โœ… AccountsManagerTests testCurrentAccountId_PersistsToUserDefaults 104ms
โœ… AccountsManagerTests testCurrentAccount_WhenChanged_PostsNotification 101ms
โœ… AccountsManagerTests testLoadCatalogs_PostsCatalogDidLoadNotification 100ms
โœ… AccountsManagerTests testMockLibraryAccountProvider_CurrentAccountId_MatchesUUID 96ms
โœ… AccountsManagerTests testMockLibraryAccountProvider_CurrentAccount_ReturnsTPPAccount 79ms
โœ… AccountsManagerTests testMultipleNotificationObservers_AllReceiveAccountChange 116ms
โœ… AccountsManagerTests testNotificationObserver_ForAccountChange_CanBeAdded 129ms
โœ… AccountsManagerTests testNotification_CanBeObservedWithCombine 170ms
โœ… AccountsManagerTests testShared_ReturnsSameInstance 123ms
โœ… AccountsManagerTests testTPPAccountUUIDs_ContainsExpectedAccounts 104ms
โœ… AccountsManagerTests testTPPNationalAccountUUIDs_ContainsPalaceBookshelf 83ms
โœ… AccountsManagerTests testUpdateAccountSet_WithCompletion_CallsCompletion 89ms
โœ… AccountsManagerTests testUpdateAccountSet_WithNilCompletion_DoesNotCrash 118ms
โœ… AccountsManagerTests testUseBetaDidChange_NotificationExists 85ms
โœ… AccountsManagerTests testUseBetaDidChange_PostsNotificationWhenSettingChanges 1m 37s
โœ… ActiveSessionsViewModelTests testContinueListening_emptyWhenSessionIdle 4ms
โœ… ActiveSessionsViewModelTests testContinueListening_includesPausedSession 5ms
โœ… ActiveSessionsViewModelTests testContinueListening_includesPlayingSession 7ms
โœ… ActiveSessionsViewModelTests testContinueListening_includesPositionGreaterThanZero_notExactlyZero 6ms
โœ… ActiveSessionsViewModelTests testDeriveMostRecent_picksListeningWhenListeningIsNewerThanReading 4ms
โœ… ActiveSessionsViewModelTests testDeriveMostRecent_picksReadingWhenReadingIsNewerThanListening 5ms
โœ… ActiveSessionsViewModelTests testInit_populatesBothArrays_fromInitialInputs 29ms
โœ… ActiveSessionsViewModelTests testReadingRowLimit_isHonored 6ms
โœ… ActiveSessionsViewModelTests testRefresh_firesOnAudiobookSessionStatePublisher 14ms
โœ… ActiveSessionsViewModelTests testRefresh_firesOnBookOpenedNotification 9ms
โœ… ActiveSessionsViewModelTests testRefresh_firesOnCurrentAccountDidChange 6ms
โœ… ActiveSessionsViewModelTests testRefresh_firesOnRegistryStateNotification 208ms
โœ… AdobeActivationTests test_acsmFulfillment_E_ADEPT_NOT_READY_surfacesError 3ms
โœ… AdobeActivationTests test_acsmFulfillment_validInput_succeedsAndReturnsEPUB 2ms
โœ… AdobeActivationTests test_deauthorize_clearsDeviceState 11ms
โœ… AdobeActivationTests test_deviceActivation_alreadyActivated_isIdempotent 2ms
โœ… AdobeActivationTests test_deviceActivation_failurePath_doesNotPersistInvalidCredentials 6ms
โœ… AdobeActivationTests test_deviceActivation_succeeds_withValidLicensor 7ms
โœ… AdobeCertificateGapTests testAdobeCertificate_expirationDate_computesFromTimestamp 7ms
โœ… AdobeCertificateGapTests testAdobeCertificate_expirationDate_nilWhenNoTimestamp 4ms
โœ… AdobeCertificateGapTests testAdobeCertificate_hasExpired_falseForFutureDate 4ms
โœ… AdobeCertificateGapTests testAdobeCertificate_hasExpired_falseWhenNoExpiration 6ms
โœ… AdobeCertificateGapTests testAdobeCertificate_hasExpired_trueForPastDate 2ms
โœ… AdobeCertificateGapTests testAdobeCertificate_initFromData_decodesValidJSON 2ms
โœ… AdobeCertificateGapTests testAdobeCertificate_initFromData_returnsNilForInvalidJSON 11ms
โœ… AdobeDRMCharacterizationTests test_acsmFulfillment_credentialsRequiredToFulfill_mapsToAdobeError 2ms
โœ… AdobeDRMCharacterizationTests test_acsmFulfillment_expiredACSM_mapsToAdobeErrorBucket 2ms
โœ… AdobeDRMCharacterizationTests test_acsmFulfillment_loanNotOnRecord_mapsToAdobeError 2ms
โœ… AdobeDRMCharacterizationTests test_authorize_incrementsCallCount_andSetsCalledFlag 2ms
โœ… AdobeDRMCharacterizationTests test_authorize_invokesCompletionWithSuccess_andCarriesIDs 6ms
โœ… AdobeDRMCharacterizationTests test_authorize_thenIsUserAuthorized_returnsTrue_simulatingGate 3ms
โœ… AdobeDRMCharacterizationTests test_deauthorize_deferredCompletion_canBeFiredManually 8ms
โœ… AdobeDRMCharacterizationTests test_deauthorize_failurePath_completionStillFires 3ms
โœ… AdobeDRMCharacterizationTests test_deauthorize_idempotency_doubleCallIsSafe 12ms
โœ… AdobeDRMCharacterizationTests test_deauthorize_invokesCompletionWithSuccess 3ms
โœ… AdobeDRMCharacterizationTests test_deauthorize_isInvokedWithLicensorCredentials_simulatingSignOut 9ms
โœ… AdobeDRMCharacterizationTests test_doubleAuthorize_doesNotShortCircuit_atTheMockLayer 2ms
โœ… AdobeDRMCharacterizationTests test_isUserAuthorized_defaultsTrue_onFreshMock 2ms
โœ… AdobeDRMCharacterizationTests test_isUserAuthorized_returnsFalse_whenFlagSet 2ms
โœ… AdobeDRMCharacterizationTests test_palaceErrorFrom_authenticationFailedNSError_mapsToDRMAuthFailed 2ms
โœ… AdobeDRMCharacterizationTests test_palaceErrorFrom_nonAdobeDomainNSError_doesNotMisroutToDRM 2ms
โœ… AdobeDRMCharacterizationTests test_palaceErrorFrom_passesThroughExistingPalaceError 2ms
โœ… AdobeDRMCharacterizationTests test_palaceErrorFrom_tooManyActivationsNSError_mapsToDRMTooMany 3ms
โœ… AdobeDRMCharacterizationTests test_palaceErrorFrom_unknownAdeptCode_fallsBackToAdobeError 2ms
โœ… AdobeDRMCharacterizationTests test_reset_clearsAllTrackingState 2ms
โœ… AdobeDRMCharacterizationTests test_workflowsInProgress_defaultsFalse 2ms
โœ… AdobeDRMErrorGapTests testAdobeDRMError_conformsToLocalizedError 2ms
โœ… AdobeDRMErrorGapTests testAdobeDRMError_errorDescription_isNotEmpty 3ms
โœ… AdobeDRMErrorGapTests testAdobeDRMError_expiredCase_exists 9ms
โœ… AdobeDRMHandlerTests testHandleCancellation_setsRegistryStateAndBroadcasts 6ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_copyFailure_failsWithAlert 17ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_didFinishCopySucceeded_marksSuccessfulAndPersistsRights 7ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_didFinishDownloadFalse_failsAndDoesNotMarkSuccessful 7ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_missingAdeptToURL_failsWithAlert 7ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_missingDestinationURL_failsWithAlert 6ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_nonReturnable_skipsFulfillmentIdPersistence 8ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_returnableButNoFulfillmentID_skipsPersistence 6ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_undecodableRightsData_returnsEarlyWithoutSideEffects 6ms
โœ… AdobeDRMHandlerTests testHandleFulfillment_unknownBookIdentifier_returnsEarlyWithoutSideEffects 6ms
โœ… AdobeDRMHandlerTests testHandleNoAuthorization_doesNotMutateRegistryOrAlert 6ms
โœ… AdobeDRMHandlerTests testProgressForwarding_invokesDelegateWithProgressAndTag 6ms
โœ… AdobeDRMServiceGapTests testAdobeDRMService_isReady_returnsBoolean 2ms
โœ… AdobeDRMServiceGapTests testAdobeDRMService_shared_isAccessible 3ms
โœ… AlertModelCoverageTests testAlertModel_basicProperties 2ms
โœ… AlertModelCoverageTests testAlertModel_customButtonTitle 6ms
โœ… AlertModelCoverageTests testAlertModel_maxRetriesExceeded 2ms
โœ… AlertModelCoverageTests testAlertModel_retryable 2ms
โœ… AlertModelCoverageTests testAlertModel_retryableWithCancel 5ms
โœ… AlertModelCoverageTests testAlertModel_uniqueId 6ms
โœ… AlertModelRetryTests testAlertModel_eachInstanceHasUniqueIdentity 6ms
โœ… AlertModelRetryTests testDefaultAlertModel_hasExpectedDefaults 4ms
โœ… AlertModelRetryTests testHalfSheetBranching_secondaryNilSelectsOKOnly_secondaryNonNilSelectsRetryCancel 2ms
โœ… AlertModelRetryTests testMaxRetriesExceeded_factoryShapesAlertForOKOnlyBranch 2ms
โœ… AlertModelRetryTests testRetryable_factoryShapesAlertForRetryPlusCancelBranch 3ms
โœ… AlertModelRetryTests testRetryable_invokesRetryActionAndCancelActionOnTheCorrectSlots 2ms
โœ… AlertModelRetryTests testRetryable_omittedCancelActionIsSafeNoOp 6ms
โœ… AlertModelTests testAlertModel_StoresProvidedValues 3ms
โœ… AlertModelTests testAlertModel_SyncingAlertStrings_AreNotEmpty 2ms
โœ… AlertUtilsTests testAlertWithDestructiveStyle 7ms
โœ… AlertUtilsTests testAlertWithDetailsHasOKButtonWhenNoRetry 15ms
โœ… AlertUtilsTests testAlertWithDetailsHasRetryAndCancelWhenRetryProvided 13ms
โœ… AlertUtilsTests testAlertWithDetailsHasViewErrorDetailsButton 12ms
โœ… AlertUtilsTests testAlertWithErrorHavingNoDescription 76ms
โœ… AlertUtilsTests testAlertWithNilError 5ms
โœ… AlertUtilsTests testAlertWithNilMessageAndError_ErrorWins 158ms
โœ… AlertUtilsTests testAlertWithNonURLError 8ms
โœ… AlertUtilsTests testAlertWithTitleAndMessage 14ms
โœ… AlertUtilsTests testAlert_explicitMessageOverridesErrorDerivedMessage 16ms
โœ… AlertUtilsTests testAlert_nilMessage_yieldsEmptyStringWithoutAffectingTitle 10ms
โœ… AlertUtilsTests testAlert_nsurlErrors_alwaysProduceNonEmptyMessage 421ms
โœ… AlertUtilsTests testAlert_nsurlErrors_keyedMessages_areDistinguishable 17ms
โœ… AlertUtilsTests testAlert_titleFallback_handlesNilEmptyAndPassThrough 54ms
โœ… AlertUtilsTests testPresentFromViewControllerOrNilWithNilAlert 207ms
โœ… AlertUtilsTests testSetProblemDocumentAppend 285ms
โœ… AlertUtilsTests testSetProblemDocumentReplace 6ms
โœ… AlertUtilsTests testSetProblemDocumentWithNilController 57ms
โœ… AlertUtilsTests testSetProblemDocumentWithNilDocument 6ms
โœ… AlertUtilsTests testSetProblemDocument_partialDocumentReplacesOnlyPresentFields 70ms
โœ… AnnotationContractTests testBookmarkAndReadingPosition_HaveDifferentMotivations 13ms
โœ… AnnotationContractTests testParseAnnotationContainer 9ms
โœ… AnnotationContractTests testReadingPosition_HasEPUBCFISelector 9ms
โœ… AnnotationDeviceIDTests testAnnotationDeviceID_WhenNoAdobeDRM_ReturnsFirebaseDeviceID 12ms
โœ… AnnotationDeviceIDTests testAnnotationDeviceID_isStableAndDerivedFromFirebaseInTestEnvironment 4ms
โœ… AnnotationPostResponseContractTests testAnnotationPostResponse_HasRequiredFields 10ms
โœ… AnnouncementChainTests test_chainAttachmentIndices_fiveAnnouncements_returnsFourChainedPairs 9ms
โœ… AnnouncementChainTests test_chainAttachmentIndices_oneAnnouncement_returnsEmpty 72ms
โœ… AnnouncementChainTests test_chainAttachmentIndices_threeAnnouncements_returnsTwoChainedPairs 6ms
โœ… AnnouncementChainTests test_chainAttachmentIndices_twoAnnouncements_returnsOnePair 28ms
โœ… AnnouncementChainTests test_chainAttachmentIndices_zeroAnnouncements_returnsEmpty 3ms
โœ… AnnouncementTests testAnnouncement_decodesValidJSON 4ms
โœ… AnnouncementTests testAnnouncement_withMissingContent_throwsError 3ms
โœ… AnnouncementTests testAnnouncement_withMissingId_throwsError 3ms
โœ… AnonymousBorrowBaselineFixtureTests test_02_afterAllowNotif_libraryPickerShowsPalaceBookshelfAtTop 4ms
โœ… AnonymousBorrowBaselineFixtureTests test_02_afterAllowNotif_notifPermissionOverlayDismissed 25ms
โœ… AnonymousBorrowBaselineFixtureTests test_03_catalog_anonymousFlowDoesNotShowSignInModal 12ms
โœ… AnonymousBorrowBaselineFixtureTests test_03_catalog_tabBarHasFourTabs 4ms
โœ… AnonymousBorrowBaselineFixtureTests test_03_catalog_threeLanesRenderInOrder 46ms
โœ… AnonymousBorrowBaselineFixtureTests test_03_catalog_titleIsPalaceBookshelf 4ms
โœ… AnonymousBorrowBaselineFixtureTests test_04_bookDetail_borrowButtonAppearsAboveDescription 6ms
โœ… AnonymousBorrowBaselineFixtureTests test_04_bookDetail_borrowButtonPresent 4ms
โœ… AnonymousBorrowBaselineFixtureTests test_04_bookDetail_preBorrowDoesNotShowReadOrRemove 3ms
โœ… AnonymousBorrowBaselineFixtureTests test_05_afterBorrow_borrowButtonGoneReadAndRemoveAppear 6ms
โœ… AnonymousBorrowBaselineFixtureTests test_05_afterBorrow_libraryAttributionShowsPalaceBookshelf 10ms
โœ… AnonymousBorrowBaselineFixtureTests test_06_myBooks_borrowedBookAppears 4ms
โœ… AnonymousBorrowBaselineFixtureTests test_06_myBooks_sortIndicatorShowsTitle 4ms
โœ… AnonymousBorrowCandidateFixtureTests test_03_catalog_anonymousFlowDoesNotShowSignInModal 3ms
โœ… AnonymousBorrowCandidateFixtureTests test_03_catalog_tabBarHasFourTabs 3ms
โœ… AnonymousBorrowCandidateFixtureTests test_03_catalog_threeLanesRenderInOrder 24ms
โœ… AnonymousBorrowCandidateFixtureTests test_03_catalog_titleIsPalaceBookshelf 3ms
โœ… AnonymousBorrowCandidateFixtureTests test_05_afterBorrow_borrowButtonGoneReadAndRemoveAppear 5ms
โœ… AnonymousBorrowCandidateFixtureTests test_06_myBooks_borrowedBookAppears 4ms
โœ… AnonymousBorrowDeltaTests test_03_catalog_structureMatchesBetweenVersions 4ms
โœ… AnonymousBorrowDeltaTests test_06_myBooks_postBorrowStateMatchesBetweenVersions 11ms
โœ… AppContainerAudiobookFactoryTests testAudiobookFactories_areCoherentAcrossProductionReads 2ms
โœ… AppContainerAudiobookFactoryTests testAudiobookSession_returnsSameInstanceAcrossReads 3ms
โœ… AppContainerAudiobookFactoryTests testPlaybackBootstrapper_returnsSameInstanceAcrossReads 2ms
โœ… AppContainerAuthCoordinatorRegistrationTests testProductionAppContainer_authCoordinator_isSingletonAcrossCalls 3ms
โœ… AppContainerAuthCoordinatorRegistrationTests testProductionAppContainer_downloadCenter_isSingletonAcrossCalls 2ms
โœ… AppContainerAuthCoordinatorRegistrationTests testProductionAppContainer_exposesNonNilAuthCoordinator 2ms
โœ… AppContainerImageLoaderInjectionTests testContainer_holdsInjectedImageLoader 4ms
โœ… AppContainerImageLoaderInjectionTests testContainer_imageLoader_evictDecodedRoutesToInjectedInstance 3ms
โœ… AppContainerImageLoaderInjectionTests testContainer_imageLoader_setForwardsToInjectedInstance 19ms
โœ… AppContainerImageLoaderInjectionTests testProductionContainer_exposesNonNilImageLoader 49ms
โœ… AppContainerIsolationLintTests testDeferredListFileIsLoaded 5ms
โœ… AppContainerIsolationLintTests testLintCatchesSyntheticViolation 6ms
โœ… AppContainerIsolationLintTests testLintIgnoresCommentLines 3ms
โœ… AppContainerIsolationLintTests testLintRespectsPerLineExemptionMarker 2ms
โœ… AppContainerIsolationLintTests testNoAppContainerProductionOutsideWhitelist 1.98s
โœ… AppContainerResetTests testResetForTesting_cancelsOldBackgroundWork 17ms
โœ… AppContainerResetTests testResetForTesting_disablesBackgroundLoadCatalogs 14ms
โœ… AppContainerResetTests testResetForTesting_isIdempotent_multipleConsecutiveCallsAreSafe 17ms
โœ… AppContainerResetTests testResetForTesting_reinitializesCachedGraph 16ms
โœ… AppContainerTests testEnvironmentValues_appContainerDefault_matchesProductionFactory 5ms
โœ… AppContainerTests testInit_twoContainersWithDifferentRegistries_remainIndependent 5ms
โœ… AppContainerTests testInit_withMockBookRegistry_exposesTheMockNotTheProductionRegistry 4ms
โœ… AppContainerTests testProduction_handsOutStableAppScopedRegistry 5ms
โœ… AppContainerWithSignInModalSheetPresenterTests testWithSignInModalSheetPresenter_overrideValue_isPreferredOverStaticCache 12ms
โœ… AppContainerWithSignInModalSheetPresenterTests testWithSignInModalSheetPresenter_productionContainer_fallsThroughToStaticCacheWhenOverrideNil 2ms
โœ… AppHealthViewModelTests testAppLaunchStatusThresholds 223ms
โœ… AppHealthViewModelTests testHealthMetricItemProperties 2ms
โœ… AppHealthViewModelTests testInitialState 3ms
โœ… AppHealthViewModelTests testLoadDataIncludesMemoryMetric 249ms
โœ… AppHealthViewModelTests testLoadDataIncludesOfflineQueueMetrics 250ms
โœ… AppHealthViewModelTests testLoadDataPopulatesMetrics 215ms
โœ… AppHealthViewModelTests testOfflineQueueStatusUpdates 224ms
โœ… AppHealthViewModelTests testPerformanceReportGenerated 225ms
โœ… AppLaunchTrackerExtendedTests testAllMilestones_RecordedInChronologicalOrder 26ms
โœ… AppLaunchTrackerExtendedTests testColdLaunch_AfterReset 5ms
โœ… AppLaunchTrackerExtendedTests testDefaultIsColdLaunch 6ms
โœ… AppLaunchTrackerExtendedTests testDuplicateMilestone_DoesNotCreateExtraEntries 3ms
โœ… AppLaunchTrackerExtendedTests testDuplicateMilestone_OverwritesTimestamp 54ms
โœ… AppLaunchTrackerExtendedTests testLaunchMilestone_AllCases 2ms
โœ… AppLaunchTrackerExtendedTests testMarkWarmLaunch_ChangesType 4ms
โœ… AppLaunchTrackerExtendedTests testMilestoneCount_MatchesRecordedCount 3ms
โœ… AppLaunchTrackerExtendedTests testTimeBetween_NilWhenBothMissing 2ms
โœ… AppLaunchTrackerExtendedTests testTimeBetween_NilWhenEndMissing 8ms
โœ… AppLaunchTrackerExtendedTests testTimeBetween_NilWhenStartMissing 5ms
โœ… AppLaunchTrackerExtendedTests testTimeToFirstFrame_NilWithoutFirstFrame 3ms
โœ… AppLaunchTrackerExtendedTests testTimeToInteractive_NilWithoutCatalogLoaded 5ms
โœ… AppLaunchTrackerExtendedTests testTimeToInteractive_NilWithoutProcessStart 2ms
โœ… AppLaunchTrackerExtendedTests testTimeToInteractive_RequiresProcessStartAndCatalogLoaded 37ms
โœ… AppLaunchTrackerExtendedTests testWarmLaunch_ReportsWithWarmType 270ms
โœ… AppLaunchTrackerTests testCatalogLoadedReportsToMonitor 153ms
โœ… AppLaunchTrackerTests testDefaultLaunchTypeIsCold 9ms
โœ… AppLaunchTrackerTests testRecordAllMilestones 45ms
โœ… AppLaunchTrackerTests testRecordProcessStart 14ms
โœ… AppLaunchTrackerTests testReset 15ms
โœ… AppLaunchTrackerTests testTimeBetweenMilestones 59ms
โœ… AppLaunchTrackerTests testTimeBetweenUnrecordedMilestones 11ms
โœ… AppLaunchTrackerTests testTimeToFirstFrame 33ms
โœ… AppLaunchTrackerTests testTimeToInteractive 43ms
โœ… AppLaunchTrackerTests testWarmLaunchType 9ms
โœ… AppRouteTests testAppRoute_Audio_IsHashable 2ms
โœ… AppRouteTests testAppRoute_BookDetail_IsHashable 2ms
โœ… AppRouteTests testAppRoute_DifferentTypes_NotEqual 2ms
โœ… AppRouteTests testBookRoute_IsHashable 12ms
โœ… AppRouteTests testSearchRoute_IsHashable 2ms
โœ… AppTabHostMiniPlayerIntegrationTests testAppTabHost_fullScreenCoverBindsToPresenterIsPlayerExpanded 37ms
โœ… AppTabHostMiniPlayerIntegrationTests testAppTabHost_presentOnFirstOpen_flipsCoverBinding_synchronouslyForF011 22ms
โœ… AppTabHostMiniPlayerIntegrationTests testAppTabHost_safeAreaInsetContainsMiniPlayer 269ms
โœ… AppTabHostMiniPlayerIntegrationTests testNavigationHostView_epubRoute_setsIsReaderActiveTrue 12ms
โœ… AppTabHostMiniPlayerIntegrationTests testNavigationHostView_popsEpubRoute_setsIsReaderActiveFalse 31ms
โœ… AppTabHostMiniPlayerIntegrationTests testReaderActive_drivenThroughTwoRoutePushes_andTwoPops_acrossEpubAndPdf 8ms
โœ… AppTabHostViewBadgeCountTests test_computeReadyCount_emptyArray_returnsZero 2ms
โœ… AppTabHostViewBadgeCountTests test_computeReadyCount_mixedReservedAndReady_returnsOnlyReadyCount 37ms
โœ… AppTabHostViewBadgeCountTests test_computeReadyCount_oneReadyBook_returnsOne 8ms
โœ… AppTabHostViewBadgeCountTests test_computeReadyCount_reservedBooksOnly_returnsZero 16ms
โœ… AppTabHostViewBadgeCountTests test_computeReadyCount_threeReadyBooks_returnsThree 10ms
โœ… AppTabHostViewBadgeCountTests test_computeReservedCount_emptyArray_returnsZero 3ms
โœ… AppTabHostViewBadgeCountTests test_computeReservedCount_readyBooksOnly_returnsZero 19ms
โœ… AppTabHostViewBadgeCountTests test_computeReservedCount_twoReservedBooks_returnsTwo 14ms
โœ… AppTabHostViewBadgeCountTests test_shouldUpdateBadge_loadedOrSynced_returnsTrue 4ms
โœ… AppTabHostViewBadgeCountTests test_shouldUpdateBadge_unloadedOrLoadingOrSyncing_returnsFalse 3ms
โœ… AppTabRouterCoverageTests testAppTabRouterHub_weakRouterReference 5ms
โœ… AppTabRouterCoverageTests testAppTabRouter_defaultIsCatalog 3ms
โœ… AppTabRouterCoverageTests testAppTabRouter_publishesSelectionChanges 4ms
โœ… AppTabRouterCoverageTests testAppTabRouter_sequentialTabChangesPreserveLastValue 2ms
โœ… AppTabRouterGapTests testAppTabRouterHub_registeredRouterIsWeaklyHeld 5ms
โœ… AppTabRouterGapTests testAppTabRouter_roundTripToDefaultEmitsTwoChangeEvents 5ms
โœ… AppTabRouterGapTests testAppTabRouter_tabSwitchPublishesChangeEvent 3ms
โœ… ArrayExtensionsTests testSafeSubscriptGet_NegativeIndex_ReturnsNil 4ms
โœ… ArrayExtensionsTests testSafeSubscriptGet_OutOfBounds_ReturnsNil 3ms
โœ… ArrayExtensionsTests testSafeSubscriptGet_StringArray_ReturnsElement 5ms
โœ… ArrayExtensionsTests testSafeSubscriptGet_ValidIndex_ReturnsElement 2ms
โœ… ArrayExtensionsTests testSafeSubscriptGet_emptyArray_returnsNilForAllIndices 5ms
โœ… ArrayExtensionsTests testSafeSubscriptSet_updatesValidIndicesAndIgnoresInvalidWrites 3ms
โœ… AudioBookmarkGapTests testAudioBookmark_copy_createsIndependentCopy 280ms
โœ… AudioBookmarkGapTests testAudioBookmark_creation_storesBasicProperties 2ms
โœ… AudioBookmarkGapTests testAudioBookmark_isSimilar_returnsFalseForDifferentChapter 8ms
โœ… AudioBookmarkGapTests testAudioBookmark_isSimilar_returnsTrueForSameChapterPosition 244ms
โœ… AudioBookmarkGapTests testAudioBookmark_toData_producesRoundTripData 29ms
โœ… AudioBookmarkGapTests testAudioBookmark_toTPPBookLocation_producesValidLocation 5ms
โœ… AudioEngineWrapperTests test_chapterStatusCache_after_pause_doesNotDispose 2ms
โœ… AudioEngineWrapperTests test_chapterStatusCache_emptyChapters_returnsNoFault 139ms
โœ… AudioEngineWrapperTests test_feedbookVendor_classifiesCantook_fromValidSignature 5ms
โœ… AudioEngineWrapperTests test_feedbookVendor_isIdempotent_acrossRapidOpenClosePairs 15ms
โœ… AudioEngineWrapperTests test_feedbookVendor_returnsNil_forMissingMetadata 10ms
โœ… AudioEngineWrapperTests test_feedbookVendor_returnsNil_forUnknownIssuer 3ms
โœ… AudioEngineWrapperTests test_openFindawayBook_repeatedOpen_doesNotDoubleReleaseSemaphore 34ms
โœ… AudioEngineWrapperTests test_openFindawayBook_succeeds_withValidLicense 4ms
โœ… AudioInterruptionLogicTests testNoResume_whenNoShouldResume_andWasNotPlaying 2ms
โœ… AudioInterruptionLogicTests testResume_phoneCallDeclinedScenario 15ms
โœ… AudioInterruptionLogicTests testResume_siriInterruptionScenario 3ms
โœ… AudioInterruptionLogicTests testResume_whenNoShouldResume_butWasPlaying 14ms
โœ… AudioInterruptionLogicTests testResume_whenShouldResumeSet_andWasPlaying 2ms
โœ… AudioInterruptionLogicTests testResume_whenShouldResumeSet_butWasNotPlaying 2ms
โœ… AudiobookAccessibilityTests testAudiobookIndicator_labelExists 7ms
โœ… AudiobookAccessibilityTests testPauseLabel_isDescriptive 4ms
โœ… AudiobookAccessibilityTests testPlayLabel_isDescriptive 27ms
โœ… AudiobookAccessibilityTests testPlayPauseLabel_changesWithState 4ms
โœ… AudiobookAccessibilityTests testPlayPauseLabels_areDifferent 2ms
โœ… AudiobookAccessibilityTests testSkipBackLabel_indicatesTimeUnit 8ms
โœ… AudiobookAccessibilityTests testSkipBackLabel_isDescriptiveWithDuration 3ms
โœ… AudiobookBackgroundAudioTests testContinuousPlayback_accumulatesCorrectly 17ms
โœ… AudiobookBackgroundAudioTests testInterruptedPlayback_savesPartialTime 24ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testIsAtBeginning_preservedAfterMigration_doesNotOverwriteValidPosition 261ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testSaveListeningPosition_delegatesNetworkSaveToPositionWriter 673ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testSaveListeningPosition_savesLocallyImmediately 46ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testSaveListeningPosition_writerError_doesNotCrash_completionCalledWithError 16.98s
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testSaveListeningPosition_writerThrottled_localStillCommitted 74ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests testTimestampNewerRace_preservedAfterMigration_keepsLocal 53.17s
โœ… AudiobookBookmarkBusinessLogicTests testBusinessLogic_canBeInitialized 4ms
โœ… AudiobookBookmarkBusinessLogicTests testBusinessLogic_hasBookReference 5ms
โœ… AudiobookBookmarkBusinessLogicTests testDebounce_DeallocDuringPendingWork_DoesNotCrash 1.55s
โœ… AudiobookBookmarkBusinessLogicTests testDebounce_RapidCalls_OnlyLastSyncs 22ms
โœ… AudiobookBookmarkBusinessLogicTests testFlushPendingOperations_ExecutesPendingWork 8ms
โœ… AudiobookBookmarkBusinessLogicTests testFlush_AfterDealloc_DoesNotCrash 23ms
โœ… AudiobookBookmarkBusinessLogicTests testLoadTracks_succeeds 39ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_BothNil_ReturnsNil 6ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_LocalNewerThanRemote_UsesLocal 23ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_OnlyLocalExists_UsesLocal 28ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_OnlyRemoteExists_UsesRemote 31ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_RemoteNewerThanLocal_UsesRemote 48ms
โœ… AudiobookBookmarkBusinessLogicTests testPositionRestoration_SameTimestamp_UsesLocal 28ms
โœ… AudiobookBookmarkBusinessLogicTests testSaveBookmark_AddsToRegistry 1.06s
โœ… AudiobookBookmarkBusinessLogicTests testSaveBookmark_CreatesBookmark 1.06s
โœ… AudiobookBookmarkBusinessLogicTests testSaveListeningPositionSync_SavesImmediately 61ms
โœ… AudiobookBookmarkBusinessLogicTests testSaveListeningPosition_SavesLocallyImmediately 64ms
โœ… AudiobookBookmarkBusinessLogicTests testSaveListeningPosition_SyncsToServer 82ms
โœ… AudiobookBookmarkBusinessLogicTests testSaveListeningPosition_track0_29s_track1AlreadySaved_doesNotOverwriteWithBeginning 27ms
โœ… AudiobookBookmarkBusinessLogicTests testSaveListeningPosition_track0_time0_savesToServer 23ms
โœ… AudiobookBookmarkBusinessLogicTests testSyncBookmarks_MergesLocalAndRemote 38ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_balancedTOC_returnsOriginalCount 3ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_exactlyAtThreshold_returnsOriginal 6ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_oneOverThreshold_collapses 3ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_oversubdividedTOC_collapsesToTrackCount 2ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_slightlyInflatedTOC_returnsOriginalCount 2ms
โœ… AudiobookChapterTOCNormalizationTests testNormalizedChaptersCount_zeroTracks_returnsOriginal 2ms
โœ… AudiobookCrossVendorSmokeTests testSmoke_BearerToken_wiresThroughTwoLegManifestFetch 38ms
โœ… AudiobookCrossVendorSmokeTests testSmoke_LCP_wiresThroughToAudiobooksFactory 16ms
โœ… AudiobookCrossVendorSmokeTests testSmoke_LocalFile_wiresThroughLocalManifestRead 61ms
โœ… AudiobookCrossVendorSmokeTests testSmoke_OpenAccess_wiresThroughSingleLegManifestFetch 28ms
โœ… AudiobookDataManagerEmptyQueueTests testSyncValues_withEmptyQueue_makesNoRequests 13ms
โœ… AudiobookDataManagerErrorHandlingTests testSyncValues_with404Response_removesEntriesAndURL 2.05s
โœ… AudiobookDataManagerErrorHandlingTests testSyncValues_with500Response_keepsEntriesForRetry 2.13s
โœ… AudiobookDataManagerErrorHandlingTests testSyncValues_with503Response_keepsEntriesForRetry 2.04s
โœ… AudiobookDataManagerErrorHandlingTests testSyncValues_withNetworkError_keepsEntries 2.13s
โœ… AudiobookDataManagerErrorHandlingTests testSyncValues_withPartialSuccess_removesOnlySuccessfulEntries 2.04s
โœ… AudiobookDataManagerModelsTests testAudiobookDataManagerStoreInit_empty 13ms
โœ… AudiobookDataManagerModelsTests testAudiobookDataManagerStoreInit_fromData_invalidJson_returnsNil 5ms
โœ… AudiobookDataManagerModelsTests testAudiobookDataManagerStoreInit_fromData_validJson 5ms
โœ… AudiobookDataManagerModelsTests testAudiobookDataManagerStoreJsonRepresentation 2ms
โœ… AudiobookDataManagerModelsTests testAudiobookDataManagerStoreRoundTrip 6ms
โœ… AudiobookDataManagerModelsTests testAudiobookTimeEntryCodable 4ms
โœ… AudiobookDataManagerModelsTests testAudiobookTimeEntryEquality 11ms
โœ… AudiobookDataManagerModelsTests testLibraryBookCodable 3ms
โœ… AudiobookDataManagerModelsTests testLibraryBookEquality 2ms
โœ… AudiobookDataManagerModelsTests testLibraryBookHashable 6ms
โœ… AudiobookDataManagerModelsTests testLibraryBookInit_directAndFromTimeEntryAreEqual 2ms
โœ… AudiobookDataManagerModelsTests testLibraryBookInit_fromTimeEntry 3ms
โœ… AudiobookDataManagerModelsTests testRequestDataInit_fromLibraryBookAndEntries 8ms
โœ… AudiobookDataManagerModelsTests testRequestDataInit_timeEntryDurationMapsToSecondsPlayed 2ms
โœ… AudiobookDataManagerModelsTests testRequestDataJsonRepresentation 3ms
โœ… AudiobookDataManagerModelsTests testRequestDataTimeEntryDescription 2ms
โœ… AudiobookDataManagerModelsTests testResponseDataInit_fromData_emptyResponses 3ms
โœ… AudiobookDataManagerModelsTests testResponseDataInit_fromData_invalidJson_returnsNil 8ms
โœ… AudiobookDataManagerModelsTests testResponseDataInit_fromData_validJson 2ms
โœ… AudiobookDataManagerModelsTests testResponseDataInit_jsonAndDirectProduceSameResult 17ms
โœ… AudiobookDataManagerNetworkSyncTests testAudiobookDataManager_Sync_InitializesCorrectly 12ms
โœ… AudiobookDataManagerNetworkSyncTests testSyncValues_requestBodyContainsCorrectFormat 1.02s
โœ… AudiobookDataManagerNetworkSyncTests testSyncValues_withMultipleBooks_makesRequestForEach 1.09s
โœ… AudiobookDataManagerNetworkSyncTests testSyncValues_withQueuedEntries_postsToCorrectURL 1.07s
โœ… AudiobookDataManagerNetworkSyncTests testSyncValues_withSuccessfulResponse_removesEntriesFromQueue 2.03s
โœ… AudiobookDataManagerSaveTests testDataManagerConformance_savesViaProtocol 12ms
โœ… AudiobookDataManagerSaveTests testSave_addsEntryToQueue 14ms
โœ… AudiobookDataManagerSaveTests testSave_multipleEntries_allQueued 36ms
โœ… AudiobookDataManagerSaveTests testSave_storesURLMapping 13ms
โœ… AudiobookDataManagerStoreRecoveryTests testAudiobookDataManagerStoreInit_rejectsMalformedPayloads 13ms
โœ… AudiobookDataManagerStoreRecoveryTests testAudiobookDataManagerStoreInit_withPartialData_returnsNil 8ms
โœ… AudiobookDataManagerStoreRecoveryTests testLoadStore_withCorruptedJSON_doesNotCrash 12ms
โœ… AudiobookDataManagerStoreRecoveryTests testLoadStore_withEmptyFile_doesNotCrash 12ms
โœ… AudiobookDataManagerStoreRecoveryTests testSaveAndLoadStore_preservesData 2.33s
โœ… AudiobookFileLoggerTests testCleanup_whenOverSizeLimit_deletesOldestFileFirst 74ms
โœ… AudiobookFileLoggerTests testGetLogsDirectoryUrl_directoryExists 4ms
โœ… AudiobookFileLoggerTests testGetLogsDirectoryUrl_returnsURL 8ms
โœ… AudiobookFileLoggerTests testInit_withCustomLogsRoot_usesProvidedDirectory 7ms
โœ… AudiobookFileLoggerTests testLogEvent_atExact2MBBoundary_appendsRatherThanRotates 129ms
โœ… AudiobookFileLoggerTests testLogEvent_concurrentWritesToSameBook_atLeastSomeEventsAppear 72ms
โœ… AudiobookFileLoggerTests testLogEvent_containsTimestamp 7ms
โœ… AudiobookFileLoggerTests testLogEvent_createsLogFile 7ms
โœ… AudiobookFileLoggerTests testLogEvent_multipleEvents_allAppear 10ms
โœ… AudiobookFileLoggerTests testRetrieveLog_atExact1MBBoundary_doesNotTruncate 45ms
โœ… AudiobookFileLoggerTests testRetrieveLog_nonexistentBook_returnsNil 8ms
โœ… AudiobookFileLoggerTests testRetrieveLog_truncatesAbove1MBAndPrependsMarker 46ms
โœ… AudiobookFileLoggerTests testRetrieveLogs_emptyBookIds_returnsEmptyDict 3ms
โœ… AudiobookFileLoggerTests testRetrieveLogs_multipleBooks 19ms
โœ… AudiobookFirstOpenHangTests testAwaitReadinessAndIssueFirstPlay_drivesProbeAndCommand_onProductionWiring 895ms
โœ… AudiobookFirstOpenHangTests testAwaitReadinessAndIssueFirstPlay_timeout_surfacesLoadFailure_andNeverIssuesPlay 1.07s
โœ… AudiobookFirstOpenHangTests testFirstOpen_engineNeverReady_within2s_emitsLoadError 1.17s
โœ… AudiobookFirstOpenHangTests testFirstOpen_engineNotReadyAtBindTime_awaitsReadiness_beforeIssuingPlay 1.06s
โœ… AudiobookFirstOpenHangTests testNavBackAndReopen_secondOpenSucceeds_withoutDoublePlay 1.18s
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_doneButton_callsMinimize 15ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_isEmptyWhenNoPlaybackModel 46ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDownAtExactThreshold_doesNotMinimize 3ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDownBelowThreshold_doesNotMinimize 3ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDownInvokesMinimize 5ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDownWithExactHorizontalDriftLimit_doesNotMinimize 4ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDownWithExcessiveHorizontalDrift_doesNotMinimize 5ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeDown_drivesIsPlayerExpandedFalse 87ms
โœ… AudiobookFullPlayerCoverContainerTests testFullPlayerCover_swipeUp_doesNotMinimize 5ms
โœ… AudiobookLoadFailureSAMLReauthTests testRegressionForBug_SAMLOpenFailureGetsReauth_perHelpSpot17727 105ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_forBasicAuthAccount 72ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_forOAuthAccount 84ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_onCancelledLoadEvenWhenSAMLStale 88ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_whenAuthStateIsLoggedIn 81ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_whenAuthStateIsLoggedOut 82ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_whenCurrentBookIsNil 74ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldNotTrigger_whenNoStoredCredentials 90ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldTrigger_forAnyNonCancelledLoadErrorWhenSAMLStale 113ms
โœ… AudiobookLoadFailureSAMLReauthTests testShouldTrigger_whenStaleCredentialsAndSAMLAndBook 72ms
โœ… AudiobookLoaderDispatchTests testLoad_bearerTokenBook_dispatchesToBearerTokenAdapter 87ms
โœ… AudiobookLoaderDispatchTests testLoad_cancelDuringDispatch_surfacesCancelled 10ms
โœ… AudiobookLoaderDispatchTests testLoad_lcpBook_dispatchesToLCPAdapter 17ms
โœ… AudiobookLoaderDispatchTests testLoad_lcpPriorityOverOthers 44ms
โœ… AudiobookLoaderDispatchTests testLoad_localFileBook_dispatchesToLocalFileAdapter 74ms
โœ… AudiobookLoaderDispatchTests testLoad_noAdapterMatches_failsWithManifestFetchFailed 24ms
โœ… AudiobookLoaderDispatchTests testLoad_openAccessBook_dispatchesToOpenAccessAdapter 57ms
โœ… AudiobookLoaderFinalizeBuildTests test_audiobookLoadError_factoryFailedCarriesManifestType 4ms
โœ… AudiobookLoaderFinalizeBuildTests test_audiobookLoadError_manifestDecodingFailedCarriesUnderlying 11ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_factoryReturnsNil_noEncryptedBlock_decodesFine 20ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_factoryReturnsNil_throwsFactoryFailed 5ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_invalidJSON_throwsManifestDecodingFailed 2ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_nilDecryptor_doesNotTrap 12ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_overdriveBook_passesBearerToken 302ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_truncatedJSON_throwsCleanly 2ms
โœ… AudiobookLoaderFinalizeBuildTests test_finalizeBuild_validManifest_succeeds 11ms
โœ… AudiobookLoaderOPDSShapeMatrixTests testMatrix_OPDS1XMLFeedTopLevelLCP_routesToLCP 30ms
โœ… AudiobookLoaderOPDSShapeMatrixTests testMatrix_OPDS2JSONFeedNestedLCP_routesToLCP 38ms
โœ… AudiobookLoaderOPDSShapeMatrixTests testMatrix_findawayTypedManifest_routesToOpenAccessAdapter 50ms
โœ… AudiobookLoaderOPDSShapeMatrixTests testMatrix_openAccessNoDRM_routesToOpenAccessAdapter 27ms
โœ… AudiobookLoaderOPDSShapeMatrixTests testMatrix_openAccessWithBearerToken_routesToBearerTokenAdapter 26ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_allPresent_returnsTrue 4ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_emptyPin_returnsFalse 11ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_emptyUsername_returnsFalse 6ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_nilPin_returnsFalse 40ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_nilTokenURL_returnsFalse 3ms
โœ… AudiobookLoaderPredicateTests testHasRefreshableCredentials_nilUsername_returnsFalse 2ms
โœ… AudiobookLoaderPredicateTests testLooksLikeHTMLResponse_applicationJSON_returnsFalse 8ms
โœ… AudiobookLoaderPredicateTests testLooksLikeHTMLResponse_noContentTypeHeader_returnsFalse 11ms
โœ… AudiobookLoaderPredicateTests testLooksLikeHTMLResponse_textHTMLWithCharset_returnsTrue 3ms
โœ… AudiobookLoaderPredicateTests testLooksLikeHTMLResponse_textHTML_returnsTrue 2ms
โœ… AudiobookLoaderPredicateTests testLooksLikeHTMLResponse_xhtml_returnsTrue 6ms
โœ… AudiobookLoaderTests testLoad_missingLocalFileAndUnreachableURL_failsWithManifestError 133ms
โœ… AudiobookLoaderTests testLoad_whenCancelledFirst_surfacesCancelledError 46ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_coverImage_readsFromPresenter 10ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_formatTime_returnsExpectedMMSS 10ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_hasAccessibilityLabel 9ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_isHidden_whenHasActiveSessionFalse 19ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_isHidden_whenIsReaderActiveTrue 9ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_isPlayingPublished_drivesGlyphLabel 17ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_isVisible_whenSessionActiveAndReaderNotActive 16ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_playPauseAction_routesThroughAudiobookSession 9ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_scrubber_reflectsPresenterPlaybackProgress 16ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_skipBackButton_callsSpySessionSkipBack 6ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_skipForwardButton_callsSpySessionSkipForward 27ms
โœ… AudiobookMiniPlayerViewTests testMiniPlayer_tapInvokesExpand 15ms
โœ… AudiobookMiniPlayerViewTests testShouldShowChrome_truthTable_killsBooleanMutations 19ms
โœ… AudiobookNetworkValidationTests testFullyDownloaded_bypassesNetworkRulesAcrossAllConnectivityCombinations 5ms
โœ… AudiobookNetworkValidationTests testFullyDownloaded_neverNeedsNetwork_offline 8ms
โœ… AudiobookNetworkValidationTests testStreaming_networkValidationCoversAllConnectivityCombinations 7ms
โœ… AudiobookOpenStateRaceTests testF016Repro_audiobookOpenAwaitsReadiness_doesNotSilentlyReadPastNilDetails 201ms
โœ… AudiobookOpenStateRaceTests testF016Repro_audiobookOpenUnderDetailsFailed_gateThrows_callerMapsToNotAuthenticated 120ms
โœ… AudiobookOpenStateRaceTests testIntegration_openAudiobook_underDetailsFailed_returnsNotAuthenticated 236ms
โœ… AudiobookPhoneAlertContentTests testLoaderAndUnknownErrors_returnNil_toAvoidDoubleAlerts 3ms
โœ… AudiobookPhoneAlertContentTests testValidationErrors_allProduceAlertContent 7ms
โœ… AudiobookPhoneAlertContentTests testWifiRequired_producesAlertContent 19ms
โœ… AudiobookPlaybackStateTests testPlaybackStartAndStop_cycle 32ms
โœ… AudiobookPlaybackStateTests testPlaybackStarted_canBeCalledMultipleTimes 34ms
โœ… AudiobookPlaybackStateTests testPlaybackStopped_canBeCalledWithoutStart 18ms
โœ… AudiobookPlaybackTests testAudiobookTimeEntry_DurationCappedAt60 19ms
โœ… AudiobookPlaybackTests testAudiobookTimeEntry_ValidDuration 28ms
โœ… AudiobookPlaybackTests testChapterIndex_ValidTrack 24ms
โœ… AudiobookPlaybackTests testChapterNavigation_NextChapter 15ms
โœ… AudiobookPlaybackTests testChapterNavigation_NextChapter_AtEnd 13ms
โœ… AudiobookPlaybackTests testChapterNavigation_PreviousChapter 14ms
โœ… AudiobookPlaybackTests testChapterNavigation_PreviousChapter_ClampsToZero 23ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_0_75x_CalculatesCorrectDuration 18ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_1_0x_CalculatesCorrectDuration 16ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_1_25x_CalculatesCorrectDuration 19ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_1_5x_CalculatesCorrectDuration 13ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_2_0x_CalculatesCorrectDuration 24ms
โœ… AudiobookPlaybackTests testPlaybackSpeed_ContentPlayedCalculation 19ms
โœ… AudiobookPlaybackTests testSkipAhead_Adds30Seconds 13ms
โœ… AudiobookPlaybackTests testSkipAhead_ClampsToTrackEnd 13ms
โœ… AudiobookPlaybackTests testSkipAhead_WithinTrackDuration 29ms
โœ… AudiobookPlaybackTests testSkipBehind_ClampsToZero 17ms
โœ… AudiobookPlaybackTests testSkipBehind_Subtracts30Seconds 36ms
โœ… AudiobookPlaybackTests testSleepTimer_15Minutes 13ms
โœ… AudiobookPlaybackTests testSleepTimer_30Minutes 13ms
โœ… AudiobookPlaybackTests testSleepTimer_60Minutes 18ms
โœ… AudiobookPlaybackTests testSleepTimer_Expired 25ms
โœ… AudiobookPlaybackTests testSleepTimer_RemainingTime 16ms
โœ… AudiobookPlaybackTests testTrackPosition_Creation 22ms
โœ… AudiobookPlaybackTests testTrackPosition_ToAudioBookmark 18ms
โœ… AudiobookPlaybackTests testTrackPosition_ToTPPBookLocation 21ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_accountSwitchNotification_doesNotClearQueue 463ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_allCrossAccount_backgroundTaskStillEnds 531ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_crossAccountUpload_isSkipped_andQueuePreserved 68ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_midFlightCancellation_notReplayedByQueue 442ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_sameAccountUpload_postsNormally 122ms
โœ… AudiobookPlaytimesLifecycleTests testPlaytimes_switchBack_flushesPreservedEntries 338ms
โœ… AudiobookPositionAdapterContractTests test_audiobookSave_localFirstThenWriter 29ms
โœ… AudiobookPositionAdapterContractTests test_audiobookSave_preservesIsAtBeginningGuard 37ms
โœ… AudiobookPositionAdapterContractTests test_audiobookSave_preservesTimestampNewerRace 69ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_NaNTimestamp_fails 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_capMultiplier_isExactly1Point1 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_finiteCheckRunsBeforeNegativeCheck 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_happyPath_succeeds 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_infiniteTimestamp_fails 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_negativeTimestamp_fails 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_positionAtExact110Percent_succeeds 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_positionAtExactTotalDuration_succeeds 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_positionExceeds110Percent_fails 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_timestampExactlyAtNegativeBoundary_fails 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_timestampZero_succeeds 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_totalDurationNegative_skipsCapCheck 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_totalDurationZero_skipsCapCheck 2ms
โœ… AudiobookPositionPolicyValidatorTests testValidate_trackKeyMismatch_fails 2ms
โœ… AudiobookPositionRestoreTests testIsUserAuthenticated_authDocLoadFailed_returnsFalse 304ms
โœ… AudiobookPositionRestoreTests testIsUserAuthenticated_noCurrentAccount_returnsFalse 863ms
โœ… AudiobookPositionRestoreTests testIsValidPosition_foreignKey_returnsFalse 56ms
โœ… AudiobookPositionRestoreTests testIsValidPosition_negativeTimestamp_returnsFalse 46ms
โœ… AudiobookPositionRestoreTests testIsValidPosition_validPosition_returnsTrue 25ms
โœ… AudiobookPositionRestoreTests testSelectMostRecentValidBookmark_allFailValidation_returnsNil 32ms
โœ… AudiobookPositionRestoreTests testSelectMostRecentValidBookmark_dropsCapExceedingCandidate_keepsValidOlder 32ms
โœ… AudiobookPositionRestoreTests testSelectMostRecentValidBookmark_ignoresArrayOrder_usesTimestamp 51ms
โœ… AudiobookPositionRestoreTests testSelectMostRecentValidBookmark_picksNewestByTimestamp 64ms
โœ… AudiobookPositionRestoreTests testValidationFailure_trackKeyInManifest_returnsNil 42ms
โœ… AudiobookPositionRestoreTests testValidationFailure_trackKeyNotInManifest_returnsTrackKeyFailure 41ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthForNilError 4ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthForNonSAMLAuth 13ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthForWrongCode 12ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthForWrongDomain 57ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthWithNilBook 6ms
โœ… AudiobookSAMLReauthTests testShouldNotTriggerSAMLReauthWithoutCredentials 15ms
โœ… AudiobookSessionErrorDescriptionTests testAllErrorCases_haveNonEmptyDescriptions 3ms
โœ… AudiobookSessionErrorDescriptionTests testErrorEquatable_differentTypes 4ms
โœ… AudiobookSessionErrorDescriptionTests testErrorEquatable_sameTypes 4ms
โœ… AudiobookSessionErrorDescriptionTests testUnknownError_preservesCustomMessage 5ms
โœ… AudiobookSessionErrorExtTests testErrorDescriptions 5ms
โœ… AudiobookSessionErrorExtTests testErrorEquality 2ms
โœ… AudiobookSessionErrorExtTests testUnknownErrorDescription_preservesCallerMessageVerbatim 6ms
โœ… AudiobookSessionErrorExtTests testUnknownErrorEquality 6ms
โœ… AudiobookSessionErrorTests testAudiobookSessionError_Equatable 2ms
โœ… AudiobookSessionErrorTests testAudiobookSessionError_localizedDescription_isCaseSpecificAndPreservesUnknownMessage 5ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_cancelled_isUnknown 9ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_factoryFailed_isPlayerCreationFailed 4ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_lcpFamily_isManifestLoadFailed 3ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_manifestFamily_isManifestLoadFailed 2ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_tokenRefresh_isNotAuthenticated 2ms
โœ… AudiobookSessionManagerErrorMappingTests testMap_vendorKey_surfacesUnderlyingMessage 3ms
โœ… AudiobookSessionManagerFlagGatePresentationTests testDismissPlayerOnPhone_flagOff_popsAudioRoute_preservesUnderlyingRoute 1.43s
โœ… AudiobookSessionManagerFlagGatePresentationTests testDismissPlayerOnPhone_flagOn_clearsPresenter_andDoesNotPopCoordinator 1.31s
โœ… AudiobookSessionManagerFlagGatePresentationTests testPresentSession_flagOff_pushesAudioRoute_andDoesNotDrivePresenter 2.15s
โœ… AudiobookSessionManagerFlagGatePresentationTests testPresentSession_flagOn_drivesPresenter_andDoesNotPushAudioRoute 1.32s
โœ… AudiobookSessionManagerPresenterMigrationTests testOpenAudiobook_firstOpen_callsPresenterPresentOnFirstOpen 505ms
โœ… AudiobookSessionManagerPresenterMigrationTests testOpenAudiobook_firstOpen_doesNotPushAudioRouteOnRealCoordinator 102ms
โœ… AudiobookSessionManagerPresenterMigrationTests testOpenAudiobook_firstOpen_setsPresenterIsPlayerExpandedTrue_beforeReadinessGateCompletes 119ms
โœ… AudiobookSessionManagerPresenterMigrationTests testOpenAudiobook_resumeFromMiniPlayer_doesNOTForceIsPlayerExpanded 231ms
โœ… AudiobookSessionManagerPresenterMigrationTests testOpenAudiobook_switchingAudiobooks_clearsPreviousPlaybackModel 771ms
โœ… AudiobookSessionManagerPresenterMigrationTests testStopPlayback_clearsPresenterPlaybackModel 126ms
โœ… AudiobookSessionManagerPresenterMigrationTests testStopPlayback_doesNotLeaveAudioModelInCoordinatorCache 141ms
โœ… AudiobookSessionManagerPresenterMigrationTests testStopPlayback_doesNotPopRealCoordinatorPath 965ms
โœ… AudiobookSessionManagerShutdownTests test_buildPlaybackFailureRecord_isCallableOffMainActor 10ms
โœ… AudiobookSessionManagerShutdownTests test_doubleStopPlayback_isIdempotent 10ms
โœ… AudiobookSessionManagerShutdownTests test_networkValidationError_fullyDownloadedBypassesAllNetworkRules 110ms
โœ… AudiobookSessionManagerShutdownTests test_networkValidationError_isPureAcrossManyCalls 16ms
โœ… AudiobookSessionManagerShutdownTests test_networkValidationError_wifiRequiredOnCellularWhileStreaming 5ms
โœ… AudiobookSessionManagerShutdownTests test_rapidStopPlayback_leavesSessionInIdleState 28ms
โœ… AudiobookSessionManagerShutdownTests test_stopPlayback_emitsIdleStateToPublisher 15ms
โœ… AudiobookSessionManagerShutdownTests test_stopPlayback_neverBound_isFastNoOp 12ms
โœ… AudiobookSessionPresenterTests testErrorState_tearsDownSession_soPlaybackViewDoesNotLingerAfterFailedOpen 116ms
โœ… AudiobookSessionPresenterTests testExpand_setsIsPlayerExpandedTrue 7ms
โœ… AudiobookSessionPresenterTests testHasActiveSession_becomesFalseWhenSessionReturnsToIdle 111ms
โœ… AudiobookSessionPresenterTests testHasActiveSession_becomesTrueWhenSessionTransitionsToLoading 60ms
โœ… AudiobookSessionPresenterTests testHasActiveSession_becomesTrueWhenSessionTransitionsToPlaying 64ms
โœ… AudiobookSessionPresenterTests testHasActiveSession_isFalseWhenSessionIdle 59ms
โœ… AudiobookSessionPresenterTests testInit_freshPresenterWithIdleSession_hasNoActiveSessionAndCollapsedPlayer 8ms
โœ… AudiobookSessionPresenterTests testIsReaderActive_isPubliclyMutable_andPersistsTransitions 9ms
โœ… AudiobookSessionPresenterTests testMinimize_setsIsPlayerExpandedFalse 10ms
โœ… AudiobookSessionPresenterTests testPresentOnFirstOpen_setsIsPlayerExpandedTrue 8ms
โœ… AudiobookSessionPresenterTests testPresenter_adoptCoverImage_writesIntoPublishedMirror 8ms
โœ… AudiobookSessionPresenterTests testPresenter_adoptsNewPlaybackModel_clearsPriorCurrentLocationSubscription 113ms
โœ… AudiobookSessionPresenterTests testPresenter_clearActiveSession_clearsPolishPhaseFields 63ms
โœ… AudiobookSessionPresenterTests testPresenter_expand_minimize_expandAgain_drivesIsPlayerExpandedCorrectly_acrossThreeTransitions 5ms
โœ… AudiobookSessionPresenterTests testPresenter_isPlayingFlipsAfterSessionPublisherEmits 166ms
โœ… AudiobookSessionPresenterTests testPresenter_normalizedProgress_handlesEdgeCases 8ms
โœ… AudiobookSessionStateTests testErrorState 3ms
โœ… AudiobookSessionStateTests testIdleState 2ms
โœ… AudiobookSessionStateTests testLoadingState 4ms
โœ… AudiobookSessionStateTests testPausedState 19ms
โœ… AudiobookSessionStateTests testPlayingState 2ms
โœ… AudiobookSessionStateTests testStateEquality 27ms
โœ… AudiobookSessionStateTransitionTests testErrorState_isNotActive_butHasBookId 1.13s
โœ… AudiobookSessionStateTransitionTests testIdleState_isNotActive 1.33s
โœ… AudiobookSessionStateTransitionTests testLoadingState_isActive_andHasBookId 1.27s
โœ… AudiobookSessionStateTransitionTests testPausedState_isActive_andHasBookId 1.74s
โœ… AudiobookSessionStateTransitionTests testPlayingState_isActive_andHasBookId 1.28s
โœ… AudiobookSessionStateTransitionTests testSessionManager_cyclePlaybackRate_withoutManager_returnsNormalTime 1.26s
โœ… AudiobookSessionStateTransitionTests testSessionManager_initialState_isIdle 1.45s
โœ… AudiobookSessionStateTransitionTests testSessionManager_pause_withoutManager_doesNotCrash 1.50s
โœ… AudiobookSessionStateTransitionTests testSessionManager_play_withoutManager_doesNotCrash 1.44s
โœ… AudiobookSessionStateTransitionTests testSessionManager_skipToChapter_withoutManager_doesNotCrash 1.28s
โœ… AudiobookSessionStateTransitionTests testSessionManager_stopPlayback_publishesIdleState 1.13s
โœ… AudiobookSessionStateTransitionTests testSessionManager_stopPlayback_resetsState 2.47s
โœ… AudiobookSessionStateTransitionTests testSessionManager_togglePlayPause_withoutManager_doesNotCrash 1.32s
โœ… AudiobookSessionStateTransitionTests testSessionManager_updateCoverImage_nil_clearsImage 1.39s
โœ… AudiobookSessionStateTransitionTests testSessionManager_updateCoverImage_setsImage 1.32s
โœ… AudiobookSessionStateTransitionTests testStateEquality_differentBookIds 1.52s
โœ… AudiobookSessionStateTransitionTests testStateEquality_differentStates 21.76s
โœ… AudiobookSessionStateTransitionTests testStateEquality_sameStates 5.04s
โœ… AudiobookSleepTimerIntegrationTests testEndOfChapterSleepTimer_savesPartialTime 56ms
โœ… AudiobookSleepTimerIntegrationTests testSleepTimer30Minutes_savesAllPlayedTime 232ms
โœ… AudiobookSleepTimerIntegrationTests testSleepTimerCancelResume_preservesAllTime 68ms
โœ… AudiobookSleepTimerIntegrationTests testSleepTimerMultipleMinutes_createsSeparateEntries 37ms
โœ… AudiobookSleepTimerIntegrationTests testSleepTimerScenario_savesAllPlayedTime 72ms
โœ… AudiobookStorageLocationTests testApplicationSupportDirectoryExists 4ms
โœ… AudiobookStorageLocationTests testAudiobooksDirectoryPath 3ms
โœ… AudiobookStorageLocationTests testOverdriveDirectoryPath 4ms
โœ… AudiobookTOCTests testChapterName_MatchesAfterNavigation 714ms
โœ… AudiobookTOCTests testChapterName_SavedCorrectly 19ms
โœ… AudiobookTOCTests testChapter_AutoAdvanceToNext 23ms
โœ… AudiobookTOCTests testChapter_HasDuration 12ms
โœ… AudiobookTOCTests testChapter_PositionAtStart 18ms
โœ… AudiobookTOCTests testChapter_PositionInMiddle 379ms
โœ… AudiobookTOCTests testChapter_PositionPersistsAfterRestart 21ms
โœ… AudiobookTOCTests testChapter_SelectionPersistsAfterReturn 23ms
โœ… AudiobookTOCTests testChapter_TotalDuration 14ms
โœ… AudiobookTOCTests testTOC_ChaptersAreOrdered 22ms
โœ… AudiobookTOCTests testTOC_ChaptersHaveTitles 23ms
โœ… AudiobookTOCTests testTOC_ContentsAndBookmarksTabs 18ms
โœ… AudiobookTOCTests testTOC_HasChapters 26ms
โœ… AudiobookTOCTests testTOC_OpenFirstChapter 791ms
โœ… AudiobookTOCTests testTOC_OpenRandomChapter 19ms
โœ… AudiobookTOCTests testTOC_OpenSpecificChapter 219ms
โœ… AudiobookTOCTests testTOC_SwitchToBookmarks 195ms
โœ… AudiobookTOCTests testTOC_SwitchToChapters 28ms
โœ… AudiobookTimeEntryTests testTimeEntry_codableRoundTrip 8ms
โœ… AudiobookTimeEntryTests testTimeEntry_conformsToProtocol 2ms
โœ… AudiobookTimeEntryTests testTimeEntry_durationCanExceed60InStruct 2ms
โœ… AudiobookTimeEntryTests testTimeEntry_equality 4ms
โœ… AudiobookTimeEntryTests testTimeEntry_hashable 5ms
โœ… AudiobookTimeEntryTests testTimeEntry_storesProperties 2ms
โœ… AudiobookTimeTrackerEdgeTests testPlaybackStopped_savesAccumulatedTime_beforeCancellingTimer 13ms
โœ… AudiobookTimeTrackerEdgeTests testReceiveValue_crossingMinuteBoundary_savesEntry 51ms
โœ… AudiobookTimeTrackerEdgeTests testReceiveValue_withinSameMinute_doesNotSaveUntilStop 13ms
โœ… AudiobookTimeTrackerEdgeTests testStopAndSave_calledMultipleTimes_doesNotDuplicate 16ms
โœ… AudiobookTimeTrackerEdgeTests testTimeEntry_containsCorrectBookAndLibraryIds 8ms
โœ… AudiobookTimeTrackerEdgeTests testTimeEntry_durationCappedAt60_andIsNonNegativeAtInit 25ms
โœ… AudiobookTimeTrackerEdgeTests testTimeEntry_duringMinute_isUTCFormat 8ms
โœ… AudiobookTimeTrackerEdgeTests testZeroDuration_isNotSaved 15ms
โœ… AudiobookTimeTrackerLifecycleTests testAppTerminationNotification_savesData 1.02s
โœ… AudiobookTimeTrackerLifecycleTests testStopAndSave_canBeCalledMultipleTimes 18ms
โœ… AudiobookTimeTrackerLifecycleTests testStopAndSave_savesAllAccumulatedTime 17ms
โœ… AudiobookTimeTrackerLifecycleTests testTimeEntryProperty_isThreadSafe 21ms
โœ… AudiobookTimeTrackerLifecycleTests testTrackerDeallocation_savesAccumulatedTime 18ms
โœ… AudiobookTimeTrackerTests testExactMinuteOfPlayback_savesCorrectTimeEntry 14ms
โœ… AudiobookTimeTrackerTests testMultipleMinuteBoundaries_createsMultipleEntries 34ms
โœ… AudiobookTimeTrackerTests testNoPlayback_savesNoTimeEntry 13ms
โœ… AudiobookTimeTrackerTests testPlaybackStarted_savesCorrectAggregateTime 16ms
โœ… AudiobookTimeTrackerTests testPlaybackStopped_stopsTimer 20ms
โœ… AudiobookTimeTrackerTests testSaveCurrentDuration_savesTimeEntryCorrectly 15ms
โœ… AudiobookTimeTrackerTests testTimeEntries_areInUTC 22ms
โœ… AudiobookTimeTrackerTests testTimeEntries_areLimitedTo60Seconds 14ms
โœ… AudiobookTimeTrackerTests testTimeEntry_hasCorrectMetadata 15ms
โœ… AudiobookTrackCompletionTests testTrackerFinalize_savesAccumulatedTime 28ms
โœ… AudiobookTrackCompletionTests testZeroDuration_notSaved 17ms
โœ… AudiobookTypeRoutingTests testAudiobookLCPBook_hasExpectedIdentifiers 5ms
โœ… AudiobookTypeRoutingTests testBearerTokenBook_hasExpectedIdentifiers 247ms
โœ… AudiobookTypeRoutingTests testLCPAudiobook_canOpenBook_usesCorrectAcquisitionType 603ms
โœ… AudiobookTypeRoutingTests testOpenAccessAudiobook_hasExpectedIdentifiers 9ms
โœ… AudiobookTypeRoutingTests testReadiumLCPBook_hasExpectedIdentifiers 7ms
โœ… AudiobookVendorAdapterTests testFirstMatchPriorityOrder 9ms
โœ… AudiobookVendorAdapterTests testFirstMatchPriorityOrder_skipsNonClaimingAdapter 17ms
โœ… AudiobookVendorAdapterTests testProtocol_canHandleMustBeSync 6ms
โœ… AudiobookVendorAdapterTests testProtocol_resolveManifestSignature_propagatesFailure 6ms
โœ… AudiobookVendorAdapterTests testProtocol_resolveManifestSignature_propagatesSuccess 9ms
โœ… AudiobookmarkTests testDecodeEarlyBookmark 6ms
โœ… AudiobookmarkTests testDecodeLocatorAudioBookTime2 10ms
โœ… AudiobookmarkTests testDecodeNewerBookmark 4ms
โœ… AudiobookmarkTests testEncodeAndDecodeBookmark 5ms
โœ… AuthCoordinatorTelemetryTests testAppContainerProduction_wiresAuthCoordinator 7ms
โœ… AuthCoordinatorTelemetryTests testCoordinator_payload_idpType_reflectsMechanismProvider 16ms
โœ… AuthCoordinatorTelemetryTests testCoordinator_payload_libraryUUID_reflectsProviderClosure 8ms
โœ… AuthCoordinatorTelemetryTests testCoordinator_refreshFlow_emitsStartAndEnd_correlatedByID 31ms
โœ… AuthCoordinatorTelemetryTests testCoordinator_samlModalCancel_emitsCancelSubEvent_forFastDashboardFilter 6ms
โœ… AuthDecisionEventEmissionTests testErrorCode_classifierClassified_is1001 12ms
โœ… AuthDecisionEventEmissionTests testErrorCode_partitionsPerStep_eachStepGetsDistinctCode 2ms
โœ… AuthDecisionEventEmissionTests testErrorDomain_isStableValue_distinctFromPlaybackFailureDomain 2ms
โœ… AuthDecisionEventEmissionTests testErrorUserInfo_dropsAbsentFields 10ms
โœ… AuthDecisionEventEmissionTests testErrorUserInfo_includesAllDashboardFields 2ms
โœ… AuthDecisionEventEmissionTests testErrorUserInfo_includesNSLocalizedDescription_withStepAndDecision 8ms
โœ… AuthDecisionEventEmissionTests testProductionRecorder_constructsWithoutCrash 11ms
โœ… AuthDocumentContractTests testAuthDocument_HasRequiredLinks 31ms
โœ… AuthDocumentContractTests testParseAuthDocument_ExtractsAllFields 9ms
โœ… AuthDocumentVariantsContractTests testOAuthAuthDocument_FeatureFlagsExpressedViaDisabledList 4ms
โœ… AuthDocumentVariantsContractTests testOAuthAuthDocument_HasMultipleAuthMethods 17ms
โœ… AuthDocumentVariantsContractTests testSAMLAuthDocument_HasAnnouncements 3ms
โœ… AuthDocumentVariantsContractTests testSAMLAuthDocument_HasRequiredLinks 3ms
โœ… AuthDocumentVariantsContractTests testSAMLAuthDocument_ParsesWithSAMLType 4ms
โœ… AuthErrorCategoryTests testHTTPURLResponse_bare401WithoutProblemDoc_shouldIndicateAuthRefresh 2ms
โœ… AuthErrorCategoryTests testHTTPURLResponse_withOldCredentialsInvalidType_shouldIndicateAuthRefresh 2ms
โœ… AuthErrorCategoryTests testHTTPURLResponse_withRecoverableError_shouldIndicateAuthRefresh 2ms
โœ… AuthErrorCategoryTests testHTTPURLResponse_withUnrecoverableError_shouldNotIndicateAuthRefresh 2ms
โœ… AuthErrorCategoryTests testHTTPURLResponse_withUnrecoverableNoAccess_shouldNotIndicateAuthRefresh 3ms
โœ… AuthErrorCategoryTests testProblemDocument_nilType_isNeitherCategory 2ms
โœ… AuthErrorCategoryTests testProblemDocument_nonAuthType_isNeitherCategory 2ms
โœ… AuthErrorCategoryTests testProblemDocument_recoverableSAMLBearerTokenInvalid_isRecoverable 2ms
โœ… AuthErrorCategoryTests testProblemDocument_recoverableSAMLSessionExpired_isRecoverable 4ms
โœ… AuthErrorCategoryTests testProblemDocument_recoverableTokenExpired_isRecoverable 5ms
โœ… AuthErrorCategoryTests testProblemDocument_unrecoverableInvalidCredentials_isUnrecoverable 2ms
โœ… AuthErrorCategoryTests testProblemDocument_unrecoverableNoAccess_isUnrecoverable 11ms
โœ… AuthErrorProblemDocSeamTests testMakeFromHTTPResponse_PreservesCallerUserInfo 9ms
โœ… AuthErrorProblemDocSeamTests testMakeFromHTTPResponse_WithNonJSONBody_NoProblemDoc 4ms
โœ… AuthErrorProblemDocSeamTests testMakeFromHTTPResponse_WithProblemDocBody_EmbedsDoc 3ms
โœ… AuthErrorProblemDocSeamTests testRewrappedError_PreservesUpstreamProblemDocument 2ms
โœ… AuthErrorProblemDocSeamTests testTokenRequest_On403WithProblemDoc_FlowsThroughToUserFacingTitle 13ms
โœ… AuthErrorProblemDocSeamTests testTokenRequest_On403WithoutProblemDoc_FallsBackToGenericTitle 8ms
โŠ˜ AuthFlowSecurityTests testSession_identifierRotatedOnSignIn 349ms
โŠ˜ AuthFlowSecurityTests testToken_networkExecutorRefreshCount_singleFlightSemantics 11ms
โŠ˜ AuthFlowSecurityTests testToken_reauthenticatorCallCount_observableForRawCallAssertion 32ms
โœ… AuthReducerTests testAuthDocumentLoadCompleted_clearsLoadingFlag 2ms
โœ… AuthReducerTests testAuthDocumentLoadStarted_setsLoadingFlag 3ms
โœ… AuthReducerTests testBearerTokenReceived_storesTokenAndExpiration 19ms
โœ… AuthReducerTests testClassifyValidationError_genericError_fallsBackToInvalidCredentials 11ms
โœ… AuthReducerTests testClassifyValidationError_networkConnectivityError_returnsConnectivityCopy 3ms
โœ… AuthReducerTests testClassifyValidationError_problemDocument_takesPrecedenceOverEverything 3ms
โœ… AuthReducerTests testCredentialCaptureStarted_acceptsNilCredentials 2ms
โœ… AuthReducerTests testCredentialCaptureStarted_storesBarcodeAndPinAndClearsStaleError 3ms
โœ… AuthReducerTests testCredentialsValidationFailed_clearsFlagAndSurfacesError 3ms
โœ… AuthReducerTests testCredentialsValidationStarted_setsFlagAndClearsAnyPriorError 5ms
โœ… AuthReducerTests testCredentialsValidationSucceeded_clearsFlagWithoutTouchingCapturedCreds 2ms
โœ… AuthReducerTests testErrorCleared_dropsPriorErrorWithoutTouchingOtherFields 6ms
โœ… AuthReducerTests testLoggingInAfterSignUpFlagSet_storesValue 2ms
โœ… AuthReducerTests testRefreshAuthStarted_basicAuth_neverArmsBypass 3ms
โœ… AuthReducerTests testRefreshAuthStarted_oauthNonExisting_armsIgnoreSignedInState 3ms
โœ… AuthReducerTests testRefreshAuthStarted_oidcNonExisting_armsIgnoreSignedInState 14ms
โœ… AuthReducerTests testRefreshAuthStarted_samlNonExisting_armsIgnoreSignedInState 4ms
โœ… AuthReducerTests testRefreshAuthStarted_samlWithExistingCredentials_doesNotArmBypass 2ms
โœ… AuthReducerTests testRefreshAuthStarted_tokenAuth_neverArmsBypass 2ms
โœ… AuthReducerTests testSignOutCompleted_resetsToInitialState 3ms
โœ… AuthReducerTests testUserAccountUpdated_clearsAllInFlightAuthState 5ms
โœ… AuthTypeTests testAuthType_AnonymousRawValue_IsCorrect 5ms
โœ… AuthTypeTests testAuthType_BasicRawValue_IsCorrect 3ms
โœ… AuthTypeTests testAuthType_CoppaRawValue_IsCorrect 6ms
โœ… AuthTypeTests testAuthType_InitFromInvalidString_ReturnsNil 18ms
โœ… AuthTypeTests testAuthType_OAuthRawValue_IsCorrect 5ms
โœ… AuthTypeTests testAuthType_SamlRawValue_IsCorrect 5ms
โœ… AuthTypeTests testAuthType_TokenRawValue_IsCorrect 6ms
โœ… AuthenticationTests testCatalogRequiresAuthentication_ForBasicType_ReturnsFalse 283ms
โœ… AuthenticationTests testCatalogRequiresAuthentication_ForOAuthType_ReturnsTrue 3.41s
โœ… AuthenticationTests testCoppaURL_WhenOfAge_ReturnsOverUrl 3ms
โœ… AuthenticationTests testCoppaURL_WhenUnderAge_ReturnsUnderUrl 3ms
โœ… AuthenticationTests testIsBasic_ForBasicType_ReturnsTrue 7ms
โœ… AuthenticationTests testIsOauth_ForOAuthType_ReturnsTrue 4ms
โœ… AuthenticationTests testIsSaml_ForSamlType_ReturnsTrue 5ms
โœ… AuthenticationTests testIsToken_ForTokenType_ReturnsTrue 3ms
โœ… AuthenticationTests testNeedsAgeCheck_ForBasicType_ReturnsFalse 7ms
โœ… AuthenticationTests testNeedsAgeCheck_ForCoppaType_ReturnsTrue 3ms
โœ… AuthenticationTests testNeedsAuth_ForAnonymousType_ReturnsFalse 5ms
โœ… AuthenticationTests testNeedsAuth_ForBasicType_ReturnsTrue 2ms
โœ… AuthenticationTests testNeedsAuth_ForCoppaType_ReturnsFalse 5ms
โœ… AuthenticationTests testNeedsAuth_ForOAuthType_ReturnsTrue 303ms
โœ… AuthenticationTests testNeedsAuth_ForSamlType_ReturnsTrue 4ms
โœ… AuthenticationTests testNeedsAuth_ForTokenType_ReturnsTrue 74ms
โœ… BackgroundDownloadHandlerTests testDetectRightsManagement_adobeAdept 3ms
โœ… BackgroundDownloadHandlerTests testDetectRightsManagement_bearerToken 5ms
โœ… BackgroundDownloadHandlerTests testDetectRightsManagement_epubZip 5ms
โœ… BackgroundDownloadHandlerTests testDetectRightsManagement_readiumLCP 5ms
โœ… BackgroundDownloadHandlerTests testDetectRightsManagement_unknownType 4ms
โœ… BackgroundDownloadHandlerTests testHandleDownloadProgress_firstBytes_detectsMimeType 17ms
โœ… BackgroundDownloadHandlerTests testHandleDownloadProgress_noDelegate_doesNotCrash 43ms
โœ… BackgroundDownloadHandlerTests testInit_withDelegate 2ms
โœ… BackgroundDownloadHandlerTests testInit_withoutDelegate 11ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_applicationXml 2ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_atomXml 5ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_caseInsensitive 2ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_epub_returnsFalse 6ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_html_returnsFalse 4ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_json_returnsFalse 3ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_opdsCatalog 2ms
โœ… BackgroundDownloadHandlerTests testIsOPDSEntryMimeType_textXml 5ms
โœ… BackgroundDownloadHandlerTests testMoveFile_moveFailure_logsError 7ms
โœ… BackgroundDownloadHandlerTests testMoveFile_noDelegate_returnsFalse 7ms
โœ… BackgroundDownloadHandlerTests testMoveFile_noFileUrl_returnsFalse 13ms
โœ… BackgroundDownloadHandlerTests testMoveFile_success_setsDownloadSuccessful 7ms
โœ… BackgroundDownloadHandlerTests testReplaceBook_existingFile_replacesIt 10ms
โœ… BackgroundDownloadHandlerTests testReplaceBook_noDelegate_returnsFalse 6ms
โœ… BackgroundDownloadHandlerTests testReplaceBook_noFileUrl_returnsFalse 13ms
โœ… BackgroundDownloadHandlerTests testReplaceBook_success_setsDownloadSuccessful 8ms
โœ… BackgroundDownloadHandlerTests testValidateDownloadedFile_emptyFile_returnsFalse 13ms
โœ… BackgroundDownloadHandlerTests testValidateDownloadedFile_existingFileWithContent_returnsTrue 8ms
โœ… BackgroundDownloadHandlerTests testValidateDownloadedFile_missingFile_returnsFalse 12ms
โœ… BackgroundListenerTests testOpenAccessListenerIdentifiesCorrectSessions 45ms
โœ… BackgroundListenerTests testOverdriveListenerIdentifiesCorrectSessions 50ms
โœ… BackupExclusionMigrationTests test_run_continuesAfterMissingRoot_doesNotPoisonSubsequentRoots 9ms
โœ… BackupExclusionMigrationTests test_run_flagsFilesAddedBetweenInvocations 11ms
โœ… BackupExclusionMigrationTests test_run_recursivelyFlagsEveryFileAndDirectory 6ms
โœ… BadgeDefinitionTests testBadgeCatalog_ContainsAllBadges 34ms
โœ… BadgeDefinitionTests testBadgeCatalog_HasUniqueIDs 14ms
โœ… BadgeDefinitionTests testFiftyBooksClub_CapsAtOne 3ms
โœ… BadgeDefinitionTests testFiftyBooksClub_FailingCriteria 5ms
โœ… BadgeDefinitionTests testFiftyBooksClub_Metadata 2ms
โœ… BadgeDefinitionTests testFiftyBooksClub_PassingCriteria 16ms
โœ… BadgeDefinitionTests testFiftyBooksClub_ProgressCalculation 7ms
โœ… BadgeDefinitionTests testHundredBooksClub_FailingCriteria 7ms
โœ… BadgeDefinitionTests testHundredBooksClub_Metadata 4ms
โœ… BadgeDefinitionTests testHundredBooksClub_PassingCriteria 3ms
โœ… BadgeDefinitionTests testHundredBooksClub_ProgressCalculation 16ms
โœ… BadgeDefinitionTests testHundredBooksClub_ZeroCompletions 3ms
โœ… BadgeDefinitionTests testMakeBadge_DefaultsToNotEarned 11ms
โœ… BadgeDefinitionTests testMakeBadge_ProducesCorrectBadge 10ms
โœ… BadgeDefinitionTests testSpeedReader_FailingCriteria_MultiDayRead 6ms
โœ… BadgeDefinitionTests testSpeedReader_Metadata 2ms
โœ… BadgeDefinitionTests testSpeedReader_PassingCriteria_SameDayStartAndFinish 3ms
โœ… BadgeDefinitionTests testSpeedReader_ProgressWithCompletionsButNoneSameDay 6ms
โœ… BadgeDefinitionTests testSpeedReader_ZeroProgress_NoCompletions 5ms
โœ… BadgeDefinitionTests testStreakImmortal_CapsAtOne 7ms
โœ… BadgeDefinitionTests testStreakImmortal_FailingCriteria 4ms
โœ… BadgeDefinitionTests testStreakImmortal_Metadata 3ms
โœ… BadgeDefinitionTests testStreakImmortal_PassingCriteria 5ms
โœ… BadgeDefinitionTests testStreakImmortal_ProgressCalculation 8ms
โœ… BadgeDefinitionTests testStreakLegend_FailingCriteria 2ms
โœ… BadgeDefinitionTests testStreakLegend_Metadata 3ms
โœ… BadgeDefinitionTests testStreakLegend_PassingCriteria 6ms
โœ… BadgeDefinitionTests testStreakLegend_ProgressCalculation 11ms
โœ… BadgeDefinitionTests testStreakLegend_UsesLongestStreak 2ms
โœ… BadgeDefinitionTests testWeekendWarrior_FailingCriteria_NoWeekendSessions 10ms
โœ… BadgeDefinitionTests testWeekendWarrior_Metadata 10ms
โœ… BadgeDefinitionTests testWeekendWarrior_PassingCriteria_FourConsecutiveWeekends 38ms
โœ… BadgeDefinitionTests testWeekendWarrior_ProgressCalculation_TwoWeekends 4ms
โœ… BadgeServiceTests testAllBadgesAreDefined 2ms
โœ… BadgeServiceTests testAudiobookAdventurerEarned 144ms
โœ… BadgeServiceTests testBadgeEarnedNotificationFires 23ms
โœ… BadgeServiceTests testEarlyBirdBadge 11ms
โœ… BadgeServiceTests testFirstBookFinishedBadge 8ms
โœ… BadgeServiceTests testFirstBookNotEarnedWithNoCompletions 24ms
โœ… BadgeServiceTests testGenreExplorerProgress 7ms
โœ… BadgeServiceTests testInProgressBadges 12ms
โœ… BadgeServiceTests testLibraryExplorerProgress 10ms
โœ… BadgeServiceTests testLockedBadges 6ms
โœ… BadgeServiceTests testMarathonReaderEarned 9ms
โœ… BadgeServiceTests testMarathonReaderProgress 5ms
โœ… BadgeServiceTests testNightOwlBadge 20ms
โœ… BadgeServiceTests testStreakMasterProgress 6ms
โœ… BadgeServiceTests testTenBooksClubEarned 7ms
โœ… BadgeServiceTests testTenBooksClubProgress 9ms
โœ… BadgesViewModelTests testBadgeCategories_AreMutuallyExclusive 8ms
โœ… BadgesViewModelTests testInitialState_HasEmptyBadgeLists 5ms
โœ… BadgesViewModelTests testInitialState_IsNotLoading 5ms
โœ… BadgesViewModelTests testInitialState_NoSelectedBadge 6ms
โœ… BadgesViewModelTests testLoad_PopulatesEarnedBadges 111ms
โœ… BadgesViewModelTests testLoad_PopulatesInProgressBadges 6ms
โœ… BadgesViewModelTests testLoad_PopulatesLockedBadges 9ms
โœ… BadgesViewModelTests testLoad_SetsIsLoadingFalseOnCompletion 10ms
โœ… BadgesViewModelTests testNewBadgeNotification_AddsToBadgeIDs 55ms
โœ… BadgesViewModelTests testNewBadgeNotification_TriggersReload 74ms
โœ… BadgesViewModelTests testProgressSummary_FormatsCorrectly 19ms
โœ… BadgesViewModelTests testProgressSummary_ZeroEarned 3ms
โœ… BadgesViewModelTests testSelectBadge_SetsSelectedBadge 4ms
โœ… BadgesViewModelTests testTotalBadgesCount_MatchesCatalogCount 11ms
โœ… BasicAuthEmptyCredentialTests testHandleChallenge_EmptyUsername_StillUsesCredential 3ms
โœ… BasicAuthEmptyCredentialTests testHandleChallenge_NilPassword_CancelsChallenge 3ms
โœ… BasicAuthEmptyCredentialTests testHandleChallenge_NilUsername_CancelsChallenge 2ms
โœ… BasicAuthEmptyCredentialTests testHandleChallenge_ValidCredentials_UsesCredentialWithNoPersistence 2ms
โœ… BearerTokenAdapterTests testCanHandle_anyBookWithAcquisition_returnsTrue 4ms
โœ… BearerTokenAdapterTests testResolveManifest_bearerTokenFetchFails_failsWithManifestFetchFailed 27ms
โœ… BearerTokenAdapterTests testResolveManifest_bearerTokenFetchSuccess_completesWithRealManifest 15ms
โœ… BearerTokenAdapterTests testResolveManifest_detectsBearerTokenInResponse_recursesToLocationURL 14ms
โŠ˜ BearerTokenAdapterTests testResolveManifest_setsBookBearerTokenSideEffect 7ms
โœ… BearerTokenFulfillFlowTests testFulfillURL_andManifestURL_areDifferentEndpoints 3ms
โœ… BearerTokenFulfillFlowTests testFullFlow_bearerTokenWithExpiredManifestFetch_returnsNil 10ms
โœ… BearerTokenFulfillFlowTests testFullFlow_fulfillReturnsBearerToken_thenManifestIsFetched 11ms
โœ… BearerTokenFulfillFlowTests testFullFlow_manifestResponseIsNotMistakenForBearerToken 16ms
โœ… BearerTokenRefreshTests testRefreshRequest_includesAuthHeader 13ms
โœ… BearerTokenRefreshTests testRefreshRequest_withoutToken_noAuthHeader 373ms
โœ… BearerTokenRefreshTests testSimplifiedBearerToken_isExpired_withPastDate 3ms
โœ… BearerTokenRefreshTests testSimplifiedBearerToken_isNotExpired_withFutureDate 3ms
โœ… BearerTokenResponseDetectionTests testAudiobookManifestJSON_isNotMistakenForBearerToken 6ms
โœ… BearerTokenResponseDetectionTests testBearerTokenJSON_isDetectedCorrectly 3ms
โœ… BearerTokenResponseDetectionTests testBearerTokenJSON_withExpirationKey_isDetected 4ms
โœ… BearerTokenResponseDetectionTests testManifestWithAccessTokenKey_butNoLocation_isNotBearerToken 16ms
โœ… BearerTokenResponseDetectionTests testManifestWithLocationKey_butNoAccessToken_isNotBearerToken 5ms
โœ… BearerTokenResponseDetectionTests testNonBearerJSONShapes_areRejected 6ms
โœ… BearerTokenResponseDetectionTests testProblemDocumentJSON_isNotBearerToken 2ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_negativePlaybackTime_isNotBeginning 2ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_negativeTrackIndex_isNotBeginning 2ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track0_29s_isNotBeginning 44ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track0_30s_isNotBeginning 2ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track0_smallestPositiveTime_isNotBeginning 2ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track0_time0_isBeginning 374ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track1_anyTime_isNotBeginning 3ms
โœ… BeginningPositionPolicyTests testIsAtBeginning_track1_time0_isNotBeginning 38ms
โœ… BookAvailabilityFormatterTests test_isDate_crossDayBoundary 5ms
โœ… BookAvailabilityFormatterTests test_isDate_crossYearBoundary 4ms
โœ… BookAvailabilityFormatterTests test_isDate_emptyStrings_returnsFalse 4ms
โœ… BookAvailabilityFormatterTests test_isDate_invalidDateStrings_returnsFalse 4ms
โœ… BookAvailabilityFormatterTests test_isDate_moreRecentThan_newerDate_isMoreRecent 8ms
โœ… BookAvailabilityFormatterTests test_isDate_moreRecentThan_olderDate_notMoreRecent 4ms
โœ… BookAvailabilityFormatterTests test_isDate_moreRecentThan_sameDate_notMoreRecent 5ms
โœ… BookAvailabilityFormatterTests test_isDate_negativeDelay_makesNewerDateFail 4ms
โœ… BookAvailabilityFormatterTests test_isDate_newerDateWithDelay_alwaysPasses 4ms
โœ… BookAvailabilityFormatterTests test_isDate_oneSecondDifference_noDelay 4ms
โœ… BookAvailabilityFormatterTests test_isDate_sameTimestamp_withSmallDelay_returnsTrue 7ms
โœ… BookAvailabilityFormatterTests test_isDate_withInsufficientDelay_olderDateStillFails 5ms
โœ… BookAvailabilityFormatterTests test_isDate_withPositiveDelay_makesOlderDatePassAsNewer 4ms
โœ… BookAvailabilityFormatterTests test_syncDecision_bothExist_localNewer_usesLocal 3ms
โœ… BookAvailabilityFormatterTests test_syncDecision_bothExist_remoteNewer_promptsSync 6ms
โœ… BookAvailabilityFormatterTests test_syncDecision_localExistsRemoteNil_localIsUsed 2ms
โœ… BookAvailabilityFormatterTests test_syncDecision_localNilRemoteExists_remoteIsNewer 2ms
โœ… BookAvailabilityFormatterTests test_syncDecision_localNilRemoteNil_noSync 2ms
โœ… BookButtonMapperHoldReadyTests testMap_DownloadingState_Unaffected 2ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_LimitedNoCopiesAvailability_ReturnsHolding 3ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_LimitedWithCopiesAvailability_ReturnsHolding 2ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_NilAvailability_ReturnsHolding 3ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_ReadyAvailability_ReturnsCanBorrow 2ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_ReservedAvailability_ReturnsHolding 8ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_UnavailableAvailability_ReturnsHolding 3ms
โœ… BookButtonMapperHoldReadyTests testMap_HoldingState_UnlimitedAvailability_ReturnsHolding 3ms
โœ… BookButtonMapperHoldReadyTests testMap_ProcessingDownload_Unaffected 2ms
โœ… BookButtonMapperHoldReadyTests testStateForAvailability_dispatchesEachAvailabilityToItsExpectedButtonState 3ms
โœ… BookButtonMapperTests testBookButtonState_buttonTypes_streamingHTMLDownloadNeeded_yieldsReadStreamingAndReturn 6ms
โœ… BookButtonMapperTests testBookButtonState_buttonTypes_streamingHTMLDownloadSuccessful_yieldsReadStreaming 17ms
โœ… BookButtonMapperTests testBookButtonState_buttonTypes_streamingHTMLUnregistered_yieldsGet 19ms
โœ… BookButtonMapperTests testMapDownloadFailed 2ms
โœ… BookButtonMapperTests testMapDownloadNeeded 3ms
โœ… BookButtonMapperTests testMapDownloadSuccessful 5ms
โœ… BookButtonMapperTests testMapDownloading 2ms
โœ… BookButtonMapperTests testMapHolding 4ms
โœ… BookButtonMapperTests testMapReturning 3ms
โœ… BookButtonMapperTests testMapSAMLStarted_returnsDownloadInProgress 3ms
โœ… BookButtonMapperTests testMapUsed 2ms
โœ… BookButtonMapperTests testMap_coversAllTPPBookStates_withNeutralInputs 3ms
โœ… BookButtonMapperTests testMap_exhaustiveSwitch_noDefaultClause_andSAMLStartedExplicit 9ms
โœ… BookButtonMapperTests testMap_unregistered_limitedWithPositiveCopies_returnsCanBorrow 3ms
โœ… BookButtonMapperTests testMap_unregistered_limitedWithUnknownCopies_returnsCanBorrow 8ms
โœ… BookButtonMapperTests testMap_unregistered_limitedWithZeroCopies_returnsCanHold 2ms
โœ… BookButtonMapperTests testMappingIsDeterministic 6ms
โœ… BookButtonMapperTests testProcessingDownloadOverridesDownloadSuccessful 2ms
โœ… BookButtonMapperTests testProcessingDownloadOverridesState 8ms
โœ… BookButtonMapperTests testStateForNilAvailability 2ms
โœ… BookButtonMapperTests testUnregisteredWithNilAvailability 6ms
โœ… BookButtonMapperViewModelTests testMap_DownloadFailed_ReturnsDownloadFailed 2ms
โœ… BookButtonMapperViewModelTests testMap_DownloadNeeded_ReturnsDownloadNeeded 2ms
โœ… BookButtonMapperViewModelTests testMap_DownloadSuccessful_ReturnsDownloadSuccessful 2ms
โœ… BookButtonMapperViewModelTests testMap_DownloadingPrioritizedOverAvailability 2ms
โœ… BookButtonMapperViewModelTests testMap_Downloading_ReturnsDownloadInProgress 2ms
โœ… BookButtonMapperViewModelTests testMap_Holding_WithNilAvailability_ReturnsHolding 2ms
โœ… BookButtonMapperViewModelTests testMap_Holding_WithReadyAvailability_ReturnsCanBorrow 2ms
โœ… BookButtonMapperViewModelTests testMap_Holding_WithReservedAvailability_ReturnsHolding 2ms
โœ… BookButtonMapperViewModelTests testMap_IsProcessingDownload_ReturnsDownloadInProgress 2ms
โœ… BookButtonMapperViewModelTests testMap_Returning_ReturnsReturning 2ms
โœ… BookButtonMapperViewModelTests testMap_Unregistered_WithLimitedAvailability_CopiesAvailable_ReturnsCanBorrow 2ms
โœ… BookButtonMapperViewModelTests testMap_Unregistered_WithNilAvailability_ReturnsUnsupported 2ms
โœ… BookButtonMapperViewModelTests testMap_Unregistered_WithUnavailability_ReturnsCanHold 2ms
โœ… BookButtonMapperViewModelTests testMap_Unregistered_WithUnlimitedAvailability_ReturnsCanBorrow 38ms
โœ… BookButtonMapperViewModelTests testMap_Used_ReturnsUsed 2ms
โœ… BookButtonMapperViewModelTests testStateForAvailability_Nil_ReturnsNil 2ms
โœ… BookButtonMapperViewModelTests testStateForAvailability_Ready_ReturnsCanBorrow 3ms
โœ… BookButtonMapperViewModelTests testStateForAvailability_Reserved_ReturnsHoldingFrontOfQueue 2ms
โœ… BookButtonStateTests testAllCases 2ms
โœ… BookButtonStateTests testDownloadFailed_cancelAndRetry 2ms
โœ… BookButtonStateTests testDownloadInProgress_cancelButton 6ms
โœ… BookButtonStateTests testEquatable 2ms
โœ… BookButtonStateTests testReturning_returningButton 2ms
โœ… BookButtonStateTests testStateForAvailability_nilAvailability 2ms
โœ… BookButtonStateTests testStateForAvailability_unlimited 4ms
โœ… BookButtonStateTests testUnsupported_emptyButtons 63ms
โœ… BookButtonTypeMetaTests testBookButtonType_exhaustiveSwitch_coverage_includesReadStreaming 8ms
โœ… BookButtonTypeMetaTests testBookButtonType_readStreaming_displaysIndicatorTrue 21ms
โœ… BookButtonTypeMetaTests testBookButtonType_readStreaming_titleIsRead 3ms
โœ… BookButtonTypeMetaTests testBookButtonType_readStreaming_usesPrimaryButtonStyle 3ms
โœ… BookButtonTypeTests testAllCases_haveRawValues 4ms
โœ… BookButtonTypeTests testBorderColor 4ms
โœ… BookButtonTypeTests testButtonBackgroundColor 5ms
โœ… BookButtonTypeTests testButtonStyle_destructive 2ms
โœ… BookButtonTypeTests testButtonStyle_primary 12ms
โœ… BookButtonTypeTests testButtonStyle_secondary 7ms
โœ… BookButtonTypeTests testButtonStyle_tertiary 24ms
โœ… BookButtonTypeTests testButtonTextColor 18ms
โœ… BookButtonTypeTests testDisplaysIndicator_falseForOthers 3ms
โœ… BookButtonTypeTests testDisplaysIndicator_trueForExpected 6ms
โœ… BookButtonTypeTests testHasBorder 6ms
โœ… BookButtonTypeTests testIsPrimary 6ms
โœ… BookButtonTypeTests testTitle_returnsNonEmptyStrings 2ms
โœ… BookCellModelActionTests testAcquireReaderPresentationLock_FirstCall_Succeeds 19ms
โœ… BookCellModelActionTests testAcquireReaderPresentationLock_ReleasesAfterDelay 541ms
โœ… BookCellModelActionTests testAcquireReaderPresentationLock_SecondRapidCall_IsBlocked 20ms
โœ… BookCellModelActionTests testCancelHold_AlertContainsBookTitle 9ms
โœ… BookCellModelActionTests testCancelHold_AlertHasBothPrimaryAndDistinctCancelButton 11ms
โœ… BookCellModelActionTests testCancelHold_CancellingAlert_DoesNotSetReturningState 12ms
โœ… BookCellModelActionTests testCancelHold_ConfirmingAlert_SetsReturningState 15ms
โœ… BookCellModelActionTests testCancelHold_DoesNotStartReturnImmediately 12ms
โœ… BookCellModelActionTests testCancelHold_ShowsConfirmationAlert_BeforeRevoking 8ms
โœ… BookCellModelActionTests testRemove_doesNotShowAlertImmediatelyOrAfterDrain 42ms
โœ… BookCellModelActionTests testReturn_AlertContainsBookTitle 25ms
โœ… BookCellModelActionTests testReturn_AlertHasBothPrimaryAndDistinctCancelButton 10ms
โœ… BookCellModelActionTests testReturn_CancellingAlert_DoesNotSetReturningState 14ms
โœ… BookCellModelActionTests testReturn_CancellingAlert_ResetsIsLoading 18ms
โœ… BookCellModelActionTests testReturn_ConfirmingAlert_DismissesAlert 14ms
โœ… BookCellModelActionTests testReturn_ConfirmingAlert_SetsReturningState 10ms
โœ… BookCellModelActionTests testReturn_DoesNotStartReturnImmediately 14ms
โœ… BookCellModelActionTests testReturn_ShowsConfirmationAlert_BeforeRevoking 18ms
โœ… BookCellModelCacheInvalidationTests testCacheInvalidatesDownloadingToFailed 11ms
โœ… BookCellModelCacheInvalidationTests testCacheInvalidatesDownloadingToSuccessful 10ms
โœ… BookCellModelCacheInvalidationTests testCacheInvalidatesFailedToSuccessful 8ms
โœ… BookCellModelCacheInvalidationTests testCacheInvalidatesOnDirectInvalidation 15ms
โœ… BookCellModelCacheInvalidationTests testCacheReturnsDifferentModelsForDifferentBooks 13ms
โœ… BookCellModelCacheInvalidationTests testCacheReturnsSameModel 7ms
โœ… BookCellModelCacheInvalidationTests testClearAllRemovesAllModels 18ms
โœ… BookCellModelCacheInvalidationTests testInvalidateForSpecificBook 14ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_EmptyBooksArray_DoesNotCrash 16ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_EmptyBooksArray_WithNonZeroRange_DoesNotCrash 18ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_EndOfList_DoesNotAccessBeyondBounds 104ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_LargeBuffer_ClampsToArraySize 55ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_NegativeBufferRange_ClampsToZero 46ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_NormalRange_PreloadsModels 150ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_RangeExceedsArraySize_DoesNotCrash 22ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_SingleElementArray_DoesNotCrash 12ms
โœ… BookCellModelCachePrefetchSafetyTests testPrefetch_StartOfList_DoesNotAccessNegativeIndex 62ms
โœ… BookCellModelCacheTests testAggressiveConfiguration_HasLargerValues 1.34s
โœ… BookCellModelCacheTests testCacheWithSameIdentifierDifferentUpdatedDate 1.37s
โœ… BookCellModelCacheTests testClear 1.44s
โœ… BookCellModelCacheTests testConcurrentAccess_DoesNotCrash 1.46s
โœ… BookCellModelCacheTests testDefaultConfiguration_HasReasonableValues 1.42s
โœ… BookCellModelCacheTests testDifferentBooksGetDifferentModels 1.36s
โœ… BookCellModelCacheTests testDirectInvalidation_RefreshesModel 1.30s
โœ… BookCellModelCacheTests testDirectInvalidation_WorksForHoldingState 1.24s
โœ… BookCellModelCacheTests testDirectInvalidation_WorksForStateTransitions 1.18s
โœ… BookCellModelCacheTests testEmptyCache_survivesAllPublicMutatorsWithoutCrashOrSpuriousEntries 1.33s
โœ… BookCellModelCacheTests testInvalidate 1.37s
โœ… BookCellModelCacheTests testInvalidateMultiple 1.20s
โœ… BookCellModelCacheTests testLRUEviction 1.25s
โœ… BookCellModelCacheTests testMemoryWarning 1.60s
โœ… BookCellModelCacheTests testModelCreation 1.29s
โœ… BookCellModelCacheTests testModelReuse_returnsSameInstanceAndDoesNotGrowCacheCount 1.23s
โœ… BookCellModelCacheTests testModelUpdate_SameInstance_DoesNotMutateBook 1.31s
โœ… BookCellModelCacheTests testModelUpdate_SwapsInstance_IgnoringTimestamp 2.01s
โœ… BookCellModelCacheTests testModelUpdate_WithNewerBook_DefersUpdateToTask 1.28s
โœ… BookCellModelCacheTests testModelUpdate_WithSameBook_DoesNotUpdate 1.25s
โœ… BookCellModelCacheTests testModelUpdatesWhenBookChanges 1.50s
โœ… BookCellModelCacheTests testPreload 1.38s
โœ… BookCellModelComputedPropertyTests testAuthors_ReturnsBookAuthors 48ms
โœ… BookCellModelComputedPropertyTests testAuthors_ReturnsEmptyStringWhenNil 12ms
โœ… BookCellModelComputedPropertyTests testBookState_ReturnsRegistryStateByDefault 22ms
โœ… BookCellModelComputedPropertyTests testBookState_SetToNonReturning_ClearsOverride 31ms
โœ… BookCellModelComputedPropertyTests testBookState_SetToReturning_OverridesRegistryState 20ms
โœ… BookCellModelComputedPropertyTests testButtonTypes_WhenReturning_UsesReturningState 23ms
โœ… BookCellModelComputedPropertyTests testIsManagingHold_DefaultsFalse 66ms
โœ… BookCellModelComputedPropertyTests testIsProcessing_ReturnsIsLoading 15ms
โœ… BookCellModelComputedPropertyTests testLoadBookCoverImage_UsesCachedImage 82ms
โœ… BookCellModelComputedPropertyTests testShowHalfSheet_CanBeToggled 37ms
โœ… BookCellModelComputedPropertyTests testShowHalfSheet_DefaultsFalse 10ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_FalseForDownloadFailed 46ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_FalseForDownloading 12ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_FalseForHolding 7ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_FalseForUnregistered 8ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_FalseForUsed 11ms
โœ… BookCellModelComputedPropertyTests testShowUnreadIndicator_TrueForDownloadSuccessful 9ms
โœ… BookCellModelComputedPropertyTests testStatePublisher_EmitsOnIsLoadingChange 20ms
โœ… BookCellModelComputedPropertyTests testTitle_ReturnsBookTitle 20ms
โœ… BookCellModelOfflineTests testDidSelectDownload_whenOffline_doesNotInvokeDownloadCenter 43ms
โœ… BookCellModelOfflineTests testDidSelectDownload_whenOffline_doesNotSetIsLoading 21ms
โœ… BookCellModelOfflineTests testDidSelectDownload_whenOffline_surfacesRetryableNoConnectionAlert 34ms
โœ… BookCellModelOfflineTests testDidSelectDownload_whenOnline_proceedsWithoutAlert 36ms
โœ… BookCellModelOfflineTests testDidSelectReserve_whenOffline_doesNotSetIsLoading 19ms
โœ… BookCellModelOfflineTests testReachabilityDropsToOffline_whileLoading_clearsLoadingAndShowsAlert 82ms
โœ… BookCellModelOfflineTests testReachabilityInitialState_offline_withoutLoading_doesNotShowAlert 37ms
โœ… BookCellModelOfflineTests testReachabilityRecovers_doesNotAutoStartDownload 40ms
โœ… BookCellModelOfflineTests testReadAction_whenOffline_isNotGatedByReachability 110ms
โœ… BookCellModelRegistryBindingTests testRegistryStateChange_ClearsLoadingForTerminalStates 65ms
โœ… BookCellModelRegistryBindingTests testRegistryStateChange_IgnoresOtherBookIds 233ms
โœ… BookCellModelRegistryBindingTests testRegistryStateChange_ToDownloadFailed_ClearsLoading 17ms
โœ… BookCellModelRegistryBindingTests testRegistryStateChange_UpdatesRegistryState 39ms
โœ… BookCellModelStateTests testBookCellStateButtonState_MapsThroughCorrectly 4ms
โœ… BookCellModelStateTests testBookCellStateForDownloadFailed 17ms
โœ… BookCellModelStateTests testBookCellStateForDownloadInProgress 33ms
โœ… BookCellModelStateTests testBookCellStateForDownloadSuccessful 52ms
โœ… BookCellModelStateTests testDownloadErrorRoutesToCellAlertWhenHalfSheetHidden 19ms
โœ… BookCellModelStateTests testDownloadErrorRoutesToHalfSheetAlertWhenHalfSheetVisible 17ms
โœ… BookCellModelStateTests testInitialStateForDownloadFailed 10ms
โœ… BookCellModelStateTests testInitialStateForDownloadNeeded 7ms
โœ… BookCellModelStateTests testInitialStateForDownloading 9ms
โœ… BookCellModelStateTests testInitialStateForHolding 10ms
โœ… BookCellModelStateTests testInitialStateForUnregisteredBook 7ms
โœ… BookCellModelStateTests testInitialStateMatchesRegistry 10ms
โœ… BookCellModelStateTests testIsLoading_EmitsViaStatePublisher_WhenChanged 8ms
โœ… BookCellModelStateTests testIsLoading_SettlesFalseAfterImageFetchCompletes 182ms
โœ… BookCellModelStateTests testValidateStateConsistencyDetectsMismatch 22ms
โœ… BookCellModelStateTests testValidateStateConsistencyPasses 7ms
โœ… BookCellModelStreamingHTMLTests testBookCellModel_didSelectRead_epubBook_doesNotPushStreamingRoute 107ms
โœ… BookCellModelStreamingHTMLTests testBookCellModel_didSelectRead_streamingHTMLBook_presentsStreamingReaderView_viaCoordinator 28ms
โœ… BookCellStateComprehensiveTests testBookCellState_CanBorrow_MapsToNormal 2ms
โœ… BookCellStateComprehensiveTests testBookCellState_CanHold_MapsToNormal 2ms
โœ… BookCellStateComprehensiveTests testBookCellState_DownloadFailed_MapsToDownloadFailed 3ms
โœ… BookCellStateComprehensiveTests testBookCellState_DownloadInProgress_MapsToDownloading 4ms
โœ… BookCellStateComprehensiveTests testBookCellState_DownloadNeeded_MapsToNormal 2ms
โœ… BookCellStateComprehensiveTests testBookCellState_HoldingFrontOfQueue_MapsToNormal 3ms
โœ… BookCellStateComprehensiveTests testBookCellState_Holding_MapsToNormal 18ms
โœ… BookCellStateComprehensiveTests testBookCellState_ManagingHold_MapsToNormal 11ms
โœ… BookCellStateComprehensiveTests testBookCellState_Returning_MapsToNormal 4ms
โœ… BookCellStateComprehensiveTests testBookCellState_Unsupported_MapsToNormal 23ms
โœ… BookCellStateComprehensiveTests testBookCellState_Used_MapsToNormal 5ms
โœ… BookCellStateComprehensiveTests testButtonState_ExtractionFromDownloadFailed 11ms
โœ… BookCellStateComprehensiveTests testButtonState_ExtractionFromDownloading 273ms
โœ… BookCellStateComprehensiveTests testButtonState_ExtractionFromNormal 3ms
โœ… BookContentResetServiceTests testPurge_force_invokesEvenWithActiveAudiobooks 30ms
โœ… BookContentResetServiceTests testResetAccount_otherAccount_removesContentDirectory 14ms
โœ… BookDetailMetadataHydrationTests testHydrate_PopulatesAudienceAndLanguageFromAlternateFeed 1.52s
โœ… BookDetailMetadataHydrationTests testHydrate_PreservesAcquisitionAndNavigationalURLs 1.51s
โœ… BookDetailMetadataHydrationTests testHydrate_TriggeredWhenOnlyAudienceOrLanguageMissing_DoesNotFireIfOthersPopulated 1.55s
โœ… BookDetailMetadataHydrationTests testHydrate_WhenAllTargetFieldsEmpty_PopulatesFromAlternateFeed 1.35s
โœ… BookDetailMetadataHydrationTests testHydrate_WhenMetadataAlreadyPresent_DoesNotFetch 1.39s
โœ… BookDetailMetadataHydrationTests testHydrate_WhenNoAlternateURL_DoesNotFetch 1.34s
โœ… BookDetailViewModelTests testAllBookStates_HaveValidMapping 16ms
โœ… BookDetailViewModelTests testAllButtonStates_HaveValidButtonTypes 19ms
โœ… BookDetailViewModelTests testAvailability_Nil_ReturnsNil 7ms
โœ… BookDetailViewModelTests testAvailability_Unlimited_MapsToCanBorrow 8ms
โœ… BookDetailViewModelTests testBookContentType_Audiobook 12ms
โœ… BookDetailViewModelTests testBookContentType_EPUB 16ms
โœ… BookDetailViewModelTests testBookContentType_PDF 6ms
โœ… BookDetailViewModelTests testBookDetailViewModel_didSelectGet_streamingHTMLBook_thenButtonsAreReadStreaming 14ms
โœ… BookDetailViewModelTests testBookDetailViewModel_handleAction_readStreaming_callsDidSelectReadStreaming 25ms
โœ… BookDetailViewModelTests testBookLane_Creation 14ms
โœ… BookDetailViewModelTests testBookLane_EmptyBooks 4ms
โœ… BookDetailViewModelTests testBookLane_WithNilURL 7ms
โœ… BookDetailViewModelTests testBookState_SetReturning_SetsLocalOverride_HidesViaRegistryOnlyWhenUnregistered 14ms
โœ… BookDetailViewModelTests testBookState_SetUnregistered_ClearsLocalOverride 9ms
โœ… BookDetailViewModelTests testBook_GetExpirationDate_ReturnsDate_WhenLimitedAvailability 8ms
โœ… BookDetailViewModelTests testBook_GetExpirationDate_ReturnsNilForUnborrowed 9ms
โœ… BookDetailViewModelTests testButtonState_DownloadFailed_MapsToDownloadFailed 14ms
โœ… BookDetailViewModelTests testButtonState_DownloadNeeded_MapsToDownloadNeeded 4ms
โœ… BookDetailViewModelTests testButtonState_DownloadSuccessful_MapsToDownloadSuccessful 4ms
โœ… BookDetailViewModelTests testButtonState_Downloading_MapsToDownloadInProgress 7ms
โœ… BookDetailViewModelTests testButtonState_Holding_MapsToHolding 5ms
โœ… BookDetailViewModelTests testButtonState_IsProcessingDownload_MapsToDownloadInProgress 5ms
โœ… BookDetailViewModelTests testButtonState_Returning_MapsToReturning 6ms
โœ… BookDetailViewModelTests testButtonState_ReturnsStableButtonState 8ms
โœ… BookDetailViewModelTests testButtonState_Unregistered_MapsToCanBorrow 4ms
โœ… BookDetailViewModelTests testButtonState_Used_MapsToUsed 4ms
โœ… BookDetailViewModelTests testButtonTypesProvider_DelegatesToStableButtonState 10ms
โœ… BookDetailViewModelTests testButtonTypes_CanBorrowAudiobookWithSample_IncludesAudiobookSample 33ms
โœ… BookDetailViewModelTests testButtonTypes_CanBorrowWithSample_IncludesSampleButton 9ms
โœ… BookDetailViewModelTests testButtonTypes_CanBorrow_ReturnsGetButton 7ms
โœ… BookDetailViewModelTests testButtonTypes_CanHold_ReturnsReserveButton 10ms
โœ… BookDetailViewModelTests testButtonTypes_DownloadFailed_ReturnsCancelAndRetry 9ms
โœ… BookDetailViewModelTests testButtonTypes_DownloadInProgress_ReturnsCancelButton 12ms
โœ… BookDetailViewModelTests testButtonTypes_DownloadSuccessful_AudiobookReturnsListen 12ms
โœ… BookDetailViewModelTests testButtonTypes_DownloadSuccessful_EpubReturnsRead 10ms
โœ… BookDetailViewModelTests testButtonTypes_PreviewDisabled_ExcludesSampleButton 7ms
โœ… BookDetailViewModelTests testButtonTypes_Returning_ReturnsReturningButton 8ms
โœ… BookDetailViewModelTests testButtonTypes_Unsupported_ReturnsEmpty 8ms
โœ… BookDetailViewModelTests testCredentialCheck_AllowsActionWhenLoggedIn 8ms
โœ… BookDetailViewModelTests testCredentialCheck_PreventsActionWhenNotLoggedIn 17ms
โœ… BookDetailViewModelTests testDidSelectCancel_ResetsDownloadProgress 15ms
โœ… BookDetailViewModelTests testDownloadProgress_IgnoresDifferentBook 525ms
โœ… BookDetailViewModelTests testDownloadProgress_NeverGoesBackwards 13ms
โœ… BookDetailViewModelTests testEnsureAuthPattern_ChecksCredentialsAfterModalDismiss 4ms
โœ… BookDetailViewModelTests testFetchRelatedBooks_NilURL_IsNoOp_AndDoesNotSetLoading 11ms
โœ… BookDetailViewModelTests testHalfSheet_DismissedOnHoldPlaced 4ms
โœ… BookDetailViewModelTests testHalfSheet_DismissedOnUnregistered 4ms
โœ… BookDetailViewModelTests testHalfSheet_StaysOpenDuringDownload 7ms
โœ… BookDetailViewModelTests testHalfSheet_StaysOpenOnDownloadFailed 6ms
โœ… BookDetailViewModelTests testHalfSheet_StaysOpenOnDownloadSuccess 4ms
โœ… BookDetailViewModelTests testHalfSheet_StaysOpenOnUsedState 6ms
โœ… BookDetailViewModelTests testHandleAction_Cancel_ResetsDownloadProgressToZero 11ms
โœ… BookDetailViewModelTests testHandleAction_Close_DoesNothingButInsertsProcessing 7ms
โœ… BookDetailViewModelTests testHandleAction_DuplicateTap_IsIgnored 39ms
โœ… BookDetailViewModelTests testHandleAction_ManageHold_SetsManagingHoldAndHoldingState 9ms
โœ… BookDetailViewModelTests testHandleBookRegistryChange_UpdatesBookFromRegistry 16ms
โœ… BookDetailViewModelTests testHoldingState_ButtonTypesIncludeHoldManagement 13ms
โœ… BookDetailViewModelTests testHoldingState_MapsFromBorrowAttempt 5ms
โœ… BookDetailViewModelTests testIsBorrowProcessing_DefaultsToRegistryProcessingFlagAtInit 8ms
โœ… BookDetailViewModelTests testIsBorrowProcessing_FlipsBackToFalseOnCompletionNotification 15ms
โœ… BookDetailViewModelTests testIsBorrowProcessing_FlipsOnProcessingNotification_ForSameBook 20ms
โœ… BookDetailViewModelTests testIsBorrowProcessing_IgnoresNotificationsForDifferentBook 28ms
โœ… BookDetailViewModelTests testIsFullSize_ReturnsFalseOnNonIpad 11ms
โœ… BookDetailViewModelTests testIsProcessing_ReturnsTrueWhenButtonInSet 7ms
โœ… BookDetailViewModelTests testManagedHoldState_ButtonTypes 9ms
โœ… BookDetailViewModelTests testProcessingButtonTypes_DownloadRelated 7ms
โœ… BookDetailViewModelTests testProcessingButtons_ClearedWhenLoginCancelled 18ms
โœ… BookDetailViewModelTests testProcessingButtons_DidSetUpdatesIsProcessingFlag 9ms
โœ… BookDetailViewModelTests testRegistryTransitionToDownloadFailed_ClearsDownloadProcessingButtons 24ms
โœ… BookDetailViewModelTests testRegistryTransitionToDownloadSuccessful_ClearsDownloadProcessingButtons 50ms
โœ… BookDetailViewModelTests testRegistryTransitionToDownloading_ClearsDownloadProcessingButtons 15ms
โœ… BookDetailViewModelTests testRegistryTransitionToHolding_ClearsReserveAndDismissesHalfSheet 29ms
โœ… BookDetailViewModelTests testRegistryTransitionToUnregistered_ResetsManagingHoldAndHalfSheetAndReturning 20ms
โœ… BookDetailViewModelTests testRelatedBooks_ClearedWhenNavigatingToDifferentBook 33ms
โœ… BookDetailViewModelTests testRelatedBooks_PersistAfterViewReappears 13ms
โœ… BookDetailViewModelTests testRelatedBooks_PreservedDuringRefetchForSameBook 11ms
โœ… BookDetailViewModelTests testRemoveProcessingButton_RemovesTheButton 39ms
โœ… BookDetailViewModelTests testSelectRelatedBook_DifferentBook_UpdatesBookAndClearsLanes 29ms
โœ… BookDetailViewModelTests testSelectRelatedBook_SameBook_IsNoOp 13ms
โœ… BookDetailViewModelTests testShowMoreBooksForLane_LaneWithNilURL_DoesNotSetSelected 12ms
โœ… BookDetailViewModelTests testShowMoreBooksForLane_MissingLane_LeavesSelectedNil 7ms
โœ… BookDetailViewModelTests testShowMoreBooksForLane_SetsSelectedBookURL 12ms
โœ… BookDetailViewModelTests testStableButtonState_ManagingHold_WhileHoldingOverridesToManagingHold 17ms
โœ… BookDetailViewModelTests testStableButtonState_UpdatesWhenBookStateChanges 18ms
โœ… BookDetailViewModelTests testViewModel_BookStatePublisher_TriggersBookUpdate 15ms
โœ… BookDetailViewModelTests testViewModel_ReceivesBookFromRegistry_NotCachedVersion 30ms
โœ… BookDetailViewModelTests testViewModel_UpdatesBookWhenRegistryChanges 19ms
โœ… BookFileManagerTests testContentDirectoryURL_createsDirectoryOnFirstCall 4ms
โœ… BookFileManagerTests testContentDirectoryURL_distinctAccounts_distinctDirectories 4ms
โœ… BookFileManagerTests testContentDirectoryURL_idempotent_reusesExistingDirectory 4ms
โœ… BookFileManagerTests testFileUrl_byIdentifier_andByBook_returnSameUrlForSameAccount 7ms
โœ… BookFileManagerTests testFileUrl_byIdentifier_returnsNilWhenBookNotInRegistry 2ms
โœ… BookFileManagerTests testFileUrl_byIdentifier_returnsUrlWhenBookInRegistry 7ms
โœ… BookFileManagerTests testFileUrl_forBook_buildsHashedFileNameWithEpubExtension 21ms
โœ… BookFileManagerTests testPathExtension_defaultsToEpub_forNilOrNonLCPBooks 9ms
โœ… BookListViewAccessibilityTests testBookCell_unchangedFrom3_0_1 4ms
โœ… BookListViewAccessibilityTests testBookListView_announcesOpenDetailsHint 7ms
โœ… BookListViewAccessibilityTests testBookListView_doesNotIgnoreChildren 3ms
โœ… BookListViewAccessibilityTests testBookListView_doesNotRemoveButtonTrait 6ms
โœ… BookListViewAccessibilityTests testBookListView_rowWrapperIsSwiftUIButton 6ms
โœ… BookListViewAccessibilityTests testBookListView_usesCanonicalVoiceOverLabel 3ms
โœ… BookListViewAccessibilityTests testNormalBookCell_unchangedFrom3_0_1 5ms
โœ… BookListViewAccessibilityTests testVoiceOverLabel_audiobook_includesAudiobookDesignation 22ms
โœ… BookListViewAccessibilityTests testVoiceOverLabel_ebook_titleByAuthor 5ms
โœ… BookPreviewTests testEpubBookPreviewExtraction 7ms
โœ… BookPreviewTests testOverdriveMPEGAudiobookExtraction 3ms
โœ… BookPreviewTests testOverdriveWaveAudiobookExtraction 4ms
โœ… BookPreviewTests testOverdriveWebAudiobookExtraction 5ms
โœ… BookRegistryStoreTests test_addBook_thenRetrieve 17ms
โœ… BookRegistryStoreTests test_addBook_withLocationAndBookmarks 11ms
โœ… BookRegistryStoreTests test_allBooks_returnsAllRegisteredBooks 25ms
โœ… BookRegistryStoreTests test_bookForIdentifier_returnsNilForUnregisteredOrInvalidInputs 77ms
โœ… BookRegistryStoreTests test_concurrentReadsAndWrites_noDataRace 273ms
โœ… BookRegistryStoreTests test_fulfillmentId_emptyIdentifier_returnsNil 5ms
โœ… BookRegistryStoreTests test_fulfillmentId_nilIdentifier_returnsNil 17ms
โœ… BookRegistryStoreTests test_fulfillmentId_setAndGet 19ms
โœ… BookRegistryStoreTests test_heldBooks_onlyReturnsHoldingState 29ms
โœ… BookRegistryStoreTests test_mutateRegistrySync_directMutation 17ms
โœ… BookRegistryStoreTests test_myBooks_returnsCorrectStates 52ms
โœ… BookRegistryStoreTests test_processing_defaultsFalseForUnknownAndRegisteredBooks 21ms
โœ… BookRegistryStoreTests test_readRegistry_returnsSnapshot 43ms
โœ… BookRegistryStoreTests test_record_returnsNilForUnregisteredOrInvalidInputs 36ms
โœ… BookRegistryStoreTests test_registrySnapshot_returnsDictionaryRepresentations 25ms
โœ… BookRegistryStoreTests test_registrySubject_emitsOnAdd 13ms
โœ… BookRegistryStoreTests test_removeAll_clearsRegistry 23ms
โœ… BookRegistryStoreTests test_removeBook_nonexistentId_completesWithNilBook 91ms
โœ… BookRegistryStoreTests test_removeBook_removesFromRegistry 15ms
โœ… BookRegistryStoreTests test_setProcessing_true_thenFalse 14ms
โœ… BookRegistryStoreTests test_setState_updatesState 39ms
โœ… BookRegistryStoreTests test_state_returnsUnregisteredForUnregisteredOrInvalidInputs 25ms
โœ… BookRegistryStoreTests test_updateAndRemoveBook_setsStateUnregistered 10ms
โœ… BookRegistryStoreTests test_updatedBookMetadata_preservesExistingAuthorsWhenIncomingIsEmpty 7ms
โœ… BookRegistryStoreTests test_updatedBookMetadata_returnsNilWhenBookIsNotInRegistry 5ms
โœ… BookRegistryStoreTests test_updatedBookMetadata_takesIncomingAuthorsWhenPresent 7ms
โŠ˜ BookRegistrySyncReadinessTests testIntegration_underDetailsLoading_setStateSyncingFiresUnconditionally 194ms
โœ… BookRegistrySyncReadinessTests testReadiness_underDetailsFailed_throwsAuthDocumentFetchFailed 189ms
โœ… BookRegistrySyncReadinessTests testReadiness_underDetailsLoading_blocksUntilTransition 236ms
โœ… BookRegistrySyncTests test_bulkDeletionProtection_emptyFeedWithLargeLibrary_skipsDeletion 9ms
โœ… BookRegistrySyncTests test_bulkDeletionProtection_emptyFeedWithSingleLocalBook_skipsDeletion 14ms
โœ… BookRegistrySyncTests test_bulkDeletionProtection_emptyFeedWithTwoLocalBooks_skipsDeletion 4ms
โœ… BookRegistrySyncTests test_bulkDeletionProtection_normalFeedDoesNotSkip 4ms
โœ… BookRegistrySyncTests test_bulkDeletionProtection_zeroLocalBooks_doesNotSkip 10ms
โœ… BookRegistrySyncTests test_checkIfBookFileExists_returnsFalseForUnknownBook 18ms
โœ… BookRegistrySyncTests test_largeDeletionWarning_notTriggeredForSmallRatio 13ms
โœ… BookRegistrySyncTests test_loadStateTransition_downloadingWithNoFile_becomesDownloadFailed 20ms
โœ… BookRegistrySyncTests test_load_allowsLoadForDifferentAccount 16ms
โœ… BookRegistrySyncTests test_load_preventsReentrantLoadsForSameAccount 14ms
โœ… BookRegistrySyncTests test_load_withMalformedJSON_doesNotCrashAndLoadsEmpty 14ms
โœ… BookRegistrySyncTests test_load_withMissingFile_transitionsToLoadedWithEmptyRegistry 15ms
โœ… BookRegistrySyncTests test_registrySnapshot_producesSerializableData 18ms
โœ… BookRegistrySyncTests test_registryUrl_returnsPathContainingAccountAndRegistryFile 5ms
โœ… BookRegistrySyncTests test_reset_clearsSyncUrlAndStore 44ms
โœ… BookRegistrySyncTests test_reset_removesRegistryFileFromDisk 15ms
โœ… BookRegistrySyncTests test_storeSnapshotWithMultipleStates 72ms
โœ… BookRegistrySyncTests test_syncUrl_isSetDuringSync_andClearedAfter 8ms
โŠ˜ BookRegistrySyncTests test_sync_whenAlreadySyncing_returnsBeforeSettingSyncingState 10ms
โŠ˜ BookRegistrySyncTests test_sync_whenNotSyncing_withCredentialsAndNoLoansUrl_resolvesToLoaded 8ms
โœ… BookRegistrySyncTests test_sync_whenStateIsLoading_shortCircuitsBeforeTouchingAccounts 4ms
โœ… BookRegistrySyncTests test_sync_whenStateIsUnloaded_shortCircuitsBeforeTouchingAccounts 29ms
โœ… BookRegistrySyncTests test_sync_withCurrentAccountButNoCredentials_resolvesToLoadedSynchronously 12ms
โœ… BookRegistrySyncTests test_validateDownloadedContent_marksDownloadNeededWhenFileMissing 21ms
โœ… BookReturnCleverReauthTests testReturn_OAuthIntermediary_AuthError_MarksCredentialsStaleBeforeReauth 18ms
โœ… BookReturnServiceAuthCoordinatorTests testService_authErrorOnReturn_withCoordinatorWired_routesThroughCoordinator_notLegacyReauthenticator 84ms
โœ… BookReturnServiceAuthCoordinatorTests testService_authErrorOnReturn_withoutCoordinator_fallsBackToLegacyReauthenticator 548ms
โœ… BookReturnServiceAuthCoordinatorTests testService_coordinatorCancellation_announcesReturnFailed_andDoesNotRetry 295ms
โœ… BookReturnServiceContractTests test_returnBook_authError_triggersReauth 880ms
โœ… BookReturnServiceContractTests test_returnBook_genericError_presentsAlert 1.08s
โœ… BookReturnServiceContractTests test_returnBook_noActiveLoan_treatsAsSuccess 1.13s
โœ… BookReturnServiceContractTests test_returnBook_withRevokeURL_happyPath_callsRegistrySetState_then_syncCompletes 1.07s
โœ… BookReturnServiceContractTests test_returnBook_withoutRevokeURL_skipsNetwork_clearsLocalContent 933ms
โœ… BookReturnServiceTests testReturnBook_SAMLBrowserAuth_invalidCredentials_marksCredentialsStaleBeforeReauth 301ms
โœ… BookReturnServiceTests testReturnBook_basicAuth_invalidCredentials_doesNotMarkCredentialsStale 31ms
โœ… BookReturnServiceTests testReturnBook_bookNotInRegistry_callsCompletionAndDoesNothing 61ms
โœ… BookReturnServiceTests testReturnBook_cancelAllInFlightTasks_emptiesTheRetentionSet 25ms
โœ… BookReturnServiceTests testReturnBook_noRevokeURL_downloaded_deletesContentAndRemovesBook 78ms
โœ… BookReturnServiceTests testReturnBook_noRevokeURL_notDownloaded_skipsContentDeletion 147ms
โœ… BookReturnServiceTests testReturnBook_revokeURLPath_retainsTaskWhileInFlight_andDrainsOnCompletion 34ms
โœ… BookReturnServiceTests testReturnBook_revokeURLReturnsGenericError_announcesFailureAndRunsCompletion 29ms
โœ… BookReturnServiceTests testReturnBook_revokeURLReturnsInvalidCredentials_reauthenticatesAndRetries 40ms
โœ… BookReturnServiceTests testReturnBook_revokeURLReturnsLoanTermLimitDetail_cleansUpLocallyAndAnnouncesSuccess 25ms
โœ… BookReturnServiceTests testReturnBook_revokeURLReturnsNoActiveLoan_cleansUpLocallyAndAnnouncesSuccess 44ms
โœ… BookReturnServiceTests testReturnBook_revokeURLReturnsParsingError_treatsAsSuccessAndCleansUp 26ms
โœ… BookReturnServiceTests testReturnService_cancelAllInFlightTasks_cancelsRetainedTask 24ms
โœ… BookReturnServiceTests testReturnService_inFlightTasks_shortCircuitAfterServiceDeinits 37ms
โœ… BookSignInRedirectHandlerTests testClearAndSetCookies_replacesSessionCookiesWithUserAccountCookies 17ms
โœ… BookSignInRedirectHandlerTests testHandleBookFound_nilRequest_skipsRetry 12ms
โœ… BookSignInRedirectHandlerTests testHandleBookFound_setsCookiesAndRetriesDownloadIfRequestPresent 15ms
โœ… BookSignInRedirectHandlerTests testHandleLoginCancellation_setsDownloadNeededAndCancelsViaDelegate 6ms
โœ… BookSignInRedirectHandlerTests testHandleProblem_alreadySAMLStarted_setsFailedAndPresentsReauthModal 42ms
โœ… BookSignInRedirectHandlerTests testHandleProblem_hasCredentialsAndNotSaml_logsButDoesNotAuthenticate 98ms
โœ… BookSignInRedirectHandlerTests testHandleProblem_noCredentialsLoginRequired_presentsReauthAndRetriesOnHasCredentials 57ms
โœ… BookSignInRedirectHandlerTests testHandleProblem_samlCookiesExpired_setsSAMLStartedAndRetries 41ms
โœ… BookStateIntegrationTests testBookBorrow_UpdatesRegistry 29ms
โœ… BookStateIntegrationTests testBookDownloadFailure_UpdatesStateToDownloadFailed 7ms
โœ… BookStateIntegrationTests testBookReturn_RemovesFromRegistry 5ms
โœ… BookStateIntegrationTests testBookStateChange_PublishesViaCombine 5ms
โœ… BookStateIntegrationTests testBookStateTransition_FullDownloadLifecycle 3ms
โœ… BookStateIntegrationTests testBookWithHolds_ShowsHoldingState 4ms
โœ… BookStateIntegrationTests testConcurrentStateChanges_DoNotCorruptRegistry 16ms
โœ… BookStateIntegrationTests testRegistryPublisher_EmitsOnBookAdd 7ms
โœ… BookmarkBusinessLogicExtendedTests testBookmarkAtIndex_returnsNilForOutOfRangeIndicesAndItemForValid 113ms
โœ… BookmarkBusinessLogicExtendedTests testBookmarkAtIndex_validIndex_returnsBookmark 105ms
โœ… BookmarkBusinessLogicExtendedTests testDeleteBookmarkAtIndex_guardsOutOfRangeAndRemovesOnlyValidIndex 126ms
โœ… BookmarkBusinessLogicExtendedTests testDeleteBookmarkAtIndex_validIndex_removesAndReturns 125ms
โœ… BookmarkBusinessLogicExtendedTests testDeleteBookmark_existingBookmark_removes 146ms
โœ… BookmarkBusinessLogicExtendedTests testReadOnlySurfaces_noBookmarksText_shouldSelect_shouldAllowRefresh 163ms
โœ… BookmarkDeletionLogTests testUpdateLocalBookmarks_matchingLocalBookmark_preservesLocal 212ms
โœ… BookmarkDeletionLogTests testUpdateLocalBookmarks_serverBookmarkNotDeleted_addsLocally 181ms
โœ… BookmarkDeletionLogTests testUpdateLocalBookmarks_withPendingDeletion_deletesFromServer 246ms
โœ… BookmarkDeviceIdMatchingTests testUpdateLocalBookmarks_ServerBookmarkFromDifferentDevice_AddedLocally 108ms
โœ… BookmarkDeviceIdMatchingTests testUpdateLocalBookmarks_ServerBookmarkFromSameDevice_NotLocallyPresent_MarkedForDeletion 98ms
โœ… BookmarkDeviceIdMatchingTests testUpdateLocalBookmarks_ServerBookmarkWithNilDevice_AddedLocally 88ms
โœ… BookmarkExistenceTests testIsBookmarkExisting_differentProgress_returnsNil 118ms
โœ… BookmarkExistenceTests testIsBookmarkExisting_matchingBookmark_returnsBookmark 93ms
โœ… BookmarkExistenceTests testIsBookmarkExisting_noBookmarks_returnsNil 120ms
โœ… BookmarkExistenceTests testIsBookmarkExisting_returnsNilForNilLocationAndForLocationWithoutMatch 91ms
โœ… BookmarkManagerTests test_addGenericBookmark 18ms
โœ… BookmarkManagerTests test_addGenericBookmark_initializesArrayIfNil 37ms
โœ… BookmarkManagerTests test_addGenericBookmark_toMissingBook_doesNotCrash 9ms
โœ… BookmarkManagerTests test_addMultipleReadiumBookmarks_sortedByProgress 48ms
โœ… BookmarkManagerTests test_addOrReplaceGenericBookmark_addsWhenNew 18ms
โœ… BookmarkManagerTests test_addOrReplaceGenericBookmark_initializesArrayIfNil 28ms
โœ… BookmarkManagerTests test_addOrReplaceGenericBookmark_replacesExisting 23ms
โœ… BookmarkManagerTests test_addReadiumBookmark 24ms
โœ… BookmarkManagerTests test_addReadiumBookmark_initializesArrayIfNil 25ms
โœ… BookmarkManagerTests test_addReadiumBookmark_toMissingBook_doesNotCrash 10ms
โœ… BookmarkManagerTests test_bookmarksAreIsolatedBetweenBooks 58ms
โœ… BookmarkManagerTests test_deleteGenericBookmark_byAnnotationId 48ms
โœ… BookmarkManagerTests test_deleteGenericBookmark_bySimilarity 41ms
โœ… BookmarkManagerTests test_deleteReadiumBookmark 30ms
โœ… BookmarkManagerTests test_everyMutationCallsSave 46ms
โœ… BookmarkManagerTests test_locationAndBookmarksAreIndependent 58ms
โœ… BookmarkManagerTests test_missingBook_locationAndBookmarkLookups_returnAbsentValues 10ms
โœ… BookmarkManagerTests test_replaceGenericBookmark 26ms
โœ… BookmarkManagerTests test_replaceReadiumBookmark 38ms
โœ… BookmarkManagerTests test_setAndGetLocation 17ms
โœ… BookmarkManagerTests test_setLocationSync_callsSaveSyncInsteadOfSave 19ms
โœ… BookmarkManagerTests test_setLocationSync_emptyIdentifier_neitherSyncNorAsyncSaveFires 5ms
โœ… BookmarkManagerTests test_setLocation_emptyIdentifier_doesNotSaveAndDoesNotTouchAnyBook 22ms
โœ… BookmarkManagerTests test_setLocation_nil_clearsLocation 48ms
โœ… BookmarkSortingTests testBookmarks_sortedByProgressWithinBook 192ms
โœ… BookmarkSyncTests testUpdateLocalBookmarks_addsServerBookmarks 111ms
โœ… BookmarkSyncTests testUpdateLocalBookmarks_handlesEmptyServerList 118ms
โœ… BookmarkSyncTests testUpdateLocalBookmarks_preservesFailedUploads 90ms
โœ… BorrowAndDownloadIntegrationTests testAudiobookBorrow_ManifestWithZeroTracks_ParsesGracefully 26ms
โœ… BorrowAndDownloadIntegrationTests testBorrowFlow_NetworkError_ShowsAlert_RegistryUnchanged 34ms
โœ… BorrowAndDownloadIntegrationTests testBorrowFlow_Success_RegistryUpdated_DownloadTriggered_NoAlert 17ms
โœ… BorrowAndDownloadIntegrationTests testDownload_StartedWhileOffline_FailsImmediately_NoTaskSpawned 50ms
โœ… BorrowAndDownloadIntegrationTests testFullLifecycle_BorrowDownloadReturn_OnRealRegistry 103ms
โœ… BorrowAndDownloadIntegrationTests testReachabilityDrop_DuringActiveDownloads_FailsAllOfThem 44ms
โœ… BorrowAndDownloadIntegrationTests testReturn_RemovesBookFromRegistry_AndEmitsUnregisteredState 47ms
โœ… BorrowErrorMessageTests testAllRetryableParsingErrors_showUserFriendlyBaseMessage 31ms
โœ… BorrowErrorMessageTests testBookTitle_isIncludedInMessage 3ms
โœ… BorrowErrorMessageTests testDifferentBookTitles_produceDistinctMessages 3ms
โœ… BorrowErrorMessageTests testMessageFormat_matchesLegacyPattern_noProblemDoc 4ms
โœ… BorrowErrorMessageTests testMessageFormat_matchesLegacyPattern_withProblemDoc 3ms
โœ… BorrowErrorMessageTests testNetworkErrors_showUserFriendlyBaseMessage 3ms
โœ… BorrowErrorMessageTests testNilProblemDocument_usesRecoverySuggestion 6ms
โœ… BorrowErrorMessageTests testNoTechnicalErrorString_appearsAsMessage 4ms
โœ… BorrowErrorMessageTests testOPDSFeedInvalid_showsUserFriendlyMessage_notTechnicalError 3ms
โœ… BorrowErrorMessageTests testProblemDocument_takesPriorityOverRecoverySuggestion 5ms
โœ… BorrowErrorMessageTests testWithProblemDocument_appendsServerDetail 3ms
โœ… BorrowErrorMessageTests testWithProblemDocument_emptyDetail_fallsBackToBaseMessage 3ms
โœ… BorrowErrorMessageTests testWithProblemDocument_nilDetail_fallsBackToBaseMessage 6ms
โœ… BorrowErrorPresenterTests testProcess_genericProblemDoc_publishesAlertWithProblemDocDetail 34ms
โœ… BorrowErrorPresenterTests testProcess_invalidCredentialsTwice_secondCallSkipsReauthAndShowsAlert 194ms
โœ… BorrowErrorPresenterTests testProcess_invalidCredentialsWhileAlreadyRequesting_skipsBoth 71ms
โœ… BorrowErrorPresenterTests testProcess_invalidCredentials_triggersReauthAndRetriesViaDelegate 166ms
โœ… BorrowErrorPresenterTests testProcess_loanAlreadyExists_publishesLoanAlreadyExistsAlertWithoutRetry 36ms
โœ… BorrowErrorPresenterTests testProcess_noErrorDict_publishesGenericBorrowFailedAlert 35ms
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_OAuthIntermediary_authError_routesThroughCoordinator 617ms
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_OIDC_silentReauthFails_fallsBackToCoordinator 589ms
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_OIDC_silentReauthSucceeds_doesNotInvokeCoordinator 3.26s
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_SAML_authError_routesThroughCoordinator_skipsLegacyPresentSignInModal 562ms
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_perBookCircuitBreaker_clearAllReleasesAllBookGates 1.08s
โœ… BorrowOperationAuthCoordinatorTests testCoordinator_perBookCircuitBreaker_isStillHonored_acrossTwoSeparateAttempts 1.11s
โœ… BorrowOperationCleverReauthTests testBorrow_OAuthIntermediary_AuthError_RoutesToBrowserReauthModal 174ms
โœ… BorrowOperationCleverReauthTests testBorrow_OAuthIntermediary_NoActiveLoanProblemDoc_TreatedAsAuthError 173ms
โœ… BorrowOperationContractTests test_borrowAsync_401NoProblemDoc_routesToSignInModal 25ms
โœ… BorrowOperationContractTests test_borrowAsync_alreadyBorrowed_isIdempotent_perSQ007 150ms
โœ… BorrowOperationContractTests test_borrowAsync_attemptDownloadFalse_onSuccessfulBorrow_doesNotCallStartDownload 130ms
โœ… BorrowOperationContractTests test_borrowAsync_attemptDownloadTrue_onSuccessfulBorrow_callsStartDownload 21ms
โœ… BorrowOperationContractTests test_borrowAsync_authError_triggersRetryViaSilentReauth 26ms
โœ… BorrowOperationContractTests test_borrowAsync_holdResponse_doesNotCallStartDownload 159ms
โœ… BorrowOperationStreamingHTMLTests testBorrowOperation_borrowSucceeded_epubBook_callsStartDownloadOnce 196ms
โœ… BorrowOperationStreamingHTMLTests testBorrowOperation_borrowSucceeded_streamingHTMLBook_attemptDownloadFalse_doesNotCallStartDownload 1.14s
โœ… BorrowOperationStreamingHTMLTests testBorrowOperation_borrowSucceeded_streamingHTMLBook_doesNotCallStartDownload 215ms
โœ… BorrowOperationTests testBorrowAsync_attemptDownloadTrue_callsDelegateStartDownload 182ms
โœ… BorrowOperationTests testBorrowAsync_genericError_presentsAlertAndRethrows 207ms
โœ… BorrowOperationTests testBorrowAsync_holdingRace_throwsHoldCopyUnavailableAndSetsHolding 107ms
โœ… BorrowOperationTests testBorrowAsync_noAcquisitionURL_throwsInvalidState 15ms
โœ… BorrowOperationTests testBorrowAsync_success_addsBookToRegistryAsDownloadNeeded 21ms
โœ… BorrowOperationTests testBorrow_401NetworkUnauthorizedNoProblemDoc_presentsSignInModal 180ms
โœ… BorrowOperationTests testBorrow_403NetworkForbiddenNoProblemDoc_presentsSignInModal 184ms
โœ… BorrowOperationTests testBorrow_AlreadyHasLoanWithoutCredentials_proceedsAsAuthError 183ms
โœ… BorrowOperationTests testBorrow_NetworkUnknownError_fallsThroughToAlert 181ms
โœ… BorrowOperationTests testBorrow_SAMLBrowserAuth_withCredentials_routesToReauthModalNotAlert 185ms
โœ… BorrowOperationTests testBorrow_SQ007AlreadyHasLoanWithCredentials_doesNotShowAlert 192ms
โœ… BorrowOperationTests testBorrow_StateHolding_isTreatedAsAlreadyHavingLoan 220ms
โœ… BorrowOperationTests testBorrow_StateUnregistered_isNotTreatedAsAlreadyHavingLoan 175ms
โœ… BorrowOperationTimeoutTests testWithTimeout_FastOperation_ReturnsValue 13ms
โœ… BorrowOperationTimeoutTests testWithTimeout_OperationThrowsBeforeDeadline_PropagatesOriginalError 24ms
โœ… BorrowOperationTimeoutTests testWithTimeout_SlowOperation_ThrowsTimeoutError 122ms
โœ… BorrowReducerContractTests test_registryStateChanged_transitionContract 10ms
โœ… BorrowReducerContractTests test_userActions_transitionContract 10ms
โœ… BorrowReducerTests testBookStateAssigned_toOtherState_doesNotChangeOverride 2ms
โœ… BorrowReducerTests testBookStateAssigned_toReturning_armsTheOverride 2ms
โœ… BorrowReducerTests testBookStateAssigned_toUnregistered_clearsTheOverride 2ms
โœ… BorrowReducerTests testCancelTapped_resetsDownloadProgressAndIsIdempotent 4ms
โœ… BorrowReducerTests testDownloadErrorOccurred_resyncsBookStateAndPurgesAllAcquireSpinners 4ms
โœ… BorrowReducerTests testDownloadProgressUpdated_clampsToMaxSeen_neverSlidesBackward 5ms
โœ… BorrowReducerTests testDownloadStartConfirmed_setsDownloadingAndOpensHalfSheet 6ms
โœ… BorrowReducerTests testManageHoldTapped_setsHoldingStateAndManagingFlag 2ms
โœ… BorrowReducerTests testProcessingButtonInserted_addsTheButton 4ms
โœ… BorrowReducerTests testProcessingButtonRemoved_removesOnlyThatButton_andIsIdempotent 5ms
โœ… BorrowReducerTests testRegistryStateChanged_clearsAcquireFlags_forAllBorrowCompletedStates 2ms
โœ… BorrowReducerTests testRegistryStateChanged_toDownloadFailed_keepsHalfSheetOpenForRetryAlert 2ms
โœ… BorrowReducerTests testRegistryStateChanged_toDownloadNeeded_clearsBorrowProcessingFlags 5ms
โœ… BorrowReducerTests testRegistryStateChanged_toDownloadSuccessful_keepsHalfSheetOpenSoUserCanReadOrListen 4ms
โœ… BorrowReducerTests testRegistryStateChanged_toDownloading_clearsDownloadSpinnersOnly 2ms
โœ… BorrowReducerTests testRegistryStateChanged_toHolding_clearsReserveAndDismissesHalfSheet 2ms
โœ… BorrowReducerTests testRegistryStateChanged_toUnregistered_closesHalfSheetAndClearsReturnSpinners 18ms
โœ… BorrowReducerTests testRegistryStateChanged_whenReturningOverrideArmed_acceptsUnregisteredAsTerminal 3ms
โœ… BorrowReducerTests testRegistryStateChanged_whenReturningOverrideArmed_suppressesNonTerminalState 3ms
โœ… BorrowReducerTests testReturnStartConfirmed_insertsReturningSpinnerOnlyAndPreservesBookState 43ms
โœ… BorrowReducerTests testSignInCancelled_releasesAcquireSpinnersAndPreservesUnrelatedFlags 2ms
โœ… BundledRegistrySnapshotTests testBundleMain_LoadsAValidSnapshotWhenEmbedded 608ms
โœ… BundledRegistrySnapshotTests testLoad_RoundTripsThroughOPDS2CatalogsFeedDecoder 6ms
โœ… BundledRegistrySnapshotTests testLoad_WhenResourceMissing_ReturnsNil 2ms
โœ… BundledRegistrySnapshotTests testLoad_WhenResourcePresent_ReturnsBytes 3ms
โœ… BundledRegistrySnapshotTests testLoad_WhenResourceUnreadable_ReturnsNil 5ms
โœ… ButtonStateTests testCanBorrow_audiobookButtonsRespectPreviewToggle 10ms
โœ… ButtonStateTests testCanBorrow_epubButtonsRespectPreviewToggle 10ms
โœ… ButtonStateTests testCanHold_audiobookButtonsRespectPreviewToggle 12ms
โœ… ButtonStateTests testCanHold_epubButtonsRespectPreviewToggle 9ms
โœ… ButtonStateTests testDownloadFailed_yieldsCancelAndRetry 10ms
โœ… ButtonStateTests testDownloadInProgress_yieldsOnlyCancelButton 6ms
โœ… ButtonStateTests testDownloadNeededAudiobook 12ms
โœ… ButtonStateTests testDownloadNeededEpub 9ms
โœ… ButtonStateTests testDownloadSuccessfulAudiobook 9ms
โœ… ButtonStateTests testDownloadSuccessfulEpub 12ms
โœ… ButtonStateTests testDownloadSuccessfulPDF 10ms
โœ… ButtonStateTests testHoldingFrontOfQueue_withoutHoldReady_returnsManageHoldOnly 6ms
โœ… ButtonStateTests testHolding_audiobookButtonsRespectPreviewToggle 10ms
โœ… ButtonStateTests testHolding_epubButtonsRespectPreviewToggle 271ms
โœ… ButtonStateTests testUnsupported_yieldsEmptyButtonSetAndNoLeakageFromOtherStates 5ms
โœ… ButtonStateTests testUsedEpub 7ms
โœ… ButtonStyleTypeTests testAllCases 3ms
โœ… ButtonStyleTypeTests testEquality 4ms
โœ… C64ConversionTests testC64ConverionWithAccentedString 2ms
โœ… C64ConversionTests testC64ConverionWithEmptyString 2ms
โœ… C64ConversionTests testC64ConverionWithNilString 7ms
โœ… C64ConversionTests testC64ConverionWithRegularString 1ms
โœ… C64ConversionTests testC64ConverionWithSpecialCharacters 6ms
โœ… C64ConversionTests testC64ConverionWithUnicodeCharecters 3ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests testCarPlayBridge_dismissBookOnPhone_callsPresenterMinimize 46ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests testCarPlayBridge_dismissBookOnPhone_doesNotKillSession 169ms
โœ… CarPlayAuthHelperReadinessTests testIntegration_underDetailsFailed_returnsFalse 876ms
โœ… CarPlayAuthHelperReadinessTests testReadiness_underDetailsFailed_gateThrows 119ms
โœ… CarPlayAuthHelperReadinessTests testReadiness_underDetailsLoading_gateBlocksUntilTransition 196ms
โœ… CarPlayChapterListTests testCarPlayBridge_NoChaptersAvailable_ReturnsNil 8ms
โœ… CarPlayChapterListTests testCarPlayBridge_NoPlayback_CurrentChapterIsNil 5ms
โœ… CarPlayChapterListTests testCarPlayBridge_SkipToChapter_WithoutPlayback_DoesNotCrash 7ms
โœ… CarPlayIntegrationTests testCarPlayTemplateIntegration_BookSelectionHandling 5ms
โœ… CarPlayIntegrationTests testCarPlay_ImageProvider_CachesBehavior 9ms
โœ… CarPlayLibraryRefreshTests testCarPlay_BookRegistry_IsAccessible 8ms
โœ… CarPlayLibraryRefreshTests testCarPlay_DownloadedAudiobooks_CanBeFiltered 2ms
โœ… CarPlayLibraryRefreshTests testCarPlay_LibraryName_CanBeUpdated 8ms
โœ… CarPlayNowPlayingTemplateTests testCarPlayBridge_DoesNotConfigureNowPlayingOnInit 5ms
โœ… CarPlayNowPlayingTemplateTests testCarPlayBridge_HasPlaybackStatePublisher 509ms
โœ… CarPlayNowPlayingTemplateTests testCarPlayBridge_NowPlayingConfigurationIsIdempotent 3ms
โœ… CarPlayNowPlayingTemplateTests testCarPlayImageProvider_InitializesIndependently 11ms
โœ… CarPlayOpenAppAlertTests testCarPlay_OpenAppMessage_MentionsPalace 5ms
โœ… CarPlayOpenAppAlertTests testCarPlay_OpenAppMessage_MentionsPhone 2ms
โœ… CarPlayOpenAppAlertTests testCarPlay_OpenAppStrings_AreConfigured 2ms
โœ… CarPlayOpenAppAlertTests testSceneDelegate_HasMainSceneConnected_Flag 2ms
โœ… CarPlayPlaybackErrorTests testAudiobookSessionError_MapsToCarPlayAlert 13ms
โœ… CarPlayPlaybackErrorTests testBridge_currentBook_nilWhenNoSession 3ms
โœ… CarPlayPlaybackErrorTests testBridge_isPlaying_reflectsSessionManager 4ms
โœ… CarPlayPlaybackErrorTests testCarPlay_ErrorStrings_AuthRequired 2ms
โœ… CarPlayPlaybackErrorTests testCarPlay_ErrorStrings_NotDownloaded 2ms
โœ… CarPlayPlaybackErrorTests testCarPlay_ErrorStrings_Offline 2ms
โœ… CarPlayPlaybackErrorTests testCarPlay_ErrorStrings_PlaybackFailed 4ms
โœ… CarPlayPlaybackErrorTests testNowPlayingInfo_isAccessible 3ms
โœ… CarPlayTests testAudiobookSessionManager_Initialization 859ms
โœ… CarPlayTests testCarPlayBridge_Initialization 8ms
โœ… CarPlayTests testCarPlayImageProvider_GeneratesPlaceholder 1.00s
โœ… CarPlayTests testCarPlay_BookDownloadedState 5ms
โœ… CarPlayTests testCarPlay_ChapterListFormatting 2ms
โœ… CarPlayTests testCarPlay_ChapterNumber_Formatting 2ms
โœ… CarPlayTests testCarPlay_ErrorStrings_NotEmpty 9ms
โœ… CarPlayTests testCarPlay_FiltersOnlyAudiobooks 15ms
โœ… CarPlayTests testCarPlay_NoEbooksInLibrary 8ms
โœ… CarPlayTests testCarPlay_ShortDurationFormatting 3ms
โœ… CarPlayTests testCarPlay_UIStrings_NotEmpty 3ms
โœ… CarPlayTests testCarPlay_ZeroDurationFormatting 3ms
โœ… CarPlayTimeTrackingTests testCarPlayChapterSkip_properlyTracksTime 42ms
โœ… CarPlayTimeTrackingTests testCarPlayDisconnect_trackerContinuesIndependently 35ms
โœ… CarPlayTimeTrackingTests testCarPlayPlayback_usesStandardTrackerDelegateMethods 35ms
โœ… CatalogAPIDedupeTests testFetchFeed_ConcurrentCallersForDifferentURLs_DoNotDedupe 115ms
โœ… CatalogAPIDedupeTests testFetchFeed_ConcurrentCallersForSameURL_ShareOneNetworkRequest 117ms
โœ… CatalogAPIDedupeTests testFetchFeed_SequentialCallsAfterCompletion_FireFreshRequests 217ms
โœ… CatalogAPIEntryPointTests testExtractSearchEntryPointsFromEmptyFeed 16ms
โœ… CatalogAccessibilityTests testCollapseSectionLabel_isDescriptive 2ms
โœ… CatalogAccessibilityTests testExpandCollapseLabel_roundTripsOnRepeatedFlips 3ms
โœ… CatalogAccessibilityTests testExpandCollapseLabels_areDifferent 3ms
โœ… CatalogAccessibilityTests testExpandSectionLabel_isDescriptive 2ms
โœ… CatalogAccessibilityTests testMoreBooksInLaneLabel_includesLaneTitle 3ms
โœ… CatalogAccessibilityTests testMoreBooksLabel_differsForDifferentLanes 2ms
โœ… CatalogAccessibilityTests testMoreBooksLabel_indicatesNavigation 3ms
โœ… CatalogAccessibilityTests testSwitchLibraryLabel_isDescriptive 3ms
โœ… CatalogCacheKeyAndIsolationTests testCacheKey_SameAccount_RepeatedReads_ShareOneCacheEntry 15ms
โœ… CatalogCacheKeyAndIsolationTests testCacheKey_SamePathDifferentQueryStrings_AreDistinctEntries 8ms
โœ… CatalogCacheKeyAndIsolationTests testCacheKey_SameURL_DistinctAccounts_AreDistinctEntries 8ms
โœ… CatalogCacheKeyAndIsolationTests testCacheKey_SchemeCasing_RetainedAsURLSpec 7ms
โœ… CatalogCacheKeyAndIsolationTests testCacheKey_TrailingSlashDifference_AreDistinctEntries 8ms
โœ… CatalogCacheKeyAndIsolationTests testConcurrentStaleReads_AcrossDistinctURLs_EachURLGetsItsOwnRefresh 13ms
โœ… CatalogCacheKeyAndIsolationTests testConcurrentStaleReads_BackgroundRefreshDoesNotPoisonNeighborKey 122ms
โœ… CatalogCacheKeyAndIsolationTests testInMemoryCache_AfterSystemMemoryWarning_IsClearedAndNextReadHitsNetwork 15ms
โœ… CatalogCacheKeyAndIsolationTests testInvalidateCache_DoesNotClearUnrelatedURLs 12ms
โœ… CatalogCacheKeyAndIsolationTests testInvalidateCache_IsScopedToCurrentAccount 27ms
โœ… CatalogCacheKeyAndIsolationTests testMemoryWarning_ClearsBothInMemoryAndFormatEntriesCache 12ms
โœ… CatalogCacheKeyAndIsolationTests testSignOutContract_InvalidateAllCachedURLs_NextReadsHitNetwork 10ms
โœ… CatalogCacheMetadataExactBoundaryTests testIsExpired_AtExactlyMaxAge_IsNotExpired 4ms
โœ… CatalogCacheMetadataExactBoundaryTests testIsStale_AtExactlyDefaultStaleTTL_IsFresh 14ms
โœ… CatalogCacheMetadataExactBoundaryTests testStaleTTL_ExtremelyLargeServerMaxAge_IsClampedToCeiling 3ms
โœ… CatalogCacheMetadataExactBoundaryTests testStaleTTL_ServerMaxAgeJustBelowFloor_IsClampedToFiveMinutes 3ms
โœ… CatalogCacheMetadataTests testCacheLifecycle_FreshThenStaleThenExpired 2ms
โœ… CatalogCacheMetadataTests testDecode_LegacyMetadataWithoutIsBundledField_DefaultsToFalse 2ms
โœ… CatalogCacheMetadataTests testEncodeDecode_PreservesAllProperties 3ms
โœ… CatalogCacheMetadataTests testEncodeDecode_PreservesIsBundledFalse_Explicitly 3ms
โœ… CatalogCacheMetadataTests testEncodeDecode_PreservesIsBundledTrue 2ms
โœ… CatalogCacheMetadataTests testInvariant_ExpiredImpliesStale 6ms
โœ… CatalogCacheMetadataTests testIsBundled_DefaultsFalse_ForBackCompat 3ms
โœ… CatalogCacheMetadataTests testIsBundled_False_PreservesExistingStalenessBehavior 8ms
โœ… CatalogCacheMetadataTests testIsBundled_True_ForcesStaleness_AcrossAllServerMaxAges 5ms
โœ… CatalogCacheMetadataTests testIsBundled_True_ForcesStaleness_RegardlessOfFreshTimestamp 3ms
โœ… CatalogCacheMetadataTests testIsExpired_EpochTimestamp_IsAlwaysStaleAndExpired 12ms
โœ… CatalogCacheMetadataTests testIsExpired_TransitionsAtTwentyFourHourBoundary 2ms
โœ… CatalogCacheMetadataTests testIsStale_DeepInsideTTL_RemainsFresh 2ms
โœ… CatalogCacheMetadataTests testIsStale_FreshCache_StaysFreshAcrossSubSecondJitter 5ms
โœ… CatalogCacheMetadataTests testIsStale_FutureTimestamp_TreatsAsFresh 2ms
โœ… CatalogCacheMetadataTests testIsStale_TransitionsAtSixHourBoundary 2ms
โœ… CatalogCacheMetadataTests testIsStale_WithServerMaxAge_RespectsOverride 2ms
โœ… CatalogCacheMetadataTests testStaleTTL_ClampsAboveTwelveHoursDownToCeiling 3ms
โœ… CatalogCacheMetadataTests testStaleTTL_ClampsBelowFiveMinutesUpToFloor 2ms
โœ… CatalogCacheMetadataTests testStaleTTL_HalvesServerMaxAgeInMidRange 4ms
โœ… CatalogCacheMetadataTests testStaleTTL_NilOrNegativeServerMaxAge_UsesDefault 3ms
โœ… CatalogFeedModelTests testCatalogEntryFromOPDS1Entry 16ms
โœ… CatalogFeedModelTests testCatalogFeedFromNilFeedReturnsNil 3ms
โœ… CatalogFeedModelTests testCatalogFeedFromOPDS1 79ms
โœ… CatalogFeedModelTests testSearchFormatEntryEquality 5ms
โœ… CatalogFilterGroupModelTests testEdgeCase_EmptyGroupName 8ms
โœ… CatalogFilterGroupModelTests testEdgeCase_SpecialCharactersInName 21ms
โœ… CatalogFilterGroupModelTests testEquality_DifferentFiltersMakesGroupsUnequal 9ms
โœ… CatalogFilterGroupModelTests testEquality_DifferentIdsMakesGroupsUnequal 6ms
โœ… CatalogFilterGroupModelTests testEquality_DifferentNamesMakesGroupsUnequal 4ms
โœ… CatalogFilterGroupModelTests testEquality_IdenticalGroupsAreEqual 8ms
โœ… CatalogFilterGroupModelTests testFilters_FilterByHrefPresence 3ms
โœ… CatalogFilterGroupModelTests testFilters_FindActiveFilter 13ms
โœ… CatalogFilterGroupModelTests testFilters_MultipleActiveFilters 3ms
โœ… CatalogFilterGroupModelTests testFilters_NoActiveFilter 3ms
โœ… CatalogFilterGroupModelTests testHashable_EqualGroupsHaveSameHash 2ms
โœ… CatalogFilterGroupModelTests testHashable_GroupsCanBeUsedInSet 5ms
โœ… CatalogFilterGroupModelTests testIdentifiable_UsesIdProperty 3ms
โœ… CatalogFilterGroupModelTests testInit_StoresAllProperties 38ms
โœ… CatalogFilterGroupModelTests testInit_WithEmptyFilters 5ms
โœ… CatalogFilterGroupModelTests testInit_WithManyFilters 13ms
โœ… CatalogFilterGroupModelTests testInit_WithSingleFilter 4ms
โœ… CatalogFilterModelTests testEdgeCase_ComplexURL 2ms
โœ… CatalogFilterModelTests testEdgeCase_EmptyStringId 2ms
โœ… CatalogFilterModelTests testEdgeCase_EmptyStringTitle 2ms
โœ… CatalogFilterModelTests testEdgeCase_SpecialCharactersInTitle 2ms
โœ… CatalogFilterModelTests testEdgeCase_UnicodeInTitle 5ms
โœ… CatalogFilterModelTests testEquality_DifferentActiveStateMakesFiltersUnequal 2ms
โœ… CatalogFilterModelTests testEquality_DifferentHrefMakesFiltersUnequal 2ms
โœ… CatalogFilterModelTests testEquality_DifferentIdsMakesFiltersUnequal 2ms
โœ… CatalogFilterModelTests testEquality_DifferentTitlesMakesFiltersUnequal 3ms
โœ… CatalogFilterModelTests testEquality_IdenticalFiltersAreEqual 2ms
โœ… CatalogFilterModelTests testEquality_NilAndNonNilHrefMakesFiltersUnequal 2ms
โœ… CatalogFilterModelTests testHashable_DifferentFiltersCanBeUsedInSet 2ms
โœ… CatalogFilterModelTests testHashable_EqualFiltersHaveSameHash 2ms
โœ… CatalogFilterModelTests testIdentifiable_UsesIdProperty 2ms
โœ… CatalogFilterModelTests testInit_StoresAllProperties 2ms
โœ… CatalogFilterModelTests testInit_WithInactiveState 2ms
โœ… CatalogFilterModelTests testInit_WithNilHref 2ms
โœ… CatalogFilterServiceTests testActiveFacetHrefs_excludesDefaultsWhenFlagFalse 2ms
โœ… CatalogFilterServiceTests testActiveFacetHrefs_returnsActiveURLs 9ms
โœ… CatalogFilterServiceTests testActiveFiltersCount_emptySet_returnsZero 2ms
โœ… CatalogFilterServiceTests testActiveFiltersCount_excludesDefaults 2ms
โœ… CatalogFilterServiceTests testCategorizeFacetURL_categorisesCorrectly 2ms
โœ… CatalogFilterServiceTests testFindFacetGroupName_matchesURL 2ms
โœ… CatalogFilterServiceTests testFindFacetGroupName_returnsNilForUnknownURL 2ms
โœ… CatalogFilterServiceTests testFindFilterInCurrentFacets_caseInsensitiveMatch 3ms
โœ… CatalogFilterServiceTests testFindFilterInCurrentFacets_returnsNilWhenNotFound 5ms
โœ… CatalogFilterServiceTests testGroupPriority_caseInsensitive 2ms
โœ… CatalogFilterServiceTests testGroupPriority_collectionIsHighest 2ms
โœ… CatalogFilterServiceTests testGroupPriority_distributorBeforeFormat 2ms
โœ… CatalogFilterServiceTests testGroupPriority_unknownGroupReturnsFallback 2ms
โœ… CatalogFilterServiceTests testKeysForCurrentFacets_excludesSortGroups 6ms
โœ… CatalogFilterServiceTests testKeysForCurrentFacets_mapsGroupTitleKeysToFullKeys 2ms
โœ… CatalogFilterServiceTests testMakeGroupTitleKey_omitsHref 2ms
โœ… CatalogFilterServiceTests testMakeKey_producesCanonicalFormat 2ms
โœ… CatalogFilterServiceTests testNormalizeTitle_trimsAndLowercases 5ms
โœ… CatalogFilterServiceTests testParseKey_handlesEmptyComponents 2ms
โœ… CatalogFilterServiceTests testParseKey_returnsNilForInvalidKey 4ms
โœ… CatalogFilterServiceTests testParseKey_roundTrips 5ms
โœ… CatalogFilterServiceTests testParsedKey_isDefaultTitle_detectsAllVariants 3ms
โœ… CatalogFilterServiceTests testParsedKey_isDefaultTitle_rejectsNonDefaults 2ms
โœ… CatalogFilterServiceTests testPrioritizeSelectedFilters_ordersCollectionBeforeFormat 2ms
โœ… CatalogFilterServiceTests testReconstructSelections_matchesByGroupAndTitle 2ms
โœ… CatalogFilterServiceTests testReconstructSelections_skipsInvalidKeys 2ms
โœ… CatalogFilterServiceTests testSelectionKeys_excludesDefaultsWhenFlagFalse 5ms
โœ… CatalogFilterServiceTests testSelectionKeys_excludesSortGroups 3ms
โœ… CatalogFilterServiceTests testSelectionKeys_includesDefaultsWhenFlagTrue 3ms
โœ… CatalogFilterTests testCatalogFilter_StoresValues 3ms
โœ… CatalogLaneAssemblyTests testDistinctIDs_sameTitle_areNotDeduped 3ms
โœ… CatalogLaneAssemblyTests testFlatPublications_duplicateIDs_areDeduped 3ms
โœ… CatalogLaneAssemblyTests testNoGroupsOrPublications_emptyEntries 3ms
โœ… CatalogLaneAssemblyTests testOrdering_groupOrderPreservedAcrossDedupe 4ms
โœ… CatalogLaneAssemblyTests testPublicationInEveryGroup_resultsInNEntriesNotNPlusOne 3ms
โœ… CatalogLaneAssemblyTests testPublicationInMultipleGroups_dedupedByID_firstOccurrenceWins 3ms
โœ… CatalogLaneAssemblyTests testSingleGroup_unchangedFromFlatten 3ms
โœ… CatalogLaneModelStructTests testBooks_EmptyCollection 6ms
โœ… CatalogLaneModelStructTests testBooks_LargeCollection 573ms
โœ… CatalogLaneModelStructTests testBooks_MixedContentTypes 17ms
โœ… CatalogLaneModelStructTests testBooks_MultipleBooks 40ms
โœ… CatalogLaneModelStructTests testBooks_OrderPreserved 26ms
โœ… CatalogLaneModelStructTests testBooks_SingleBook 9ms
โœ… CatalogLaneModelStructTests testEdgeCase_ComplexMoreURL 194ms
โœ… CatalogLaneModelStructTests testEdgeCase_EmptyTitle 3ms
โœ… CatalogLaneModelStructTests testEdgeCase_LongTitle 84ms
โœ… CatalogLaneModelStructTests testEdgeCase_SpecialCharactersInTitle 5ms
โœ… CatalogLaneModelStructTests testEdgeCase_UnicodeInTitle 71ms
โœ… CatalogLaneModelStructTests testIdentifiable_HasUniqueId 82ms
โœ… CatalogLaneModelStructTests testIdentifiable_IdIsUUID 180ms
โœ… CatalogLaneModelStructTests testInit_StoresAllProperties 21ms
โœ… CatalogLaneModelStructTests testInit_WithDefaultIsLoading 9ms
โœ… CatalogLaneModelStructTests testInit_WithLoadingState 5ms
โœ… CatalogLaneModelStructTests testInit_WithNilMoreURL 6ms
โœ… CatalogLaneModelStructTests testSnapshotBooks_WithDeterministicData 13ms
โœ… CatalogLaneModelTests testHasUniqueId 3ms
โœ… CatalogLaneMoreFilterStateTests testActiveSortTitle_WithMultipleActive_ReturnsFirst 7ms
โœ… CatalogLaneMoreFilterStateTests testOpeningFilterSheet_PopulatesPendingFromApplied 28ms
โœ… CatalogLaneMoreFilterStateTests testOpeningFilterSheet_WithNoApplied_ClearsPending 5ms
โœ… CatalogLaneMoreFilterStateTests testRestoreFilterState_RestoresAppliedSelections 17ms
โœ… CatalogLaneMoreFilterStateTests testRestoreFilterState_RestoresFacetGroups 5ms
โœ… CatalogLaneMoreFilterStateTests testRestoreFilterState_WithEmptyState_ClearsAll 7ms
โœ… CatalogLaneMoreFilterStateTests testSortFacets_CaseInsensitiveGroupMatch 10ms
โœ… CatalogLaneMoreFilterStateTests testURL_MatchesInitializer 6ms
โœ… CatalogLaneMoreViewModelTests testActiveFiltersCount_AfterClearingSelections 9ms
โœ… CatalogLaneMoreViewModelTests testActiveFiltersCount_FiltersOutAllDefaults 8ms
โœ… CatalogLaneMoreViewModelTests testActiveFiltersCount_WhenEmpty 13ms
โœ… CatalogLaneMoreViewModelTests testActiveFiltersCount_WithAppliedSelections 17ms
โœ… CatalogLaneMoreViewModelTests testActiveSortTitle_WhenActiveFacetExists_ReturnsTitle 10ms
โœ… CatalogLaneMoreViewModelTests testActiveSortTitle_WhenNoActiveFacet_FallsBackToFirstFilterTitle 8ms
โœ… CatalogLaneMoreViewModelTests testActiveSortTitle_WhenSortGroupEmpty_ReturnsNil 10ms
โœ… CatalogLaneMoreViewModelTests testAllBooks_CombinesMultipleLanes 20ms
โœ… CatalogLaneMoreViewModelTests testAllBooks_EmptyWhenNoData 54ms
โœ… CatalogLaneMoreViewModelTests testAllBooks_WhenLanesEmpty_ReturnsUngroupedBooks 118ms
โœ… CatalogLaneMoreViewModelTests testAllBooks_WhenLanesHaveBooks_ReturnsLaneBooks 36ms
โœ… CatalogLaneMoreViewModelTests testAppliedSelectionsUpdate 12ms
โœ… CatalogLaneMoreViewModelTests testApplyRegistryUpdates_OnlyTargetsChangedIdentifier_WhenProvided 51ms
โœ… CatalogLaneMoreViewModelTests testApplyRegistryUpdates_PreservesIdentifierSequenceAfterBorrow 19ms
โœ… CatalogLaneMoreViewModelTests testDisplayedSortFacets_WhenNoneActive_MarksFirstAsDefault 12ms
โœ… CatalogLaneMoreViewModelTests testDisplayedSortFacets_WhenOneActive_Unchanged 9ms
โœ… CatalogLaneMoreViewModelTests testDisplayedSortFacets_WhenPendingIDUnknown_FallsBackNormally 9ms
โœ… CatalogLaneMoreViewModelTests testDisplayedSortFacets_WhenPendingSet_HighlightsOnlyPendingFacet 12ms
โœ… CatalogLaneMoreViewModelTests testErrorPublishes 13ms
โœ… CatalogLaneMoreViewModelTests testError_CanBeCleared 7ms
โœ… CatalogLaneMoreViewModelTests testError_CanBeSet 12ms
โœ… CatalogLaneMoreViewModelTests testFacetGroups_MultipleGroups 20ms
โœ… CatalogLaneMoreViewModelTests testFilterStateInitialValues 5ms
โœ… CatalogLaneMoreViewModelTests testInitialState 9ms
โœ… CatalogLaneMoreViewModelTests testIsApplyingFiltersInitiallyFalse 29ms
โœ… CatalogLaneMoreViewModelTests testIsLoadingMoreInitiallyFalse 9ms
โœ… CatalogLaneMoreViewModelTests testIsLoadingPublishes 16ms
โœ… CatalogLaneMoreViewModelTests testLanesPublishes 13ms
โœ… CatalogLaneMoreViewModelTests testPagination_ClearedWhenNil 16ms
โœ… CatalogLaneMoreViewModelTests testPagination_NextPageURLCanBeSet 9ms
โœ… CatalogLaneMoreViewModelTests testPendingSelectionsUpdate 14ms
โœ… CatalogLaneMoreViewModelTests testProcessOPDS2GroupedFeed_UsesFeedURLForActiveDetection 8ms
โœ… CatalogLaneMoreViewModelTests testProcessOPDS2PublicationFeed_UsesFeedURLForActiveDetection 12ms
โœ… CatalogLaneMoreViewModelTests testShouldShowPagination_WhenNextPageURLExists 13ms
โœ… CatalogLaneMoreViewModelTests testShowSearchToggle 9ms
โœ… CatalogLaneMoreViewModelTests testShowingFiltersSheetToggle 8ms
โœ… CatalogLaneMoreViewModelTests testShowingSortSheetToggle 8ms
โœ… CatalogLaneMoreViewModelTests testSortFacets_WhenNoSortGroup_ReturnsEmpty 71ms
โœ… CatalogLaneMoreViewModelTests testSortFacets_WhenSortGroupExists_ReturnsFacets 6ms
โœ… CatalogLaneMoreViewModelTests testTitle_Empty 12ms
โœ… CatalogLaneMoreViewModelTests testTitle_WithSpecialCharacters 17ms
โœ… CatalogLaneMoreViewModelTests testUIStateInitialValues 16ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_audiobookFormat 16ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_audiobookIncludesAudiobookDesignation 6ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_audiobook_authorOnly 24ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_bookWithoutAuthor 4ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_doesNotIncludeSummaryOrBlurbs 820ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_ebookDoesNotIncludeAudiobookDesignation 9ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_ebook_noAuthor_titleOnly 15ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_ebook_titleByAuthor 4ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_includesTitleAndAuthor 98ms
โœ… CatalogLaneRowViewAccessibilityTests testAccessibilityLabel_usesCommaSeparatedFormat 173ms
โœ… CatalogLaneRowViewAccessibilityTests testSwimlaneTitle_sourceDeclaresHeaderAccessibilityTrait 6ms
โœ… CatalogLaneSortingTests testExtractFacets_ActiveSortFacet_IsMarkedActive 4ms
โœ… CatalogLaneSortingTests testExtractFacets_GroupedFeedWithSortFacets_ExtractsSortGroup 15ms
โœ… CatalogLaneSortingTests testLaneMoreViewModel_ActiveSortTitle_ReturnsActiveFacetTitle 47ms
โœ… CatalogLaneSortingTests testLaneMoreViewModel_GroupedFeedWithSortFacets_ExposesSortFacets 31ms
โœ… CatalogLoadIntegrationTests testAuthenticationRequired_ReturnsUnauthorizedError 7ms
โœ… CatalogLoadIntegrationTests testCacheInvalidation_TriggersFreshFetch 6ms
โœ… CatalogLoadIntegrationTests testFetchFeed_DelegatesToLoadTopLevelCatalog 9ms
โœ… CatalogLoadIntegrationTests testFreshLoad_FetchesFromNetwork 5ms
โœ… CatalogLoadIntegrationTests testNetworkFailure_PropagatesError 4ms
โœ… CatalogLoadIntegrationTests testOPDSFeedXML_IsGeneratedCorrectly 29ms
โœ… CatalogOPDS2NegotiationTests testFetchFeed_OPDS1AtomBodyTaggedWithOPDS2ContentType_StillFallsBackToOPDS1 5ms
โœ… CatalogOPDS2NegotiationTests testFetchFeed_OPDS2JSONBodyTaggedWithOPDS1ContentType_StillParsesAsOPDS2 7ms
โœ… CatalogOPDS2NegotiationTests testFetchFeed_OPDS2RequestedButServerReturnsMalformedJSON_ThrowsInvalidJSON 14ms
โœ… CatalogOPDS2NegotiationTests testFetchFeed_OPDS2RequestedButServerReturnsOPDS1Atom_FallsBackToOPDS1 4ms
โœ… CatalogOPDS2NegotiationTests testFetchFeed_ServerReturnsOPDS2JSON_ParsesAsOPDS2Feed 10ms
โœ… CatalogOPDS2NegotiationTests testOPDSFormatDetect_ByFirstByte_JSON_RoutesToOPDS2 2ms
โœ… CatalogOPDS2NegotiationTests testOPDSFormatDetect_ByFirstByte_XML_RoutesToOPDS1 2ms
โœ… CatalogOPDS2NegotiationTests testOPDSFormatDetect_NonJSONNonXMLFirstByte_RoutesToUnknown 3ms
โœ… CatalogOPDS2NegotiationTests testRepositoryCache_AfterOPDS1FallbackNegotiation_PreservesIsOPDS2False 16ms
โœ… CatalogOPDS2NegotiationTests testRepositoryCache_AfterOPDS2Negotiation_PreservesIsOPDS2Flag 10ms
โœ… CatalogOPDS2NegotiationTests testRequestAcceptHeader_WhenOPDS2Disabled_DoesNotAdvertiseOPDS2 5ms
โœ… CatalogOPDS2NegotiationTests testRequestAcceptHeader_WhenOPDS2Enabled_PrefersJSONOverAtom 18ms
โœ… CatalogPreloaderTests testPreloader_ContinuesOnFailure 9ms
โœ… CatalogPreloaderTests testPreloader_NilCurrentAccount_StillPreloadsRecent 29ms
โœ… CatalogPreloaderTests testPreloader_PreloadsCurrentAccountCatalog 7ms
โœ… CatalogPreloaderTests testPreloader_PreloadsRecentlyUsedAccounts_UpToLimit 11ms
โœ… CatalogPreloaderTests testPreloader_SkipsAccountsWithNoCatalogURL 9ms
โœ… CatalogPreloaderTests testPreloader_SkipsDuplicateCurrentAccount 9ms
โœ… CatalogProblemDocumentTests testFetchFeed_503ProblemDocument_surfacesStructuredErrorThroughAPI 51ms
โœ… CatalogProblemDocumentTests testParser_plainJSONContentType_doesNotTriggerProblemDocumentPath 54ms
โœ… CatalogProblemDocumentTests testParser_problemJSONContentTypeWithCharset_stillDetected 3ms
โœ… CatalogProblemDocumentTests testParser_problemJSONContentType_errorDescriptionIncludesTitleAndDetail 6ms
โœ… CatalogProblemDocumentTests testParser_problemJSONContentType_throwsProblemDocumentErrorNotInvalidJSON 4ms
โœ… CatalogProblemDocumentTests testParser_undecodableProblemBody_stillSurfacesAsProblemDocument 3ms
โœ… CatalogRepositoryCoreTests testDifferentURLsAreCachedSeparately 12ms
โœ… CatalogRepositoryCoreTests testInvalidateCacheForcesFreshFetch 120ms
โœ… CatalogRepositoryCoreTests testLoadTopLevelCatalogCachesFeed 15ms
โœ… CatalogRepositoryCoreTests testLoadTopLevelCatalogCallsAPI 16ms
โœ… CatalogRepositoryCoreTests testLoadTopLevelCatalogFallsToCacheOnNetworkError 124ms
โœ… CatalogRepositoryCoreTests testLoadTopLevelCatalogPropagatesError 21ms
โœ… CatalogRepositoryCoreTests testLoadTopLevelCatalogReturnsFeedTitle 14ms
โœ… CatalogRepositoryCoreTests testSearchDelegatesToAPI 21ms
โœ… CatalogRepositoryCoreTests testSearchPropagatesError 6ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testCachedFeed_AtExactly24h_ReturnsFeed_PastBoundary_ReturnsNil 7ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testCachedFeed_PerURLIsolation_DoesNotLeakBetweenURLs 10ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testInvalidateCache_ExplicitInvalidate_ForcesNextReadToNetwork 12ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testInvalidateCache_OnlyClearsRequestedURL_DoesNotClearOthers 17ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_AtExactly24HourBoundary_StillStaleButUsableNotTooOld 117ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_AtExactlyTenMinuteBoundary_StillCountsAsFresh 8ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_ConcurrentStaleReads_BothSeeCachedAndCacheGetsRefreshed 124ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_FreshCacheWithinTenMinutes_ReturnsCacheAndSkipsNetwork 28ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_JustPastTenMinutes_ReturnsStaleAndSchedulesBackgroundRefresh 119ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_NetworkFailureWithNoCache_Throws 11ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_NetworkFailureWithTooOldCache_ReturnsCachedFallback 7ms
โœ… CatalogRepositoryStaleWhileRevalidateTests testLoadTopLevelCatalog_PastTwentyFourHours_FetchesFromNetworkAndReplacesCache 7ms
โœ… CatalogRepositoryTests testFetchFeed_DoesNotCache_AlwaysFetchesFresh 12ms
โœ… CatalogRepositoryTests testFetchFeed_NetworkError_ThrowsError 10ms
โœ… CatalogRepositoryTests testFetchFeed_Success_ReturnsFeed 8ms
โœ… CatalogRepositoryTests testIntegration_ErrorPropagation 6ms
โœ… CatalogRepositoryTests testIntegration_FullFetchFlow 14ms
โœ… CatalogRepositoryTests testInvalidateCache_ClearsSpecificURL 10ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_401Unauthorized_ThrowsError 11ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_500ServerError_ThrowsError 8ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_CachesFeed_ReturnsFromCache 8ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_EmptyFeed_ReturnsEmptyEntries 8ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_InvalidXML_ThrowsParsingError 26ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_MultipleURLs_CachesIndependently 45ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_NetworkError_FallsBackToStaleCache 12ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_NetworkError_ThrowsError 8ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_PreservesQueryParameters 8ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_ProblemDocument_ParsesErrorDetails 46ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_SpecialCharactersInTitle_ParsesCorrectly 7ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_Success_ReturnsFeed 7ms
โœ… CatalogRepositoryTests testLoadTopLevelCatalog_UsesGETMethod 7ms
โœ… CatalogSearchViewModelRegistryUpdateTests testApplyRegistryUpdates_EmptyFilteredBooks_DoesNotCrash 8ms
โœ… CatalogSearchViewModelRegistryUpdateTests testApplyRegistryUpdates_MultipleRapidCalls_DoesNotCrash 75ms
โœ… CatalogSearchViewModelRegistryUpdateTests testApplyRegistryUpdates_NilChangedIdentifier_UpdatesAllBooks 41ms
โœ… CatalogSearchViewModelRegistryUpdateTests testApplyRegistryUpdates_UnknownIdentifier_NoChanges 40ms
โœ… CatalogSearchViewModelRegistryUpdateTests testApplyRegistryUpdates_WithBooks_UpdatesMatchingBook 46ms
โœ… CatalogSearchViewModelTests testApplyRegistryUpdates_DoesNotChangeSearchId 8ms
โœ… CatalogSearchViewModelTests testApplyRegistryUpdates_WithEmptyFilteredBooks_DoesNothing 4ms
โœ… CatalogSearchViewModelTests testClearSearch_CancelsPendingOperations 315ms
โœ… CatalogSearchViewModelTests testClearSearch_ChangesSearchId 3ms
โœ… CatalogSearchViewModelTests testClearSearch_ResetsSelectedFormat_DoesNotChangeFormatEntries 8ms
โœ… CatalogSearchViewModelTests testClearSearch_ResetsState 6ms
โœ… CatalogSearchViewModelTests testClearSearch_RestoresAllBooks 11ms
โœ… CatalogSearchViewModelTests testConcurrentUpdates_DoNotCrash 14ms
โœ… CatalogSearchViewModelTests testHasCompletedSearch_BecomesTrue_AfterSearchReturnsEmpty 185ms
โœ… CatalogSearchViewModelTests testHasCompletedSearch_FlipsTrue_OnSearchError 176ms
โœ… CatalogSearchViewModelTests testHasCompletedSearch_ResetByClearSearch 167ms
โœ… CatalogSearchViewModelTests testHasCompletedSearch_StartsFalse 3ms
โœ… CatalogSearchViewModelTests testInit_HasCorrectDefaults 3ms
โœ… CatalogSearchViewModelTests testLoadFormatEntryPoints_SelectsActiveEntry 12ms
โœ… CatalogSearchViewModelTests testLoadFormatEntryPoints_WhenFeedHasNoEntryPoints_LeavesFormatEntriesEmpty 9ms
โœ… CatalogSearchViewModelTests testLoadFormatEntryPoints_WhenFetchFails_LeavesFormatEntriesEmpty 170ms
โœ… CatalogSearchViewModelTests testLoadFormatEntryPoints_WhenSuccessful_PopulatesFormatEntries 14ms
โœ… CatalogSearchViewModelTests testLoadFormatEntryPoints_WithNilBaseURL_DoesNotCallRepository 162ms
โœ… CatalogSearchViewModelTests testLoadNextPage_DoesNotChangeSearchId 7ms
โœ… CatalogSearchViewModelTests testLoadNextPage_SetsIsLoadingMore 12ms
โœ… CatalogSearchViewModelTests testLoadNextPage_WhenAlreadyLoading_DoesNothing 7ms
โœ… CatalogSearchViewModelTests testLoadNextPage_WithNoNextURL_DoesNothing 5ms
โœ… CatalogSearchViewModelTests testPP3605_ApplyRegistryUpdates_DoesNotChangeSearchId 6ms
โœ… CatalogSearchViewModelTests testPP3605_ClearSearch_ChangesSearchId 11ms
โœ… CatalogSearchViewModelTests testPP3605_DifferentSearches_EachHaveUniqueSearchId 114ms
โœ… CatalogSearchViewModelTests testPP3605_LoadNextPage_DoesNotChangeSearchId 62ms
โœ… CatalogSearchViewModelTests testPP3605_NewSearch_ChangesSearchId 61ms
โœ… CatalogSearchViewModelTests testPP3673_clearSearch_doesNotAnnounce 219ms
โœ… CatalogSearchViewModelTests testPP3673_search_emptyQuery_doesNotAnnounce 162ms
โœ… CatalogSearchViewModelTests testPP3673_search_error_announcesFailure 60ms
โœ… CatalogSearchViewModelTests testPP3673_search_noResults_announcesNoResults 59ms
โœ… CatalogSearchViewModelTests testPP3673_search_rerun_announcesUpdatedResults 116ms
โœ… CatalogSearchViewModelTests testSearch_CancelsDebounce_OnNewQuery 1.34s
โœ… CatalogSearchViewModelTests testSearch_CancelsInFlight_OnNewQuery 217ms
โœ… CatalogSearchViewModelTests testSearch_Debounces_DoesNotSearchDuringDebounceWindow 1.03s
โœ… CatalogSearchViewModelTests testSearch_Debounces_MultipleQueries 120ms
โœ… CatalogSearchViewModelTests testSearch_DifferentQueries_HaveDifferentSearchIds 125ms
โœ… CatalogSearchViewModelTests testSearch_NewSearch_ChangesSearchId 61ms
โœ… CatalogSearchViewModelTests testSearch_SpecialCharacters_DoesNotCrash 63ms
โœ… CatalogSearchViewModelTests testSearch_UnicodeCharacters_Works 60ms
โœ… CatalogSearchViewModelTests testSearch_VeryLongQuery_Works 65ms
โœ… CatalogSearchViewModelTests testSearch_WithEmptyQuery_DoesNotCallRepository 162ms
โœ… CatalogSearchViewModelTests testSearch_WithEmptyQuery_ShowsAllBooks 179ms
โœ… CatalogSearchViewModelTests testSearch_WithError_ClearsNextPageURL 62ms
โœ… CatalogSearchViewModelTests testSearch_WithError_SetsErrorMessage 62ms
โœ… CatalogSearchViewModelTests testSearch_WithNilBaseURL_ClearsNextPageURL 161ms
โœ… CatalogSearchViewModelTests testSearch_WithNilBaseURL_DoesNotSearch 161ms
โœ… CatalogSearchViewModelTests testSearch_WithNilResult_SetsEmptyResults 62ms
โœ… CatalogSearchViewModelTests testSearch_WithNoFormatEntries_UsesDefaultBaseURL 68ms
โœ… CatalogSearchViewModelTests testSearch_WithResults_UpdatesResults 60ms
โœ… CatalogSearchViewModelTests testSearch_WithValidQuery_CallsRepository 66ms
โœ… CatalogSearchViewModelTests testSearch_WithValidQuery_ClearsIsLoadingAfterCompletion 61ms
โœ… CatalogSearchViewModelTests testSearch_WithValidQuery_SetsIsSearching 62ms
โœ… CatalogSearchViewModelTests testSearch_WithWhitespaceOnlyQuery_DoesNotCallRepository 162ms
โœ… CatalogSearchViewModelTests testSelectFormat_ChangesSelectedIndex 8ms
โœ… CatalogSearchViewModelTests testSelectFormat_SameIndex_DoesNotChangeIndex 168ms
โœ… CatalogSearchViewModelTests testSelectFormat_WithActiveQuery_TriggersNewSearch 66ms
โœ… CatalogSearchViewModelTests testSelectFormat_WithCachedDescriptorURL_UsesDescriptorSearch 66ms
โœ… CatalogSearchViewModelTests testSelectFormat_WithEmptyQuery_DoesNotSearch 168ms
โœ… CatalogSearchViewModelTests testShouldShowNoResultsState_False_WhenQueryEmpty 6ms
โœ… CatalogSearchViewModelTests testShouldShowNoResultsState_False_WhenResultsPresent 11ms
โœ… CatalogSearchViewModelTests testShouldShowNoResultsState_False_WhileLoading 69ms
โœ… CatalogSearchViewModelTests testShouldShowNoResultsState_True_WhenSearchCompletedWithZeroResults 168ms
โœ… CatalogSearchViewModelTests testUpdateBooks_DoesNotChangeFilteredBooks_WhenQueryNotEmpty 11ms
โœ… CatalogSearchViewModelTests testUpdateBooks_EmptyArray_Works 6ms
โœ… CatalogSearchViewModelTests testUpdateBooks_LargeArray_Works 221ms
โœ… CatalogSearchViewModelTests testUpdateBooks_SetsFilteredBooks_WhenQueryEmpty 9ms
โœ… CatalogSelectorsTests testWithSelectedEntryPoint_UpdatesActiveState 14ms
โœ… CatalogSelectorsTests testWithSelectedFacet_UpdatesActiveState 2ms
โœ… CatalogSortServiceTests testAllCases 2ms
โœ… CatalogSortServiceTests testSortByAuthorAZ 12ms
โœ… CatalogSortServiceTests testSortByAuthorZA 9ms
โœ… CatalogSortServiceTests testSortByRecentlyAddedAZ 11ms
โœ… CatalogSortServiceTests testSortByRecentlyAddedZA 31ms
โœ… CatalogSortServiceTests testSortByTitleAZ 9ms
โœ… CatalogSortServiceTests testSortByTitleZA 16ms
โœ… CatalogSortServiceTests testSortEmptyArray 3ms
โœ… CatalogSortServiceTests testSortOptionFromLocalizedString_invalidString_returnsNil 4ms
โœ… CatalogSortServiceTests testSortOptionFromLocalizedString_validStrings 5ms
โœ… CatalogSortServiceTests testSortOptionLocalizedStrings 9ms
โœ… CatalogSortServiceTests testSortSingleBook 7ms
โœ… CatalogSortServiceTests testSortWithNilAuthors 14ms
โœ… CatalogSortServiceTests testSortedReturnsNewArray 11ms
โœ… CatalogStateTests testState_AllBooks_Grouped 11ms
โœ… CatalogStateTests testState_AllBooks_Ungrouped 11ms
โœ… CatalogStateTests testState_ApplyingFacet_IsTrue 2ms
โœ… CatalogStateTests testState_Error_HasNoContent 32ms
โœ… CatalogStateTests testState_Loaded_ExposesContent 5ms
โœ… CatalogStateTests testState_Loading_HasNoContent 2ms
โœ… CatalogStateTests testState_SwitchingEntryPoint_HasNoContent 2ms
โœ… CatalogViewContinueRowsIntegrationTests testCatalogContentView_passesActiveSessionsToContinueRowSection 24ms
โœ… CatalogViewContinueRowsIntegrationTests testCatalogView_resumeListening_sourceWiresBothBranches 4ms
โœ… CatalogViewContinueRowsIntegrationTests testCatalogView_resumeReading_sourceWiresReaderServiceCalls 4ms
โœ… CatalogViewModelStateMachineTests testApplyEntryPoint_RequiresLoadedState 6ms
โœ… CatalogViewModelStateMachineTests testApplyEntryPoint_WithNilHref_NoOp 7ms
โœ… CatalogViewModelStateMachineTests testApplyFacet_RequiresLoadedState 15ms
โœ… CatalogViewModelStateMachineTests testApplyFacet_WithNilHref_NoOp 20ms
โœ… CatalogViewModelStateMachineTests testForceRefresh_TransitionsToLoading 15ms
โœ… CatalogViewModelStateMachineTests testLoad_WithError_TransitionsToError 23ms
โœ… CatalogViewModelStateMachineTests testLoad_WithNilResult_TransitionsToError 9ms
โœ… CatalogViewModelStateMachineTests testLoad_WithNilURL_DoesNotCallRepository 6ms
โœ… CatalogViewModelStateMachineTests testSearchRepository_ReturnsMock 2ms
โœ… CatalogViewModelStateMachineTests testViewModel_InitialState_IsLoading 4ms
โœ… ChaosFaultInjectionTests test_scenario1_midDownloadNetworkKill_failsRecoverably 19ms
โœ… ChaosFaultInjectionTests test_scenario2_diskFullDuringExtraction_throwsAndLeavesNoFullFile 5ms
โœ… ChaosFaultInjectionTests test_scenario3_lowMemoryDuringDRMFetch_remainsRecoverable 7ms
โœ… ChaosFaultInjectionTests test_scenario4_processKillDuringRegistryWrite_atomicityHolds 11ms
โœ… ChaosFaultInjectionTests test_scenario5_tokenExpiryMidAnnotationSync_invokesReauthAndRetries 12ms
โœ… ChapterChangeDetectorTests testDidChange_differentKeySameTitle_fires 4ms
โœ… ChapterChangeDetectorTests testDidChange_differentKey_fires 6ms
โœ… ChapterChangeDetectorTests testDidChange_noPriorChapter_fires 7ms
โœ… ChapterChangeDetectorTests testDidChange_sameKeyDifferentTitle_doesNotFire 6ms
โœ… ChapterChangeDetectorTests testDidChange_sameKeySameTitle_doesNotFire 39ms
โœ… ChapterTOCNormalizerTests testInflationThreshold_isExactly1Point5 4ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_atExactThreshold_returnsFalse 5ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_belowThreshold_returnsFalse 2ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_oneAboveThreshold_returnsTrue 3ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_realWorldCase_returnsTrue 5ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_slightInflation_returnsFalse 7ms
โœ… ChapterTOCNormalizerTests testIsOversubdivided_zeroExpectedChapterCount_returnsFalse 23ms
โœ… CirculationAnalyticsTests testEventPathComponents 6ms
โœ… CirculationAnalyticsTests testNetworkQueueStatusCodesExist 9ms
โœ… CirculationAnalyticsTests testPostEventConstructsCorrectURL 2ms
โœ… CirculationAnalyticsTests testPostEventWithNilAnalyticsURL 23ms
โœ… ColdStartResumeIntegrationTests testColdStart_CorruptedRegistryFile_BootsToEmptyState 128ms
โœ… ColdStartResumeIntegrationTests testColdStart_EmptyRecordsArray_RendersEmptyMyBooks 125ms
โœ… ColdStartResumeIntegrationTests testColdStart_FreshTokenNotMarkedNearExpiry 26ms
โœ… ColdStartResumeIntegrationTests testColdStart_HalfBorrowedBook_RecordPreservedForServerReconciliation 145ms
โœ… ColdStartResumeIntegrationTests testColdStart_InflightDownloadWithExistingFile_PromotedToSuccessful 149ms
โœ… ColdStartResumeIntegrationTests testColdStart_InflightDownloadWithMissingFile_MarkedFailed 136ms
โœ… ColdStartResumeIntegrationTests testColdStart_NoRegistryFile_BootsToEmptyState 140ms
โœ… ColdStartResumeIntegrationTests testColdStart_RegistryFileMissingRecordsKey_BootsToEmptyState 130ms
โœ… ColdStartResumeIntegrationTests testColdStart_StaleTokenDetectedAsNearExpiry 33ms
โœ… ColdStartResumeIntegrationTests testColdStart_TokenPastExpiry_ReportsExpired 40ms
โœ… ColorExtensionTests testIsDark_Black_ReturnsTrue 5ms
โœ… ColorExtensionTests testIsDark_DarkGray_ReturnsTrue 3ms
โœ… ColorExtensionTests testIsDark_LightGray_ReturnsFalse 2ms
โœ… ColorExtensionTests testIsDark_PureRed_ReturnsFalse 13ms
โœ… ColorExtensionTests testIsDark_White_ReturnsFalse 3ms
โœ… ConcurrentBookStateTests testConcurrent_differentContentTypes_supportedSimultaneously 19ms
โœ… ConcurrentBookStateTests testConcurrent_drmTypes_supportedSimultaneously 15ms
โœ… ConcurrentBookStateTests testConcurrent_multipleDownloads_independentStates 30ms
โœ… ConcurrentDownloadStateTests testMultipleBooks_canBeRegisteredSimultaneously 30ms
โœ… ConcurrentDownloadStateTests testMultipleBooks_canHaveDifferentStates 19ms
โœ… ConcurrentDownloadStateTests testMultipleBooks_stateChangesAreIndependent 15ms
โœ… ConcurrentTokenRefreshTests testRefreshTokenAndResume_noCredentials_failsImmediately 30ms
โœ… ConcurrentTokenRefreshTests testTokenRequest_canExecuteViaStub 67ms
โœ… ContinueRowSectionTests testContinueRowSection_hidesBothRows_whenViewModelIsEmpty 9ms
โœ… ContinueRowSectionTests testContinueRowSection_listeningRowPrecedesReadingRow 8ms
โœ… ContinueRowSectionTests testContinueRowSection_showsListeningRow_whenPresent 22ms
โœ… ContinueRowSectionTests testContinueRowSection_showsReadingRow_whenPresent 8ms
โœ… ContinueRowSectionTests testContinueRowSection_tappingListeningRow_invokesOnResumeListening 8ms
โœ… ContinueRowSectionTests testContinueRowSection_tappingReadingRow_invokesOnResumeReading 6ms
โœ… ContinuousPlaybackTrackingTests testBiblioBoardScenario_61MinutesWithTrackChanges 501ms
โœ… ContinuousPlaybackTrackingTests testRapidTrackChanges_noTimeLoss 373ms
โœ… ContinuousPlaybackTrackingTests testTrackTransition_savesTimeBeforeNextTrackStarts 47ms
โœ… CookiePersistenceTests test_CookieAccessor_IsConsultedByRequestPath 101ms
โœ… CookiePersistenceTests test_CookiesReinstalled_OnEveryRequest_AfterSharedStorageWipe 99ms
โœ… CookiePersistenceTests test_CookiesSurvive_ExecutorRecreation_AndAreInstalledIntoSharedStorage 96ms
โœ… CookiePersistenceTests test_EmptyCookiesArray_OnSamlAccount_IsNoOp 88ms
โœ… CookiePersistenceTests test_InstalledCookie_IsVisibleAtTheSamlURL 90ms
โœ… CookiePersistenceTests test_MultipleCookies_AllInstalled_AfterColdStart 96ms
โœ… CookiePersistenceTests test_NonSamlAuth_DoesNotInstall_CookiesIntoSharedStorage 107ms
โœ… CookiePersistenceTests test_RemoveAll_ClearsCookies_NoReinstallOnNextRequest 95ms
โœ… CookiePersistenceTests test_UpdatedCookieValue_IsVisibleOnNextRequest 95ms
โœ… CookiePersistenceTests test_setCookies_StoresOnAccountAndIsReadable 99ms
โœ… CrawlStateTests testCrawlState_DecodesLegacyPayload_WithoutAppVersion 2ms
โœ… CrawlStateTests testCrawlState_DecodesWithMissingOptionals 4ms
โœ… CrawlStateTests testCrawlState_EncodesAndDecodes 6ms
โœ… CrawlStateTests testCrawlState_LoadFromMissingFile_Fails 3ms
โœ… CrawlStateTests testCrawlState_PersistsToDisk 4ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenAllPresent_AndFreshAndSameVersion_ReturnsFalse 3ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenAppVersionChanged_ReturnsTrue 2ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenAppVersionMatches_AndAllFresh_ReturnsFalse 2ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenAppVersionRecordedNil_AndCurrentSet_ReturnsTrue 2ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenBothNil_ReturnsTrue 2ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenIncrementalSucceededButFullCrawlNeverHappened_ReturnsTrue 3ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenLastFullCrawlExactly7Days_ReturnsTrue 12ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenLastFullCrawlOlderThan7Days_ReturnsTrue 2ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenLastFullCrawlWithin7Days_ReturnsFalse 6ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenNoFacetURL_ReturnsTrue 5ms
โœ… CrawlStateTests testNeedsFullCrawl_WhenNoLastCrawlDate_ReturnsTrue 2ms
โœ… CrawlableFeedAnalysisTests testIsFullCrawlComplete_WhenHasNextLink_ReturnsFalse 7ms
โœ… CrawlableFeedAnalysisTests testIsFullCrawlComplete_WhenNoNextLink_ReturnsTrue 4ms
โœ… CrawlableFeedAnalysisTests testIsFullCrawlComplete_returnsTrueForNilOrEmptyLinks 6ms
โœ… CrawlableFeedAnalysisTests testIsOrderModifiedActive_WhenFacetHasRelSelf_ReturnsTrue 6ms
โœ… CrawlableFeedAnalysisTests testIsOrderModifiedActive_WhenOtherFacetActive_ReturnsFalse 6ms
โœ… CrawlableFeedAnalysisTests testIsOrderModifiedActive_returnsFalseForNilOrEmptyFacets 3ms
โœ… CrawlableFeedAnalysisTests testOrderModifiedFacetURL_WhenNoSortFacetGroup_ReturnsNil 3ms
โœ… CrawlableFeedAnalysisTests testOrderModifiedFacetURL_WhenNotActive_StillReturnsURL 5ms
โœ… CrawlableFeedAnalysisTests testOrderModifiedFacetURL_WhenPresent_ReturnsURL 15ms
โœ… CrawlableFeedAnalysisTests testOrderModifiedFacetURL_WhenSortGroupHasNoModifiedLink_ReturnsNil 4ms
โœ… CrawlableFeedAnalysisTests testOrderModifiedFacetURL_returnsNilForNilOrEmptyFacets 8ms
โœ… CrawlableFeedAnalysisTests testPublicationsNewerThan_FiltersCorrectly 5ms
โœ… CrawlableFeedAnalysisTests testShouldStopIncremental_WhenAllPublicationsNewer_ReturnsFalse 7ms
โœ… CrawlableFeedAnalysisTests testShouldStopIncremental_WhenEmptyPublications_ReturnsFalse 18ms
โœ… CrawlableFeedAnalysisTests testShouldStopIncremental_WhenPublicationExactlyAtLastCrawl_ReturnsTrue 9ms
โœ… CrawlableFeedAnalysisTests testShouldStopIncremental_WhenPublicationHasNoUpdatedDate_ReturnsFalse 4ms
โœ… CrawlableFeedAnalysisTests testShouldStopIncremental_WhenPublicationOlderThanLastCrawl_ReturnsTrue 8ms
โœ… CrawlerFallbackTests testCrawlFirstPage_NetworkDown_ReturnsFailure 405ms
โœ… CrawlerFallbackTests testCrawlFirstPage_PreservesPaginationLinks_InParsedPage 18ms
โœ… CrawlerFallbackTests testCrawlFirstPage_Success_ReturnsPartialData 85ms
โœ… CrawlerFallbackTests testCrawlRemainingPages_OneParallelPageFails_ReturnsFailure 16ms
โœ… CrawlerFallbackTests testCrawlRemainingPages_WhenSecondPageFails_ReturnsFailure 27ms
โœ… CrawlerFallbackTests testCrawl_EmptyFeed_ReturnsSuccessWithNoLibraries 14ms
โœ… CrawlerFallbackTests testCrawl_WhenCrawlStateCorrupted_TreatsAsFirstLaunch 40ms
โœ… CrawlerFallbackTests testCrawl_WhenCrawlableReturnsError_ReturnsFailure 7ms
โœ… CrawlerFallbackTests testCrawl_WhenCrawlableReturnsMalformedJSON_ReturnsFailure 86ms
โœ… CrawlerFallbackTests testCrawl_WhenCrawlableSucceeds_ReturnsCrawledData 44ms
โœ… CrawlerFallbackTests testCrawl_WhenResponseMissingCatalogs_ReturnsFailure 10ms
โœ… CrawlerFallbackTests testIncrementalCrawlFails_NextAttemptDoesFullCrawl 15ms
โœ… CredentialEdgeCaseTests testBarcodeAndPin_EmptyStrings_ProduceMalformedBasicAuthHeader 3ms
โœ… CredentialEdgeCaseTests testCredentials_BarcodeAndPin_RoundTripsThroughCodable 2ms
โœ… CredentialEdgeCaseTests testCredentials_TokenWithNilBarcodeAndPin_SurvivesCodableRoundTrip 5ms
โœ… CredentialEdgeCaseTests testTokenCredential_EmptyBarcode_IsDistinctFromNil 2ms
โœ… CredentialEdgeCaseTests testTokenCredential_EmptyPin_IsDistinctFromNil 2ms
โœ… CredentialEdgeCaseTests testTokenCredential_NilBarcode_ReturnsNilUsername 2ms
โœ… CredentialPrivacyTests testErrorLogger_metadataKeysNeverIncludeCredentialFields 12ms
โœ… CredentialPrivacyTests testException_messageDoesNotEmbedCredentials 2ms
โœ… CredentialPrivacyTests testLCPPassphraseError_doesNotEmbedPassphrase 2ms
โœ… CredentialPrivacyTests testSignInFailureLog_doesNotContainBarcodeOrPIN 2ms
โœ… CredentialPromptCoordinatorTests testRequestCredentials_adobeExpired_presentsAdobeAlertInsteadOfSignIn 35ms
โœ… CredentialPromptCoordinatorTests testRequestCredentials_alreadyInFlight_skipsDuplicateModal 75ms
โœ… CredentialPromptCoordinatorTests testRequestCredentials_signInCancelled_registersCompletionAndDoesNotRetry 190ms
โœ… CredentialPromptCoordinatorTests testRequestCredentials_signInSuccess_retriesDownloadViaDelegate 68ms
โœ… CrossDeviceBookmarkSyncTests testBookmarkSpec_DifferentDevices_ProduceDifferentPayloads 4ms
โœ… CrossDeviceBookmarkSyncTests testBookmarkSpec_IncludesDeviceID 11ms
โœ… CrossDeviceBookmarkSyncTests testBookmarkWithNilDevice_TreatedAsSameDevice 4ms
โœ… CrossDeviceBookmarkSyncTests testBookmark_HasCorrectMotivation 3ms
โœ… CrossDeviceBookmarkSyncTests testDifferentDevice_DifferentPosition_ShouldSync 7ms
โœ… CrossDeviceBookmarkSyncTests testDifferentDevice_IdenticalPosition_ShouldNotSync 31ms
โœ… CrossDeviceBookmarkSyncTests testNoLocalPosition_DifferentDevice_ShouldSync 3ms
โœ… CrossDeviceBookmarkSyncTests testNoLocalPosition_SameDevice_ShouldNotSync 9ms
โœ… CrossDeviceBookmarkSyncTests testNoServerPosition_ShouldNotSync 15ms
โœ… CrossDeviceBookmarkSyncTests testParseServerBookmarks_MultipleDevices 4ms
โœ… CrossDeviceBookmarkSyncTests testReadingProgress_HasCorrectMotivation 7ms
โœ… CrossDeviceBookmarkSyncTests testSameDevice_DifferentPosition_ShouldNotSync 9ms
โœ… CrossDeviceSyncE2ETests test_annotationConflict_serverWins 258ms
โœ… CrossDeviceSyncE2ETests test_audiobookPositionOnDeviceA_readableOnDeviceB 390ms
โœ… CrossDeviceSyncE2ETests test_bookmarkAddedOnDeviceA_visibleOnDeviceB 370ms
โœ… CrossDeviceSyncE2ETests test_bookmarkDeletedOnDeviceA_goneOnDeviceB 351ms
โœ… CrossDeviceSyncE2ETests test_positionWrittenOnDeviceA_readableOnDeviceB 394ms
โœ… CrossDomain401Tests test200FromDifferentDomain_shouldNotIndicateAuthRefreshNeeded 2ms
โœ… CrossDomain401Tests test401FromDifferentDomain_shouldNotIndicateAuthRefreshNeeded 7ms
โœ… CrossDomain401Tests test401FromDifferentSubdomain_shouldIndicateAuthRefreshNeeded 3ms
โœ… CrossDomain401Tests test401FromSameDomain_shouldIndicateAuthRefreshNeeded 2ms
โœ… CrossDomain401Tests test401FromSameSubdomain_shouldIndicateAuthRefreshNeeded 2ms
โœ… CrossDomain401Tests test401WithNilOriginalURL_shouldIndicateAuthRefreshNeeded 4ms
โœ… CrossDomain401Tests test403FromDifferentDomain_shouldNotIndicateAuthRefreshNeeded 2ms
โœ… CrossDomain401Tests testProblemDocFromDifferentDomain_shouldNotIndicateAuthRefreshNeeded 3ms
โœ… CrossFormatMappingTests testChapterBeyondMappingRange 2ms
โœ… CrossFormatMappingTests testCodableRoundTrip 10ms
โœ… CrossFormatMappingTests testCustomChapterMapping 2ms
โœ… CrossFormatMappingTests testFirstChapterMapping 2ms
โœ… CrossFormatMappingTests testLastChapterMapping 2ms
โœ… CrossFormatMappingTests testMappingWithMissingChapterIndex 2ms
โœ… CrossFormatMappingTests testMappingWithZeroChapters 12ms
โœ… CrossFormatMappingTests testMappingWrongFormat 2ms
โœ… CrossFormatMappingTests testOneToOneAudiobookToEpub 2ms
โœ… CrossFormatMappingTests testOneToOneEpubToAudiobook 7ms
โœ… CrossFormatMappingTests testOneToOneMappingCreation 2ms
โœ… CrossFormatMappingTests testProportionalAudiobookToEpub 2ms
โœ… CrossFormatMappingTests testProportionalEpubToAudiobook 2ms
โœ… CrossFormatMappingTests testProportionalMappingCreation 2ms
โœ… DPLAErrorTests testCertificateUrl_isValid 6ms
โœ… DPLAErrorTests testDrmKeyError_readableError 2ms
โœ… DPLAErrorTests testRequestError_readableError 3ms
โŠ˜ DRMAdversarialTests testAdobe_didIgnoreFulfillment_noLongerShowsSignInModal 30ms
โŠ˜ DRMAdversarialTests testAdobe_epubWithoutValidLicense_openFails 7ms
โŠ˜ DRMAdversarialTests testAdobe_fulfillmentPath_callsEnsureDeviceActivated 104ms
โœ… DRMAdversarialTests testLCP_publicationWithoutPassphrase_returnsAuthRequired 12ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_localURLIsCorrect 5ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_storesLocalURL 6ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_storesSuggestedFilename 3ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_withEmptyFilename 6ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_withLongFilename 5ms
โœ… DRMFulfilledPublicationTests testDRMFulfilledPublication_withSpecialCharacters 8ms
โœ… DataBase64Tests testBase64UrlSafe_ReplacesPlus_WithDash 2ms
โœ… DataBase64Tests testBase64UrlSafe_ReplacesSlash_WithUnderscore 5ms
โœ… DataBase64Tests testBase64UrlSafe_emptyAndAscii_canonicalAndNoNewlines 7ms
โœ… DataReceptionComparisonTests testGET_receivesBearerTokenJSON_andCanBeDetected 16ms
โœ… DataReceptionComparisonTests testGET_receivesNonEmptyBody_forValidJSON 37ms
โœ… DateExtensionTests testAddingDays_increasesDate 3ms
โœ… DateExtensionTests testDateComparison_differentDay 4ms
โœ… DateExtensionTests testDateComparison_sameDay 3ms
โœ… DateExtensionTests testISO8601_roundTrip 4ms
โœ… DateExtensionTests testRfc339String_includesTimezone 2ms
โœ… DateExtensionTests testRfc339String_producesValidFormat 2ms
โœ… DateExtensionTests testSubtractingDays_decreasesDate 2ms
โœ… DateExtensionTests testTimeIntervalSinceNow_negative 4ms
โœ… DateExtensionTests testTimeIntervalSinceNow_positive 2ms
โœ… DateFormattingTests testCustomFormat 5ms
โœ… DateFormattingTests testLongDateFormat 3ms
โœ… DateFormattingTests testShortDateFormat 3ms
โœ… DateFormattingTests testTimeFormat 7ms
โœ… Date_NYPLAdditionsTests testISO8601FullDateParsing 3ms
โœ… Date_NYPLAdditionsTests testInvalidRFC3339Date 3ms
โœ… Date_NYPLAdditionsTests testParsesRFC3339DateCorrectly 15ms
โœ… Date_NYPLAdditionsTests testParsesRFC3339DateWithFractionalSecondsCorrectly 3ms
โœ… Date_NYPLAdditionsTests testRFC1123 7ms
โœ… Date_NYPLAdditionsTests testRFC1123Performance 485ms
โœ… Date_NYPLAdditionsTests testRFC3339RoundTrip 4ms
โœ… DebugSettingsTests testBadgeLogging_defaultFalse 6ms
โœ… DebugSettingsTests testBadgeLogging_enabledStateIsResetByResetAll 7ms
โœ… DebugSettingsTests testCreateSimulatedBorrowError_nilWhenDisabled 2ms
โœ… DebugSettingsTests testCreateSimulatedBorrowError_returnsErrorWhenEnabled 7ms
โœ… DebugSettingsTests testCreateTestHoldBooks_allReady 4ms
โœ… DebugSettingsTests testCreateTestHoldBooks_mixedHolds 13ms
โœ… DebugSettingsTests testCreateTestHoldBooks_nilWhenDisabled 5ms
โœ… DebugSettingsTests testCreateTestHoldBooks_oneReady 6ms
โœ… DebugSettingsTests testCreateTestHoldBooks_oneReserved 5ms
โœ… DebugSettingsTests testDefaultSimulatedBorrowError 2ms
โœ… DebugSettingsTests testIsBorrowErrorSimulationEnabled 4ms
โœ… DebugSettingsTests testIsTestHoldsEnabled 6ms
โœ… DebugSettingsTests testResetAll 5ms
โœ… DebugSettingsTests testSimulatedBorrowError_allCasesHaveDisplayNames 3ms
โœ… DebugSettingsTests testSimulatedBorrowError_canBeSet 10ms
โœ… DebugSettingsTests testSimulatedBorrowError_credentialsSuspended 2ms
โœ… DebugSettingsTests testSimulatedBorrowError_generic 2ms
โœ… DebugSettingsTests testSimulatedBorrowError_holdLimit 5ms
โœ… DebugSettingsTests testSimulatedBorrowError_loanLimit 2ms
โœ… DebugSettingsTests testSimulatedBorrowError_none_nilProblemDoc 3ms
โœ… DebugSettingsTests testTestHoldsConfig_allCasesHaveDisplayNames 46ms
โœ… DebugSettingsTests testTestHoldsConfig_allReady_badgeCount 2ms
โœ… DebugSettingsTests testTestHoldsConfig_default 4ms
โœ… DebugSettingsTests testTestHoldsConfig_mixedHolds_badgeCount 2ms
โœ… DebugSettingsTests testTestHoldsConfig_none_badgeCount 2ms
โœ… DebugSettingsTests testTestHoldsConfig_oneReady_badgeCount 4ms
โœ… DebugSettingsTests testTestHoldsConfig_oneReserved_badgeCount 6ms
โœ… DefaultCatalogAPITests testCatalogAPI_IntegrationWithRepository_HandlesErrors 40ms
โœ… DefaultCatalogAPITests testCatalogAPI_IntegrationWithRepository_WorksCorrectly 12ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_ActiveEntry_GetsSearchDescriptorURL 7ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_FacetWithEmptyTitle_IsExcluded 7ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_FeedWithNoFacets_ReturnsEmpty 11ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_FirstEntryActive_MarkedCorrectly 3ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_GroupsFeedURLs_AreCorrect 7ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_InactiveEntries_HaveNilSearchDescriptorURL 8ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_NoSearchLink_AllDescriptorURLsNil 6ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_NonEntryPointFacets_AreExcluded 8ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_SecondEntryActive_MarkedCorrectly 10ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_StableIDs_MatchGroupsFeedURL 6ms
โœ… DefaultCatalogAPITests testExtractSearchEntryPoints_ThreeEntryPoints_ReturnsAllThree 41ms
โœ… DefaultCatalogAPITests testFetchFeed_AfterReset_CallCountResetsToZero 8ms
โœ… DefaultCatalogAPITests testFetchFeed_DefaultResponse_UsedWhenNoStubSet 11ms
โœ… DefaultCatalogAPITests testFetchFeed_DifferentURLs_ReturnDifferentStubs 14ms
โœ… DefaultCatalogAPITests testFetchFeed_EmptyFeed_ReturnsEmptyEntries 8ms
โœ… DefaultCatalogAPITests testFetchFeed_EmptyResponseData_ThrowsParsingError 9ms
โœ… DefaultCatalogAPITests testFetchFeed_FailAfterMultipleCalls_SimulatesIntermittentFailure 10ms
โœ… DefaultCatalogAPITests testFetchFeed_GlobalError_AffectsAllRequests 3ms
โœ… DefaultCatalogAPITests testFetchFeed_InvalidXML_ThrowsParsingError 38ms
โœ… DefaultCatalogAPITests testFetchFeed_MultipleCalls_TracksAllRequests 10ms
โœ… DefaultCatalogAPITests testFetchFeed_NetworkError_ThrowsError 3ms
โœ… DefaultCatalogAPITests testFetchFeed_ServerError500_ThrowsError 8ms
โœ… DefaultCatalogAPITests testFetchFeed_SpecialCharactersInFeedTitle_ParsesCorrectly 8ms
โœ… DefaultCatalogAPITests testFetchFeed_Timeout_ThrowsError 8ms
โœ… DefaultCatalogAPITests testFetchFeed_TracksRequestDetails 26ms
โœ… DefaultCatalogAPITests testFetchFeed_URLWithQueryParameters_PreservesParameters 4ms
โœ… DefaultCatalogAPITests testFetchFeed_UnauthorizedError_ThrowsError 16ms
โœ… DefaultCatalogAPITests testFetchFeed_UsesGETMethod 7ms
โœ… DefaultCatalogAPITests testFetchFeed_ValidOPDSResponse_ReturnsParsedFeed 10ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyOpenedAudiobook_excludesEbooks_evenWhenEbookOpenedMoreRecently 3ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyOpenedAudiobook_returnsAudiobookWithLatestOpenTimestamp 3ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyOpenedAudiobook_returnsNil_whenNoAudiobookHasRecordedOpen 7ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyOpenedAudiobook_returnsNil_whenNoTrackerInjected 2ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_breaksTimestampTies_byBookIdAscending 8ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_emptyRegistryReturnsEmpty 6ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_excludesAudiobooks 12ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_excludesBooksWithoutSavedLocation 12ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_excludesSamples 10ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_fallsBackDeterministically_whenJSONLacksTimestamp 3ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_ordersByLastReadTimestampDescending 5ms
โœ… DefaultRecentlyReadingServiceTests testRecentlyReading_parsesLastReadTimestampFromLocationJSON 16ms
โœ… DeriveInitialStateTests testDeriveInitialState_ForBookWithoutAcquisition_ReturnsUnsupported 30ms
โœ… DeriveInitialStateTests testDeriveInitialState_ForReadyBook_ReturnsHolding 9ms
โœ… DeriveInitialStateTests testDeriveInitialState_ForReservedBook_ReturnsHolding 6ms
โœ… DeriveInitialStateTests testDeriveInitialState_ForStandardBook_ReturnsDownloadNeeded 7ms
โœ… DeveloperSettingsTierTests testAppStoreProductionReceipt_hidesEngineeringTools 2ms
โœ… DeveloperSettingsTierTests testDebugReceiptNamedReceiptButMissingOnDisk_showsEngineeringTools 11ms
โœ… DeveloperSettingsTierTests testNoReceiptURL_showsEngineeringTools 3ms
โœ… DeveloperSettingsTierTests testTestFlightSandboxReceipt_showsEngineeringTools 7ms
โœ… DeviceLogCollectorGapTests testDeviceLogCollector_collectLogs_exercisesFormattingMethods 6.47s
โœ… DeviceLogCollectorGapTests testDeviceLogCollector_collectLogs_outputContainsFormattedStructure 6.31s
โœ… DeviceLogCollectorTests testCollectLogs_capturesRecentOSLogEntries 3.91s
โœ… DeviceLogCollectorTests testCollectLogs_containsEndMarker 4.45s
โœ… DeviceLogCollectorTests testCollectLogs_containsExpectedHeader 15.44s
โœ… DeviceLogCollectorTests testCollectLogs_defaultParameterIs7Days 3.67s
โœ… DeviceLogCollectorTests testCollectLogs_formattedEntriesContainExpectedFields 3.87s
โœ… DeviceLogCollectorTests testCollectLogs_outputIsValidUTF8 3.55s
โœ… DeviceLogCollectorTests testCollectLogs_reportsEntryCount 4.78s
โœ… DeviceLogCollectorTests testCollectLogs_returnsNonEmptyData 4.56s
โœ… DeviceLogCollectorTests testCollectLogs_withCustomDayRange_reflectsInOutput 3.63s
โœ… DeviceOrientationTests testDeviceOrientation_isObservableObject 9ms
โœ… DeviceOrientationTests testInitialIsLandscape_basedOnScreenDimensions 7ms
โœ… DeviceOrientationTests testIsLandscape_isPublished 2ms
โœ… DeviceOrientationTests testStartAndStopTracking_multipleTimesDoesNotCrash 3ms
โœ… DeviceOrientationTests testStartTracking_doesNotCrash 3ms
โœ… DeviceOrientationTests testStopTracking_beforeStartTracking_doesNotCrash 2ms
โœ… DeviceOrientationTests testStopTracking_doesNotCrash 2ms
โœ… DeviceSpecificErrorMonitorTests testGetDeviceID_isConsistent 45ms
โœ… DeviceSpecificErrorMonitorTests testGetDeviceID_looksLikeUUIDAndFormatIsStableAcrossCalls 16ms
โœ… DeviceSpecificErrorMonitorTests testGetDeviceID_returnsNonEmptyString 7ms
โœ… DeviceSpecificErrorMonitorTests testGetDeviceInfo_containsExpectedKeys 13ms
โœ… DeviceSpecificErrorMonitorTests testGetDeviceInfo_valuesAreNonEmpty 6ms
โœ… DeviceSpecificErrorMonitorTests testInit_eachInstance_canQueryDeviceInfo 6ms
โœ… DeviceSpecificErrorMonitorTests testInit_returnsIndependentInstance 4ms
โœ… DeviceSpecificErrorMonitorTests testIsEnhancedLoggingEnabled_returnsBool 4ms
โœ… DeviceSpecificErrorMonitorTests testLogError_doesNotCrashAndPreservesMonitorState 8ms
โœ… DeviceSpecificErrorMonitorTests testLogError_withMetadata_doesNotCrash 15ms
โœ… DeviceSpecificErrorMonitorTests testLogNetworkFailure_doesNotCrash 96ms
โœ… DictionaryExtensionsTests testMapKeys_ChangesKeyType_StringToInt 5ms
โœ… DictionaryExtensionsTests testMapKeys_CollidingKeys_OverwritesValue 2ms
โœ… DictionaryExtensionsTests testMapKeys_EmptyDictionary_ReturnsEmpty 2ms
โœ… DictionaryExtensionsTests testMapKeys_TransformsKeys_PreservesValues 10ms
โœ… DictionaryExtensionsTests testMapKeys_UniqueTransform_PreservesCount 4ms
โœ… DiskBudgetManagerTests testDefaultBudget_onLargeDevice_returnsRelaxedLargeDeviceQuota 3ms
โœ… DiskBudgetManagerTests testDefaultBudget_onSmallDevice_returnsRelaxedSmallDeviceQuota 2ms
โœ… DiskBudgetManagerTests testDirectoryUsageBytes_emptyDirectory_returnsZero 3ms
โœ… DiskBudgetManagerTests testDirectoryUsageBytes_missingDirectory_returnsZero 4ms
โœ… DiskBudgetManagerTests testDirectoryUsageBytes_sumsAllNonHiddenFiles 4ms
โœ… DiskBudgetManagerTests testListContentFilesSortedByLRU_missingDirectory_returnsEmpty 15ms
โœ… DiskBudgetManagerTests testListContentFilesSortedByLRU_returnsOldestFirst 5ms
โœ… DiskBudgetTests testContentDirectory_createdOnAccess 14ms
โœ… DiskBudgetTests testDiskSpace_available_returnsPositiveValue 7ms
โœ… DownloadAlertPresenterTests testAlertForProblemDocument_errorOnly_includesErrorDescription 24ms
โœ… DownloadAlertPresenterTests testAlertForProblemDocument_genericProblem_keepsBookInRegistryAndAllowsRetry 38ms
โœ… DownloadAlertPresenterTests testAlertForProblemDocument_noActiveLoan_removesFromRegistryAndDisablesRetry 49ms
โœ… DownloadAlertPresenterTests testFailDownloadWithAlert_emptyMessage_alsoFallsBackToActionableText 38ms
โœ… DownloadAlertPresenterTests testFailDownloadWithAlert_nilMessage_doesNotShowDeveloperPlaceholder 38ms
โœ… DownloadAlertPresenterTests testFailDownloadWithAlert_nilMessage_includesActionableFallback 467ms
โœ… DownloadAlertPresenterTests testFailDownloadWithAlert_retryAction_invokesStartDownloadOnce 36ms
โœ… DownloadAlertPresenterTests testFailDownloadWithAlert_setsDownloadFailedAndAnnouncesAndPublishesError 77ms
โœ… DownloadAnnouncementServiceTests testAnnounceBorrowFailed_forwardsTitle 6ms
โœ… DownloadAnnouncementServiceTests testAnnounceBorrowStarted_forwardsTitle 5ms
โœ… DownloadAnnouncementServiceTests testAnnounceBorrowSucceeded_forwardsTitle 9ms
โœ… DownloadAnnouncementServiceTests testAnnounceDownloadCompleted_announcesAndResetsProgress 5ms
โœ… DownloadAnnouncementServiceTests testAnnounceDownloadFailed_announcesAndResetsProgress 5ms
โœ… DownloadAnnouncementServiceTests testAnnounceDownloadProgress_forwardsTitleIdentifierAndProgress 7ms
โœ… DownloadAnnouncementServiceTests testAnnounceDownloadStarted_forwardsTitleAndIdentifier 16ms
โœ… DownloadAnnouncementServiceTests testAnnounceReturnFailed_forwardsTitle 13ms
โœ… DownloadAnnouncementServiceTests testAnnounceReturnStarted_forwardsTitle 11ms
โœ… DownloadAnnouncementServiceTests testAnnounceReturnSucceeded_forwardsTitle 9ms
โœ… DownloadAnnouncementServiceTests testCompletedAndFailed_orderingIsAnnounceThenReset 10ms
โœ… DownloadAnnouncementServiceTests testIdentifierPropagation_distinctBooksAreNotAliased 39ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testCoordinator_401_OIDC_routesToCoordinator_setsDownloadNeeded_andRetriesOnSuccess 439ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testCoordinator_401_SAML_routesToCoordinator_setsSAMLStarted_andRetriesOnSuccess 440ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testCoordinator_401_SAML_userCancel_doesNotRetryButFlipsPerBookState 441ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testCoordinator_noActiveLoan_SAML_routesToCoordinator_setsSAMLStarted 447ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testForeignHost_401_SAML_doesNotMarkCredentialsStale_doesNotDispatchCoordinator 427ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests testForeignHost_401_SAML_withNilProvider_fallsBackToLegacyDispatch 443ms
โœ… DownloadAuthRetryHandlerTaskLifecycleTests testCancelAllInFlightTasks_cancelsAndClearsAndPreventsRetry 121ms
โœ… DownloadAuthRetryHandlerTaskLifecycleTests testHandlerRelease_weakSelfCapture_preventsPostReleaseRegistryWrites 170ms
โœ… DownloadAuthRetryHandlerTaskLifecycleTests testInFlightTasks_areTrackedWhenLaunched_twoRetryPathsBothRetained 23ms
โœ… DownloadAuthRetryHandlerTaskLifecycleTests testInFlightTasks_autoRemoveAfterEachCompletion_setDoesNotGrowUnbounded 87ms
โœ… DownloadAuthRetryHandlerTests testAutoBorrowCompletion_whenBorrowFails_publishesAlertAndRemovesBook 197ms
โœ… DownloadAuthRetryHandlerTests testAutoBorrowCompletion_whenBorrowSucceedsAndDownloadAlreadyFinished_doesNotPublishAlert 183ms
โœ… DownloadAuthRetryHandlerTests testAutoBorrowCompletion_whenBorrowSucceedsAndDownloadStarts_doesNotPublishAlert 179ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_accountHost_browserSAML_guardDoesNotFire_drivesSAMLRetry 182ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_foreignHost_browserSAML_shortCircuitsReturnsFalse_noReauth 190ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withCredentials_browserOIDC_presentsReauthAndRetriesOnLoggedIn 200ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withCredentials_browserOIDC_userCancelsReauth_doesNotRetry 215ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withCredentials_browserSAML_setsStateToSAMLStartedAndRetries 191ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withCredentials_credentialPromptStrategy_fallsThroughReturnsFalse 14ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withCredentials_tokenRefresh_returnsFalseSoCallerCanAlert 23ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withoutCredentials_loginRequired_presentsSignInAndRetriesOnHasCredentials 180ms
โœ… DownloadAuthRetryHandlerTests testHandle_401_withoutCredentials_loginRequired_userCancelsSignIn_doesNotRetry 179ms
โœ… DownloadAuthRetryHandlerTests testHandle_403_foreignHost_noCredentials_guardDoesNotIntercept_signInStillFires 8ms
โœ… DownloadAuthRetryHandlerTests testHandle_noActiveLoan_basicAuth_triggersAutoBorrowWithAttemptDownloadTrue 21ms
โœ… DownloadAuthRetryHandlerTests testHandle_noActiveLoan_browserSAML_treatsAsSessionExpiryAndRetries 506ms
โœ… DownloadAuthRetryHandlerTests testHandle_nonAuthError_withoutCredentials_loginRequired_presentsSignInModal 9ms
โœ… DownloadAuthRetryHandlerTests testHandle_unrelatedFailure_anonymousAccount_returnsFalse 10ms
โœ… DownloadCancellationHandlerTests testCancel_adobeDRMRights_shortCircuitsToAdobeCancel 106ms
โœ… DownloadCancellationHandlerTests testCancel_noTaskInDownloadingState_setsDownloadNeededAndCleansUp 35ms
โœ… DownloadCancellationHandlerTests testCancel_noTaskInSAMLStartedState_treatedAsCancellable 45ms
โœ… DownloadCancellationHandlerTests testCancel_unknownIdentifierWithNonCancellableState_isNoOp 79ms
โœ… DownloadCancellationHandlerTests testCancel_withTask_setsDownloadNeededAndCancelsTask 33ms
โœ… DownloadCompletionParserTests testParse_OPDS2Publication_followUpFailed_returnsFailure 22ms
โœ… DownloadCompletionParserTests testParse_OPDS2Publication_followUpStarted_returnsFollowUpStarted 20ms
โœ… DownloadCompletionParserTests testParse_OPDSEntry_followUpFailed_returnsFailure 21ms
โœ… DownloadCompletionParserTests testParse_OPDSEntry_followUpStarted_returnsFollowUpStarted 16ms
โœ… DownloadCompletionParserTests testParse_knownRightsInCache_skipsDetection 14ms
โœ… DownloadCompletionParserTests testParse_problemDocument_returnsFailureWithParsedDoc 11ms
โœ… DownloadCompletionParserTests testParse_supportedMime_returnsProceed 28ms
โœ… DownloadCompletionParserTests testParse_unknownRights_detectsFromMimeAndUpdatesCache 42ms
โœ… DownloadCompletionParserTests testParse_unsupportedMime_returnsFailure 11ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_concurrentCompletions_maintainsConsistency 5ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_concurrentRegistrations_maintainsConsistency 3ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_downloadInfoCache_storesMultipleEntries 984ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_downloadInfoCache_updatesExistingEntry 10ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_mixedOperations_maintainsConsistency 17ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_partialDequeue_leavesRemainder 22ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_queueFIFO_maintainsOrder 13ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_throttling_returnsDelayAfterRecentStart 4ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_throttling_returnsZeroAfterDelay 3ms
โœ… DownloadCoordinatorIntegrationTests testCoordinator_zeroCapacityDequeue_returnsEmpty 7ms
โœ… DownloadCoordinatorTests testCoordinator_cacheDownloadInfo_storesAndRetrieves 6ms
โœ… DownloadCoordinatorTests testCoordinator_canStartDownload_respectsMaxConcurrent 6ms
โœ… DownloadCoordinatorTests testCoordinator_canStartDownload_withinLimit 4ms
โœ… DownloadCoordinatorTests testCoordinator_dequeuePending_returnsBooks 327ms
โœ… DownloadCoordinatorTests testCoordinator_enqueuePending_addsToQueue 45ms
โœ… DownloadCoordinatorTests testCoordinator_enqueuePending_preventsDuplicates 47ms
โœ… DownloadCoordinatorTests testCoordinator_redirectAttempts_tracksCorrectly 4ms
โœ… DownloadCoordinatorTests testCoordinator_registerCompletion_decrementsActiveCount 11ms
โœ… DownloadCoordinatorTests testCoordinator_registerStart_incrementsActiveCount 7ms
โœ… DownloadCoordinatorTests testCoordinator_removeCachedDownloadInfo_removesEntry 8ms
โœ… DownloadCoordinatorTests testCoordinator_reset_clearsAllState 65ms
โœ… DownloadDiskSpaceTests testAvailableDiskSpace_isPositive 4ms
โœ… DownloadDiskSpaceTests testDocumentsDirectory_exists 7ms
โœ… DownloadErrorInfoTests testConvenienceInit_setsFieldsCorrectly 3ms
โœ… DownloadErrorInfoTests testFullInit_withNilRetryAction 31ms
โœ… DownloadErrorInfoTests testFullInit_withRetryAction 15ms
โœ… DownloadErrorRecoveryPolicyTests testBorrowPolicy_doesNotRetryOnFatalErrors 6ms
โœ… DownloadErrorRecoveryPolicyTests testBorrowPolicy_recoversAfterNoActiveLoan 20ms
โœ… DownloadErrorRecoveryPolicyTests testBorrowPolicy_retriesOnAllTransientErrors 7ms
โœ… DownloadErrorRecoveryPolicyTests testDefaultPolicy_hasReasonableDefaults 4ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_failsAfterMaxAttempts 30ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_immediateSuccess_noRetries 5ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_nonRetryableError_failsImmediately 3ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_retriesOnTransientError 49ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_successfulOperation_returnsResult 7ms
โœ… DownloadErrorRecoveryPolicyTests testExecuteWithRetry_worksWithDifferentTypes 14ms
โœ… DownloadErrorRecoveryPolicyTests testPolicyPresets_areOrderedByAggressiveness 20ms
โœ… DownloadErrorRecoveryTests testErrorRecovery_cancelledDownload_resetsToDownloadNeeded 11ms
โœ… DownloadErrorRecoveryTests testErrorRecovery_downloadFailed_allowsRetry 9ms
โœ… DownloadErrorRecoveryTests testErrorRecovery_multipleFailures_trackedSeparately 6ms
โœ… DownloadFreeSpaceExhaustionTests testDefaultDiskBudget_normalDeviceBranch 4ms
โœ… DownloadFreeSpaceExhaustionTests testDefaultDiskBudget_smallDeviceBranch 2ms
โœ… DownloadFreeSpaceExhaustionTests testDirectoryUsage_countsLCPFilesEvenIfThoseFilesArePreservedDuringEviction 7ms
โœ… DownloadFreeSpaceExhaustionTests testEviction_atExactBudget_doesNothing 8ms
โœ… DownloadFreeSpaceExhaustionTests testEviction_bytesToAddExceedsBudgetButDirectoryEmpty_isNoOp 7ms
โœ… DownloadFreeSpaceExhaustionTests testEviction_evictsOnlyOldestWhenSufficient 13ms
โœ… DownloadFreeSpaceExhaustionTests testEviction_orphan_reclaimedButRegistryUntouched 8ms
โœ… DownloadFreeSpaceExhaustionTests testLRUSort_producesOldestFirst 11ms
โœ… DownloadFreeSpaceExhaustionTests testMoveFile_destinationParentReadOnly_failsCleanly 8ms
โœ… DownloadFreeSpaceExhaustionTests testMoveFile_disk_out_leavesNoPartialGarbageAtDestination 8ms
โœ… DownloadFreeSpaceExhaustionTests testReplaceBook_destinationParentReadOnly_failsCleanly 9ms
โœ… DownloadInfoTests testDownloadInfo_creation_setsInitialValues 3ms
โœ… DownloadInfoTests testDownloadInfo_progressUpdates_handlesEdgeCases 6ms
โœ… DownloadInfoTests testDownloadInfo_rightsManagementString_returnsCorrectString 3ms
โœ… DownloadInfoTests testDownloadInfo_withDownloadProgress_createsNewInstance 4ms
โœ… DownloadInfoTests testDownloadInfo_withRightsManagement_createsNewInstance 4ms
โœ… DownloadIntegrityTests testMoveFile_firstDownload_landsExactBytes 21ms
โœ… DownloadIntegrityTests testReplaceBook_byteForByteHashMatch 29ms
โœ… DownloadIntegrityTests testReplaceBook_manifestReFetch_overwritesOldManifest 23ms
โœ… DownloadIntegrityTests testReplaceBook_openAccessAudiobookManifest_writesAndMarksSuccessful 34ms
โœ… DownloadIntegrityTests testReplaceBook_sameSizeDifferentBytes_writesNewBytes 22ms
โœ… DownloadIntegrityTests testReplaceBook_validationFailureLeavesRegistryUnchanged 53ms
โœ… DownloadIntegrityTests testValidate_missingFile_fails 12ms
โœ… DownloadIntegrityTests testValidate_nonEmptyFile_passes 11ms
โœ… DownloadIntegrityTests testValidate_repeatedCallsAreIdempotent 12ms
โœ… DownloadIntegrityTests testValidate_zeroByteFile_fails 12ms
โœ… DownloadOnlyOnWiFiTests testAccessibilityIdentifier_exists 4ms
โœ… DownloadOnlyOnWiFiTests testDefaultValue_isFalse 11ms
โœ… DownloadOnlyOnWiFiTests testLocalizedStrings_areNotEmpty 3ms
โœ… DownloadOnlyOnWiFiTests testMock_canBeConfigured 2ms
โœ… DownloadOnlyOnWiFiTests testMock_defaultIsFalse 2ms
โœ… DownloadOnlyOnWiFiTests testMock_resetClearsSetting 3ms
โœ… DownloadOnlyOnWiFiTests testReachability_isOnWiFi_consistentWithDetailedStatus 10ms
โœ… DownloadOnlyOnWiFiTests testReachability_isOnWiFi_returnsBool 12ms
โœ… DownloadOnlyOnWiFiTests testSetting_persistsAcrossReads 18ms
โœ… DownloadOnlyOnWiFiTests testSetting_persistsToUserDefaultsAcrossToggleCycle 12ms
โœ… DownloadPersistenceStoreTests testBookDownloadsOverallProgress 8ms
โœ… DownloadPersistenceStoreTests testGetIncompleteDownloads 8ms
โœ… DownloadPersistenceStoreTests testMarkCompleted 5ms
โœ… DownloadPersistenceStoreTests testRegisterDownload 12ms
โœ… DownloadPersistenceStoreTests testUpdateProgress 24ms
โœ… DownloadProgressPublisherCoreTests testAnnounceBorrowFailed_doesNotCrash 10ms
โœ… DownloadProgressPublisherCoreTests testAnnounceBorrowStarted_doesNotCrash 8ms
โœ… DownloadProgressPublisherCoreTests testAnnounceBorrowSucceeded_doesNotCrash 5ms
โœ… DownloadProgressPublisherCoreTests testAnnounceDownloadCompleted_doesNotCrash 10ms
โœ… DownloadProgressPublisherCoreTests testAnnounceDownloadFailed_doesNotCrash 24ms
โœ… DownloadProgressPublisherCoreTests testAnnounceDownloadProgress_doesNotCrash 5ms
โœ… DownloadProgressPublisherCoreTests testAnnounceDownloadStarted_doesNotCrash 10ms
โœ… DownloadProgressPublisherCoreTests testAnnounceReturnFailed_doesNotCrash 4ms
โœ… DownloadProgressPublisherCoreTests testAnnounceReturnStarted_doesNotCrash 4ms
โœ… DownloadProgressPublisherCoreTests testAnnounceReturnSucceeded_doesNotCrash 4ms
โœ… DownloadProgressPublisherCoreTests testBroadcastUpdate_postsNotification 9ms
โœ… DownloadProgressPublisherCoreTests testBroadcastUpdate_throttles_rapidCalls 580ms
โœ… DownloadProgressPublisherCoreTests testBroadcastUpdate_usesNotificationSender 7ms
โœ… DownloadProgressPublisherCoreTests testConformsToDownloadProgressPublishing 7ms
โœ… DownloadProgressPublisherCoreTests testPublishAndAnnounceError_publishesOnErrorPublisher 9ms
โœ… DownloadProgressPublisherCoreTests testPublishAndAnnounceError_withRetryAction 3ms
โœ… DownloadProgressPublisherCoreTests testSendProgress_differentBooks_publishesSeparately 19ms
โœ… DownloadProgressPublisherCoreTests testSendProgress_multipleUpdates_allReceived 7ms
โœ… DownloadProgressPublisherCoreTests testSendProgress_publishesOnProgressPublisher 7ms
โœ… DownloadProgressPublisherTests testProgressPublisher_emitsMultipleUpdates 7ms
โœ… DownloadProgressPublisherTests testProgressPublisher_emitsProgressUpdates 6ms
โœ… DownloadQueueIntegrationTests testMaxConcurrentDownloads_limitsActiveDownloads 3ms
โœ… DownloadQueueIntegrationTests testQueuedBooks_preserveOrderAcrossMultipleDequeues 47ms
โœ… DownloadQueueIntegrationTests testQueuedBooks_startedWhenCapacityAvailable 23ms
โœ… DownloadQueueOrchestratorTests testEnqueuePending_appendsToCoordinatorPendingQueue 57ms
โœ… DownloadQueueOrchestratorTests testEnqueuePending_doesNotPostOnDefaultCenter_whenInjectedCenterDiffers 54ms
โœ… DownloadQueueOrchestratorTests testEnqueuePending_marksBookAsDownloadingInRegistry 11ms
โœ… DownloadQueueOrchestratorTests testEnqueuePending_postsDidChangeNotificationOnInjectedCenter 40ms
โœ… DownloadQueueOrchestratorTests testSchedulePendingStartsAsync_atCap_doesNotDequeueOrCallDelegate 96ms
โœ… DownloadQueueOrchestratorTests testSchedulePendingStartsAsync_emptyQueue_doesNotCallDelegate 24ms
โœ… DownloadQueueOrchestratorTests testSchedulePendingStartsAsync_passesNilRequestToDelegate 14ms
โœ… DownloadQueueOrchestratorTests testSchedulePendingStartsAsync_underCap_dequeuesUpToRemainingCapacityInFIFOOrder 108ms
โœ… DownloadQueueOrchestratorTests testSchedulePendingStartsIfPossible_drivesDelegateAsynchronously 78ms
โœ… DownloadRMSDKHandoffTests testRMSDKHandoff_featureDRMConnectorDisabled_skipsSuite 2ms
โœ… DownloadRedirectTests testBearerTokenJSON_shouldUseDistributorToken_notPalaceToken 2ms
โœ… DownloadRedirectTests testRedirectRequest_crossDomain_shouldNotContainAuthHeader 2ms
โœ… DownloadRedirectTests testRedirectRequest_sameDomain_shouldNotContainAuthHeader 8ms
โœ… DownloadRedirectTests testRedirectRequest_shouldNotContainAuthHeader_whenFollowingRedirect 2ms
โœ… DownloadRedirectTests testRedirect_httpsToHttp_shouldBeBlocked 3ms
โœ… DownloadRedirectTests testRedirect_httpsToHttps_shouldBeAllowed 3ms
โœ… DownloadRedirectTests testRedirect_maxRedirectAttempts_shouldBeEnforced 2ms
โœ… DownloadResumeAfterKillTests testCancel_at99PercentProgress_resetsStateAndClearsMaps 62ms
โœ… DownloadResumeAfterKillTests testMoveFile_overStalePartialAtDestination_removesAndReplaces 14ms
โœ… DownloadResumeAfterKillTests testReplaceBook_missingSourceAfterKill_failsCleanly 12ms
โœ… DownloadResumeAfterKillTests testReplaceBook_noDoubleWriteOrConcatenation 22ms
โœ… DownloadResumeAfterKillTests testReplaceBook_partialAtDestination_isReplacedByFreshFullPayload 19ms
โœ… DownloadResumeAfterKillTests testReplaceBook_truncatedResumePayload_failsValidationAndStateUnchanged 23ms
โœ… DownloadResumeAfterKillTests testValidateDownloadedFile_after99PercentCancelLeavesZeroBytes_returnsFalse 9ms
โœ… DownloadSlotManagementTests testHoldingState_bookRegistryTracksCorrectly 31ms
โœ… DownloadSlotManagementTests testStateTransition_completeDownloadFlow 26ms
โœ… DownloadSlotManagementTests testStateTransition_downloadingToFailed 2.21s
โœ… DownloadSlotManagementTests testStateTransition_downloadingToHolding 17ms
โœ… DownloadSlotManagementTests testStateTransitions_holdingStateIsTracked 86ms
โœ… DownloadStartCoordinatorContractTests test_startDownload_downloadNeeded_callsProcessWithCredentials 65ms
โœ… DownloadStartCoordinatorContractTests test_startDownload_downloadSuccessful_isNonsensical_returns 12ms
โœ… DownloadStartCoordinatorContractTests test_startDownload_downloadingState_isShortCircuited 13ms
โœ… DownloadStartCoordinatorContractTests test_startDownload_holding_callsStartBorrow_withAttemptDownloadTrue 24ms
โœ… DownloadStartCoordinatorContractTests test_startDownload_unregistered_routesThroughProcessUnregistered 15ms
โœ… DownloadStartCoordinatorTests testStartBorrow_resultsInHolding_releasesSlotAndSchedules 43ms
โœ… DownloadStartCoordinatorTests testStartBorrow_success_invokesCompletionAndDoesNotReleaseSlot 42ms
โœ… DownloadStartCoordinatorTests testStartBorrow_throws_releasesSlotAndSchedulesAndCallsCompletion 59ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_alreadyDownloadingState_skips 53ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_capExceeded_enqueuesPending 15ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_credentialsAvailable_dispatches 13ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_existingDownloadInProgress_skipsDuplicate 12ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_terminalState_isNonsensicalNoOp 12ms
โœ… DownloadStartCoordinatorTests testStartDownloadAsync_unregisteredState_callsProcessUnregisteredFirst 27ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_epubBook_stillCallsStartBorrow 8ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_holding_routesToStartBorrow 8ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_nonBorrowStates_doNotCallStartBorrow 246ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_overdriveDistributorEpub_doesNotRouteToOverdriveHandler 14ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_streamingHTMLBook_returnsEarlyWithoutCallingStartBorrow 5ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_streamingHTMLBook_unregisteredState_alsoReturnsEarly 6ms
โœ… DownloadStartDispatcherTests testProcessDownloadWithCredentials_unregistered_routesToStartBorrow 8ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_downloadNeededAutoBorrow_completionFires_withDownloadingState 26ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_downloadNeededAutoBorrow_completionFires_withHoldingState 5ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_downloadNeededWithBorrowLink_triggersAutoBorrow 6ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_expiredBookWithBorrowLink_triggersReBorrow 22ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_initedRequestPassedThrough_overridesAcquisitionURL 7ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_nonSamlStateWithCookies_doesNotRouteToSAMLHandler 56ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_normalOpenAccess_callsAddDownloadTaskWithBearerRequest 42ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_samlStateWithoutCookies_fallsThroughToAddDownloadTask 15ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_samlState_routesThroughSAMLHandler 22ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_unexpiredBookWithBorrowLink_doesNotReBorrowViaExpiredBranch 27ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_wifiOnlyEnforced_failsAndDoesNotStartDownload 9ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_wifiOnlyToggleOff_offWifi_proceedsWithDownload 15ms
โœ… DownloadStartDispatcherTests testProcessRegularDownload_wifiOnlyToggleOn_onWifi_proceedsWithDownload 19ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_hasBorrowLink_doesNotRegister 15ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_loginNotRequired_noBorrowLink_registersAsDownloadNeeded 9ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_loginRequiredNoOpenAccess_returnsUnregistered 34ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_openAccessBook_registersAndReturnsDownloadNeeded 11ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_openAccessWithLoginRequired_stillRegistersAsDownloadNeeded 9ms
โœ… DownloadStartDispatcherTests testProcessUnregisteredState_streamingHTMLOpenAccessBook_transitionsToDownloadNeeded 31ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_borrowFromLimited_reservedResponse_returnsRaceLossError 3ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_borrowFromReady_unavailableResponse_returnsRaceLossError 56ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_borrowFromUnlimited_unavailableResponse_returnsRaceLossError 4ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_placeHold_reservedResponse_noError 3ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_placeHold_unavailableResponse_noError 5ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_postLimited_returnsDownloadNeededWithNoError 5ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_postReady_returnsDownloadNeededWithNoError 4ms
โœ… DownloadStateMachineIntegrationTests testBorrowResponseState_postUnlimited_returnsDownloadNeededWithNoError 3ms
โœ… DownloadStateMachineIntegrationTests testState_completeFailedDownloadWithRetryFlow 16ms
โœ… DownloadStateMachineIntegrationTests testState_completeSuccessfulDownloadFlow 11ms
โœ… DownloadStateMachineIntegrationTests testState_downloadFailedToDownloading_retryTransition 5ms
โœ… DownloadStateMachineIntegrationTests testState_downloadNeededToDownloading_validTransition 14ms
โœ… DownloadStateMachineIntegrationTests testState_downloadingToDownloadFailed_validTransition 15ms
โœ… DownloadStateMachineIntegrationTests testState_downloadingToDownloadSuccessful_validTransition 13ms
โœ… DownloadStateMachineIntegrationTests testState_unregisteredToDownloadNeeded_validTransition 6ms
โœ… DownloadStateMachineTests testState_downloadFailed_canRetry 6ms
โœ… DownloadStateMachineTests testState_downloadNeeded_canTransitionToDownloadSuccessful 5ms
โœ… DownloadStateMachineTests testState_downloadNeeded_canTransitionToDownloading 7ms
โœ… DownloadStateMachineTests testState_downloading_canTransitionToFailed 5ms
โœ… DownloadStateMachineTests testState_downloading_canTransitionToSuccess 6ms
โœ… DownloadStateManagerTests testBookIdentifierToDownloadTask_storesAndRetrieves 5ms
โœ… DownloadStateManagerTests testCleanupDownload_removesAllTracking 11ms
โœ… DownloadStateManagerTests testCleanupDownload_removesOldTaskIdEntry 10ms
โœ… DownloadStateManagerTests testCleanupDownload_withoutTaskId_stillCleansInfo 8ms
โœ… DownloadStateManagerTests testConcurrentAccess_doesNotCrash 9ms
โœ… DownloadStateManagerTests testDownloadInfoAsync_cachesInCoordinator 36ms
โœ… DownloadStateManagerTests testDownloadInfoAsync_existingEntry_returnsInfo 5ms
โœ… DownloadStateManagerTests testDownloadInfoAsync_missingEntry_returnsNil 3ms
โœ… DownloadStateManagerTests testDownloadInfo_sync_returnsNilForMissing 3ms
โœ… DownloadStateManagerTests testDownloadProgress_noInfo_returnsZero 3ms
โœ… DownloadStateManagerTests testInit_defaultMaxConcurrentDownloads 4ms
โœ… DownloadStateManagerTests testInit_emptyCollections 8ms
โœ… DownloadStateManagerTests testResetAll_clearsEverything 11ms
โœ… DownloadStateManagerTests testTaskIdentifierToBook_recycleSameId_doesNotLeakOldBook 13ms
โœ… DownloadStateManagerTests testTaskIdentifierToBook_setBeforeRemove_intentionalOverwrite 12ms
โœ… DownloadStateManagerTests testTaskIdentifierToBook_storesAndRetrieves 9ms
โœ… DownloadTaskLifecycleServiceTests testHandleTaskCompletionError_cancelledError_doesNotAlert 22ms
โœ… DownloadTaskLifecycleServiceTests testHandleTaskCompletionError_realError_logsFailureAndAlerts 27ms
โœ… DownloadTaskLifecycleServiceTests testHandleTaskCompletionError_successPath_registersCompletionAndSchedules 35ms
โœ… DownloadTaskLifecycleServiceTests testHandleTaskCompletionError_unknownTask_isNoOp 27ms
โœ… DownloadTaskLifecycleServiceTests testRegisterStartedTask_announcesDownloadStartedAndNotifiesCenter 49ms
โœ… DownloadTaskLifecycleServiceTests testRegisterStartedTask_marksBookAsDownloadingInRegistry 47ms
โœ… DownloadTaskLifecycleServiceTests testRegisterStartedTask_resumesTheTask 37ms
โœ… DownloadTaskLifecycleServiceTests testRegisterStartedTask_storesDownloadInfoKeyedByBookIdentifier 32ms
โœ… DownloadTaskLifecycleServiceTests testRegisterStartedTask_storesTaskIdentifierToBookMapping 2.10s
โœ… DownloadThrottlingServiceTests testLimitActiveDownloads_alwaysCallsScheduleAfterPolicyApplied 71ms
โœ… DownloadThrottlingServiceTests testLimit_atCap_doesNothingButCallsSchedule 51ms
โœ… DownloadThrottlingServiceTests testLimit_overCap_audiobookTaskNotSuspended 57ms
โœ… DownloadThrottlingServiceTests testLimit_overCap_suspendsExcessNonAudiobookTasks 51ms
โœ… DownloadThrottlingServiceTests testLimit_underCap_resumesSuspendedTasks 58ms
โœ… DownloadThrottlingServiceTests testPauseAllDownloads_preservesAudiobookTasks 44ms
โœ… DownloadThrottlingServiceTests testPauseAllDownloads_suspendsAllNonAudiobookTasks 45ms
โœ… DownloadThrottlingServiceTests testResumeIntelligentDownloads_reAppliesCurrentCap 26ms
โœ… DownloadThrottlingServiceTests testSetupNetworkMonitoring_calledTwice_replacesPriorObserver 38ms
โœ… DownloadThrottlingServiceTests testSetupNetworkMonitoring_observesAppDidBecomeActiveAndReAppliesCap 37ms
โœ… DownloadWatchdogTests testDefaultConfiguration 11ms
โœ… DownloadWatchdogTests testStartAndStop 8ms
โœ… DownloadWatchdogTests testWatchdogConfiguration 180ms
โœ… EPUBKeyCommandsPP4289Tests testReaderKeyCommands_everyBindingClaimsPriorityOverSystem 3ms
โœ… EPUBKeyCommandsPP4289Tests testReaderKeyCommands_includesCmdComma_routedToSettings 19ms
โœ… EPUBKeyCommandsPP4289Tests testReaderKeyCommands_includesCmdW_routedToCloseReader 25ms
โœ… EPUBKeyCommandsPP4289Tests testReaderKeyCommands_preservesArrowLeftRightSpaceShiftSpaceEscape 6ms
โœ… EPUBModuleTests testEPUBModule_canBeInitialized 5ms
โœ… EPUBModuleTests testEPUBModule_conformsToReaderFormatModule 14ms
โœ… EPUBModuleTests testReaderError_epubNotValid_exists 18ms
โœ… EPUBModuleTests testReaderError_epubNotValid_isError 6ms
โœ… EPUBPositionTests testBookLocation_CreationFromDictionary 3ms
โœ… EPUBPositionTests testBookLocation_CreationWithValidData 4ms
โœ… EPUBPositionTests testBookLocation_DictionaryRoundTrip 4ms
โœ… EPUBPositionTests testBookLocation_FailsWithMissingLocationString 6ms
โœ… EPUBPositionTests testBookLocation_FailsWithMissingRenderer 4ms
โœ… EPUBPositionTests testLocationSimilarity_DifferentProgressions 33ms
โœ… EPUBPositionTests testLocationSimilarity_IdenticalLocations 7ms
โœ… EPUBPositionTests testLocatorRoundTrip_preservesCssSelectorPositionProgression_throughJSONValue 15ms
โœ… EPUBPositionTests testLocatorRoundTrip_withoutCssSelector_succeedsAndPreservesPosition 94ms
โœ… EPUBPositionTests testThrottlingInterval_Value 2ms
โœ… EPUBSearchViewModelTests testClearSearch_ResetsState 14ms
โœ… EPUBSearchViewModelTests testFetchNextBatch_WhenNotIdle_DoesNothing 6ms
โœ… EPUBSearchViewModelTests testFetchNextBatch_WithMoreResults_AppendsResults 13ms
โœ… EPUBSearchViewModelTests testInit_HasCorrectDefaults 3ms
โœ… EPUBSearchViewModelTests testSearch_CancelsInFlight_OnNewQuery 15ms
โœ… EPUBSearchViewModelTests testSearch_FiltersDuplicateResults 7ms
โœ… EPUBSearchViewModelTests testSearch_GroupsResultsByTitle 22ms
โœ… EPUBSearchViewModelTests testSearch_PublicationNotSearchable_SetsFailureState 4ms
โœ… EPUBSearchViewModelTests testSearch_SetsIsSearching 5ms
โœ… EPUBSearchViewModelTests testSearch_WithEmptyQuery_DoesNotSearch 6ms
โœ… EPUBSearchViewModelTests testSearch_WithError_SetsErrorMessage 8ms
โœ… EPUBSearchViewModelTests testSearch_WithIteratorError_SetsErrorState 23ms
โœ… EPUBSearchViewModelTests testSearch_WithNoResults_SetsEmptyState 7ms
โœ… EPUBSearchViewModelTests testSearch_WithResults_UpdatesResults 7ms
โœ… EPUBSearchViewModelTests testSearch_WithValidQuery_PerformsSearch 4ms
โœ… EPUBSearchViewModelTests testSelectResult_NavigatesToLocation 2ms
โœ… EPUBSearchViewModelTests testSelectResult_WithNilDelegate_DoesNotCrash 2ms
โœ… EPUBSearchViewModelTests testState_IsLoadingState_ReturnsCorrectValues 15ms
โœ… EPUBToolbarToggleTests testDoubleToggle_restoresOriginalState 3ms
โœ… EPUBToolbarToggleTests testDualPath_edgeTap_doesNotToggleToolbar 5ms
โœ… EPUBToolbarToggleTests testFixedDualPath_centerTap_togglesToolbarExactlyOnce 2ms
โœ… EPUBToolbarToggleTests testFixedDualPath_repeatedCenterTaps_alternateToolbarState 4ms
โœ… EPUBToolbarToggleTests testKeyboardNavigable_doubleToggle_restoresState 8ms
โœ… EPUBToolbarToggleTests testKeyboardNavigable_toggleToolbar_changesState 48ms
โœ… EPUBToolbarToggleTests testSingleToggle_changesToolbarVisibility 2ms
โœ… EPUBToolbarToggleTests testTapRegion_classifiesViewportInToThreeZones 5ms
โœ… EPUBToolbarToggleTests testTapRegion_threshold_isInclusiveOnEdgeAndExclusiveAtCenter 3ms
โœ… EPUBToolbarToggleTests testTapRegion_zeroWidthViewport_defaultsToCenter 4ms
โœ… EPUBToolbarToggleTests testUnfixedDualPath_centerTap_doubleTogglesToolbar 3ms
โœ… EmailAddressTests testEmail_withLeadingWhitespace_isTrimmed 3ms
โœ… EmailAddressTests testEmail_withTrailingWhitespace_isTrimmed 4ms
โœ… EmailAddressTests testEquality_differentRawValue_haveDifferentRawValue 9ms
โœ… EmailAddressTests testEquality_sameRawValue_haveSameRawValue 3ms
โœ… EmailAddressTests testInvalidEmail_emptyString 10ms
โœ… EmailAddressTests testInvalidEmail_justText 4ms
โœ… EmailAddressTests testInvalidEmail_multipleAtSigns 3ms
โœ… EmailAddressTests testInvalidEmail_noAtSign 3ms
โœ… EmailAddressTests testInvalidEmail_noDomain 4ms
โœ… EmailAddressTests testInvalidEmail_noLocalPart 9ms
โœ… EmailAddressTests testRawValue_matchesInput 3ms
โœ… EmailAddressTests testValidEmail_simpleAddress 3ms
โœ… EmailAddressTests testValidEmail_withDots 3ms
โœ… EmailAddressTests testValidEmail_withNumbers 39ms
โœ… EmailAddressTests testValidEmail_withPlus 4ms
โœ… EmailAddressTests testValidEmail_withSubdomain 19ms
โœ… EpubSampleFactoryTests testCreateSample_withBookWithoutSample_returnsError 10ms
โœ… EpubSampleFactoryTests testSamplePlayerError_fileSaveFailed_withUnderlyingError 3ms
โœ… EpubSampleFactoryTests testSamplePlayerError_sampleDownloadFailed_withUnderlyingError 4ms
โœ… EpubSampleFactoryTests testSamplePlayerError_threeDistinctCasesWithOptionalPayloads 8ms
โœ… EpubSampleFactoryTests testSampleURLWrappers_polymorphismAllowsCallSiteRouting 3ms
โœ… ErrorActivityTrackerTests testCategoryRawValues 15ms
โœ… ErrorActivityTrackerTests testClear_removesAllEntries 4ms
โœ… ErrorActivityTrackerTests testDisplayString_containsTimestampCategoryAndMessage 5ms
โœ… ErrorActivityTrackerTests testLog_allCategories_areStoredCorrectly 9ms
โœ… ErrorActivityTrackerTests testLog_capturesFileAndLine 8ms
โœ… ErrorActivityTrackerTests testLog_exceedingMaxEntries_trimmsOldest 7ms
โœ… ErrorActivityTrackerTests testLog_multipleEntries_preservesOrder 2ms
โœ… ErrorActivityTrackerTests testLog_singleEntry_appearsInSnapshot 5ms
โœ… ErrorActivityTrackerTests testLog_timestampsAreMonotonicallyIncreasing 3ms
โœ… ErrorActivityTrackerTests testRecentActivities_defaultParameter_returns5Minutes 12ms
โœ… ErrorActivityTrackerTests testRecentActivities_filtersOldEntries 3ms
โœ… ErrorActivityTrackerTests testShortSource_containsFileAndLine 3ms
โœ… ErrorDetailTests testBookInfo_withNilIdentifier_isNil 7ms
โœ… ErrorDetailTests testCapture_populatesBasicFields 23ms
โœ… ErrorDetailTests testCapture_populatesDeviceContext 8ms
โœ… ErrorDetailTests testCapture_withBookInfo_populatesBookContext 11ms
โœ… ErrorDetailTests testCapture_withError_storesUnderlyingError 10ms
โœ… ErrorDetailTests testCapture_withoutBookInfo_bookInfoIsNil 10ms
โœ… ErrorDetailTests testFormattedReport_containsActivityTrailSection 9ms
โœ… ErrorDetailTests testFormattedReport_containsDeviceSection 8ms
โœ… ErrorDetailTests testFormattedReport_containsErrorSection 6ms
โœ… ErrorDetailTests testFormattedReport_containsHeader 15ms
โœ… ErrorDetailTests testFormattedReport_withBookInfo_containsBookSection 9ms
โœ… ErrorDetailTests testFormattedReport_withError_containsErrorDetails 8ms
โœ… ErrorDetailViewControllerGapTests testErrorDetailVC_rendersDeviceContextLines 24ms
โœ… ErrorDetailViewControllerGapTests testErrorDetailVC_rendersFieldsCorrectly 33ms
โœ… ErrorDetailViewControllerGapTests testErrorDetailVC_rendersSectionsCorrectly 170ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_Init_setsTitleAndPopulatesTextView 9ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_NavigationItems_AreConfigured 22ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_RenderContent_ContainsDeviceFields 12ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_RenderContent_ContainsErrorTitle 18ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_RenderContent_ContainsSection 9ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_RenderContent_EmptyTrailShowsMessage 12ms
โœ… ErrorDetailViewControllerTests testErrorDetailViewController_ViewDidLoad_HasTextView 15ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_ContainsTimestamp 2ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_DeviceContextFields 2ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_EmptyActivityTrail 2ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_WithBookInfo_ContainsBookSection 2ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_WithUnderlyingError_ContainsDomain 8ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_includesAllSectionsAndPassesThroughTitleAndMessage 2ms
โœ… ErrorDetailViewControllerTests testErrorDetail_FormattedReport_omitsBookSectionWhenNoBookInfoButRendersRestOfReport 2ms
โœ… ErrorLogExporterTests testErrorLogData_deviceLogsField_acceptsEmptyData 2ms
โœ… ErrorLogExporterTests testErrorLogData_deviceLogsField_acceptsLargeData 5ms
โœ… ErrorLogExporterTests testErrorLogData_initializesWithAllFields 3ms
โœ… ErrorLogExporterTests testErrorLogExporter_sharedInstance_isNotNil 30ms
โœ… ErrorLogExporterTests testPP3651_collectLogsForPreview_containsPatronIDField 60ms
โœ… ExpiredLoanStringsTests testExpiredLoanMessageWithDate_containsFormatSpecifier 2ms
โœ… ExpiredLoanStringsTests testExpiredLoanMessageWithDate_formatsDateCorrectly 1.36s
โœ… ExpiredLoanStringsTests testExpiredLoanMessage_isNonEmpty 215ms
โœ… ExpiredLoanStringsTests testExpiredLoanMessage_mentionsRemoval 2ms
โœ… ExpiredLoanStringsTests testExpiredLoanTitle_isNonEmpty 2ms
โœ… FacetEnumTests testFacet_LocalizedStrings_AreDistinct 4ms
โœ… FacetEnumTests testFacet_LocalizedStrings_AreNotEmpty 4ms
โœ… FacetEnumTests testFacet_LocalizedStrings_MatchStringsFile 3ms
โœ… FacetToolbarAccessibilityTests testFilterButtonLabel_differsBasedOnFilterState 4ms
โœ… FacetToolbarAccessibilityTests testFilterButtonLabel_noFiltersApplied 6ms
โœ… FacetToolbarAccessibilityTests testFilterButtonLabel_withFiltersApplied 3ms
โœ… FacetToolbarAccessibilityTests testSortButtonLabel_hasConsistentFormat 3ms
โœ… FacetToolbarAccessibilityTests testSortButtonLabel_includesSortOption 7ms
โœ… FacetViewModelLogoDelegateTests testAccountScreenURL_WithValidHomePageURL 4ms
โœ… FacetViewModelLogoDelegateTests testActiveSort_DefaultsToFirstFacet_AuthorFirst 5ms
โœ… FacetViewModelLogoDelegateTests testActiveSort_DefaultsToFirstFacet_TitleFirst 8ms
โœ… FacetViewModelLogoDelegateTests testLogoDidUpdate_SetsLogo 5ms
โœ… FacetViewModelTests testActiveSortPublished 799ms
โœ… FacetViewModelTests testChangingSortMultipleTimes 858ms
โœ… FacetViewModelTests testCurrentAccountURLWithNilAccount 1.07s
โœ… FacetViewModelTests testEmptyGroupName 805ms
โœ… FacetViewModelTests testFacetLocalizedStrings 2ms
โœ… FacetViewModelTests testFacetRawValues 4ms
โœ… FacetViewModelTests testFacetsArrayPublished 1.03s
โœ… FacetViewModelTests testGroupNamePublished 922ms
โœ… FacetViewModelTests testGroupNameWithSpecialCharacters 1.09s
โœ… FacetViewModelTests testInitWithAuthorAndTitleFacets 879ms
โœ… FacetViewModelTests testInitWithSingleFacet 833ms
โœ… FacetViewModelTests testInitWithTitleFirst 1.02s
โœ… FacetViewModelTests testLogoInitiallyNilWithoutAccount 805ms
โœ… FacetViewModelTests testMultipleSubscribersToActiveSort 902ms
โœ… FacetViewModelTests testSettingSameSortValue 899ms
โœ… FacetViewModelTests testShowAccountScreenInitiallyFalse 900ms
โœ… FacetViewModelTests testShowAccountScreenToggle 1.25s
โœ… FacetViewModelTests testUpdatingFacetsDoesNotChangeActiveSort 1.04s
โœ… FetchManifestWithBearerTokenLCPSafetyTests testFetchManifestWithBearerToken_receivingLCPLicense_returnsJSON 41ms
โœ… FetchManifestWithBearerTokenTests testEmptyResponseBody_returnsNil 26ms
โœ… FetchManifestWithBearerTokenTests testHTMLResponse_returnsNil 15ms
โœ… FetchManifestWithBearerTokenTests testHTTP401_returnsNil 14ms
โœ… FetchManifestWithBearerTokenTests testHTTP500_returnsNil 13ms
โœ… FetchManifestWithBearerTokenTests testInvalidJSON_returnsNil 11ms
โœ… FetchManifestWithBearerTokenTests testJSONArray_returnsNil 9ms
โœ… FetchManifestWithBearerTokenTests testSuccess_requestsFromCorrectURL 15ms
โœ… FetchManifestWithBearerTokenTests testSuccess_returnsManifestJSON 42ms
โœ… FetchManifestWithBearerTokenTests testSuccess_sendsCorrectBearerTokenHeader 12ms
โœ… FetchOpenAccessManifestLCPSafetyTests testBearerTokenResponseVsLCPLicense_areDistinct 4ms
โœ… FetchOpenAccessManifestLCPSafetyTests testLCPLicenseResponse_notDetectedAsBearerToken_inFetchFlow 4ms
โœ… FetchOpenAccessManifestLCPSafetyTests testLCPLicenseResponse_wouldBeReturnedAsManifest_withoutRouting 3ms
โœ… FetchOpenAccessManifestLCPSafetyTests testManifestVsLCPLicense_structuralDifferences 6ms
โœ… FileURLGenerationTests testFileUrl_contentDirectoryExists 6ms
โœ… FileURLGenerationTests testFileUrl_deterministicForSameIdentifier 15ms
โœ… FileURLGenerationTests testFileUrl_epubBook_hasEpubExtension 9ms
โœ… FindawayChapterStatusGuardTests testFindawayObservationPattern_RetainsObserverForDuration 16ms
โœ… FloatTPPAdditionsTests testApproxEqual_isSymmetric 4ms
โœ… FloatTPPAdditionsTests testApproxEqual_returnsFalseWhenRightHandSideIsNil 8ms
โœ… FloatTPPAdditionsTests testApproxEqual_returnsTrueOnlyForValuesWithinEpsilon 9ms
โœ… FloatTPPAdditionsTests testRoundTo_formatsAsPercentageWithSpecifiedDecimalPlaces 2ms
โœ… FloatTPPAdditionsTests testRoundTo_preservesTrailingZerosFromFormatSpecifier 2ms
โœ… FocusIndicationTests testAccessibilityElements_areOrderedLogically 27ms
โœ… FocusIndicationTests testCatalogCell_accessibilityLabelBehavior 9ms
โœ… FocusIndicationTests testFocusColor_hasSufficientContrastInDarkMode 2ms
โœ… FocusIndicationTests testFocusColor_hasSufficientContrastInLightMode 2ms
โœ… FocusIndicationTests testFocusableButton_hasFocusEffect 8ms
โœ… FocusIndicationTests testReaderToolbar_buttonsInLogicalOrder 13ms
โœ… FocusIndicationTests testTPPRoundedButton_isAccessible 8ms
โœ… FontManagerTests testAllFontFamiliesHaveCSSValue 2ms
โœ… FontManagerTests testAllFontFamiliesHaveCategory 6ms
โœ… FontManagerTests testAllFontFamiliesHaveDisplayName 3ms
โœ… FontManagerTests testAllFontFamiliesHavePreviewText 17ms
โœ… FontManagerTests testAvailableFamiliesNotEmpty 19ms
โœ… FontManagerTests testFamilyAvailabilityForSystemFonts 2ms
โœ… FontManagerTests testFontFamilyCategorization 2ms
โœ… FontManagerTests testFontFamilyIsCodable 2ms
โœ… FontManagerTests testFontsInCategory 16ms
โœ… FontManagerTests testNonExistentFontIsNotAvailable 5ms
โœ… FontManagerTests testOpenDyslexicCSSContainsFontName 2ms
โœ… FontManagerTests testRegisterCustomFontsDoesNotCrash 20ms
โœ… FontManagerTests testRegisterNonexistentFontReturnsFalse 3ms
โœ… FontManagerTests testSharedInstanceExists 6ms
โœ… FontManagerTests testSwiftUIFontCreation 13ms
โœ… FontManagerTests testSystemFontsAreAvailable 3ms
โœ… FontManagerTests testUIFontCreation 8ms
โœ… ForceResetTests testConsume_clearsTheUserDefaultsKey 10ms
โœ… ForceResetTests testConsume_secondCallAfterSet_returnsFalse 13ms
โœ… ForceResetTests testConsume_supportsMultipleSetThenConsumeCycles 17ms
โœ… ForceResetTests testConsume_whenFlagNeverSet_returnsFalse 4ms
โœ… ForceResetTests testConsume_whenFlagSet_returnsTrueOnce 12ms
โœ… ForceResetTests testRegressionForBug_resetAccountForcesNextOIDCSessionEphemeral_perHelpSpot17716 11ms
โœ… GeneralCacheTests testCachePolicy_cacheFirst_callsFetcher_onCacheMiss 3ms
โœ… GeneralCacheTests testCachePolicy_cacheFirst_returnsCachedValue_whenPresent 3ms
โœ… GeneralCacheTests testCachePolicy_cacheFirst_usesCache_whenFetcherFails 4ms
โœ… GeneralCacheTests testCachePolicy_noCache_alwaysFetches 3ms
โœ… GeneralCacheTests testCache_withCodableValues 10ms
โœ… GeneralCacheTests testCache_withIntKeys 17ms
โœ… GeneralCacheTests testClearAllCaches_preservesBundleIDDirectory 116ms
โœ… GeneralCacheTests testClearMemory_removesMemoryEntries 29ms
โœ… GeneralCacheTests testClear_removesAllEntries 5ms
โœ… GeneralCacheTests testDiskCache_persistsValue 6ms
โœ… GeneralCacheTests testFileURL_returnsURL 4ms
โœ… GeneralCacheTests testGet_unknownKey_returnsNil 3ms
โœ… GeneralCacheTests testMemoryAndDisk_persistsValue 8ms
โœ… GeneralCacheTests testNoneMode_doesNotStore 4ms
โœ… GeneralCacheTests testRemove_deletesEntry 3ms
โœ… GeneralCacheTests testRemove_nonexistentKey_doesNotCrash 3ms
โœ… GeneralCacheTests testSet_afterExternalDirectoryDeletion_recreatesAndSucceeds 60ms
โœ… GeneralCacheTests testSet_andGet_returnsValue 33ms
โœ… GeneralCacheTests testSet_overwrite_updatesValue 3ms
โœ… GeneralCacheTests testSet_withExpiration_isAvailableBeforeExpiry 3ms
โœ… GroupEnumTests testGroup_UsedAsSection_FacetViewModelGroupNameMatches 29ms
โœ… HTMLTextViewTests testAngleBracketsWithSpaces 51ms
โœ… HTMLTextViewTests testBOMCausesIssuesWithoutSanitization 81ms
โœ… HTMLTextViewTests testBOMCharacter 56ms
โœ… HTMLTextViewTests testBOMCharacterIsRemoved 64ms
โœ… HTMLTextViewTests testControlCharacters 150ms
โœ… HTMLTextViewTests testControlCharactersAreRemoved 43ms
โœ… HTMLTextViewTests testControlCharactersCauseIssuesWithoutSanitization 88ms
โœ… HTMLTextViewTests testDataURL 138ms
โœ… HTMLTextViewTests testDeeplyNestedTags 94ms
โœ… HTMLTextViewTests testDefensiveMeasuresPreventCrashes 1.62s
โœ… HTMLTextViewTests testEmptyParagraph 42ms
โœ… HTMLTextViewTests testEmptyString 2ms
โœ… HTMLTextViewTests testExistingDoctypeNotDoubleWrapped 97ms
โœ… HTMLTextViewTests testExistingHTMLTagNotDoubleWrapped 46ms
โœ… HTMLTextViewTests testFallbackStripsHTMLTags 52ms
โœ… HTMLTextViewTests testFastPathLongContent 17ms
โœ… HTMLTextViewTests testFastPathLongContentWithHTML 21ms
โœ… HTMLTextViewTests testFastPathNoHTMLTags 6ms
โœ… HTMLTextViewTests testFormElements 208ms
โœ… HTMLTextViewTests testHTML5Elements 54ms
โœ… HTMLTextViewTests testHTMLDocumentWrapping 73ms
โœ… HTMLTextViewTests testHTMLEntities 55ms
โœ… HTMLTextViewTests testHTMLTagsAreNotDisplayedAsText 524ms
โœ… HTMLTextViewTests testHTMLWithMultipleTags 183ms
โœ… HTMLTextViewTests testInvalidUTF8Sequence 50ms
โœ… HTMLTextViewTests testLeadingWhitespaceIsTrimmed 49ms
โœ… HTMLTextViewTests testMalformedBrokenAttributes 48ms
โœ… HTMLTextViewTests testMalformedEmptyTags 51ms
โœ… HTMLTextViewTests testMalformedNestedTags 43ms
โœ… HTMLTextViewTests testMalformedOnlyClosingTag 43ms
โœ… HTMLTextViewTests testMalformedOnlyOpeningTag 50ms
โœ… HTMLTextViewTests testMalformedRandomAngleBrackets 40ms
โœ… HTMLTextViewTests testMalformedTable 52ms
โœ… HTMLTextViewTests testMalformedUnclosedTags 54ms
โœ… HTMLTextViewTests testMathMLContent 126ms
โœ… HTMLTextViewTests testMixedContentRapidCalls 3.46s
โœ… HTMLTextViewTests testMultipleDoctypes 51ms
โœ… HTMLTextViewTests testMultipleEmptyParagraphs 42ms
โœ… HTMLTextViewTests testNullCharacterInHTML 47ms
โœ… HTMLTextViewTests testNumericEntities 89ms
โœ… HTMLTextViewTests testOPDSSummaryPatterns 183ms
โœ… HTMLTextViewTests testOnlyAngleBracket 235ms
โœ… HTMLTextViewTests testOnlyClosingAngleBracket 3ms
โœ… HTMLTextViewTests testOnlyWhitespaceBeforeTag 46ms
โœ… HTMLTextViewTests testPlainTextWithoutHTML 5ms
โœ… HTMLTextViewTests testProcessingInstruction 56ms
โœ… HTMLTextViewTests testRapidBookDetailViewSimulation 11.57s
โœ… HTMLTextViewTests testRapidSequentialCalls 5.30s
โœ… HTMLTextViewTests testRefugeeGraphicNovelSummaryPattern 689ms
โœ… HTMLTextViewTests testSVGContent 80ms
โœ… HTMLTextViewTests testSafeVsUnsafeParsingComparison 1.07s
โœ… HTMLTextViewTests testScriptTag 73ms
โœ… HTMLTextViewTests testSimpleHTMLParagraph 52ms
โœ… HTMLTextViewTests testStartsWithCDATA 44ms
โœ… HTMLTextViewTests testStartsWithClosingTag 141ms
โœ… HTMLTextViewTests testStartsWithComment 75ms
โœ… HTMLTextViewTests testStartsWithDoctype 50ms
โœ… HTMLTextViewTests testStartsWithEndOfDocument 42ms
โœ… HTMLTextViewTests testStartsWithXMLDeclaration 53ms
โœ… HTMLTextViewTests testStyleTag 49ms
โœ… HTMLTextViewTests testSummaryWithLineBreaks 45ms
โœ… HTMLTextViewTests testSummaryWithLinks 79ms
โœ… HTMLTextViewTests testTableHTML 61ms
โœ… HTMLTextViewTests testTypicalBookDescriptionHTML 65ms
โœ… HTMLTextViewTests testTypicalBookSummary 50ms
โœ… HTMLTextViewTests testUnclosedScriptTag 146ms
โœ… HTMLTextViewTests testUnexpectedSummaryStarts 279ms
โœ… HTMLTextViewTests testUnicodeContent 78ms
โœ… HTMLTextViewTests testVeryLongAttribute 212ms
โœ… HTMLTextViewTests testWhitespaceOnly 6ms
โœ… HoldNotificationClassificationTests testIsHoldRelated_returnsTrueForHoldOrReservationKeywords_falseOtherwise 3ms
โœ… HoldNotificationClassificationTests testIsHoldRelated_withTypeHold_returnsTrue 3ms
โœ… HoldsBadgeCountTests testBadgeCount_allReserved_returnsZero 9ms
โœ… HoldsBadgeCountTests testBadgeCount_mixedHolds_countsOnlyReady 12ms
โœ… HoldsBadgeCountTests testBadgeCount_multipleReady_countsAll 7ms
โœ… HoldsBadgeCountTests testBadgeCount_noBooks_returnsZero 5ms
โœ… HoldsBadgeCountTests testBadgeCount_oneReadyBook_returnsOne 4ms
โœ… HoldsBadgeCountTests testBadgeCount_oneReservedBook_returnsZero 6ms
โœ… HoldsBadgeCountTests testBadgeCount_regularBook_notCounted 4ms
โœ… HoldsBadgeCountTests testReadyBookHasReadyAvailability 6ms
โœ… HoldsBadgeCountTests testReservedBookHasReservedAvailability 4ms
โœ… HoldsBookViewModelTests testBookPropertyReturnsCorrectBook 5ms
โœ… HoldsBookViewModelTests testHoldReady_DistinguishesFromReserved 8ms
โœ… HoldsBookViewModelTests testHoldReady_IdentifiesReadyHolds 5ms
โœ… HoldsBookViewModelTests testIdMatchesBookIdentifier 16ms
โœ… HoldsBookViewModelTests testIsReservedForHoldBook 9ms
โœ… HoldsBookViewModelTests testIsReservedForNonReservedBook 4ms
โœ… HoldsBookViewModelTests testIsReservedForReadyBook 4ms
โœ… HoldsBookViewModelTests testIsReserved_WithLimitedAvailability_ReturnsFalse 141ms
โœ… HoldsReducerTests testDismissSyncError_clearsTheErrorMessage 2ms
โœ… HoldsReducerTests testRegistryChanged_partitionsBooksByReservedStatus 8ms
โœ… HoldsReducerTests testRegistryChanged_withActiveSearch_leavesVisibleBooksAlone 21ms
โœ… HoldsReducerTests testSearchQueryChanged_nonEmpty_returnsFilterEffectThatYieldsFilterCompleted 81ms
โœ… HoldsReducerTests testSearchQueryChanged_toEmpty_restoresAllHeldBooks 54ms
โœ… HoldsReducerTests testSyncBegan_setsLoadingTrueAndClearsPreviousError 7ms
โœ… HoldsReducerTests testSyncEnded_setsLoadingFalse 14ms
โœ… HoldsReducerTests testSyncFailed_whenAnonymous_suppressesErrorBanner 2ms
โœ… HoldsReducerTests testSyncFailed_whenAuthenticatedWithNoCacheAndNoMessage_fallsBackToGenericText 6ms
โœ… HoldsReducerTests testSyncFailed_whenAuthenticatedWithNoCache_surfacesServerDetailMessage 2ms
โœ… HoldsReducerTests testSyncFailed_whenCachedDataVisible_suppressesErrorBanner 5ms
โœ… HoldsSyncFailureTests testDismissSyncError_ClearsError 32ms
โœ… HoldsSyncFailureTests testSyncBegan_ClearsPreviousSyncError 46ms
โœ… HoldsSyncFailureTests testSyncFailure_AnonymousLibrary_SuppressesErrorBanner_EvenWhenHasCredentialsRacesTrue 36ms
โœ… HoldsSyncFailureTests testSyncFailure_AnonymousUser_SuppressesErrorBanner 22ms
โœ… HoldsSyncFailureTests testSyncFailure_AuthenticatedUser_ShowsErrorBanner 43ms
โœ… HoldsSyncFailureTests testSyncFailure_LibraryNeedsAuth_AndHasCredentials_ShowsBanner 146ms
โœ… HoldsSyncFailureTests testSyncFailure_SetsSyncError 13ms
โœ… HoldsSyncFailureTests testSyncFailure_StaleDataPersists_ErrorSuppressedWhenCachedDataExists 35ms
โœ… HoldsSyncFailureTests testSyncFailure_StopsLoading 36ms
โœ… HoldsSyncFailureTests testSyncFailure_WithProblemDocument_ShowsServerMessage 105ms
โœ… HoldsSyncFailureTests testSyncFailure_WithTitleOnly_UsesTitle 25ms
โœ… HoldsSyncFailureTests testSyncFailure_WithoutProblemDocument_ShowsGenericMessage 29ms
โœ… HoldsViewModelTests testFilterBooksWithEmptyQueryReturnsAll 26ms
โœ… HoldsViewModelTests testFilterBooksWithQuery 17ms
โœ… HoldsViewModelTests testFilterBooks_CaseInsensitive 22ms
โœ… HoldsViewModelTests testFilterBooks_WithAuthorMatch_ReturnsMatchingBooks 21ms
โœ… HoldsViewModelTests testFilterBooks_WithTitleMatch_ReturnsMatchingBooks 30ms
โœ… HoldsViewModelTests testInitialState_EmptyBookLists 6ms
โœ… HoldsViewModelTests testInitialState_HasCorrectDefaults 6ms
โœ… HoldsViewModelTests testIsLoading_PublishesChanges 17ms
โœ… HoldsViewModelTests testLoadHolds_WithEmptyResult_SetsEmptyState 5ms
โœ… HoldsViewModelTests testLoadHolds_WithSuccess_UpdatesHolds 10ms
โœ… HoldsViewModelTests testOpenSearchDescriptionHumanReadableDescription 5ms
โœ… HoldsViewModelTests testOpenSearchDescription_IncludesAllBooks 18ms
โœ… HoldsViewModelTests testRegistryDidChange_ReloadsData 337ms
โœ… HoldsViewModelTests testReloadData_CallsMethod 19ms
โœ… HoldsViewModelTests testReloadData_HandlesMultipleBooks 15ms
โœ… HoldsViewModelTests testReloadData_SeparatesReservedAndReadyBooks 21ms
โœ… HoldsViewModelTests testSearchQueryUpdate 8ms
โœ… HoldsViewModelTests testSelectNewLibraryToggle 9ms
โœ… HoldsViewModelTests testShowLibraryAccountViewToggle 29ms
โœ… HoldsViewModelTests testShowSearchSheetToggle 9ms
โœ… HoldsViewModelTests testSyncBeganSetsLoadingTrue 12ms
โœ… HoldsViewModelTests testSyncEndedSetsLoadingFalse 333ms
โœ… HoldsViewModelTests testVisibleBooks_PublishesChanges 321ms
โœ… ImageCacheContinuationTests testGetAsync_whenOperationsCancelledWhileQueued_everyCallResumes 242ms
โœ… ImageCacheTypeTests testImageCacheType_defaultSetUses7DayTTL 4ms
โœ… ImageLoaderTests testClearAll_clearsUnderlyingImageCache 3ms
โœ… ImageLoaderTests testCompletionBridge_book_deallocatedBeforeCompletion_noCrash 127ms
โœ… ImageLoaderTests testCompletionBridge_cover_invokesOnMainThread 13ms
โœ… ImageLoaderTests testCompletionBridge_thumbnail_invokesOnMainThread 16ms
โœ… ImageLoaderTests testCoverImage_cacheHit_returnsCachedImageWithoutTouchingFallback 6ms
โœ… ImageLoaderTests testCoverImage_displayPoints_cacheHit_skipsNetwork 10ms
โœ… ImageLoaderTests testDownsampleImage_returnsImageWithinMaxDimension 9ms
โœ… ImageLoaderTests testGetSet_delegateToUnderlyingCache 5ms
โœ… ImageLoaderTests testRemove_delegateToUnderlyingCache 3ms
โœ… ImageLoaderTests testSet_defaultExpiry_isSevenDays 4ms
โœ… ImageLoaderTests testThumbnailImage_falsBackToTenPrintPlaceholder_whenThumbnailURLIsNil 15ms
โœ… IntExtensionsTests testOrdinal_FourAndAbove_ReturnsTh 5ms
โœ… IntExtensionsTests testOrdinal_TwentyFirstPattern_ReturnsCorrectSuffix 3ms
โœ… IntExtensionsTests testOrdinal_Zero_ReturnsZeroth 3ms
โœ… IntExtensionsTests testOrdinal_followsEnglishOrdinalRules_includingTeenExceptions 28ms
โœ… IsReaderActiveTrackingModifierTests testIsReaderActiveTrackingModifier_isConstructibleWithPresenter 66ms
โœ… IsReaderActiveTrackingModifierTests testTracksReaderActiveExtension_appliesModifierToView 5ms
โœ… IsReaderActiveTrackingModifierTests testTracksReaderActive_setsFalseOnDisappear 132ms
โœ… IsReaderActiveTrackingModifierTests testTracksReaderActive_setsTrueOnAppear 386ms
โœ… KeyboardNavigationFKATests testFKA_escapeKey_isStillConsumed 9ms
โœ… KeyboardNavigationFKATests testFKA_leftArrow_isNotConsumed 9ms
โœ… KeyboardNavigationFKATests testFKA_pageDown_isStillConsumed 37ms
โœ… KeyboardNavigationFKATests testFKA_pageUp_isStillConsumed 8ms
โœ… KeyboardNavigationFKATests testFKA_rightArrow_isNotConsumed 14ms
โœ… KeyboardNavigationFKATests testFKA_spaceKey_isStillConsumed 5ms
โœ… KeyboardNavigationFKATests testHandleCommand_goBackward_navigatesLeft 4ms
โœ… KeyboardNavigationFKATests testHandleCommand_goForward_navigatesRight 8ms
โœ… KeyboardNavigationFKATests testHandleCommand_toggleUI_togglesToolbar 5ms
โœ… KeyboardNavigationFKATests testHandleKeyEvent_whenNavigableIsNil_returnsFalse 8ms
โœ… KeyboardNavigationFKATests testNoFKA_rightArrow_isConsumed 8ms
โœ… KeyboardNavigationHandlerTests testArrowKeyRelease_doesNotTurnPage 5ms
โœ… KeyboardNavigationHandlerTests testArrowKey_withCommandModifier_doesNotTurnPage 7ms
โœ… KeyboardNavigationHandlerTests testArrowKey_withShiftModifier_doesNotTurnPage 7ms
โœ… KeyboardNavigationHandlerTests testEscapeKeyRelease_doesNotToggleToolbar 7ms
โœ… KeyboardNavigationHandlerTests testEscapeKey_whenToolbarHidden_togglesToolbar 12ms
โœ… KeyboardNavigationHandlerTests testEscapeKey_whenToolbarVisible_togglesToolbar 7ms
โœ… KeyboardNavigationHandlerTests testEscapeKey_withModifier_doesNotToggleToolbar 9ms
โœ… KeyboardNavigationHandlerTests testLeftArrow_whenToolbarHidden_goesToPreviousPage 6ms
โœ… KeyboardNavigationHandlerTests testLeftArrow_whenToolbarVisible_doesNotChangePage 7ms
โœ… KeyboardNavigationHandlerTests testPageDown_whenToolbarHidden_advancesPage 5ms
โœ… KeyboardNavigationHandlerTests testPageUp_whenToolbarHidden_goesBackward 5ms
โœ… KeyboardNavigationHandlerTests testRightArrow_whenToolbarHidden_advancesToNextPage 5ms
โœ… KeyboardNavigationHandlerTests testRightArrow_whenToolbarVisible_doesNotChangePage 12ms
โœ… KeyboardNavigationHandlerTests testSpaceKey_whenToolbarHidden_advancesPage 7ms
โœ… KeyboardNavigationHandlerTests testSpaceKey_whenToolbarVisible_doesNotAdvancePage 7ms
โœ… KeyboardNavigationHandlerTests testUnhandledKey_isNotConsumed 7ms
โœ… KeyboardVoiceOverTests testEscapeKey_respectsVoiceOverToolbarBehavior 4ms
โœ… KeyboardVoiceOverTests testKeyboardHandler_doesNotBlockAccessibilityNotifications 7ms
โœ… KeyboardVoiceOverTests testKeyboardNavigation_worksRegardlessOfVoiceOverState 6ms
โœ… KeyboardVoiceOverTests testReaderViewController_voiceOverObserverExists 11ms
โœ… KeyboardVoiceOverTests testTouchNavigation_notAffectedByKeyboardSupport 3ms
โœ… LCPAcquisitionPredicateTests testHasLCPAcquisition_audiobookContentType_required 10ms
โœ… LCPAcquisitionPredicateTests testHasLCPAcquisition_nestedLCPInIndirectChain_returnsTrue 4ms
โœ… LCPAcquisitionPredicateTests testHasLCPAcquisition_noLCPAnywhere_returnsFalse 6ms
โœ… LCPAcquisitionPredicateTests testHasLCPAcquisition_topLevelLCPMime_returnsTrue 4ms
โœ… LCPAdapterTests testCanHandle_marketplaceJSONFeedFixture_returnsTrue 12ms
โœ… LCPAdapterTests testCanHandle_openAccessAudiobook_returnsFalse 3ms
โœ… LCPAdapterTests testCanHandle_xmlFeedLCPFixture_returnsTrue 3ms
โœ… LCPAdapterTests testResolveManifest_lcpInstantiationFailure_failsWithLcpInstantiationFailed 5ms
โœ… LCPAdapterTests testResolveManifest_licenseFileExists_usesLicenseFile 12ms
โœ… LCPAdapterTests testResolveManifest_localLCPAFile_usesLocalFile 64ms
โœ… LCPAdapterTests testResolveManifest_neitherLocalNorLicense_redownloadsLicense 12ms
โœ… LCPAdapterTests testResolveManifest_redownloadFailure_failsWithLicenseDownloadFailed 9ms
โœ… LCPAudiobookURLSchemeTests testHTTPURLConversion_toReadiumLCPScheme 3ms
โœ… LCPAudiobookURLSchemeTests testReadiumLCPScheme_isCorrect 3ms
โœ… LCPAudiobookURLSchemeTests testReadiumLCPURL_preservesPath 2ms
โœ… LCPAudiobookURLSchemeTests testReadiumLCPURL_preservesQueryParameters 3ms
โœ… LCPAudiobooksTests testCachedContentDictionary_initiallyReturnsNil 4ms
โœ… LCPAudiobooksTests testCanOpenBook_withEpub_returnsFalse 6ms
โœ… LCPAudiobooksTests testCanOpenBook_withLCPAudiobook_returnsTrue 7ms
โœ… LCPAudiobooksTests testCanOpenBook_withNonLCPAudiobook_returnsFalse 6ms
โœ… LCPAudiobooksTests testCanOpenBook_withPDF_returnsFalse 8ms
โœ… LCPAudiobooksTests testCancelPrefetch_doesNotCrash 3ms
โœ… LCPAudiobooksTests testCancelPrefetch_withoutStart_doesNotCrash 4ms
โœ… LCPAudiobooksTests testContentDictionary_afterRelease_failsFast 8ms
โœ… LCPAudiobooksTests testDecrypt_afterRelease_failsFast 6ms
โœ… LCPAudiobooksTests testGetPublication_initiallyReturnsNil 3ms
โœ… LCPAudiobooksTests testInit_withLcplLicenseURL_setsLicenseUrl 3ms
โœ… LCPAudiobooksTests testInit_withNilURL_returnsNil 42ms
โœ… LCPAudiobooksTests testInit_withSeparateLicenseURL_acceptsBothURLs 3ms
โœ… LCPAudiobooksTests testInit_withValidFileURL_createsInstance 3ms
โœ… LCPAudiobooksTests testInit_withValidHTTPURL_createsInstance 6ms
โœ… LCPAudiobooksTests testReleaseResources_canBeCalledMultipleTimes 5ms
โœ… LCPAudiobooksTests testReleaseResources_cancelsPrefetch 3ms
โœ… LCPAudiobooksTests testReleaseResources_clearsPublication 3ms
โœ… LCPAudiobooksTests testStartPrefetch_afterRelease_isNoOp 13ms
โœ… LCPAudiobooksTests testStartPrefetch_doesNotCrash 4ms
โœ… LCPAudiobooksTests testSupportsStreaming_returnsTrue 4ms
โœ… LCPBotanCRLGuardTests testCreateContext_WithGarbageJSONLicense_ThrowsRatherThanReturningNilSilently 5ms
โœ… LCPBotanCRLGuardTests testDecryptExtension_WithEmptyData_ReturnsNil 5ms
โœ… LCPBotanCRLGuardTests testDecryptExtension_WithoutContext_ReturnsNil 5ms
โœ… LCPBotanCRLGuardTests testDecrypt_WithEmptyData_ReturnsNilWithoutCallingR2LCPClient 4ms
โœ… LCPBotanCRLGuardTests testDecrypt_WithNonDRMContext_ReturnsNilWithoutCallingR2LCPClient 44ms
โœ… LCPCharacterizationTests test_LCPLibraryService_canFulfill_acceptsLcplExtensionCaseInsensitively 5ms
โœ… LCPCharacterizationTests test_LCPLibraryService_canFulfill_rejectsEpubAndPdf 5ms
โœ… LCPCharacterizationTests test_LCPLibraryService_licenseExtensionConstant_isLcpl 4ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_extractsPublicationLink_byRel 6ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_parsesLinkOptionalFields_preservesNils 4ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_parsesMinimalValidJSON_succeeds 6ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_returnsNil_onCompletelyMalformedJSON 4ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_returnsNil_onEmptyFile 3ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_returnsNil_onMissingRequiredId 3ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_returnsNil_whenFileDoesNotExist 4ms
โœ… LCPCharacterizationTests test_TPPLCPLicense_returnsNil_whenRelNotFound 23ms
โœ… LCPCharacterizationTests test_TPPLicensesServiceError_descriptionExposesMessage 5ms
โœ… LCPCharacterizationTests test_TPPLicensesService_acquirePublication_invalidLicense_callsCompletionWithLicenseError 7ms
โœ… LCPCharacterizationTests test_TPPLicensesService_acquirePublication_missingPublicationLink_failsWithDistinctMessage 6ms
โœ… LCPCharacterizationTests test_createContext_emptyPemCrl_isAcceptedByHeaderGuard 21ms
โœ… LCPCharacterizationTests test_createContext_jsonContentTypeRejected_atHeaderGuard 4ms
โœ… LCPCharacterizationTests test_createContext_prefixCappedAt40Chars_preventsLogSpam 4ms
โœ… LCPCharacterizationTests test_createContext_whitespacePadding_isTrimmedBeforeHeaderCheck 3ms
โœ… LCPCharacterizationTests test_decryptExtensionOverload_noPriorContext_returnsNil 4ms
โœ… LCPCharacterizationTests test_decrypt_emptyData_returnsNil_priorToReachingR2LCPClient 2ms
โœ… LCPCharacterizationTests test_decrypt_nonDRMContext_returnsNil_priorToForceCastingInsideR2LCPClient 4ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_emptyHashedPassphrasesArray_returnsNilWithoutCrashing 18ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_extremelyLongPassphrase_isHandledWithoutCrashing 5ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_garbageJSON_returnsNilWithoutCrashing 8ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_multipleGarbageInputs_returnsConsistentNil 7ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_passphraseContainingNUL_isHandledWithoutCrashing 5ms
โœ… LCPCharacterizationTests test_findOneValidPassphrase_passphraseContainingUTF8_isHandledWithoutCrashing 10ms
โœ… LCPCharacterizationTests test_pathInZip_returnsNilForUnknownContentType 2ms
โœ… LCPCharacterizationTests test_pathInZip_returnsNilWhenTypeIsMissing 2ms
โœ… LCPCharacterizationTests test_pathInZip_routesAudiobookLCPToRootPath 4ms
โœ… LCPCharacterizationTests test_pathInZip_routesEpubToMetaInfPath 3ms
โœ… LCPClientTests test_createContext_botanThrowsDecoding_isCaughtByObjCExceptionWrapper 6ms
โœ… LCPClientTests test_createContext_invalidPemCrl_throwsInvalidPemCrl 3ms
โœ… LCPClientTests test_createContext_validHeaderGarbageJSON_throwsRatherThanReturningNilSilently 5ms
โœ… LCPClientTests test_decryptExtension_withEmptyData_returnsNil 3ms
โœ… LCPClientTests test_decryptExtension_withoutContext_returnsNil 5ms
โœ… LCPClientTests test_decrypt_emptyData_returnsNil 6ms
โœ… LCPClientTests test_decrypt_nonDRMContext_returnsNilWithoutCallingR2LCPClient 5ms
โœ… LCPClientTests test_findOneValidPassphrase_garbageLicenseJSON_returnsNilWithoutCrashing 11ms
โœ… LCPFulfillmentHandlerTests testFulfill_audiobook_inUsedState_secondaryDownloadError_doesNotFlipToFailed 265ms
โœ… LCPFulfillmentHandlerTests testFulfill_audiobook_marksDownloadSuccessfulEvenBeforeCompletion 36ms
โœ… LCPFulfillmentHandlerTests testFulfill_audiobook_secondaryDownloadError_doesNotFlipStreamingReadyBook 266ms
โœ… LCPFulfillmentHandlerTests testFulfill_completionWithError_publishesFulfilmentErrorAlert 54ms
โœ… LCPFulfillmentHandlerTests testFulfill_completionWithoutLocalURL_publishesNoLocalURLAlert 35ms
โœ… LCPFulfillmentHandlerTests testFulfill_epub_secondaryDownloadError_stillSurfacesAlert 37ms
โœ… LCPFulfillmentHandlerTests testFulfill_invokesLCPServiceWithRenamedLicenseURL 11ms
โœ… LCPFulfillmentHandlerTests testFulfill_storesReturnedDownloadTaskInStateManager 45ms
โœ… LCPKeychainMigrationTests testRunIfNeeded_whenFlagAlreadySet_skipsMigration 34ms
โœ… LCPKeychainMigrationTests testRunIfNeeded_whenFlagUnset_runsMigrationAndSetsFlag 9ms
โœ… LCPKeychainMigrationTests testRunIfNeeded_whenMigrationThrows_leavesFlagUnsetAndRetriesNextTime 7ms
โœ… LCPLibraryServiceTests testCanFulfill_withAudiobookExtension_returnsFalse 2ms
โœ… LCPLibraryServiceTests testCanFulfill_withEpubExtension_returnsFalse 5ms
โœ… LCPLibraryServiceTests testCanFulfill_withLcpaExtension_returnsFalse 2ms
โœ… LCPLibraryServiceTests testCanFulfill_withLcplExtension_returnsTrue 5ms
โœ… LCPLibraryServiceTests testCanFulfill_withMixedCaseLcplExtension_returnsTrue 3ms
โœ… LCPLibraryServiceTests testCanFulfill_withNoExtension_returnsFalse 4ms
โœ… LCPLibraryServiceTests testCanFulfill_withPdfExtension_returnsFalse 15ms
โœ… LCPLibraryServiceTests testCanFulfill_withUppercaseLcplExtension_returnsTrue 2ms
โœ… LCPLibraryServiceTests testContentProtection_isAvailable 10ms
โœ… LCPLibraryServiceTests testContentProtection_multipleAccess_returnsValue 31ms
โœ… LCPLibraryServiceTests testDecrypt_withEmptyData_returnsNil 3ms
โœ… LCPLibraryServiceTests testDecrypt_withInvalidData_returnsNil 3ms
โœ… LCPLibraryServiceTests testDecrypt_withSmallData_returnsNil 11ms
โœ… LCPLibraryServiceTests testFulfillAsync_withEmptyPath_throwsError 80ms
โœ… LCPLibraryServiceTests testFulfillAsync_withInvalidURL_throwsError 8ms
โœ… LCPLibraryServiceTests testFulfill_reportsProgress 13ms
โœ… LCPLibraryServiceTests testFulfill_withNonExistentFile_callsCompletionWithError 13ms
โœ… LCPLibraryServiceTests testInit_createsInstance 6ms
โœ… LCPLibraryServiceTests testInit_multipleInstances_areIndependent 4ms
โœ… LCPLibraryServiceTests testLicenseExtension_isLcpl 5ms
โœ… LCPLicenseDocumentDetectionTests testLCPLicenseDocument_doesNotContainManifestKeys 2ms
โœ… LCPLicenseDocumentDetectionTests testLCPLicenseDocument_isNotDetectedAsBearerToken 3ms
โœ… LCPLicenseDocumentDetectionTests testLCPLicenseDocument_isValidJSON 7ms
โœ… LCPLicenseDocumentDetectionTests testLCPLicenseDocument_parsedAsManifest_lacksReadingOrder 3ms
โœ… LCPLicenseDocumentDetectionTests testLCPLicenseDocument_withMinimalFields_isNotBearerToken 3ms
โœ… LCPLicenseFilePathTests testLCPLicenseExtension_isLcpl 5ms
โœ… LCPLicenseFilePathTests testLCPLicensePath_derivedFromContentPath 5ms
โœ… LCPLicenseFilePathTests testLCPLicensePath_everyContentExtensionProducesLcplSibling 6ms
โœ… LCPOrphanedDownloadRegistryTests testBookState_downloadSuccessful_withExistingFile_staysDownloadSuccessful 12ms
โœ… LCPOrphanedDownloadRegistryTests testBookState_downloadSuccessful_withMissingFile_transitionsToDownloadNeeded 6ms
โœ… LCPOrphanedDownloadRegistryTests testLCPAudiobook_withBothFiles_remainsDownloadSuccessful 6ms
โœ… LCPOrphanedDownloadRegistryTests testLCPAudiobook_withOnlyLicense_shouldBeConsideredMissing 11ms
โœ… LCPPDFAcquisitionPredicateTests testHasLCPAcquisition_nestedLCPInIndirectChain_returnsTrue 3ms
โœ… LCPPDFAcquisitionPredicateTests testHasLCPAcquisition_noLCPAnywhere_returnsFalse 3ms
โœ… LCPPDFAcquisitionPredicateTests testHasLCPAcquisition_pdfContentType_required 5ms
โœ… LCPPDFAcquisitionPredicateTests testHasLCPAcquisition_siblingLCPAcquisition_returnsTrue 3ms
โœ… LCPPDFAcquisitionPredicateTests testHasLCPAcquisition_topLevelLCPMime_returnsTrue 4ms
โœ… LCPPDFDiskExtractTests testCachedURL_noFileOnDisk_returnsNil 9ms
โœ… LCPPDFDiskExtractTests testCachedURL_partialWriteWithGoodHeader_stillRejected 12ms
โœ… LCPPDFDiskExtractTests testCachedURL_undersizedFile_returnsNilAndDeletesFile 28ms
โœ… LCPPDFDiskExtractTests testCachedURL_validPDFHeaderAndSize_returnsURL 18ms
โœ… LCPPDFDiskExtractTests testCachedURL_wrongMagicBytes_returnsNilAndDeletesFile 22ms
โœ… LCPPDFOpenProgressTests testBegin_clearsCountersFromPreviousOpen 13ms
โœ… LCPPDFOpenProgressTests testBegin_setsPhaseAndIdentifierAndZeroesCounters 41ms
โœ… LCPPDFOpenProgressTests testFinish_resetsToIdleAndClearsIdentifier 16ms
โœ… LCPPDFOpenProgressTests testPercentComplete_clampsAt99NotAt100 9ms
โœ… LCPPDFOpenProgressTests testPercentComplete_withByteTotal_returnsTrueRatio 14ms
โœ… LCPPDFOpenProgressTests testPercentComplete_withoutByteTotal_usesDecryptCurve 58ms
โœ… LCPPDFOpenProgressTests testPercentComplete_zeroProgress_isZero 18ms
โœ… LCPPDFOpenProgressTests testRecordDecrypt_autoTransitionsFromOpeningPublicationToDecrypting 29ms
โœ… LCPPDFOpenProgressTests testRecordDecrypt_fromCache_incrementsCachedHitsNotBlocks 29ms
โœ… LCPPDFOpenProgressTests testRecordDecrypt_incrementsBlocksAndBytes 16ms
โœ… LCPPDFOpenProgressTests testRecordDecrypt_whenIdle_doesNothing 12ms
โœ… LCPPDFOpenProgressTests testRecordExtractedBytes_incrementsBytesAndTransitionsPhase 17ms
โœ… LCPPDFOpenProgressTests testRoundTrip_beginWorkFinishBegin_endsAtCleanState 10ms
โœ… LCPPassphraseReadinessTests testReadiness_underDetailsFailed_returnsNil 3ms
โœ… LCPPassphraseReadinessTests testReadiness_underDetailsLoading_doesNotShortCircuitOnNilLoansUrl 9ms
โœ… LCPSessionIdentifierTests testSessionIdentifier_isDifferentForDifferentURLs 2ms
โœ… LCPSessionIdentifierTests testSessionIdentifier_isSameAcrossMultipleComputations 9ms
โœ… LCPSessionIdentifierTests testURLHashValue_isNotStableAcrossComputations 22ms
โœ… LegacySAMLProblemDocumentPropagationTests testSAMLPresenter_problemDocumentNil_firesDelegateWithGenericFallback 104ms
โœ… LegacySAMLProblemDocumentPropagationTests testSAMLPresenter_problemDocumentTitleOnly_surfacesWithFallbackMessage 437ms
โœ… LegacySAMLProblemDocumentPropagationTests testSAMLPresenter_problemDocumentWithTitleAndDetail_surfacesToUIDelegate 104ms
โœ… LegacySAMLProblemDocumentPropagationTests testSAMLPresenter_problemDocument_errorDomainIdentifiesSAMLPath 107ms
โœ… LegacySAMLProblemDocumentPropagationTests testSAMLPresenter_problemHandler_businessLogicReleased_doesNotCrash 103ms
โœ… LegacySAMLProblemDocumentPropagationTests testSignInBusinessLogic_pinAllowsAlphanumeric_isNumericNegation 85ms
โœ… LegacySAMLProblemDocumentPropagationTests testSignInBusinessLogic_usernameIsEmailKeyboard_matchesAuthKeyboard 109ms
โœ… LibrariesSectionViewModelTests test_deleteSecondary_callsTokenDeleter_andRemovesAccount_andPersists 4ms
โœ… LibrariesSectionViewModelTests test_deleteSecondary_noOpsOnCurrentAccount 3ms
โœ… LibrariesSectionViewModelTests test_presentAddLibrary_flipsSheetBool 3ms
โœ… LibrariesSectionViewModelTests test_refresh_doesNotPersist_whenNoStaleUUIDs 2ms
โœ… LibrariesSectionViewModelTests test_refresh_filtersUUIDsNotInRegistry_andPersistsCleanedList 3ms
โœ… LibrariesSectionViewModelTests test_refresh_putsCurrentAccountFirstAndSortsOthersByName 3ms
โœ… LibrariesSectionViewModelTests test_refresh_withNoCurrentAccount_sortsAllAlphabetically 4ms
โœ… LibrariesSectionViewModelTests test_switchToAccount_callsEnvironment_andUpdatesCurrentUUID_andResortsAccounts 9ms
โœ… LibrariesSectionViewModelTests test_switchToAccount_firesCompletion_andClearsIsSwitching_whenEnvironmentReportsReady 9ms
โœ… LibrariesSectionViewModelTests test_switchToAccount_isNoOpForCurrentAccount 3ms
โœ… LibrariesSectionViewModelTests test_switchToAccount_newlyAddedAccount_insertsItFirst_andFiresCompletion 8ms
โœ… LibraryCatalogMergerTests testMerge_EmptyExistingWithNewPublications_AddsAll 3ms
โœ… LibraryCatalogMergerTests testMerge_FullCrawl_RemovesAbsentPublications 6ms
โœ… LibraryCatalogMergerTests testMerge_FullCrawl_ReplacesAllWithUpdates 29ms
โœ… LibraryCatalogMergerTests testMerge_NewPublication_AppendsToList 8ms
โœ… LibraryCatalogMergerTests testMerge_PreservesUnmodifiedPublications_InIncrementalMode 18ms
โœ… LibraryCatalogMergerTests testMerge_UpdatesExistingByID_ReplacesOldPublication 4ms
โœ… LibraryCatalogMergerTests testMerge_uuidsWithChangedLogos_includesAllTransitionsAndExcludesUnchangedURL 7ms
โœ… LibraryCatalogMergerTests testSerializeAsCatalogsFeed_PreservesPublicationIDs 5ms
โœ… LibraryCatalogMergerTests testSerializeAsCatalogsFeed_ProducesValidJSON 3ms
โœ… LibraryRegistryCrawlerTests testCrawl_HandlesNetworkFailure_ReturnsFailure 4ms
โœ… LibraryRegistryCrawlerTests testCrawl_PersistsCurrentAppVersion 7ms
โœ… LibraryRegistryCrawlerTests testCrawl_ReportsProgress 11ms
โœ… LibraryRegistryCrawlerTests testCrawl_SavesCrawlState_OnSuccess 9ms
โœ… LibraryRegistryCrawlerTests testCrawl_WhenAppVersionChanged_HitsCrawlableURL_NotFacetURL 7ms
โœ… LibraryRegistryCrawlerTests testCrawl_WhenFacetNotActive_StoresFacetURLForFutureUse 8ms
โœ… LibraryRegistryCrawlerTests testCrawl_WhenLastFullCrawlOlderThan7Days_HitsCrawlableURL 38ms
โœ… LibraryRegistryCrawlerTests testCrawl_WhenLastFullCrawlWithin7Days_UsesFacetURL 8ms
โœ… LibraryRegistryCrawlerTests testFirstLaunch_PerformsFullCrawl_PaginatesAllPages 9ms
โœ… LibraryRegistryCrawlerTests testFirstLaunch_PerformsFullCrawl_SinglePage 9ms
โœ… LibraryRegistryCrawlerTests testFullCrawl_WhenNoOrderModifiedFacet_FetchesAllPages 6ms
โœ… LibraryRegistryCrawlerTests testIncrementalCrawl_ReachingEndOfFeed_ReconcilesDeletions 18ms
โœ… LibraryRegistryCrawlerTests testIncrementalCrawl_StopsAtLastCrawlTimestamp 9ms
โœ… LibraryRegistryCrawlerTests testIncrementalCrawl_WhenNotReachingEndOfFeed_PreservesExistingEntries 11ms
โœ… LicensesServiceTests testAcquirePublication_WithInvalidLCPLFile_CompletesWithError 5ms
โœ… LicensesServiceTests testAcquirePublication_WithNonexistentFile_CompletesWithError 10ms
โœ… LicensesServiceTests testLicensesServiceError_licenseError_exposesMessageViaDescriptionVerbatim 2ms
โœ… LicensesServiceTests testPathInZip_mapsEveryContentTypeToTheCorrectPath 2ms
โŠ˜ LiveCrawlableParsingTest testCrawlableURL_FromBetaURL 4ms
โŠ˜ LiveCrawlableParsingTest testCrawlableURL_FromProdURL 14ms
โŠ˜ LiveCrawlableParsingTest testFullCrawl_LiveEndpoint 4ms
โŠ˜ LiveCrawlableParsingTest testParseLiveCrawlableFeed 5ms
โœ… LocalBookContentServiceTests testDeleteForBook_accountOverride_passedThroughToBookFileManager 14ms
โœ… LocalBookContentServiceTests testDeleteForBook_epub_missingFile_logsButDoesNotThrow 14ms
โœ… LocalBookContentServiceTests testDeleteForBook_epub_removesFileWhenPresent 7ms
โœ… LocalBookContentServiceTests testDeleteForBook_pdf_removesContentFile 29ms
โœ… LocalBookContentServiceTests testDeleteForBook_unresolvableFileURL_doesNotCrashAndLogsWarning 134ms
โœ… LocalBookContentServiceTests testDeleteForIdentifier_lookUpsBookInRegistryAndDelegates 12ms
โœ… LocalBookContentServiceTests testDeleteForIdentifier_unknownIdentifier_logsAndDoesNothing 10ms
โœ… LocalFileAdapterTests testCanHandle_localFileExists_returnsTrue 5ms
โœ… LocalFileAdapterTests testCanHandle_noLocalFile_returnsFalse 17ms
โŠ˜ LocalFileAdapterTests testResolveManifest_bearerTokenFulfillURL_refreshesTokenBeforeReturn 9ms
โœ… LocalFileAdapterTests testResolveManifest_noBearerTokenFulfillURL_skipsRefresh 7ms
โœ… LocalFileAdapterTests testResolveManifest_unreadableFile_failsWithManifestParseFailed 10ms
โœ… LocalFileAdapterTests testResolveManifest_validJSON_succeeds 37ms
โœ… LogTests testDateFormatter_isConfigured 5ms
โœ… LogTests testDebug_doesNotCrash 3ms
โœ… LogTests testDebug_doesNotPersistToLogger 113ms
โœ… LogTests testError_doesNotCrash 3ms
โœ… LogTests testError_persistsToLogger 32ms
โœ… LogTests testFault_doesNotCrash 4ms
โœ… LogTests testFault_persistsToLogger 37ms
โœ… LogTests testInfo_doesNotCrash 27ms
โœ… LogTests testInfo_doesNotPersistToLogger 114ms
โœ… LogTests testLog_objcCompatibility_doesNotCrash 6ms
โœ… LogTests testLog_withFilePathTag_trimsProperly 36ms
โœ… LogTests testSubsystem_isCorrectValue 2ms
โœ… LogTests testSubsystem_isNotEmpty 3ms
โœ… LogTests testWarn_doesNotCrash 3ms
โœ… LoginKeyboardTests testInit_WithCaseSensitiveString_ReturnsNil 15ms
โœ… LoginKeyboardTests testInit_WithDefaultString_ReturnsStandard 8ms
โœ… LoginKeyboardTests testInit_WithEmailString_ReturnsEmail 2ms
โœ… LoginKeyboardTests testInit_WithEmptyString_ReturnsNil 3ms
โœ… LoginKeyboardTests testInit_WithInvalidString_ReturnsNil 7ms
โœ… LoginKeyboardTests testInit_WithNilString_ReturnsNil 34ms
โœ… LoginKeyboardTests testInit_WithNoInputString_ReturnsNone 77ms
โœ… LoginKeyboardTests testInit_WithNumberPadString_ReturnsNumeric 2ms
โœ… MainActorHelpersTests testBarrierExecutor_Modify_TransformsValue 5ms
โœ… MainActorHelpersTests testBarrierExecutor_ReadInitialValue 8ms
โœ… MainActorHelpersTests testBarrierExecutor_Write_UpdatesValue 7ms
โœ… MainActorHelpersTests testDebouncer_Cancel_PreventsExecution 108ms
โœ… MainActorHelpersTests testDebouncer_OnlExecutesLastCall 163ms
โœ… MainActorHelpersTests testOnceExecutor_ExecutesOnlyOnce 4ms
โœ… MainActorHelpersTests testOnceExecutor_Reset_AllowsReExecution 8ms
โœ… MainActorHelpersTests testRunParallelFireAndForget_EmptyArray_CompletesImmediately 8ms
โœ… MainActorHelpersTests testRunParallelFireAndForget_ExecutesAllTasks 5ms
โœ… MainActorHelpersTests testRunParallel_EmptyArray_ReturnsEmptyArray 9ms
โœ… MainActorHelpersTests testRunParallel_MultipleItems_ReturnsInOriginalOrder 59ms
โœ… MainActorHelpersTests testRunParallel_SingleItem_ReturnsSingleResult 13ms
โœ… MainActorHelpersTests testRunParallel_ThrowingTask_PropagatesError 8ms
โœ… MainActorHelpersTests testSerialExecutor_ExecutesInOrder 7ms
โœ… MainActorHelpersTests testSerialExecutor_WaitForAll_WaitsForCompletion 64ms
โœ… MainActorHelpersTests testTaskSleepSeconds_CompletesAfterDuration 59ms
โœ… MainActorHelpersTests testThrottler_AfterInterval_ExecutesAgain 108ms
โœ… MainActorHelpersTests testThrottler_FirstCall_ExecutesImmediately 6ms
โœ… MainActorHelpersTests testThrottler_RapidCalls_SkipsSubsequent 9ms
โœ… MainActorHelpersTests testWithAsyncCallback_ConvertsCallbackToAsync 12ms
โœ… MainActorHelpersTests testWithAsyncThrowingCallback_Failure_ThrowsError 17ms
โœ… MainActorHelpersTests testWithAsyncThrowingCallback_Success_ReturnsValue 6ms
โœ… MappedCatalogBridgeTests testToCatalogContent_EmptyFeed 6ms
โœ… MappedCatalogBridgeTests testToCatalogContent_GroupedFeed 15ms
โœ… MappedCatalogBridgeTests testToCatalogContent_UngroupedFeed 8ms
โœ… MappedCatalogModelTests testEdgeCase_EmptyTitle 3ms
โœ… MappedCatalogModelTests testEdgeCase_LongTitle 4ms
โœ… MappedCatalogModelTests testEdgeCase_ManyLanes 3ms
โœ… MappedCatalogModelTests testEdgeCase_ManyUngroupedBooks 529ms
โœ… MappedCatalogModelTests testInit_CompleteFeedWithAllComponents 11ms
โœ… MappedCatalogModelTests testInit_EmptyFeed 6ms
โœ… MappedCatalogModelTests testInit_GroupedFeedWithLanes 6ms
โœ… MappedCatalogModelTests testInit_StoresAllProperties 5ms
โœ… MappedCatalogModelTests testInit_UngroupedFeedWithBooks 16ms
โœ… MappedCatalogModelTests testInit_WithEntryPoints 5ms
โœ… MappedCatalogModelTests testInit_WithFacetGroups 3ms
โœ… MockBackendExpiredCredentialsTests testBorrow_Returns403 61ms
โœ… MockBackendExpiredCredentialsTests testCatalog_StillReturns200 223ms
โœ… MockBackendExpiredCredentialsTests testLoans_Returns403WithProblemDocument 46ms
โœ… MockBackendIntegrationTests testBorrow_Returns201 11ms
โœ… MockBackendIntegrationTests testFetchAnnotations_ReturnsAnnotations 32ms
โœ… MockBackendIntegrationTests testFetchAuthDocument_ParsesCorrectly 119ms
โœ… MockBackendIntegrationTests testFetchCatalog_ReturnsParsedFeed 109ms
โœ… MockBackendLoanLimitTests testBorrow_Returns403WithLoanLimitProblem 63ms
โœ… MockBackendLoanLimitTests testCatalogBrowsing_StillWorks 48ms
โœ… MockBackendRouteMatchingTests testRouteMatching_CatchAll 3ms
โœ… MockBackendRouteMatchingTests testRouteMatching_ExactPath 4ms
โœ… MockBackendRouteMatchingTests testRouteMatching_MethodFilter 2ms
โœ… MockBackendRouteMatchingTests testScenarioLoading 17ms
โœ… MockBackendServerDownTests testAllEndpoints_Return502 25ms
โœ… MockIsolationLintTests testEveryFileWithCancellables_tearsThemDown 1.38s
โœ… MockIsolationLintTests testEveryFileWithNotificationObserver_removesIt 374ms
โœ… MockIsolationLintTests testEveryFileWithSharedSingleton_hasResetShared 470ms
โœ… MockIsolationLintTests testLintAcceptsInheritedTearDown 10ms
โœ… MockIsolationLintTests testLintCatchesSyntheticViolator 4ms
โœ… MultiLibraryTokenIsolationTests test_CancelNonEssential_ClearsTheRegistry 11ms
โœ… MultiLibraryTokenIsolationTests test_CancelNonEssential_PreservesAudiobookTasks 10ms
โœ… MultiLibraryTokenIsolationTests test_GET_ForLibraryB_SendsBBearerOverWire 14ms
โœ… MultiLibraryTokenIsolationTests test_POST_ToLibraryB_CarriesBBearerAndBody 123ms
โœ… MultiLibraryTokenIsolationTests test_ProblemDocument_RecoverableVsUnrecoverableAuthError 35ms
โœ… MultiLibraryTokenIsolationTests test_Reachability_IsStableAcrossAdjacentReads 11ms
โœ… MultiLibraryTokenIsolationTests test_Refresh401WithProblemDocument_EmbedsDocumentInError 24ms
โœ… MultiLibraryTokenIsolationTests test_Refresh401_NoProblemDoc_HasNilProblemDocument 82ms
โœ… MultiLibraryTokenIsolationTests test_RefreshA_401_MarksOnlyAStale_NotB 30ms
โœ… MultiLibraryTokenIsolationTests test_RefreshForA_AfterSwitchToB_StillHitsAsTokenURL 21ms
โœ… MultiLibraryTokenIsolationTests test_RefreshForA_DoesNotMutateBToken 25ms
โœ… MultiLibraryTokenIsolationTests test_RequestForA_CarriesABearer 22ms
โœ… MultiLibraryTokenIsolationTests test_RequestForB_CarriesBBearer_NotA 8ms
โœ… MultiLibraryTokenIsolationTests test_SwitchCurrency_PreservesBothBearers 37ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testBearerAuthorized_explicitAccountId_appliesTokenForThatAccount 4ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testBearerAuthorized_explicitAccountId_doesNotTouchAppContainerProduction 5ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testBearerAuthorized_nilAccountId_delegatesToResolver 4ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testStartDownload_capturesCurrentAccountIdOnce_doesNotReResolve 21ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testStartDownload_currentAccountIdChangesAfterCapture_originalIdUsedForRequests 9ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests testStartDownload_currentAccountIdNilAtCapture_capturesSentinelUUID 72ms
โœ… MyBooksDownloadCenterAdeptGapTests testDownloadCenter_bookStateTransitions_downloadSuccess 5ms
โœ… MyBooksDownloadCenterAdeptGapTests testDownloadCenter_bookStateTransitions_forAdobeAdeptBooks 5ms
โœ… MyBooksDownloadCenterAdeptGapTests testDownloadCenter_downloadProgressPublisher_exists 4ms
โœ… MyBooksDownloadCenterConcurrencyTests testCanStartDownload_returnsTrueOnlyStrictlyBelowMaxConcurrent 9ms
โœ… MyBooksDownloadCenterConcurrencyTests testCancellation_OfActiveDownload_FreesSlotAndSchedulesPendingStarts 52ms
โœ… MyBooksDownloadCenterConcurrencyTests testCancellation_OfActiveDownload_PromotesNextQueuedBook 43ms
โœ… MyBooksDownloadCenterConcurrencyTests testColdStart_ofCoordinator_HasNoActiveOrQueuedDownloads 12ms
โœ… MyBooksDownloadCenterConcurrencyTests testCompletion_PromotesNextQueuedToActive 25ms
โœ… MyBooksDownloadCenterConcurrencyTests testConcurrentEnqueueFromManyTasks_IsActorSerialized 77ms
โœ… MyBooksDownloadCenterConcurrencyTests testDequeuePending_RemovesBooksInFIFOOrder 25ms
โœ… MyBooksDownloadCenterConcurrencyTests testDequeuePending_zeroCapacity_returnsEmptyAndPreservesQueue 10ms
โœ… MyBooksDownloadCenterConcurrencyTests testEnqueuePending_isDedupedByBookIdentifier 26ms
โœ… MyBooksDownloadCenterConcurrencyTests testFailure_FreesSlot_AndPromotesQueuedBook 11ms
โœ… MyBooksDownloadCenterConcurrencyTests testForegroundReapplyOfCap_AlwaysPumpsThePendingQueue 46ms
โœ… MyBooksDownloadCenterConcurrencyTests testQueueOrdering_FIFOSurvivesInterleavedEnqueueAndDequeue 38ms
โœ… MyBooksDownloadCenterConcurrencyTests testRedirectAttempts_perTaskIsolated_andClearable 7ms
โœ… MyBooksDownloadCenterConcurrencyTests testRegisterCompletion_RemovesOnlyTheNamedIdentifier 7ms
โœ… MyBooksDownloadCenterConcurrencyTests testRegisterCompletion_unknownIdentifier_isSafeNoOp 21ms
โœ… MyBooksDownloadCenterConcurrencyTests testReset_ClearsActive_Queue_Cache_AndRedirectAttempts 17ms
โœ… MyBooksDownloadCenterConcurrencyTests testSchedulePendingStartsAsync_HonorsRemainingCapacity_NotQueueSize 29ms
โœ… MyBooksDownloadCenterConcurrencyTests testSchedulePendingStartsAsync_atCap_preservesQueueAndSkipsDelegate 20ms
โœ… MyBooksDownloadCenterConcurrencyTests testSchedulePendingStartsAsync_emptyQueue_doesNotInvokeDelegate 7ms
โœ… MyBooksDownloadCenterConcurrencyTests testStartingNPlus1Downloads_LeavesExactlyNActiveAnd1Queued 17ms
โœ… MyBooksDownloadCenterConcurrencyTests testThreeRoundTrips_eachCompletion_promotesExactlyOneQueuedBook 32ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_multipleBooksOverBudget_evictsLRUFirstAndFlipsAllAffected 24ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_preservesLcpAudiobook_butEvictsEpubCompanion 28ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_preservesLcpLicense 17ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_whenAddingAnticipatedBytesPushesOverBudget_makesRoom 14ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_whenOverBudget_deletesFileAndFlipsRegistryToDownloadNeeded 13ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_whenUnderBudget_doesNothing 44ms
โœ… MyBooksDownloadCenterEvictionTests testEviction_withOrphanFile_deletesButSkipsRegistryMutation 10ms
โœ… MyBooksDownloadCenterOfflineTests testCleanupDownload_RemovesTaskIdentifierToBookEntry 19ms
โœ… MyBooksDownloadCenterOfflineTests testInit_WithReachabilityConnected_DoesNotFailExistingDownloads 123ms
โœ… MyBooksDownloadCenterOfflineTests testReachabilityDrop_DuringActiveDownload_FailsBookWithinDeterministicWindow 58ms
โœ… MyBooksDownloadCenterOfflineTests testReachabilityDrop_DuringMultipleActiveDownloads_FailsEach 79ms
โœ… MyBooksDownloadCenterOfflineTests testReachabilityDrop_StaleAndActive_FailsOnlyTheActiveDownload 53ms
โœ… MyBooksDownloadCenterOfflineTests testReachabilityDrop_WithNoActiveDownloads_IsNoOp 65ms
โœ… MyBooksDownloadCenterOfflineTests testReachabilityDrop_WithStaleTaskEntryForDownloadedBook_DoesNotFlipToFailed 289ms
โœ… MyBooksDownloadCenterOfflineTests testStartDownload_WhenOffline_FailsImmediatelyWithoutSpawningTask 46ms
โœ… MyBooksDownloadSessionInvalidationTests testDownloadTask_onInvalidatedSession_isSafelyCatchable 8ms
โœ… MyBooksDownloadSessionInvalidationTests testDownloadTask_onLiveSession_returnsTaskWithoutException 3ms
โœ… MyBooksDownloadSessionInvalidationTests testExceptionCatcher_returnsNSException_insteadOfPropagating 7ms
โœ… MyBooksSimplifiedBearerTokenTests testFulfillURL_canBeSetAfterInit 6ms
โœ… MyBooksSimplifiedBearerTokenTests testFulfillURL_canBeSetViaInit 4ms
โœ… MyBooksSimplifiedBearerTokenTests testFulfillURL_defaultsToNil 3ms
โœ… MyBooksSimplifiedBearerTokenTests testIsExpired_exactlyNow_returnsTrue 5ms
โœ… MyBooksSimplifiedBearerTokenTests testIsExpired_futureExpiration_returnsFalse 3ms
โœ… MyBooksSimplifiedBearerTokenTests testIsExpired_pastExpiration_returnsTrue 3ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_acceptsExpirationKey 4ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_invalidLocationURL_returnsNil 15ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_missingAccessToken_returnsNil 16ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_missingExpiration_returnsNil 7ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_missingLocation_returnsNil 6ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_negativeExpiration_usesDistantFuture 3ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_validDictionary_createsToken 4ms
โœ… MyBooksSimplifiedBearerTokenTests testParsing_zeroExpiration_usesDistantFuture 10ms
โœ… MyBooksSimplifiedBearerTokenTests testRefreshToken_invalidJSON_returnsNil 22ms
โœ… MyBooksSimplifiedBearerTokenTests testRefreshToken_serverError_returnsNil 35ms
โœ… MyBooksSimplifiedBearerTokenTests testRefreshToken_success_returnsNewToken 17ms
โœ… MyBooksViewModelBooksPublisherTests testBooksPublisher_EmitsInitialValue 4ms
โœ… MyBooksViewModelBooksPublisherTests testBooksPublisher_EmitsOnFilter 14ms
โœ… MyBooksViewModelBooksPublisherTests testBooksPublisher_EmitsRestoredCountAfterReset 13ms
โœ… MyBooksViewModelConcurrencyTests testFilterBooks_MultipleCalls_EachProducesCorrectResult 43ms
โœ… MyBooksViewModelConcurrencyTests testFilterBooks_RapidChanges_SettlesOnLastQuery 114ms
โœ… MyBooksViewModelConcurrencyTests testLoadData_AfterInit_IsNotLoadingAndHasBooks 46ms
โœ… MyBooksViewModelConcurrencyTests testReloadData_WhenRegistryIdle_BookListRemainsAccessible 22ms
โœ… MyBooksViewModelDownloadStateTests testRegistryState_DownloadFailed_BookRemainsVisible 7ms
โœ… MyBooksViewModelDownloadStateTests testRegistryState_DownloadSuccessful_BookRemainsInList 8ms
โœ… MyBooksViewModelDownloadStateTests testRegistryState_HoldingBook_NotInMyBooksIfNotInMyBooks 7ms
โœ… MyBooksViewModelEmptyArrayTests testFilterLogic_EmptyArray_ReturnsEmpty 5ms
โœ… MyBooksViewModelEmptyArrayTests testSortLogic_EmptyArray_ReturnsEmpty 3ms
โœ… MyBooksViewModelEmptyArrayTests testSortLogic_SingleBook_ReturnsSame 6ms
โœ… MyBooksViewModelEmptyStateTests testBooksAndInstructionsLabel_CoordinateAfterFilterReset 14ms
โœ… MyBooksViewModelEmptyStateTests testBooksPublisher_EmitsRegistryContents 12ms
โœ… MyBooksViewModelEmptyStateTests testShowInstructionsLabel_FalseWhenRegistryHasBooks 7ms
โœ… MyBooksViewModelEmptyStateTests testShowInstructionsLabel_TrueWhenRegistryEmpty 5ms
โœ… MyBooksViewModelExtendedTests testAlert_ClearsOnNilAssignment 1.73s
โœ… MyBooksViewModelExtendedTests testFacetViewModel_InitializedWithCorrectConfig 1.80s
โœ… MyBooksViewModelExtendedTests testFilterBooks_WithEmptyQuery_RestoresAllBooks 1.78s
โœ… MyBooksViewModelExtendedTests testFilterBooks_WithQuery_NarrowsToMatchingBooks 1.98s
โœ… MyBooksViewModelExtendedTests testInitialFacetSort_DefaultsToTitle 1.39s
โœ… MyBooksViewModelExtendedTests testInitialState_HasCorrectDefaults 1.90s
โœ… MyBooksViewModelExtendedTests testIsPadProperty_MatchesUIDevice 1.60s
โœ… MyBooksViewModelExtendedTests testLoadAccount_WhenRegistryIsSyncing_ShowsSyncAlert 1.48s
โœ… MyBooksViewModelExtendedTests testResetFilter_RestoresBooksAfterQuery 1.63s
โœ… MyBooksViewModelExtendedTests testSelectNewLibrary_PublishesTransitionToSubscribers 1.49s
โœ… MyBooksViewModelExtendedTests testSelectedBook_PublishesThroughCombine 1.66s
โœ… MyBooksViewModelExtendedTests testShowLibraryAccountView_PublishesTransitionsToSubscribers 1.32s
โœ… MyBooksViewModelExtendedTests testShowSearchSheet_PublishesTransitionsToSubscribers 1.73s
โœ… MyBooksViewModelExtendedTests testSortByAuthor_ReordersBooks 1.66s
โœ… MyBooksViewModelExtendedTests testSortByTitle_ReordersBooks 1.63s
โœ… MyBooksViewModelFacetIntegrationTests testFacetSortChange_PropagatestoViewModel 6ms
โœ… MyBooksViewModelFacetIntegrationTests testFacetViewModel_ConfiguredCorrectly 5ms
โœ… MyBooksViewModelFacetIntegrationTests testFacet_LocalizedStrings_MatchExpected 2ms
โœ… MyBooksViewModelFacetIntegrationTests testInitialActiveSort_IsFirstFacet 5ms
โœ… MyBooksViewModelFacetPublisherTests testFacetSort_RoundTripPropagation 8ms
โœ… MyBooksViewModelFacetPublisherTests testFacetViewModel_PublishesActiveSortChanges 8ms
โœ… MyBooksViewModelFacetPublisherTests testMyBooksViewModel_SubscribesToFacetChanges 14ms
โœ… MyBooksViewModelFilterSortInteractionTests testFilter_MaintainsSortOrder_Logic 45ms
โœ… MyBooksViewModelFilterSortInteractionTests testSortAfterFilter_ProducesCorrectOrder 13ms
โœ… MyBooksViewModelFilterTests testFilterBooks_EmptyQuery_ResetsToAllBooks 15ms
โœ… MyBooksViewModelFilterTests testFilterBooks_WithQuery_MaintainsSearchQuerySeparately 55ms
โœ… MyBooksViewModelFilterTests testFilterLogic_AuthorMatch_CaseInsensitive 11ms
โœ… MyBooksViewModelFilterTests testFilterLogic_MatchesBothTitleAndAuthor_ReturnsAll 18ms
โœ… MyBooksViewModelFilterTests testFilterLogic_NilAuthors_DoesNotCrash 11ms
โœ… MyBooksViewModelFilterTests testFilterLogic_NoMatches_ReturnsEmpty 15ms
โœ… MyBooksViewModelFilterTests testFilterLogic_SpecialCharacters_HandledCorrectly 17ms
โœ… MyBooksViewModelFilterTests testFilterLogic_TitleMatch_CaseInsensitive 16ms
โœ… MyBooksViewModelFilterTests testResetFilter_RestoresAllBooks 26ms
โœ… MyBooksViewModelGuardConditionsTests testLoadData_CompletesWithIsLoadingFalse 18ms
โœ… MyBooksViewModelGuardConditionsTests testLoadData_SequentialFilterCalls_EachProducesCorrectResult 17ms
โœ… MyBooksViewModelLargeDatasetTests testFilterLogic_ManyBooks_FiltersCorrectly 151ms
โœ… MyBooksViewModelLargeDatasetTests testSortLogic_ManyBooks_Completes 180ms
โœ… MyBooksViewModelLoadAccountTests testLoadAccount_WhenNotSyncing_DoesNotShowSyncAlert 151ms
โœ… MyBooksViewModelLoadAccountTests testLoadAccount_WhenSyncing_ShowsAlert 94ms
โœ… MyBooksViewModelLoginStateTests testLoadData_EmptyRegistry_ShowsInstructionsLabel 1.16s
โœ… MyBooksViewModelLoginStateTests testLoadData_MultipleBooks_ExposesAllViaPublishedProperty 1.01s
โœ… MyBooksViewModelLoginStateTests testLoadData_PopulatedRegistry_HidesInstructionsLabel 1.39s
โœ… MyBooksViewModelLoginStateTests testRegistryChangeNotification_TriggersReload_UpdatesBooks 1.23s
โœ… MyBooksViewModelMultipleAuthorSortingTests testSortByAuthor_SameFirstName_SortsByFullName 18ms
โœ… MyBooksViewModelMultipleAuthorSortingTests testSortByTitle_ThePrefix_SortedAlphabetically 13ms
โœ… MyBooksViewModelMultipleAuthorSortingTests testSort_AlreadySorted_MaintainsOrder 10ms
โœ… MyBooksViewModelNotificationTests testRegistryChangeNotification_IsRegistered 18ms
โœ… MyBooksViewModelNotificationTests testStateChangeNotification_IsRegistered 9ms
โœ… MyBooksViewModelNotificationTests testSyncEndedNotification_CausesBookListToUpdate 322ms
โœ… MyBooksViewModelNotificationTests testSyncEndedNotification_IsRegistered 8ms
โœ… MyBooksViewModelOfflineFilteringTests testExpiredBookFiltering_Logic 96ms
โœ… MyBooksViewModelOfflineFilteringTests testOfflineState_FiltersExpiredBooks_Logic 13ms
โœ… MyBooksViewModelOfflineFilteringTests testOnlineState_ShowsAllBooks_Logic 13ms
โœ… MyBooksViewModelPublisherTests testAlertPublisher_EmitsWhenSet 34ms
โœ… MyBooksViewModelPublisherTests testAlertPublisher_InitiallyNil 11ms
โœ… MyBooksViewModelPublisherTests testFacetViewModelPublisher_TriggersSortUpdate 34ms
โœ… MyBooksViewModelPublisherTests testIsLoadingPublisher_EmitsChanges 16ms
โœ… MyBooksViewModelPublisherTests testSearchQueryPublisher_EmitsChanges 17ms
โœ… MyBooksViewModelPublisherTests testSelectedBookPublisher_EmitsChanges 15ms
โœ… MyBooksViewModelPublisherTests testShowInstructionsLabelPublisher_InitialState 9ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_EmojiInContent_HandledCorrectly 41ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_NumbersInQuery_Matches 6ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_PartialWord_Matches 10ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_UnicodeCharacters_Matches 14ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_VeryLongQuery_NoMatch 8ms
โœ… MyBooksViewModelSearchEdgeCaseTests testFilterLogic_WhitespaceQuery_HandledCorrectly 6ms
โœ… MyBooksViewModelSearchQueryTests testSearchQuery_IndependentOfFilterBooks 45ms
โœ… MyBooksViewModelSearchQueryTests testSearchQuery_PublisherEmitsAllChanges 17ms
โœ… MyBooksViewModelSearchQueryTests testSearchQuery_SetAndRetrieve 7ms
โœ… MyBooksViewModelSortPersistenceTests testActiveFacetSort_StaysInSync 1.12s
โœ… MyBooksViewModelSortPersistenceTests testSortOrder_MaintainedAfterFilter 929ms
โœ… MyBooksViewModelSortPersistenceTests testSortOrder_MaintainedAfterReset 906ms
โœ… MyBooksViewModelSortingIntegrationTests testAuthorSort_SortKeyFormat 5ms
โœ… MyBooksViewModelSortingIntegrationTests testSortByAuthor_MultipleBooks_CorrectOrder 13ms
โœ… MyBooksViewModelSortingIntegrationTests testSortByTitle_MultipleBooks_CorrectOrder 12ms
โœ… MyBooksViewModelSortingIntegrationTests testSort_SecondaryField_BreaksTies 318ms
โœ… MyBooksViewModelSortingIntegrationTests testTitleSort_SortKeyFormat 8ms
โœ… MyBooksViewModelSortingTests testSortChange_FromTitleToAuthor_UpdatesActiveFacetSort 16ms
โœ… MyBooksViewModelSortingTests testSortComparator_AuthorSort_ComparesCorrectly 10ms
โœ… MyBooksViewModelSortingTests testSortComparator_EmptyAuthor_TreatedAsEmptyString 14ms
โœ… MyBooksViewModelSortingTests testSortComparator_IdenticalKeys_MaintainsOrder 18ms
โœ… MyBooksViewModelSortingTests testSortComparator_NilAuthors_HandledCorrectly 14ms
โœ… MyBooksViewModelSortingTests testSortComparator_TitleSort_ComparesCorrectly 8ms
โœ… MyBooksViewModelStateTransitionTests testAlert_StateTransitions 82ms
โœ… MyBooksViewModelStateTransitionTests testIsLoading_TransitionsDuringLoad 9ms
โœ… MyBooksViewModelStateTransitionTests testShowInstructionsLabel_TransitionsOnRegistryChange 320ms
โœ… MyBooksViewModelUIBindingTests testSelectNewLibrary_PublisherEmitsOnChange 18ms
โœ… MyBooksViewModelUIBindingTests testShowLibraryAccountView_PublisherEmitsOnChange 5ms
โœ… MyBooksViewModelUIBindingTests testShowSearchSheet_PublisherEmitsOnChange 6ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_bothPresent_separatedByDoubleNewline 6ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_emptyRecoverySuggestion_returnsDescriptionOnly 6ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_multilineRecoverySuggestion 18ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_nilDescription_usesDefaultDescription 9ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_noRecoverySuggestion_returnsDescription 4ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_whitespaceOnlyRecoverySuggestion_returnsDescriptionOnly 6ms
โœ… NSErrorAdditionsTests testLocalizedDescriptionWithRecovery_withRecoverySuggestion_returnsBoth 2ms
โœ… NSNotificationTPPTests testNSNotificationConstants_matchSwift 3ms
โœ… NSNotificationTPPTests testNotificationKeys_exist 43ms
โœ… NSNotificationTPPTests testNotificationNames_exist 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_Book_NotStored_ReturnsNil 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_ClearAudioRoutes_ClearsPath 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_ClearAudioRoutes_OnEmptyPath_DoesNotCrash 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_InitialState_NoEPUBSamplePresented 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_InitialState_PathIsEmpty 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_MultiplePushes_AccumulateInPath 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PopToRoot_ClearsEntirePath 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PopToRoot_OnEmptyPath_DoesNotCrash 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_Pop_DecreasesPathCount 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_Pop_OnEmptyPath_DoesNotCrash 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PushAudioRoute_ClearsExistingRoutes 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PushAudioRoute_FromBookDetail_PreservesStack 5ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PushAudioRoute_OnEmptyPath_AddsRoute 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_PushAudioRoute_PreventsDuplicateAudioRoutes 3ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_Push_IncreasesPathCount 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_StoreAudioModel_CanBeRetrieved 2ms
โœ… NavigationCoordinatorTests testNavigationCoordinator_StoreBook_CanBeRetrieved 5ms
โœ… NavigationFreezePreventionTests testNavigation_failurePath_clearsOnPlaybackFailed 2ms
โœ… NavigationFreezePreventionTests testNavigation_multipleBeginsThenFailure_stillClears 3ms
โœ… NavigationFreezePreventionTests testNavigation_normalFlow_clearsOnPlaybackBegan 2ms
โœ… NavigationFreezePreventionTests testNavigation_notNavigating_seekIsAllowed 2ms
โœ… NavigationFreezePreventionTests testNavigation_unloadPath_clearsOnPlaybackUnloaded 3ms
โœ… NetworkExecutorCredentialGuardTests testExecuteTokenRefresh_BothEmpty_FailsViaTokenRequestGuard 3ms
โœ… NetworkExecutorCredentialGuardTests testExecuteTokenRefresh_EmptyUsername_FailsViaTokenRequestGuard 16ms
โœ… NetworkExecutorCredentialGuardTests testExecuteTokenRefresh_ServerReturns401_ReturnsFailure 213ms
โœ… NetworkExecutorCredentialGuardTests testExecuteTokenRefresh_ValidCredentials_ReturnsTokenResponse 40ms
โœ… NetworkExecutorCredentialGuardTests testExecuteTokenRefresh_WithAccountId_Succeeds 21ms
โœ… NetworkExecutorCredentialGuardTests testRefreshTokenAndResume_DefaultAccountId_BackwardCompatible 7ms
โœ… NetworkExecutorCredentialGuardTests testRefreshTokenAndResume_NilTask_NilAccountId_DoesNotCrash 31ms
โœ… NetworkExecutorCredentialGuardTests testRefreshTokenAndResume_NoCredentials_FailsGracefully 10ms
โœ… NetworkExecutorResponseRegressionTests testGET_handlesEmptyResponseBody 64ms
โœ… NetworkExecutorResponseRegressionTests testGET_handlesHTTPErrorGracefully 26ms
โœ… NetworkExecutorResponseRegressionTests testGET_receivesLCPLicenseJSON 67ms
โœ… NetworkExecutorResponseRegressionTests testGET_receivesLargeManifestJSON 99ms
โœ… NetworkExecutorTaskTypeTests testDownload_createsDownloadTask 16ms
โœ… NetworkExecutorTaskTypeTests testGET_createsDataTask_notDownloadTask 23ms
โœ… NetworkExecutorTaskTypeTests testGET_receivesResponseData 16ms
โœ… NetworkOfflineDetectionTests testNetworkReachability_hasSharedInstance 4ms
โœ… NetworkOfflineDetectionTests testURLError_nonOfflineErrorCodes 4ms
โœ… NetworkOfflineDetectionTests testURLError_offlineErrorCodes 3ms
โœ… NetworkQueueTests testAddRequestDoesNotCrash 16ms
โœ… NetworkQueueTests testAddRequestWithHeadersDoesNotCrash 10ms
โœ… NetworkQueueTests testHTTPMethodTypeRawValues 11ms
โœ… NetworkQueueTests testMaxRetriesInQueueIsFive 14ms
โœ… NetworkQueueTests testMigrateCanBeCalledMultipleTimes 17ms
โœ… NetworkQueueTests testMigrateDoesNotCrash 17ms
โœ… NetworkQueueTests testObjCSharedReturnsInstance 6ms
โœ… NetworkQueueTests testSharedInstanceIsSingleton 7ms
โœ… NetworkQueueTests testStatusCodesContainsExpectedNetworkErrors 7ms
โœ… NetworkQueueTests testStatusCodesContainsRoamingAndCallErrors 10ms
โœ… NetworkQueueTests testStatusCodesContainsSecureConnectionFailed 7ms
โœ… NetworkRequestQueueTests testConcurrentRequests_respectsLimit 10.15s
โœ… NetworkRequestQueueTests testRequestOrdering_maintainsOrder 75ms
โœ… NetworkRetryLogicTests testNoRetry_on400BadRequest 20ms
โœ… NetworkRetryLogicTests testNoRetry_on404NotFound 46ms
โœ… NetworkRetryLogicTests testRateLimiting_429Response 9ms
โœ… NetworkRetryLogicTests testRetry_on500Error_eventualSuccess 6ms
โœ… NetworkRetryLogicTests testRetry_on502BadGateway 9ms
โœ… NetworkRetryLogicTests testRetry_on503ServiceUnavailable 10ms
โœ… NetworkRetryLogicTests testRetry_on504GatewayTimeout 396ms
โœ… NetworkTimeoutTests testDefaultTimeout_isReasonable 2ms
โœ… NetworkTimeoutTests testTimeout_configuration 2ms
โœ… NotificationEventTypeContractTests testAllCMEventTypes_ParseToiOSEnum 3ms
โœ… NotificationEventTypeContractTests testHoldAvailable_IsHoldRelated 3ms
โœ… NotificationEventTypeContractTests testHoldRemoved_IsHoldRelated 2ms
โœ… NotificationEventTypeContractTests testLoanExpiry_IsNotHoldRelated 3ms
โœ… NotificationEventTypeContractTests testLoanRemoved_IsNotHoldRelated 2ms
โœ… NotificationEventTypeContractTests testUnknownEventType_returnsNilForAllUnrecognizedRawValues 8ms
โœ… NotificationEventTypeContractTests testiOSEnum_HasNoCasesUnknownToCM 7ms
โœ… NotificationPayloadContractTests testAllFixturePayloads_ParseThroughiOSEventTypeEnum 6ms
โœ… NotificationPayloadContractTests testAllPayloads_HaveAPSAlert 4ms
โœ… NotificationPayloadContractTests testAllPayloads_HaveEventTypeField 15ms
โœ… NotificationPayloadContractTests testAllPayloads_HaveIdentifierTypeField 2ms
โœ… NotificationPayloadContractTests testAllPayloads_HaveLoansEndpointField 2ms
โœ… NotificationPayloadContractTests testAllPayloads_haveIdentifierAndLibraryAsNonEmptyStrings 5ms
โœ… NotificationPayloadContractTests testEventTypes_MatchPayloadKeys 4ms
โœ… NotificationPayloadContractTests testHoldClassification_MatchesExpectedRouting 10ms
โœ… NotificationPayloadContractTests testLoanExpiry_HasDaysToExpiryField 7ms
โœ… NotificationPayloadContractTests testNonExpiryPayloads_DoNotHaveDaysToExpiry 3ms
โœ… NotificationServiceStateMachineTests testAuthStateChange_idempotentTransitions_doNotTriggerRetry 177ms
โœ… NotificationServiceStateMachineTests testAuthStateChange_loggedInToStale_doesNotTriggerRetry 174ms
โœ… NotificationServiceStateMachineTests testAuthStateChange_loggedOutToLoggedIn_triggersRetry 165ms
โœ… NotificationServiceStateMachineTests testAuthStateChange_staleToLoggedIn_triggersRetry 193ms
โœ… NotificationServiceStateMachineTests testHoldNotification_blocksUntilLoaded_thenNavigates 207ms
โœ… NotificationServiceStateMachineTests testHoldNotification_detailsFailed_completes 178ms
โœ… NotificationServiceStateMachineTests testHoldNotification_doesNotSupportReservations_completes 164ms
โœ… NotificationServiceStateMachineTests testHoldNotification_nilCurrentAccount_skipsNoAccount 164ms
โœ… NotificationServiceStateMachineTests testHoldNotification_supportsReservations_navigates 166ms
โœ… NotificationServiceTests testBackgroundFetchIsNeeded_isReferentiallyTransparent 23ms
โœ… NotificationServiceTests testCompareAvailabilityDoesNotCrashWithNoAvailability 13ms
โœ… NotificationServiceTests testCompareAvailabilityReservedToReady 9ms
โœ… NotificationServiceTests testHoldClassificationFallback_WhenEventTypeNotInEnum 3ms
โœ… NotificationServiceTests testHoldClassificationWithAPSAlertContainingAvailableKeyword 2ms
โœ… NotificationServiceTests testHoldClassificationWithAPSAlertContainingReadyKeyword 3ms
โœ… NotificationServiceTests testHoldClassificationWithNonHoldAPSAlert 3ms
โœ… NotificationServiceTests testHoldClassificationWithReservationInBody 5ms
โœ… NotificationServiceTests testHoldClassification_byEventType_routesAllKnownEnumCasesCorrectly 2ms
โœ… NotificationServiceTests testHoldClassification_unparseableInputDefaultsToHoldRelated 3ms
โœ… NotificationServiceTests testNotificationConstants_areStableAndDistinct 2ms
โœ… NotificationServiceTests testTokenDataCodableRoundTrip 2ms
โœ… NotificationServiceTests testTokenDataEncodesToValidJSON 3ms
โœ… NotificationServiceTests testTokenDataEncoding 3ms
โœ… NotificationServiceTests testTokenDataWithEmptyToken 3ms
โœ… NotificationServiceTests testTokenDataWithSpecialCharacters_roundTripsThroughJSON 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_loggedInToLoggedIn_doesNotRetry 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_loggedInToLoggedOut_doesNotRetry 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_loggedInToStale_doesNotRetry 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_loggedOutToLoggedIn_withFlagFalse_retries 3ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_loggedOutToLoggedOut_doesNotRetry 3ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_staleToLoggedIn_withFlagFalse_retries 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_staleToLoggedIn_withFlagTrue_doesNotRetry 2ms
โœ… NotificationServiceTokenTests testShouldRetryTokenRegistration_staleToStale_doesNotRetry 2ms
โœ… NotificationServiceTokenTests testTokenData_data_isNotNil 4ms
โœ… NotificationServiceTokenTests testTokenData_emptyToken_stillEncodes 15ms
โœ… NotificationServiceTokenTests testTokenData_encodesCorrectJSON 3ms
โœ… NotificationServiceTokenTests testTokenData_longToken_encodesCorrectly 3ms
โœ… NotificationServiceTokenTests testTokenData_tokenType_isAlwaysFCMiOS 2ms
โœ… NotificationSyncThrottleTests testForceSync_bypassesThrottle_atExactThreshold 2ms
โœ… NotificationSyncThrottleTests testForceSync_bypassesThrottle_evenIfRecentlySynced 3ms
โœ… NotificationSyncThrottleTests testForceSync_proceedsRegardlessOfHistoryShape 2ms
โœ… NotificationSyncThrottleTests testHoldNotification_alwaysSyncs 2ms
โœ… NotificationSyncThrottleTests testThrottle_normalSync_blocksRecentAndAllowsAgedAndFirstSync 2ms
โœ… NotificationTokenDataTests testTokenData_codableRoundTrip 3ms
โœ… NotificationTokenDataTests testTokenData_dataNotNil 4ms
โœ… NotificationTokenDataTests testTokenData_encodesToJSON 2ms
โœ… NotificationTokenDataTests testTokenData_init 2ms
โœ… NotificationTokenRegistrationTests testRegressionForBug_SAML401LeavesFlagUnlatched_perHelpSpot17680 26ms
โœ… NotificationTokenRegistrationTests testShouldMark_whenSaveSucceeds 2ms
โœ… NotificationTokenRegistrationTests testShouldMark_whenTokenAlreadyRegistered 3ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenDeviceRegistrationLinkAbsent 4ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenExistsCheckInconclusive 2ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenFCMTokenUnavailable 5ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenProfileDocumentMissing 12ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenSaveFails 33ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenSaveNeededButNotAttempted 3ms
โœ… NotificationTokenRegistrationTests testShouldNotMark_whenSaveSucceededButPrerequisiteMissing 4ms
โœ… NowPlayingCoordinatorBackgroundTests testApplyUpdate_inBackground_bypassesDebounce 56ms
โœ… NowPlayingCoordinatorBackgroundTests testApplyUpdate_inForeground_debouncesAsBefore 380ms
โœ… NowPlayingCoordinatorBackgroundTests testDryStreamGuard_doesNotLog_atExactlyThreshold 24ms
โœ… NowPlayingCoordinatorBackgroundTests testDryStreamGuard_doesNotLog_whenNotPlaying 5ms
โœ… NowPlayingCoordinatorBackgroundTests testDryStreamGuard_doesNotLog_whenStreamIsFresh 6ms
โœ… NowPlayingCoordinatorBackgroundTests testDryStreamGuard_logsErrorOnForegroundReturn_whenLastUpdateStale 3ms
โœ… NowPlayingCoordinatorTests testClearNowPlaying_removesAllInfo 5ms
โœ… NowPlayingCoordinatorTests testClearNowPlaying_setsStoppedState 2ms
โœ… NowPlayingCoordinatorTests testSetPlaybackState_paused_setsCorrectPlaybackState 2ms
โœ… NowPlayingCoordinatorTests testSetPlaybackState_paused_setsZeroRate 64ms
โœ… NowPlayingCoordinatorTests testSetPlaybackState_playing_setsCorrectPlaybackState 2ms
โœ… NowPlayingCoordinatorTests testSetPlaybackState_playing_setsNonZeroRate 4ms
โœ… NowPlayingCoordinatorTests testUpdateArtwork_nil_clearsArtwork 2ms
โœ… NowPlayingCoordinatorTests testUpdateArtwork_setsArtworkInInfo 12ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_clampsElapsedToNotExceedDuration 2ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_clampsNegativeElapsedToZero 20ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_ensuresDurationIsAtLeastOne 3ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_preservesArtwork_acrossUpdates 2ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_rapidUpdates_lastOneWins 6ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_setsElapsedAndDuration 52ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_setsInfoCenter 155ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_setsMediaType_toAudioBook 20ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_setsPlaybackRate_whenPlaying 5ms
โœ… NowPlayingCoordinatorTests testUpdateNowPlaying_setsZeroPlaybackRate_whenPaused 6ms
โœ… NowPlayingCoordinatorTests testUpdatePlaybackRate_updatesDefaultRate 2ms
โœ… OAuthSAMLRedirectRegressionTests testRegression_handleRedirectURL_rejectsCustomSchemeURL 125ms
โœ… OAuthSAMLRedirectRegressionTests testRegression_oauthRedirect_stillUsesUniversalLinksPrefix 91ms
โœ… OAuthSAMLRedirectRegressionTests testRegression_oauthRedirect_withError_stillHandlesError 157ms
โœ… OAuthSAMLRedirectRegressionTests testRegression_samlRedirect_stillUsesUniversalLinksPrefix 117ms
โœ… OIDCAuthDocumentParsingTests testAuthDocument_containsOidcType 79ms
โœ… OIDCAuthDocumentParsingTests testAuthDocument_oidcAuthenticateLink_IsParsed 82ms
โœ… OIDCAuthDocumentParsingTests testAuthDocument_oidcDoesNotAffectOtherAuthTypes 98ms
โœ… OIDCAuthDocumentParsingTests testAuthDocument_unknownTypeStillFallsToNone 2ms
โœ… OIDCAuthTypeTests testAuthType_InitFromLegacyOidcString_ReturnsOidc 7ms
โœ… OIDCAuthTypeTests testAuthType_InitFromOidcString_ReturnsOidc 6ms
โœ… OIDCAuthTypeTests testAuthType_LegacyOidcURI_DecodesViaCodeable 4ms
โœ… OIDCAuthTypeTests testAuthType_OidcIsDistinct_FromOtherTypes 4ms
โœ… OIDCAuthTypeTests testAuthType_OidcRawValue_IsCorrect 4ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_catalogRequiresAuthentication_ReturnsFalse 113ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_hasAuthenticationUrl 108ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_isNotOtherTypes 101ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_isOidc_ReturnsTrue 106ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_methodDescription_IsOpenIDConnect 149ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_needsAgeCheck_ReturnsFalse 136ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_needsAuth_ReturnsTrue 157ms
โœ… OIDCAuthenticationPropertyTests testOidcAuthentication_otherUrlsAreNil 107ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_doesNotAffectPriorOAuthState 108ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_prefersQueryOverFragment 128ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withEmptyQueryString_doesNotSetToken 109ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withLongToken_setsFullToken 142ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withMalformedPatronJSON_doesNotSetToken 97ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withOnlyAccessToken_doesNotSetToken 102ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withOnlyPatronInfo_doesNotSetToken 111ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withPatronContainingMultipleFields_parsesAll 118ms
โœ… OIDCCallbackEdgeCaseTests testHandleOIDCCallback_withPlusEncodedPatron_decodesSpaces 95ms
โœ… OIDCCallbackHandlingTests testHandleOIDCCallback_withError_doesNotSetToken 95ms
โœ… OIDCCallbackHandlingTests testHandleOIDCCallback_withFragment_extractsTokenAndValidates 102ms
โœ… OIDCCallbackHandlingTests testHandleOIDCCallback_withNoPayload_doesNotSetToken 114ms
โœ… OIDCCallbackHandlingTests testHandleOIDCCallback_withQueryParams_extractsTokenAndValidates 93ms
โœ… OIDCCallbackHandlingTests testOIDCFlow_afterCallback_validatesAndCompletesSignIn 6.07s
โœ… OIDCCallbackSchemeTests testOidcCallbackHost_matchesAndroidConvention 4ms
โœ… OIDCCallbackSchemeTests testOidcCallbackScheme_isNotHTTPS 2ms
โœ… OIDCCallbackSchemeTests testOidcCallbackScheme_matchesAndroidConvention 3ms
โœ… OIDCIsolationRegressionTests testRegression_basicAuthentication_noTokenURLs 86ms
โœ… OIDCIsolationRegressionTests testRegression_makeRequest_oauthAndOIDC_bothUseBearerToken 109ms
โœ… OIDCIsolationRegressionTests testRegression_oauthAuthentication_typeIsCorrect 87ms
โœ… OIDCIsolationRegressionTests testRegression_oidcAuthentication_noOtherAuthURLs 102ms
โœ… OIDCIsolationRegressionTests testRegression_samlAuthentication_typeIsCorrect 92ms
โœ… OIDCIsolationRegressionTests testRegression_updateUserAccount_oauthStillStoresToken 100ms
โœ… OIDCLoginRoutingTests testLogIn_withOIDC_callsWillSignIn 146ms
โœ… OIDCLoginRoutingTests testLogIn_withOIDC_capturesCredentials 201ms
โœ… OIDCLoginRoutingTests testLogIn_withOIDC_doesNotValidateCredentialsDirectly 127ms
โœ… OIDCMakeRequestTests testMakeRequest_forOIDCSignOut_usesUserProfileURL 90ms
โœ… OIDCMakeRequestTests testMakeRequest_forOIDC_addsBearerTokenHeader 79ms
โœ… OIDCMakeRequestTests testMakeRequest_forOIDC_withoutToken_stillCreatesRequest 78ms
โœ… OIDCNSCodingTests testOidcAuthentication_NSCodingRoundTrip_PreservesProperties 132ms
โœ… OIDCNetworkLayer401Tests testOIDC_authDefinition_hasNoTokenURL 83ms
โœ… OIDCNetworkLayer401Tests testOIDC_authDefinition_isNotOauth 84ms
โœ… OIDCNetworkLayer401Tests testOIDC_authDefinition_isNotToken 98ms
โœ… OIDCNetworkLayer401Tests testOIDC_cannotDoClientSideTokenRefresh 98ms
โœ… OIDCNetworkLayer401Tests testOIDC_isTreatedLikeSAML_forReauth 91ms
โœ… OIDCReauthOnExpiredTokenTests testOIDC_afterReauth_credentialsRestored 206ms
โœ… OIDCReauthOnExpiredTokenTests testOIDC_refreshAuthIfNeeded_doesNotNilSelectedAuth 145ms
โœ… OIDCReauthOnExpiredTokenTests testOIDC_refreshAuthIfNeeded_withoutExistingCredentials_requiresUI 187ms
โœ… OIDCReauthOnExpiredTokenTests testOIDC_staleCredentials_authDefinitionPreserved 164ms
โœ… OIDCReauthOnExpiredTokenTests testOIDC_staleCredentials_stillHasCredentials 204ms
โœ… OIDCRedirectURIConstructionTests testOidcCallbackScheme_containsNoDots 94ms
โœ… OIDCRedirectURIConstructionTests testOidcCallbackScheme_doesNotContainColonOrSlash 112ms
โœ… OIDCRedirectURIConstructionTests testOidcCallbackScheme_isLowercase 122ms
โœ… OIDCRedirectURIConstructionTests testOidcRedirectURI_doesNotUseHTTPS 170ms
โœ… OIDCRedirectURIConstructionTests testOidcRedirectURI_doesNotUseUniversalLinksURL 111ms
โœ… OIDCRedirectURIConstructionTests testOidcRedirectURI_isValidURL 116ms
โœ… OIDCRegressionTests testRegression_allAuthTypes_areCodable 141ms
โœ… OIDCRegressionTests testRegression_authTypeCodable_roundTripIncludesOidc 128ms
โœ… OIDCRegressionTests testRegression_basicAuth_makeRequest_noBearerToken 143ms
โœ… OIDCRegressionTests testRegression_basicAuth_needsAuth_StillTrue 140ms
โœ… OIDCRegressionTests testRegression_defaultAuth_stillPrefersNonOAuth 154ms
โœ… OIDCRegressionTests testRegression_existingAuthTypesUnchanged 166ms
โœ… OIDCRegressionTests testRegression_oauthAuth_makeRequest_stillAddsBearerToken 149ms
โœ… OIDCRegressionTests testRegression_samlAuth_makeRequest_stillAddsBearerToken 121ms
โœ… OIDCRegressionTests testRegression_samlUpdateUserAccount_stillStoresCookies 172ms
โœ… OIDCSelectedAuthenticationTests testRefreshAuthIfNeeded_withOIDC_resetsIgnoreSignedInState 146ms
โœ… OIDCSelectedAuthenticationTests testSelectedAuthentication_canBeSetToOIDC 151ms
โœ… OIDCSignOutRegressionTests testRegression_signOut_withOAuth_stillClearsToken 114ms
โœ… OIDCSignOutRegressionTests testRegression_signOut_withSAML_stillClearsCookies 174ms
โœ… OIDCSignOutRegressionTests testSignOut_resetsInFlightAuthState 123ms
โœ… OIDCSignOutRegressionTests testSignOut_withOIDC_clearsAuthToken 115ms
โœ… OIDCSignOutRegressionTests testSignOut_withOIDC_clearsPatronInfo 143ms
โœ… OIDCSignOutRegressionTests testSignOut_withOIDC_triggersExplicitLogoutFlowAndCompletesDeauthorization 116ms
โœ… OIDCTokenRefreshRegressionTests testRefreshAuth_withOIDC_doesNotNilOutSelectedAuth_unlikeSAML 110ms
โœ… OIDCTokenRefreshRegressionTests testRefreshAuth_withOIDC_usingExistingCredentials_doesNotResetSelectedAuth 120ms
โœ… OIDCTokenRefreshRegressionTests testRefreshAuth_withOIDC_withoutExistingCredentials_setsIgnoreSignedIn 102ms
โœ… OIDCTokenRefreshRegressionTests testRegression_refreshAuth_withBasic_ignoreSignedInNotSet 117ms
โœ… OIDCTokenRefreshRegressionTests testRegression_refreshAuth_withOAuth_stillSetsIgnoreSignedIn 111ms
โœ… OIDCTokenRefreshRegressionTests testRegression_refreshAuth_withSAML_codepathIncludesSAML 124ms
โœ… OIDCUpdateUserAccountTests testUpdateUserAccount_withOIDC_doesNotStoreCookies 98ms
โœ… OIDCUpdateUserAccountTests testUpdateUserAccount_withOIDC_marksLoggedIn 129ms
โœ… OIDCUpdateUserAccountTests testUpdateUserAccount_withOIDC_setsAuthDefinition 106ms
โœ… OIDCUpdateUserAccountTests testUpdateUserAccount_withOIDC_storesAuthToken 127ms
โœ… OIDCUpdateUserAccountTests testUpdateUserAccount_withOIDC_storesPatronInfo 91ms
โœ… OIDCViewModelRegressionTests testOIDCSignIn_doesNotRequireUsernameOrPIN 161ms
โœ… OIDCViewModelSignInTests testSignIn_withActiveCredentials_showsSignOutAlert 22ms
โœ… OIDCViewModelSignInTests testSignIn_withStaleOIDCCredentials_proceedsToLogin 31ms
โœ… OPDS1BorrowEntryContractTests testBorrowEntry_HasAvailabilityWithDates 23ms
โœ… OPDS1BorrowEntryContractTests testBorrowEntry_HasLCPAcquisition 7ms
โœ… OPDS1BorrowEntryContractTests testBorrowEntry_HasRevokeLink 5ms
โœ… OPDS1BorrowEntryContractTests testParseBorrowEntry_AsSingleEntryFeed 34ms
โœ… OPDS1CatalogGroupedContractTests testGroupedFeed_EntriesHaveGroupAttributes 20ms
โœ… OPDS1CatalogGroupedContractTests testGroupedFeed_HasMultipleGroups 10ms
โœ… OPDS1CatalogGroupedContractTests testGroupedFeed_ParsesAsGroupedType 7ms
โœ… OPDS1HoldEntriesContractTests testHoldsFeed_ReadyEntry_HasReadyAvailability 16ms
โœ… OPDS1HoldEntriesContractTests testHoldsFeed_ReservedEntry_HasHoldPosition 8ms
โœ… OPDS1HoldEntriesContractTests testHoldsFeed_ReservedEntry_HasRevokeLink 9ms
โœ… OPDS1HoldEntriesContractTests testParseHoldsFeed_ReturnsTwoEntries 19ms
โœ… OPDS1LoansFeedContractTests testLoansFeed_AudiobookEntry_HasAudiobookType 10ms
โœ… OPDS1LoansFeedContractTests testLoansFeed_EPUBEntry_HasAdobeDRMAcquisition 37ms
โœ… OPDS1LoansFeedContractTests testLoansFeed_EntryHasAnnotationLink 14ms
โœ… OPDS1LoansFeedContractTests testLoansFeed_EntryHasRevokeLink 22ms
โœ… OPDS1LoansFeedContractTests testLoansFeed_OpenAccessPDF_HasDirectAcquisition 11ms
โœ… OPDS1LoansFeedContractTests testParseLoansFeed_ReturnsThreeEntries 25ms
โœ… OPDS1ParsingTests testCatalog_acquisitionLinks_areBucketedSeparatelyFromLinks 7ms
โœ… OPDS1ParsingTests testCatalog_multipleAuthors_allPreservedInOrder 8ms
โœ… OPDS1ParsingTests testCatalog_openAccessAndBorrow_bothPreservedWithCorrectRelation 10ms
โœ… OPDS1ParsingTests testCatalog_paginationNextLink_captured 8ms
โœ… OPDS1ParsingTests testCatalog_parsesEntryIdentifiers 12ms
โœ… OPDS1ParsingTests testCatalog_parsesEntryTitlesInDocumentOrder 9ms
โœ… OPDS1ParsingTests testCatalog_parsesExpectedEntryCount 21ms
โœ… OPDS1ParsingTests testCatalog_parsesFeedIdentifier 21ms
โœ… OPDS1ParsingTests testCatalog_parsesFeedTitle 9ms
โœ… OPDS1ParsingTests testCatalog_parsesFeedUpdatedAsRFC3339Date 6ms
โœ… OPDS1ParsingTests testCatalog_searchLink_parsedWithType 12ms
โœ… OPDS1ParsingTests testCatalog_singleAuthor_preserved 41ms
โœ… OPDS1ParsingTests testEmptyData_returnsNilNotCrash 3ms
โœ… OPDS1ParsingTests testEmptyFeed_yieldsEmptyEntriesArrayNotNil 7ms
โœ… OPDS1ParsingTests testEntry_category_parsedWithTerm 15ms
โœ… OPDS1ParsingTests testEntry_imageThumbnail_keptAsLink 11ms
โœ… OPDS1ParsingTests testEntry_published_fallsBackToIssuedWhenPublishedAbsent 5ms
โœ… OPDS1ParsingTests testEntry_published_isParsedFromPublishedElement 6ms
โœ… OPDS1ParsingTests testEntry_published_prefersPublishedOverIssuedWhenBothPresent 10ms
โœ… OPDS1ParsingTests testEntry_publisher_extracted 7ms
โœ… OPDS1ParsingTests testEntry_summary_decoded 7ms
โœ… OPDS1ParsingTests testEntry_unicodeTitle_preservedExactly 6ms
โœ… OPDS1ParsingTests testEntry_veryLongTitle_preservedExactly 5ms
โœ… OPDS1ParsingTests testFacetedFeed_activeFacet_attributeRecognized 10ms
โœ… OPDS1ParsingTests testFacetedFeed_facetLinks_groupedCorrectly 4ms
โœ… OPDS1ParsingTests testFacetedFeed_otherFacetsNotMarkedActive 5ms
โœ… OPDS1ParsingTests testFeedType_acquisitionFeed_detectedUngrouped 7ms
โœ… OPDS1ParsingTests testFeedType_emptyFeed_returnsAcquisitionUngrouped 12ms
โœ… OPDS1ParsingTests testLink_invalidHrefScheme_capturedAsIs 3ms
โœ… OPDS1ParsingTests testLink_missingHref_returnsNil 2ms
โœ… OPDS1ParsingTests testLink_validHref_returnsLinkWithAttributes 4ms
โœ… OPDS1ParsingTests testMalformedEntries_skippedNotCrashed 19ms
โœ… OPDS1ParsingTests testMalformedXML_returnsNilNotCrash 17ms
โœ… OPDS1ParsingTests testNonOPDSXML_returnsNil 2ms
โœ… OPDS1RevokeResponseContractTests testRevokeResponse_HasBorrowLink_NotFulfillmentLink 7ms
โœ… OPDS1RevokeResponseContractTests testRevokeResponse_ParsesAsSingleEntry 5ms
โœ… OPDS2AuthenticationDocumentTests testAnnouncements_parsesIfPresent 3ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_noAuthRequired 10ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesBarcodeFormat 3ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesBasicAuth 7ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesInputConfiguration 4ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesLabels 3ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesMaximumLength 3ms
โœ… OPDS2AuthenticationDocumentTests testAuthentication_parsesMultipleMethods 30ms
โœ… OPDS2AuthenticationDocumentTests testColorScheme_parsesIfPresent 3ms
โœ… OPDS2AuthenticationDocumentTests testFeatures_parsesDisabledFeatures 3ms
โœ… OPDS2AuthenticationDocumentTests testFeatures_parsesEnabledFeatures 9ms
โœ… OPDS2AuthenticationDocumentTests testFromData_withEmptyData_throwsError 3ms
โœ… OPDS2AuthenticationDocumentTests testFromData_withInvalidJSON_throwsError 26ms
โœ… OPDS2AuthenticationDocumentTests testFromData_withMissingRequiredFields_throwsError 2ms
โœ… OPDS2AuthenticationDocumentTests testFromData_withValidJSON_parsesDocument 4ms
โœ… OPDS2AuthenticationDocumentTests testLinks_firstRelMethod_findsPasswordReset 4ms
โœ… OPDS2AuthenticationDocumentTests testLinks_parsesCorrectly 3ms
โœ… OPDS2AuthenticationDocumentTests testServiceDescription_parsesIfPresent 8ms
โœ… OPDS2AvailabilityTests testIsAvailable_AvailableState_ReturnsTrue 3ms
โœ… OPDS2AvailabilityTests testIsReady_ReadyState_ReturnsTrue 5ms
โœ… OPDS2AvailabilityTests testIsReserved_ReservedState_ReturnsTrue 28ms
โœ… OPDS2AvailabilityTests testIsUnavailable_UnavailableState_ReturnsTrue 343ms
โœ… OPDS2BookBridgeTests testConvertAvailability_availableWithoutCopiesIsUnlimited 3ms
โœ… OPDS2BookBridgeTests testConvertAvailability_unknownStateDefaultsToUnlimited 4ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_fromDecodedJSON 73ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsAuthors 3ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsDescription 2ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsMultipleAuthors 6ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsNarrators 4ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsPublishedDate 7ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsPublisher 4ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsSubjectsAsCategories 3ms
โœ… OPDS2BookBridgeTests testFullPublicationToBook_mapsSubtitle 79ms
โœ… OPDS2BookBridgeTests testMetadata_decodesAuthorFromSingleStringAndArray 3ms
โœ… OPDS2BookBridgeTests testRelationMapping_allStandardRelations 2ms
โœ… OPDS2BookBridgeTests testRelationMapping_nonAcquisitionRelReturnsNil 3ms
โœ… OPDS2BookBridgeTests testToBook_fallsBackToFirstImageWhenNoRelSpecified 7ms
โœ… OPDS2BookBridgeTests testToBook_filtersNonAcquisitionLinks 5ms
โœ… OPDS2BookBridgeTests testToBook_fromDecodedJSON 10ms
โœ… OPDS2BookBridgeTests testToBook_handlesInvalidHrefURL 6ms
โœ… OPDS2BookBridgeTests testToBook_handlesLinkWithNoType 2ms
โœ… OPDS2BookBridgeTests testToBook_keepsPublicationWhenAtLeastOneAcquisitionIsSupported 4ms
โœ… OPDS2BookBridgeTests testToBook_keepsPublicationWhenOnlyAcquisitionIsStreamingHTMLIndirect 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsAlternateLink 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsAuthorsFromArrayMetadata 9ms
โœ… OPDS2BookBridgeTests testToBook_mapsAvailableState 5ms
โœ… OPDS2BookBridgeTests testToBook_mapsBorrowLink 7ms
โœ… OPDS2BookBridgeTests testToBook_mapsBuyLink 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsGenericAcquisitionLink 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsImageURLFromImages 35ms
โœ… OPDS2BookBridgeTests testToBook_mapsIndirectAcquisition 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsLCPIndirectAcquisition 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsOpenAccessLink 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsPreviewLink 5ms
โœ… OPDS2BookBridgeTests testToBook_mapsReadyState 5ms
โœ… OPDS2BookBridgeTests testToBook_mapsRelatedWorksLink 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsReservedState 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsRevokeLink 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsSampleLink 3ms
โœ… OPDS2BookBridgeTests testToBook_mapsThumbnailURL 4ms
โœ… OPDS2BookBridgeTests testToBook_mapsUnavailableState 2ms
โœ… OPDS2BookBridgeTests testToBook_multipleAcquisitionLinks 3ms
โœ… OPDS2BookBridgeTests testToBook_noAvailabilityDefaultsToUnlimited 4ms
โœ… OPDS2BookBridgeTests testToBook_passesThroughIdentifierTitleUpdatedAndDescription 3ms
โœ… OPDS2BookBridgeTests testToBook_returnsNilWhenNoAcquisitionLinks 3ms
โœ… OPDS2BookBridgeTests testToBook_returnsNilWhenNoUsableAcquisitionPath 4ms
โœ… OPDS2BorrowResponseContractTests testBorrowResponse_HasAvailabilityWithDates 2ms
โœ… OPDS2BorrowResponseContractTests testBorrowResponse_HasFulfillmentAndRevokeLinks 6ms
โœ… OPDS2BorrowResponseContractTests testBorrowResponse_ParsesPublicationMetadata 2ms
โœ… OPDS2CatalogWiringTests testCatalogFeed_opds2Init_createsShellOpdsFeed 4ms
โœ… OPDS2CatalogWiringTests testCatalogFeed_opds2Init_mapsEntries 4ms
โœ… OPDS2CatalogWiringTests testCatalogFeed_opds2Init_setsTitle 3ms
โœ… OPDS2CatalogWiringTests testEndToEnd_jsonToLanes 13ms
โœ… OPDS2CatalogWiringTests testExtractOPDS2Facets_fallsBackToNumberOfItemsHintWhenNoURLMatch 4ms
โœ… OPDS2CatalogWiringTests testExtractOPDS2Facets_marksFacetActiveWhenHrefMatchesCurrentURL 35ms
โœ… OPDS2CatalogWiringTests testExtractOPDS2Facets_urlMatchIgnoresQueryOrder 3ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Facets_extracted 13ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Grouped_lanesHaveMoreURLs 7ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Grouped_lanesTitlesMatch 7ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Grouped_producesLanes 7ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Navigation_producesEmptyLanesAndBooks 5ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2Publication_producesUngroupedBooks 9ms
โœ… OPDS2CatalogWiringTests testMapFeed_opds2_bookMetadataPreserved 15ms
โœ… OPDS2CatalogWiringTests testParser_detectsOPDS1XML 5ms
โœ… OPDS2CatalogWiringTests testParser_detectsOPDS2JSON 5ms
โœ… OPDS2CatalogWiringTests testParser_invalidJSONThrows 21ms
โœ… OPDS2CatalogsFeedTests testAccountSetAuthenticationDocument 133ms
โœ… OPDS2CatalogsFeedTests testInitAccountsWithPublication 130ms
โœ… OPDS2CatalogsFeedTests testLoadCatalogsFeed 126ms
โœ… OPDS2ContributorTests testDecode_ObjectValue_ParsesAllFields 23ms
โœ… OPDS2ContributorTests testDecode_StringValue_ParsesAsName 8ms
โœ… OPDS2EmptyFeedContractTests testEmptyFeed_ParsesWithZeroItems 10ms
โœ… OPDS2FeedContractTests testParseAudiobook_IncludesCompleteMetadataAndLinks 10ms
โœ… OPDS2FeedContractTests testParseFacets_ExtractsFormatEntryPoints 7ms
โœ… OPDS2FeedContractTests testParseFeed_FromBackendFixture_SucceedsWithExpectedStructure 7ms
โœ… OPDS2FeedContractTests testParsePublications_ExtractsBookMetadata 12ms
โœ… OPDS2FeedParsingTests testDateParsing_withISO8601_parsesCorrectly 168ms
โœ… OPDS2FeedParsingTests testDateParsing_withMilliseconds_parsesCorrectly 5ms
โœ… OPDS2FeedParsingTests testDateParsing_withoutMilliseconds_parsesCorrectly 9ms
โœ… OPDS2FeedParsingTests testFromData_withEmptyCatalogs_parsesSuccessfully 3ms
โœ… OPDS2FeedParsingTests testFromData_withEmptyData_throwsError 2ms
โœ… OPDS2FeedParsingTests testFromData_withInvalidJSON_throwsError 3ms
โœ… OPDS2FeedParsingTests testFromData_withMissingCatalogs_throwsError 2ms
โœ… OPDS2FeedParsingTests testFromData_withValidJSON_parsesFeed 141ms
โœ… OPDS2FeedParsingTests testLinks_parsesCorrectly 129ms
โœ… OPDS2FeedParsingTests testMetadata_parsesAdobeVendorId 144ms
โœ… OPDS2FeedParsingTests testMetadata_parsesTitle 132ms
โœ… OPDS2FeedTests testDetectOPDS2FromContentType 2ms
โœ… OPDS2FeedTests testDetectOPDS2FromData 2ms
โœ… OPDS2FeedTests testFeedEquatable 8ms
โœ… OPDS2FeedTests testParseDateWithFractionalSeconds 17ms
โœ… OPDS2FeedTests testParseDateWithoutFractionalSeconds 7ms
โœ… OPDS2FeedTests testParseFeedWithFacets 5ms
โœ… OPDS2FeedTests testParseFeedWithGroups 5ms
โœ… OPDS2FeedTests testParseFeedWithNavigation 24ms
โœ… OPDS2FeedTests testParseFeedWithPagination 6ms
โœ… OPDS2FeedTests testParseFeedWithPublications 7ms
โœ… OPDS2FeedTests testParseLinkWithIndirectAcquisition 2ms
โœ… OPDS2FeedTests testParseLinkWithProperties 4ms
โœ… OPDS2FeedTests testParseMinimalFeed 7ms
โœ… OPDS2FullMetadataTests testDecode_AllOptionalFields_ParsesCorrectly 5ms
โœ… OPDS2FullMetadataTests testDecode_AtIdKey_ParsesIdentifier 3ms
โœ… OPDS2FullMetadataTests testDecode_MissingId_GeneratesUUID 7ms
โœ… OPDS2FullMetadataTests testEncodeDecode_RoundTrip_PreservesData 3ms
โœ… OPDS2FullPublicationTests testAcquisitionLinks_FiltersCorrectly 11ms
โœ… OPDS2FullPublicationTests testBorrowLink_Found_ReturnsLink 2ms
โœ… OPDS2FullPublicationTests testCoverURL_CoverRel_ReturnsCorrectURL 2ms
โœ… OPDS2FullPublicationTests testCoverURL_LargeWidth_FallsBackToLargeImage 2ms
โœ… OPDS2FullPublicationTests testImageURL_NoRelImage_ReturnsFirst 2ms
โœ… OPDS2FullPublicationTests testIsAudiobook_AudiobookType_ReturnsTrue 2ms
โœ… OPDS2FullPublicationTests testIsEPUB_EpubType_ReturnsTrue 2ms
โœ… OPDS2FullPublicationTests testIsPDF_PdfType_ReturnsTrue 2ms
โœ… OPDS2FullPublicationTests testOpenAccessLink_Found_ReturnsLink 2ms
โœ… OPDS2FullPublicationTests testSampleLink_PreviewRel_ReturnsLink 2ms
โœ… OPDS2FullPublicationTests testSampleLink_SampleRel_ReturnsLink 2ms
โœ… OPDS2FullPublicationTests testThumbnailURL_SmallWidth_FallsBackToSmallImage 2ms
โœ… OPDS2FullPublicationTests testThumbnailURL_ThumbnailRel_ReturnsCorrectURL 2ms
โœ… OPDS2IntegrationTests testAllPublicationsConvertSuccessfully 11ms
โœ… OPDS2IntegrationTests testBorrowableBookConversion 16ms
โœ… OPDS2IntegrationTests testFeedFacets 10ms
โœ… OPDS2IntegrationTests testFeedIsGrouped 31ms
โœ… OPDS2IntegrationTests testFeedLinks 9ms
โœ… OPDS2IntegrationTests testFeedMetadata 8ms
โœ… OPDS2IntegrationTests testFormatDetection_JSON 8ms
โœ… OPDS2IntegrationTests testFormatDetection_XML 16ms
โœ… OPDS2IntegrationTests testFormatDetection_contentType 8ms
โœ… OPDS2IntegrationTests testFullPublicationFromJSON 52ms
โœ… OPDS2IntegrationTests testGroupCount 8ms
โœ… OPDS2IntegrationTests testNewAndNotableGroup 8ms
โœ… OPDS2IntegrationTests testOpenAccessBookConversion 11ms
โœ… OPDS2IntegrationTests testPopularAudiobooksGroup 8ms
โœ… OPDS2IntegrationTests testReadyBookConversion 13ms
โœ… OPDS2IntegrationTests testReservedBookWithLCPConversion 9ms
โœ… OPDS2IntegrationTests testStaffPicksGroup 18ms
โœ… OPDS2IntegrationTests testUnavailableAudiobookConversion 9ms
โœ… OPDS2LinkArrayTests testAllRel_MatchingLinks_ReturnsFiltered 4ms
โœ… OPDS2LinkArrayTests testAllRel_NoMatchingLinks_ReturnsEmpty 3ms
โœ… OPDS2LinkArrayTests testFirstRel_EmptyArray_ReturnsNil 207ms
โœ… OPDS2LinkArrayTests testFirstRel_MatchingLink_ReturnsFirst 3ms
โœ… OPDS2LinkArrayTests testFirstRel_NoMatch_ReturnsNil 5ms
โœ… OPDS2LinkComputedPropertyTests testHrefURL_InvalidURL_ReturnsNil 8ms
โœ… OPDS2LinkComputedPropertyTests testHrefURL_ValidURL_ReturnsURL 3ms
โœ… OPDS2LinkComputedPropertyTests testId_ReturnsHref 3ms
โœ… OPDS2LinkComputedPropertyTests testIsAcquisition_BorrowRel_ReturnsTrue 4ms
โœ… OPDS2LinkComputedPropertyTests testIsAcquisition_NilRel_ReturnsFalse 3ms
โœ… OPDS2LinkComputedPropertyTests testIsAcquisition_OpenAccessRel_ReturnsTrue 2ms
โœ… OPDS2LinkComputedPropertyTests testIsAcquisition_SelfRel_ReturnsFalse 2ms
โœ… OPDS2LinkComputedPropertyTests testIsBorrow_CorrectRel_ReturnsTrue 3ms
โœ… OPDS2LinkComputedPropertyTests testIsBorrow_OpenAccessRel_ReturnsFalse 2ms
โœ… OPDS2LinkComputedPropertyTests testIsImage_CoverRel_ReturnsTrue 4ms
โœ… OPDS2LinkComputedPropertyTests testIsImage_ImageType_ReturnsTrue 4ms
โœ… OPDS2LinkComputedPropertyTests testIsImage_NonImageType_ReturnsFalse 2ms
โœ… OPDS2LinkComputedPropertyTests testIsImage_ThumbnailRel_ReturnsTrue 2ms
โœ… OPDS2LinkComputedPropertyTests testIsOpenAccess_BorrowRel_ReturnsFalse 2ms
โœ… OPDS2LinkComputedPropertyTests testIsOpenAccess_CorrectRel_ReturnsTrue 3ms
โœ… OPDS2LinkComputedPropertyTests testIsSample_BorrowRel_ReturnsFalse 2ms
โœ… OPDS2LinkComputedPropertyTests testIsSample_PreviewRel_ReturnsTrue 2ms
โœ… OPDS2LinkComputedPropertyTests testIsSample_SampleRel_ReturnsTrue 2ms
โœ… OPDS2LinkComputedPropertyTests testLink_CodableRoundTrip_MinimalFields 2ms
โœ… OPDS2LinkComputedPropertyTests testLink_CodableRoundTrip_PreservesAllFields 2ms
โœ… OPDS2LinkRelTests testPasswordReset_hasCorrectRawValue 6ms
โœ… OPDS2LinkTests testLink_firstRelMethod_findsMatchingLink 90ms
โœ… OPDS2LinkTests testLink_hasHref 85ms
โœ… OPDS2ParsingTests testAuthDocument_basicAuthMechanism 35ms
โœ… OPDS2ParsingTests testAuthDocument_decodesTitleAndId 3ms
โœ… OPDS2ParsingTests testAuthDocument_featuresAndAnnouncements 3ms
โœ… OPDS2ParsingTests testAuthDocument_passwordResetLink_present 6ms
โœ… OPDS2ParsingTests testBookBridge_relationMapping_isExhaustiveForKnownRels 2ms
โœ… OPDS2ParsingTests testBookBridge_revokeAndIssues_excludedFromAcquisitions 2ms
โœ… OPDS2ParsingTests testBookBridge_unknownRel_returnsNil 3ms
โœ… OPDS2ParsingTests testCatalog_borrowLink_propertiesPreserved 5ms
โœ… OPDS2ParsingTests testCatalog_decodesWithExpectedPublicationCount 5ms
โœ… OPDS2ParsingTests testCatalog_isPublicationFeedFlag 5ms
โœ… OPDS2ParsingTests testCatalog_metadataTitleAndIdentifier 34ms
โœ… OPDS2ParsingTests testCatalog_multipleAuthors_preservedInOrder 4ms
โœ… OPDS2ParsingTests testCatalog_nextPageURL_capturedForPagination 7ms
โœ… OPDS2ParsingTests testCatalog_openAccessLink_isFlaggedOpenAccess 7ms
โœ… OPDS2ParsingTests testCatalog_publicationTitlesInOrder 5ms
โœ… OPDS2ParsingTests testCatalog_publication_imageURLs_separated 7ms
โœ… OPDS2ParsingTests testCatalog_searchURL_captured 6ms
โœ… OPDS2ParsingTests testCatalog_selfURL_captured 90ms
โœ… OPDS2ParsingTests testCatalogsFeed_parsesExistingFixture 4ms
โœ… OPDS2ParsingTests testCatalogsFeed_parsesSyntheticCatalogsArray 3ms
โœ… OPDS2ParsingTests testFeed_emptyData_throwsNotCrashes 3ms
โœ… OPDS2ParsingTests testFeed_emptyPublicationsArray_isEmptyNotNil 3ms
โœ… OPDS2ParsingTests testFeed_malformedJSON_throwsNotCrashes 3ms
โœ… OPDS2ParsingTests testFeed_publicationWithUnicodeTitle_preserved 23ms
โœ… OPDS2ParsingTests testFeed_publicationWithVeryLongTitle_preserved 5ms
โœ… OPDS2ParsingTests testGroupedFeed_decodesAllGroups 4ms
โœ… OPDS2ParsingTests testGroupedFeed_groupMoreURL_resolvesFromSelfOrSubsection 5ms
โœ… OPDS2ParsingTests testGroupedFeed_groupTitlesInOrder 9ms
โœ… OPDS2ParsingTests testGroupedFeed_navigationLanePreserved 5ms
โœ… OPDS2ParsingTests testGroupedFeed_publicationsPerGroup 7ms
โœ… OPDS2ParsingTests testProblemDocument_decodesAllRFC7807Fields 8ms
โœ… OPDS2ParsingTests testProblemDocument_malformedJSON_throwsNotCrashes 2ms
โœ… OPDS2ParsingTests testPublication_imageURLs_areExtractedFromImagesArray 3ms
โœ… OPDS2ParsingTests testPublication_isSampleClassifier_acceptsBothPreviewAndSampleRel 52ms
โœ… OPDS2ParsingTests testPublication_multipleAcquisitionLinks_allRetained 3ms
โœ… OPDS2ParsingTests testPublication_toBook_skipsWhenNoAcquisitionLinks 6ms
โœ… OPDS2ParsingTests testPublication_toBook_skipsWhenNoSupportedAcquisitionPath 3ms
โœ… OPDS2ParsingTests testPublication_toBook_succeedsForSupportedEpubOpenAccess 3ms
โœ… OPDS2PublicationExtendedTests testContributorDecodesFromObject 2ms
โœ… OPDS2PublicationExtendedTests testContributorDecodesFromString 2ms
โœ… OPDS2PublicationExtendedTests testConvertAcquisitionFromBorrowLink 2ms
โœ… OPDS2PublicationExtendedTests testConvertAcquisitionFromNonAcquisitionLink 2ms
โœ… OPDS2PublicationExtendedTests testConvertAcquisitionSynthesizesIndirectForBearerToken 2ms
โœ… OPDS2PublicationExtendedTests testConvertAcquisitionSynthesizesIndirectForLCP 2ms
โœ… OPDS2PublicationExtendedTests testConvertAcquisitionWithExplicitIndirectAcquisitions 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityAvailableWithCopies 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityAvailableWithoutCopies 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityNil 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityReady 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityReserved 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityReservedWithZeroPosition 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityUnavailable 2ms
โœ… OPDS2PublicationExtendedTests testConvertAvailabilityUnknownState 2ms
โœ… OPDS2PublicationExtendedTests testConvertIndirectAcquisitionsFlat 2ms
โœ… OPDS2PublicationExtendedTests testConvertIndirectAcquisitionsNested 2ms
โœ… OPDS2PublicationExtendedTests testConvertIndirectAcquisitions_nilOrEmptyInputYieldsEmptyResult 2ms
โœ… OPDS2PublicationExtendedTests testExtractImageURLsFallsBackToFirstImage 20ms
โœ… OPDS2PublicationExtendedTests testExtractImageURLsNil 2ms
โœ… OPDS2PublicationExtendedTests testExtractImageURLsWithExplicitRels 2ms
โœ… OPDS2PublicationExtendedTests testExtractSpecialLinks 2ms
โœ… OPDS2PublicationExtendedTests testExtractSpecialLinksEmpty 3ms
โœ… OPDS2PublicationExtendedTests testFullMetadataCodableRoundTrip 10ms
โœ… OPDS2PublicationExtendedTests testFullMetadataDecodesWithAlternateIdKey 2ms
โœ… OPDS2PublicationExtendedTests testFullMetadataDecodesWithMissingIdentifier 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationAcquisitionLinks 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationContentType 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationDurationFormatting 6ms
โœ… OPDS2PublicationExtendedTests testFullPublicationDurationFormattingSubHour 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationId_delegatesToMetadataIdentifierAcrossInstances 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationImageURLs 2ms
โœ… OPDS2PublicationExtendedTests testFullPublicationToBookReturnsNilWithNoAcquisitions 2ms
โœ… OPDS2PublicationExtendedTests testFullPublication_seriesNameAndURL_extractedFromBelongsTo 10ms
โœ… OPDS2PublicationExtendedTests testFullPublication_seriesNameOnly_whenLinksAbsent 2ms
โœ… OPDS2PublicationExtendedTests testFullPublication_seriesNil_whenBelongsToAbsent 3ms
โœ… OPDS2PublicationExtendedTests testFullPublication_seriesNil_whenBelongsToSeriesEmpty 2ms
โœ… OPDS2PublicationExtendedTests testOPDS2FullPublication_toBook_streamingMediaOnlyAcquisition_doesNotDrop 3ms
โœ… OPDS2PublicationExtendedTests testOPDS2Publication_toBook_streamingMediaOnlyAcquisition_doesNotDrop 3ms
โœ… OPDS2PublicationExtendedTests testOPDS2Publication_toBook_trulyUnsupportedFormat_stillDropped 4ms
โœ… OPDS2PublicationExtendedTests testRelationFromBorrow 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromBuy 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromGenericAcquisition 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromIssuesRelIsNil 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromNonAcquisitionRel 5ms
โœ… OPDS2PublicationExtendedTests testRelationFromOpenAccess 13ms
โœ… OPDS2PublicationExtendedTests testRelationFromPreview 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromRevokeRelIsNil 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromSample 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromSubscribe 2ms
โœ… OPDS2PublicationExtendedTests testRelationFromUnknownAcquisitionSubtype 2ms
โœ… OPDS2PublicationExtendedTests testSubjectDecodesFromObject 2ms
โœ… OPDS2PublicationExtendedTests testSubjectDecodesFromString 2ms
โœ… OPDS2PublicationImageTests testCoverURL_CoverRel_ReturnsURL 2ms
โœ… OPDS2PublicationImageTests testImageURL_NoImages_ReturnsNil 3ms
โœ… OPDS2PublicationImageTests testImageURL_NonPNGImage_ReturnsNil 5ms
โœ… OPDS2PublicationImageTests testImageURL_PNGImage_ReturnsURL 4ms
โœ… OPDS2PublicationImageTests testThumbnailURL_NoThumbnailRel_ReturnsNil 4ms
โœ… OPDS2PublicationImageTests testThumbnailURL_ThumbnailRel_ReturnsURL 5ms
โœ… OPDS2PublicationNarratorTests testToBook_WithMultipleNarrators_JoinsWithSemicolons 12ms
โœ… OPDS2PublicationNarratorTests testToBook_WithNarratorInJSON_ExposesNarratorOnBook 1.90s
โœ… OPDS2PublicationNarratorTests testToBook_WithoutNarrator_BookHasNilNarrators 301ms
โœ… OPDS2PublicationTests testPublication_hasRequiredFields 98ms
โœ… OPDS2PublicationTests testPublication_metadataHasTitle 87ms
โœ… OPDS2SamlIDPTests testDisplayName_WithEnglishName_ReturnsEnglishValue 5ms
โœ… OPDS2SamlIDPTests testDisplayName_WithNoEnglishName_ReturnsNil 6ms
โœ… OPDS2SamlIDPTests testIdpDescription_WithEnglishDescription_ReturnsValue 2ms
โœ… OPDS2SamlIDPTests testIdpDescription_WithNoDescriptions_ReturnsNil 29ms
โœ… OPDS2SamlIDPTests testInit_WithInvalidHref_ReturnsNil 5ms
โœ… OPDS2SamlIDPTests testInit_WithValidLink_MapsURLCorrectly 4ms
โœ… OPDS2SearchResultsContractTests testSearchResults_ContainsThreePublications 7ms
โœ… OPDS2SearchResultsContractTests testSearchResults_HasNextPageLink 16ms
โœ… OPDS2SearchResultsContractTests testSearchResults_ParsesWithPagination 4ms
โœ… OPDS2SubjectTests testDecode_ObjectValue_ParsesAllFields 5ms
โœ… OPDS2SubjectTests testDecode_StringValue_ParsesAsName 4ms
โœ… OPDS2SupportingTypesTests testBelongsTo_SeriesWithPosition 10ms
โœ… OPDS2SupportingTypesTests testFacetLink_IsActive_WithNumberOfItems_ReturnsTrue 4ms
โœ… OPDS2SupportingTypesTests testFacetLink_IsActive_WithoutProperties_ReturnsFalse 2ms
โœ… OPDS2SupportingTypesTests testIndirectAcquisition_NestedChild 10ms
โœ… OPDS2SupportingTypesTests testPrice_CodableRoundTrip 10ms
โœ… OPDSAcquisitionPathExpandedTests test_acquisitionFromSingleEntry_hasDictionaryRepresentation 7ms
โœ… OPDSAcquisitionPathExpandedTests test_acquisitionRelationString_distinctStringsForOpenAccessAndBorrow 2ms
โœ… OPDSAcquisitionPathExpandedTests test_entryFromSingleEntryXML_hasAuthors 10ms
โœ… OPDSAcquisitionPathExpandedTests test_entryFromSingleEntryXML_hasCorrectTitle 13ms
โœ… OPDSAcquisitionPathExpandedTests test_entryFromSingleEntryXML_hasIdentifier 4ms
โœ… OPDSAcquisitionPathExpandedTests test_entryInitWithInvalidXML_returnsNil 3ms
โœ… OPDSAcquisitionPathExpandedTests test_feedFromMainXML_hasEntries 83ms
โœ… OPDSAcquisitionPathExpandedTests test_feedFromMainXML_hasIdentifier 90ms
โœ… OPDSAcquisitionPathExpandedTests test_feedFromMainXML_hasLinks 104ms
โœ… OPDSAcquisitionPathExpandedTests test_feedFromMainXML_hasTitle 94ms
โœ… OPDSAcquisitionPathExpandedTests test_feedFromMainXML_hasUpdatedDate 89ms
โœ… OPDSAcquisitionPathExpandedTests test_initWithNilXML_returnsNilOnFeedAndLink 3ms
โœ… OPDSAcquisitionPathExpandedTests test_linkFromSingleEntryXML_hasHref 5ms
โœ… OPDSAcquisitionPathExpandedTests test_linksFromSingleEntryXML_haveCorrectCount 5ms
โœ… OPDSAcquisitionPathExpandedTests test_supportedTypes_andAudiobookTypes_areNonEmptyAndDistinguishable 2ms
โœ… OPDSFeedCacheTests testCacheEntryIsExpired 6ms
โœ… OPDSFeedCacheTests testCacheEntryIsStale 6ms
โœ… OPDSFeedCacheTests testClear 5ms
โœ… OPDSFeedCacheTests testConditionalHeaders 12ms
โœ… OPDSFeedCacheTests testConditionalHeadersEmptyWhenNoCachedEntry 3ms
โœ… OPDSFeedCacheTests testExpiredEntriesNotReturned 33ms
โœ… OPDSFeedCacheTests testGetNonExistent 8ms
โœ… OPDSFeedCacheTests testGetWithRevalidationFetchesWhenNoCache 5ms
โœ… OPDSFeedCacheTests testGetWithRevalidationReturnsFreshData 2ms
โœ… OPDSFeedCacheTests testLRUEviction 113ms
โœ… OPDSFeedCacheTests testLRUUpdatesOnAccess 8ms
โœ… OPDSFeedCacheTests testRemove 3ms
โœ… OPDSFeedCacheTests testSetAndGet 6ms
โœ… OPDSFeedCacheTests testStats 6ms
โœ… OPDSFeedMigrationTests testErrorMessageFallback_noDetail_usesLocalizedDescription 2ms
โœ… OPDSFeedMigrationTests testErrorMessageFallback_problemDocDetail 2ms
โœ… OPDSFeedMigrationTests testHalfSheetProvider_showAlert_exists 2ms
โœ… OPDSFeedMigrationTests testReturnBook_authErrors_notTolerated 2ms
โœ… OPDSFeedMigrationTests testReturnBook_nonOPDSRevokeResponse_treatedAsSuccess 2ms
โœ… OPDSFeedMigrationTests testReturnBook_otherParsingErrors_notTolerated 2ms
โœ… OPDSFeedMigrationTests testSignInModalPresenter_needsAuthCheck_anonymousReturnsFalse 2ms
โœ… OPDSFeedMigrationTests testSignInModalPresenter_needsAuthCheck_basicReturnsTrue 3ms
โœ… OPDSFeedMigrationTests testSignInModalPresenter_needsAuthCheck_oidcReturnsTrue 3ms
โœ… OPDSFeedMigrationTests testSyntheticErrorDict_containsHTTPStatus 2ms
โœ… OPDSFeedMigrationTests testSyntheticErrorDict_parsesAsProblemDocument 2ms
โœ… OPDSFeedParsingTests testParseInvalidOPDSFeed 11ms
โœ… OPDSFeedParsingTests testParseValidOPDSFeed 270ms
โœ… OPDSFeedServiceStateMachineTests testFetchLoansFeed_blocksUntilLoaded_thenFetches 401ms
โœ… OPDSFeedServiceStateMachineTests testFetchLoansFeed_failedDetailsLoad_throws 123ms
โœ… OPDSFeedServiceStateMachineTests testFetchLoansFeed_failedDetailsLoad_throwsAccountLoadError_notPalaceError 104ms
โœ… OPDSFeedServiceTests testCancelAllRequests_isNoOpAndIdempotent_whenNothingInFlight 7ms
โœ… OPDSFeedServiceTests testCancelRequest_isNoOpAndIdempotent_whenNoInflightRequestForUrl 3ms
โœ… OPDSFormatTests testDetectIsCaseInsensitive 3ms
โœ… OPDSFormatTests testDetectOPDS1FromAtomXMLContentType 2ms
โœ… OPDSFormatTests testDetectOPDS1FromGenericXMLContentType 3ms
โœ… OPDSFormatTests testDetectOPDS1FromXMLData 4ms
โœ… OPDSFormatTests testDetectOPDS2FromGenericJSONContentType 4ms
โœ… OPDSFormatTests testDetectOPDS2FromJSONArrayData 4ms
โœ… OPDSFormatTests testDetectOPDS2FromJSONContentType 3ms
โœ… OPDSFormatTests testDetectOPDS2FromJSONData 437ms
โœ… OPDSFormatTests testDetectUnknownFromEmptyData 56ms
โœ… OPDSFormatTests testDetectUnknownFromNilContentType 4ms
โœ… OPDSFormatTests testDetectUnknownFromUnrelatedContentType 3ms
โœ… OPDSFormatTests testOPDS1RawValue 2ms
โœ… OPDSFormatTests testOPDS2RawValue 3ms
โœ… OPDSParserCoreTests testParseEmptyDataThrows 4ms
โœ… OPDSParserCoreTests testParseInvalidXMLThrows 4ms
โœ… OPDSParserCoreTests testParseValidOPDS1Feed 3ms
โœ… OPDSParserCoreTests testParserErrorDescriptions 3ms
โœ… OPDSParserTests testParseFeed_throwsForInvalidData 9ms
โœ… OPDSParserTests testParseFeed_throwsForNonXML 26ms
โœ… OPDSParserTests testParserError_invalidFeed 3ms
โœ… OPDSParserTests testParserError_invalidXML 3ms
โœ… OPDSParsingTests testAcquisitionLinks 5ms
โœ… OPDSParsingTests testAnalyticsURLGeneration 5ms
โœ… OPDSParsingTests testAuthorWithMissingName 5ms
โœ… OPDSParsingTests testCategoryWithMissingTerm 3ms
โœ… OPDSParsingTests testEmptyXMLData 3ms
โœ… OPDSParsingTests testEntryExtractionFromFeed 5ms
โœ… OPDSParsingTests testEntryWithCategories 3ms
โœ… OPDSParsingTests testEntryWithContributors 6ms
โœ… OPDSParsingTests testEntryWithDuration 3ms
โœ… OPDSParsingTests testEntryWithMissingId 5ms
โœ… OPDSParsingTests testEntryWithMissingTitle 9ms
โœ… OPDSParsingTests testEntryWithMissingUpdated 3ms
โœ… OPDSParsingTests testEntryWithMultipleAuthors 3ms
โœ… OPDSParsingTests testEntryWithNamespacedContributorRoles_ParsesNarrator 4ms
โœ… OPDSParsingTests testEntryWithPublisherAndDistribution 4ms
โœ… OPDSParsingTests testEntryWithUnnamespacedContributorRole_StillParses 3ms
โœ… OPDSParsingTests testEntry_AudienceAndLanguageNilWhenAbsent 5ms
โœ… OPDSParsingTests testEntry_AudienceCategoryIsNotInRegularCategoryList 3ms
โœ… OPDSParsingTests testEntry_ParsesAudienceFromSchemaOrgCategory 8ms
โœ… OPDSParsingTests testEntry_ParsesLanguageWithDctermsNamespace 6ms
โœ… OPDSParsingTests testEntry_ParsesLanguageWithoutNamespaceDeclaration 742ms
โœ… OPDSParsingTests testFeedIgnoresMalformedEntries 7ms
โœ… OPDSParsingTests testFeedIgnoresMalformedLinks 3ms
โœ… OPDSParsingTests testFeedInitializationFromCompleteFeed 19ms
โœ… OPDSParsingTests testFeedInitializationFromMinimalXML 5ms
โœ… OPDSParsingTests testFeedInitializationFromSingleEntry 8ms
โœ… OPDSParsingTests testFeedParsingPerformance 4.54s
โœ… OPDSParsingTests testFeedTypeAcquisitionGrouped 5ms
โœ… OPDSParsingTests testFeedTypeAcquisitionUngrouped 62ms
โœ… OPDSParsingTests testFeedTypeAcquisitionUngroupedWithEmptyFeed 4ms
โœ… OPDSParsingTests testFeedTypeNavigation 6ms
โœ… OPDSParsingTests testFeedWithInvalidDate 124ms
โœ… OPDSParsingTests testFeedWithLicensorAndPatron 4ms
โœ… OPDSParsingTests testFeedWithMissingId 3ms
โœ… OPDSParsingTests testFeedWithMissingTitle 13ms
โœ… OPDSParsingTests testFeedWithMissingUpdated 4ms
โœ… OPDSParsingTests testGroupAttributes 18ms
โœ… OPDSParsingTests testHTMLEntityDecoding 14ms
โœ… OPDSParsingTests testImageLinks 4ms
โœ… OPDSParsingTests testLinkInitialization 4ms
โœ… OPDSParsingTests testLinkRelationAlternate 4ms
โœ… OPDSParsingTests testLinkRelationAnnotations 4ms
โœ… OPDSParsingTests testLinkRelationRelatedWorks 7ms
โœ… OPDSParsingTests testLinkRelationTimeTracking 5ms
โœ… OPDSParsingTests testLinkWithMissingHref 7ms
โœ… OPDSParsingTests testLinkWithOptionalAttributesNil 4ms
โœ… OPDSParsingTests testMalformedXML 2ms
โœ… OPDSParsingTests testNilXMLFeed 2ms
โœ… OPDSParsingTests testNonMarketplaceHTMLPreviewIsAccepted 7ms
โœ… OPDSParsingTests testPalaceMarketplaceHTMLPreviewIsAccepted 5ms
โœ… OPDSParsingTests testPreviewLinkParsing 3ms
โœ… OPDSParsingTests testPreviewLinkUsesFirstAvailable 4ms
โœ… OPDSParsingTests testRFC3339DateParsing 17ms
โœ… OPDSParsingTests testSeriesLink 4ms
โœ… OPDSParsingTests testSeriesLinkParsedFromEntry 3ms
โœ… OPDSParsingTests testTPPBookFromEntry_populatesSeriesNameAndURLFromSeriesLink 5ms
โœ… OPDSParsingTests testTPPBookFromEntry_seriesNameAndURLNilWhenNoSeriesElement 79ms
โœ… OfflineActionTests testActionState_CodableRoundTrip 5ms
โœ… OfflineActionTests testActionType_CodableRoundTrip 6ms
โœ… OfflineActionTests testBorrowAction_Creation 2ms
โœ… OfflineActionTests testCanRetry_CompletedState_False 15ms
โœ… OfflineActionTests testCanRetry_FailedExceedingMaxRetries_False 235ms
โœ… OfflineActionTests testCanRetry_FailedWithRetriesExhausted_False 2ms
โœ… OfflineActionTests testCanRetry_FailedWithRetriesRemaining_True 11ms
โœ… OfflineActionTests testCanRetry_PendingState_False 2ms
โœ… OfflineActionTests testCanRetry_ProcessingState_False 3ms
โœ… OfflineActionTests testCanRetry_ZeroMaxRetries_AlwaysFalse 21ms
โœ… OfflineActionTests testCancelHoldAction_Creation 4ms
โœ… OfflineActionTests testCodableRoundTrip_AllActionTypes 4ms
โœ… OfflineActionTests testCodableRoundTrip_FailedAction 3ms
โœ… OfflineActionTests testCodableRoundTrip_PendingAction 37ms
โœ… OfflineActionTests testCustomMaxRetries 2ms
โœ… OfflineActionTests testDisplayDescription_Borrow 6ms
โœ… OfflineActionTests testDisplayDescription_CancelHold 14ms
โœ… OfflineActionTests testDisplayDescription_Hold 33ms
โœ… OfflineActionTests testDisplayDescription_Return 2ms
โœ… OfflineActionTests testEquality_DifferentID_NotEqual 2ms
โœ… OfflineActionTests testEquality_SameID_Equal 4ms
โœ… OfflineActionTests testHoldAction_Creation 35ms
โœ… OfflineActionTests testNextRetryDelay_FirstRetry 3ms
โœ… OfflineActionTests testNextRetryDelay_FourthRetry 2ms
โœ… OfflineActionTests testNextRetryDelay_GrowsExponentially 11ms
โœ… OfflineActionTests testNextRetryDelay_SecondRetry 6ms
โœ… OfflineActionTests testNextRetryDelay_ThirdRetry 3ms
โœ… OfflineActionTests testRetryCount_IncrementWorks 4ms
โœ… OfflineActionTests testReturnAction_Creation 4ms
โœ… OfflineQueueServiceExtendedTests testCancel_NonexistentAction_NoOp 9ms
โœ… OfflineQueueServiceExtendedTests testCancel_SpecificPendingAction 11ms
โœ… OfflineQueueServiceExtendedTests testClearFailed_RemovesOnlyFailedActions 620ms
โœ… OfflineQueueServiceExtendedTests testIsProcessing_InitiallyFalse 13ms
โœ… OfflineQueueServiceExtendedTests testMaxRetriesReached_ActionMarkedAsFailed 3.03s
โœ… OfflineQueueServiceExtendedTests testPersistence_ProcessingState_ResetToPending 10ms
โœ… OfflineQueueServiceExtendedTests testPersistence_SaveAndReload 11ms
โœ… OfflineQueueServiceExtendedTests testProcessQueue_FIFO_Order 516ms
โœ… OfflineQueueServiceExtendedTests testQueueStatus_EmptyQueue 113ms
โœ… OfflineQueueServiceExtendedTests testQueueStatus_Summary_AllStates 4ms
โœ… OfflineQueueServiceExtendedTests testQueueStatus_TotalActive 7ms
โœ… OfflineQueueServiceExtendedTests testQueueStatus_WithPendingActions 13ms
โœ… OfflineQueueServiceExtendedTests testRetry_MovesFailedToPending 1.05s
โœ… OfflineQueueServiceTests testActionPublisherEmits 10ms
โœ… OfflineQueueServiceTests testCancelPendingAction 7ms
โœ… OfflineQueueServiceTests testClearFailed 220ms
โœ… OfflineQueueServiceTests testEnqueueAction 110ms
โœ… OfflineQueueServiceTests testEnqueueMultipleActions 11ms
โœ… OfflineQueueServiceTests testExponentialBackoff 2ms
โœ… OfflineQueueServiceTests testMaxRetriesExceeded 1.04s
โœ… OfflineQueueServiceTests testNetworkAvailableTriggersProcessing 212ms
โœ… OfflineQueueServiceTests testOfflineActionCanRetry 6ms
โœ… OfflineQueueServiceTests testOfflineActionDisplayDescription 9ms
โœ… OfflineQueueServiceTests testOfflineQueueStatusSummary 7ms
โœ… OfflineQueueServiceTests testProcessQueueFIFOOrder 212ms
โœ… OfflineQueueServiceTests testProcessQueueSuccess 109ms
โœ… OfflineQueueServiceTests testProcessingStateResetOnRestart 10ms
โœ… OfflineQueueServiceTests testQueuePersistsAcrossInstances 15ms
โœ… OfflineQueueServiceTests testRetryFailedAction 5.12s
โœ… OfflineQueueServiceTests testStatusPublisherEmits 53ms
โœ… OpenAccessAdapterTests testCanHandle_anyOPDSBook_returnsTrueAsFallback 8ms
โœ… OpenAccessAdapterTests testResolveManifest_emptyData_failsWithManifestFetchFailed 161ms
โœ… OpenAccessAdapterTests testResolveManifest_htmlResponse_failsWithManifestFetchFailed 181ms
โœ… OpenAccessAdapterTests testResolveManifest_invalidJSON_failsWithManifestParseFailed 758ms
โœ… OpenAccessAdapterTests testResolveManifest_networkError_failsWithManifestFetchFailed 2.90s
โœ… OpenAccessAdapterTests testResolveManifest_successPath_completesWithJSON 72ms
โœ… OverdriveDeferredFulfillmentTests testDeferFires_whenDownloadFailedWithBorrowAcquisition 9ms
โœ… OverdriveDeferredFulfillmentTests testDeferFires_whenDownloadNeededWithBorrowAcquisition 2ms
โœ… OverdriveDeferredFulfillmentTests testDeferSkipped_whenDefaultAcquisitionIsGeneric 3ms
โœ… OverdriveDeferredFulfillmentTests testDeferSkipped_whenDefaultAcquisitionIsOpenAccess 2ms
โœ… OverdriveDeferredFulfillmentTests testDeferSkipped_whenStateIsHolding 2ms
โœ… OverdriveDeferredFulfillmentTests testDeferSkipped_whenStateIsUnregistered 2ms
โœ… OverdriveDownloadHandlerTests testDeferOverdriveFulfillment_publishesLoanAlreadyExistsBorrowError 44ms
โœ… OverdriveDownloadHandlerTests testHandleOverdriveResponse_completionWithError_failsDownloadAndSkipsManifestBuild 53ms
โœ… OverdriveDownloadHandlerTests testHandleOverdriveResponse_manifestFactoryReturnsNil_failsDownload 49ms
โœ… OverdriveDownloadHandlerTests testHandleOverdriveResponse_missingLocationHeader_failsDownload 47ms
โœ… OverdriveDownloadHandlerTests testHandleOverdriveResponse_uppercaseHeaderKeys_arelowercaseNormalized 18ms
โœ… OverdriveDownloadHandlerTests testHandleOverdriveResponse_validHeaders_buildsManifestRequestAndAddsDownloadTask 15ms
โœ… OverdriveDownloadHandlerTests testProcessOverdriveDownload_whenWifiEnforced_failsWithWifiAndDoesNotCallAPI 6ms
โœ… OverdriveDownloadHandlerTests testProcessOverdriveDownload_withAuthToken_issuesTokenFulfillRequest 6ms
โœ… OverdriveDownloadHandlerTests testProcessOverdriveDownload_withBarcodePin_issuesBasicFulfillRequest 6ms
โœ… OverdriveFulfillmentTests test_overdriveAudiobook_deferredFulfillment_isUsedWhenStateMatches 44ms
โœ… OverdriveFulfillmentTests test_overdriveOPDSEntry_postBorrow_recognizesBorrowURLAsStale 30ms
โœ… OverdriveFulfillmentTests test_overdriveScope_addsCorrectHeaders 8ms
โœ… OverdriveFulfillmentTests test_overdriveTokenAbsent_fallsBackToBasicAuth 14ms
โœ… OverdriveFulfillmentTests test_overdriveTokenRefresh_beforeOpen 9ms
โœ… PDFExtensionsTests testBookmarkSelector_RoundTrips_AsTPPPDFPageBookmark 4ms
โœ… PDFExtensionsTests testBookmarkSelector_ValidPage_ContainsLocatorPageType 6ms
โœ… PDFExtensionsTests testLocationString_PageZero_ReturnsValidJSON 3ms
โœ… PDFExtensionsTests testLocationString_RoundTrips_WithDecoder 4ms
โœ… PDFExtensionsTests testLocationString_ValidPage_ReturnsJSONString 8ms
โœ… PDFExtensionsTests testPageNumber_EmptyLocationString_ReturnsNil 2ms
โœ… PDFExtensionsTests testPageNumber_InvalidLocationString_ReturnsNil 3ms
โœ… PDFExtensionsTests testPageNumber_LargePageNumber_ReturnsCorrectly 3ms
โœ… PDFExtensionsTests testPageNumber_NonPDFLocationString_ReturnsNil 4ms
โœ… PDFExtensionsTests testPageNumber_PageZero_ReturnsZero 3ms
โœ… PDFExtensionsTests testPageNumber_ValidLocationString_ReturnsPageNumber 3ms
โœ… PDFExtensionsTests testPdfImageRenderingQueue_CreatesNewInstanceEachTime 2ms
โœ… PDFExtensionsTests testPdfImageRenderingQueue_HasCorrectLabel 4ms
โœ… PDFExtensionsTests testPdfPreviewSize_IsLargerThanThumbnail 11ms
โœ… PDFExtensionsTests testPdfPreviewSize_IsSquare 2ms
โœ… PDFExtensionsTests testPdfPreviewSize_ReturnsExpectedDimensions 3ms
โœ… PDFExtensionsTests testPdfThumbnailRenderingQueue_CreatesNewInstanceEachTime 3ms
โœ… PDFExtensionsTests testPdfThumbnailRenderingQueue_HasCorrectLabel 2ms
โœ… PDFExtensionsTests testPdfThumbnailSize_IsSquare 3ms
โœ… PDFExtensionsTests testPdfThumbnailSize_ReturnsExpectedDimensions 39ms
โœ… PDFReaderTests testLCPPDFBook_ContentType 7ms
โœ… PDFReaderTests testPDFBook_ContentType 6ms
โœ… PDFReaderTests testPDFPageBookmark_ConformsToBookmark 4ms
โœ… PDFReaderTests testPDFPageBookmark_Decoding 2ms
โœ… PDFReaderTests testPDFPageBookmark_Encoding 9ms
โœ… PDFReaderTests testPDFPageBookmark_Initialization 4ms
โœ… PDFReaderTests testPDFPageBookmark_WithAnnotationID 2ms
โœ… PDFReaderTests testPDFPage_Decoding 5ms
โœ… PDFReaderTests testPDFPage_Encoding 3ms
โœ… PDFReaderTests testPDFPage_Initialization 5ms
โœ… PDFReaderTests testPDFPage_RoundTrip 2ms
โœ… PDFReaderTests testReaderMode_Values 3ms
โœ… PP3596RegressionTests testPP3596_multiplePlaybackStartedCalls_shouldNotOvercount 30ms
โœ… PP3596RegressionTests testPP3596_onlyActualPlaybackIsTracked 53ms
โœ… PP3596RegressionTests testPP3596_playbackStartedWithoutPlayback_shouldNotAccumulateTime 14ms
โœ… Palace PalaceTests <1ms
โœ… Palace TenPrintCoverTests <1ms
โœ… PalaceCheckPropertyTests test_BackoffDelay_isNonNegativeAndMonotone 3ms
โœ… PalaceCheckPropertyTests test_BookButtonMapper_map_isTotal_forAllStates 22ms
โœ… PalaceCheckPropertyTests test_OPDS2Publication_jsonRoundTrip 15ms
โœ… PalaceCheckPropertyTests test_TPPBookState_disallowedTransitionsAreRejected 2ms
โœ… PalaceCheckPropertyTests test_TPPBookState_selfTransitionsAlwaysAllowed 2ms
โœ… PalaceCheckPropertyTests test_TPPBookState_unregisteredToDownloadingAllowed 2ms
โœ… PalaceCheckPropertyTests test_TPPBookState_validSequencesRespectTable 9ms
โœ… PalaceCheckPropertyTests test_TPPBook_dictionaryRoundTrip 104ms
โœ… PalaceErrorCategoryTests testAuthenticationError_allCases_haveDescriptions 2ms
โœ… PalaceErrorCategoryTests testBookReaderError_allCases_haveDescriptions 9ms
โœ… PalaceErrorCategoryTests testDownloadError_allCases_haveDescriptions 2ms
โœ… PalaceErrorCategoryTests testErrorCode_authErrors_startAt6000 2ms
โœ… PalaceErrorCategoryTests testErrorCode_downloadErrors_startAt3000 2ms
โœ… PalaceErrorCategoryTests testErrorCode_drmErrors_startAt5000 5ms
โœ… PalaceErrorCategoryTests testErrorCode_networkErrors_startAt1000 2ms
โœ… PalaceErrorCategoryTests testErrorCode_uniquePerCase 2ms
โœ… PalaceErrorCategoryTests testFromNSError_unknownDomain_mapsToNetworkUnknown 2ms
โœ… PalaceErrorCategoryTests testFromNSError_urlErrorCancelled_mapsToCancelled 2ms
โœ… PalaceErrorCategoryTests testFromNSError_urlErrorNotConnected_mapsToNoConnection 3ms
โœ… PalaceErrorCategoryTests testFromNSError_urlErrorTimedOut_mapsToTimeout 7ms
โœ… PalaceErrorCategoryTests testLocalizedError_conformance 2ms
โœ… PalaceErrorCategoryTests testNetworkError_allCases_haveDescriptions 6ms
โœ… PalaceErrorCategoryTests testOpdsFeedInvalid_errorDescriptionIsUserFacing 2ms
โœ… PalaceErrorCategoryTests testOpdsFeedInvalid_localizedKey_hasPlaceholderEnglishValue 2ms
โœ… PalaceErrorCategoryTests testOpdsFeedInvalid_recoverySuggestionPresent 2ms
โœ… PalaceErrorCategoryTests testRecoverySuggestion_downloadInsufficientSpace 2ms
โœ… PalaceErrorCategoryTests testRecoverySuggestion_networkErrors_provideGuidance 2ms
โœ… PalaceErrorCategoryTests testStorageError_allCases_haveDescriptions 2ms
โœ… PalaceErrorExtendedTests testAudiobookError_allCases_haveDescriptions 2ms
โœ… PalaceErrorExtendedTests testAudiobookError_allCases_haveRecoverySuggestions 2ms
โœ… PalaceErrorExtendedTests testBookRegistryError_allCases_haveDescriptions 2ms
โœ… PalaceErrorExtendedTests testBookRegistryError_allCases_haveRecoverySuggestions 3ms
โœ… PalaceErrorExtendedTests testCancellation_yieldsNoRecoverySuggestionAcrossNetworkAndDownload 2ms
โœ… PalaceErrorExtendedTests testDRMError_allCases_haveDescriptions 2ms
โœ… PalaceErrorExtendedTests testDRMError_allCases_haveRecoverySuggestions 2ms
โœ… PalaceErrorExtendedTests testErrorCode_categoryOffsetsAreUniqueAndStable 4ms
โœ… PalaceErrorExtendedTests testErrorCode_offsetByRawValue 2ms
โœ… PalaceErrorExtendedTests testFromError_palaceErrorPassedDirectly_returnsItself 4ms
โœ… PalaceErrorExtendedTests testFromNSError_palaceDomain_code0_mapsToNetworkUnknown 8ms
โœ… PalaceErrorExtendedTests testFromNSError_palaceDomain_code3_mapsToParsingOpdsFeedInvalid 2ms
โœ… PalaceErrorExtendedTests testFromNSError_palaceDomain_code5_mapsToAuthInvalidCredentials 2ms
โœ… PalaceErrorExtendedTests testFromNSError_palaceDomain_code8_mapsToAudiobookPlaybackError 2ms
โœ… PalaceErrorExtendedTests testFromNSError_palaceDomain_unknownCode_mapsToNetworkUnknown 3ms
โœ… PalaceErrorExtendedTests testFromNSError_urlErrorBadURL_mapsToInvalidURL 5ms
โœ… PalaceErrorExtendedTests testFromNSError_urlErrorCannotConnectToHost_mapsToServerError 3ms
โœ… PalaceErrorExtendedTests testFromNSError_urlErrorCannotFindHost_mapsToServerError 3ms
โœ… PalaceErrorExtendedTests testFromNSError_urlErrorUnsupportedURL_mapsToInvalidURL 2ms
โœ… PalaceErrorExtendedTests testPalaceError_localizedErrorSurface_delegatesToInnerError 4ms
โœ… PalaceErrorExtendedTests testParsingError_allCases_haveDescriptions 2ms
โœ… PalaceErrorExtendedTests testParsingError_contentNotSupported_hasSpecificRecovery 294ms
โœ… PalaceErrorExtendedTests testParsingError_otherCases_haveGenericRecovery 3ms
โœ… PalaceErrorTests testPalaceError_authentication_accountNotFound 10ms
โœ… PalaceErrorTests testPalaceError_authentication_invalidCredentials 4ms
โœ… PalaceErrorTests testPalaceError_authentication_tokenExpired 224ms
โœ… PalaceErrorTests testPalaceError_bookRegistry_alreadyBorrowed 5ms
โœ… PalaceErrorTests testPalaceError_bookRegistry_bookNotFound 12ms
โœ… PalaceErrorTests testPalaceError_download_cannotFulfill 18ms
โœ… PalaceErrorTests testPalaceError_network_forbidden 11ms
โœ… PalaceErrorTests testPalaceError_network_notFound 4ms
โœ… PalaceErrorTests testPalaceError_network_rateLimited 2ms
โœ… PalaceErrorTests testPalaceError_network_serverError 73ms
โœ… PalaceErrorTests testPalaceError_parsing_opdsFeedInvalid 14ms
โœ… PalacePDFViewTests testAllowsCopy_defaultsToTrue 11ms
โœ… PalacePDFViewTests testCanPerformAccessibilityAction_whenAllowsCopyIsFalse_defersToSuper 18ms
โœ… PalacePDFViewTests testCanPerformCopy_whenAllowsCopyIsFalse_returnsFalse 7ms
โœ… PalacePDFViewTests testCanPerformCopy_whenAllowsCopyIsTrue_doesNotShortCircuit 7ms
โœ… PalacePDFViewTests testCanPerformCut_whenAllowsCopyIsFalse_returnsFalse 7ms
โœ… PalacePDFViewTests testCanPerformDefine_whenAllowsCopyIsFalse_returnsFalse 13ms
โœ… PalacePDFViewTests testCanPerformLookup_whenAllowsCopyIsFalse_returnsFalse 20ms
โœ… PalacePDFViewTests testCanPerformNonEditingAction_whenAllowsCopyIsFalse_defersToSuper 95ms
โœ… PalacePDFViewTests testCanPerformPaste_whenAllowsCopyIsFalse_returnsFalse 11ms
โœ… PalacePDFViewTests testCanPerformSelectAll_whenAllowsCopyIsFalse_returnsFalse 11ms
โœ… PalacePDFViewTests testCanPerformShare_whenAllowsCopyIsFalse_returnsFalse 12ms
โœ… PalacePDFViewTests testCanPerformTranslate_whenAllowsCopyIsFalse_returnsFalse 12ms
โœ… PalaceTestSetupObservationTests testBootstrap_isIdempotent_returnsSameObserver 2ms
โœ… PalaceTestSetupObservationTests testCanary_AppContainerResetForTesting_yieldsCleanGraph 10ms
โœ… PalaceTestSetupObservationTests testTestCaseDidFinish_callsRegistryResettersInRegistrationOrder 2ms
โœ… PalaceTestSetupObservationTests testTestCaseDidFinish_observerCountIncreases_recordsDelta 4ms
โœ… PalaceWiringTestCaseTests testMakeFreshAccountsManager_appliesTestOptOut 16ms
โœ… PalaceWiringTestCaseTests testSetUp_runsAllResetters 3ms
โœ… PalaceWiringTestCaseTests testTearDown_cancelsBackgroundWorkOnRegisteredManagers 12ms
โœ… PalaceWiringTestCaseTests testTearDown_drainsCancellables 6ms
โœ… ParserFuzzTests testFuzz_AnnotationsResponse_NoCrashes 2.92s
โœ… ParserFuzzTests testFuzz_LCPLicense_NoCrashes 99ms
โœ… ParserFuzzTests testFuzz_OPDS1XML_NoCrashes 697ms
โœ… ParserFuzzTests testFuzz_OPDS2JSON_NoCrashes 47.44s
โœ… PatronProfileContractTests testParsePatronProfile_ExtractsDRMInfo 2ms
โœ… PatronProfileContractTests testParsePatronProfile_ExtractsSettings 67ms
โœ… PatronProfileContractTests testParsePatronProfile_HasAnnotationAndDeviceLinks 4ms
โœ… PatronProfileContractTests testParsePatronProfile_HasExpirationDate 4ms
โœ… PerformanceMonitorTests testClearAll 6ms
โœ… PerformanceMonitorTests testEmptyReport 3ms
โœ… PerformanceMonitorTests testEndTimingSameTokenTwice 6ms
โœ… PerformanceMonitorTests testEndTimingWithInvalidToken 6ms
โœ… PerformanceMonitorTests testGenerateReport 8ms
โœ… PerformanceMonitorTests testMaxMetricsPerCategoryEnforced 5ms
โœ… PerformanceMonitorTests testMetricPublisherEmits 9ms
โœ… PerformanceMonitorTests testMetricsGroupedByCategory 3ms
โœ… PerformanceMonitorTests testPercentileCalculations 21ms
โœ… PerformanceMonitorTests testRecordDurationDirectly 3ms
โœ… PerformanceMonitorTests testRecordMetricDirectly 13ms
โœ… PerformanceMonitorTests testReportByName 7ms
โœ… PerformanceMonitorTests testReportSummaryFormat 5ms
โœ… PerformanceMonitorTests testStartAndEndTiming 59ms
โœ… PerformanceReportTests testEmptyMetrics_ReturnsZeros 2ms
โœ… PerformanceReportTests testLargeDataset_PercentileAccuracy 12ms
โœ… PerformanceReportTests testMinMaxMean 2ms
โœ… PerformanceReportTests testMinMaxMean_UnsortedInput 2ms
โœ… PerformanceReportTests testPercentile_P50_EvenCount 3ms
โœ… PerformanceReportTests testPercentile_P50_OddCount 2ms
โœ… PerformanceReportTests testPercentile_P95 2ms
โœ… PerformanceReportTests testPercentile_P99 3ms
โœ… PerformanceReportTests testReport_EmptyMonitor_ZeroMeasurements 21ms
โœ… PerformanceReportTests testReport_StatisticsByCategory 7ms
โœ… PerformanceReportTests testReport_StatisticsByName 5ms
โœ… PerformanceReportTests testReport_SummaryContainsMeasurementCount 5ms
โœ… PerformanceReportTests testReport_TotalMeasurements 3ms
โœ… PerformanceReportTests testSingleMetric_AllPercentilesEqual 2ms
โœ… PersistentLoggerTests testClearLogs_removesAllRotatedFiles 1.08s
โœ… PersistentLoggerTests testInit_withCustomLogsRoot_writesToProvidedDirectory 10ms
โœ… PersistentLoggerTests testLog_andRetrieve_containsLoggedMessage 11ms
โœ… PersistentLoggerTests testLog_containsTimestamp 9ms
โœ… PersistentLoggerTests testLog_errorLevel_isRecorded 13ms
โœ… PersistentLoggerTests testLog_faultLevel_isRecorded 8ms
โœ… PersistentLoggerTests testLog_multipleEntries_allAppear 18ms
โœ… PersistentLoggerTests testLog_rotatesAtMaxFileSize 1.10s
โœ… PersistentLoggerTests testRetrieveAllLogs_includesActiveFileHeaderExactlyOnce 8ms
โœ… PlaybackBootstrapperTests testAudiobookSessionManager_InitialState_IsIdle 12ms
โœ… PlaybackBootstrapperTests testAudiobookSessionState_ErrorIsNotActive 9ms
โœ… PlaybackBootstrapperTests testAudiobookSessionState_IdleIsNotActive 14ms
โœ… PlaybackBootstrapperTests testAudiobookSessionState_LoadingIsActive 21ms
โœ… PlaybackBootstrapperTests testAudiobookSessionState_PausedIsActive 475ms
โœ… PlaybackBootstrapperTests testAudiobookSessionState_PlayingIsActive 21ms
โœ… PlaybackBootstrapperTests testPlaybackBootstrapper_ConfiguresRemoteCommandCenter 31ms
โœ… PlaybackBootstrapperTests testPlaybackBootstrapper_SkipIntervals_AreConfigured 17ms
โœ… PlaybackFailureRecordTests testRecord_LocalizedDescriptionPrefixed 2ms
โœ… PlaybackFailureRecordTests testRecord_NilBookId_FallsBackToUnknown 2ms
โœ… PlaybackFailureRecordTests testRecord_NilError_RecordsBookIdAndDefaultCode 2ms
โœ… PlaybackFailureRecordTests testRecord_OnlyAllowedSubKeysPropagate_BlocksAccidentalLeakage 2ms
โœ… PlaybackFailureRecordTests testRecord_OpenAccess403_PreservesHttpStatusAndUrl 2ms
โœ… PlaybackOpenPolicyTests testDecideForLoad_nilDecryptor_keepsGate 2ms
โœ… PlaybackOpenPolicyTests testDecideForLoad_nonNilDecryptor_bypassesGate 3ms
โœ… PlaybackOpenPolicyTests testDecide_lcpAudiobook_bypassesReadinessGate 2ms
โœ… PlaybackOpenPolicyTests testDecide_nonLCPAudiobook_keepsReadinessGate 2ms
โœ… PlaybackOpenPolicyTests testDecide_predicates_areIndependent 2ms
โœ… PlaybackOpenPolicyTests testDecide_reBorrowOfSameBook_doesNotPersistFinalPosition 2ms
โœ… PlaybackOpenPolicyTests testDecide_switchToDifferentBook_persistsFinalPosition 2ms
โœ… PlaybackRateTests testConvert_IntermediateCases_ReturnCorrectMultipliers 2ms
โœ… PlaybackRateTests testConvert_PresetCases_ReturnCorrectMultipliers 6ms
โœ… PlaybackRateTests testFormatMultiplier_OneDecimalPlace_ShowsOneDecimalPlace 2ms
โœ… PlaybackRateTests testFormatMultiplier_TwoDecimalPlaces_ShowsTwoDecimalPlaces 7ms
โœ… PlaybackRateTests testFormatMultiplier_WholeNumber_ShowsOneDecimalPlace 2ms
โœ… PlaybackRateTests testFormatMultiplier_allStepsProduceLabelEndingWithMultiplySign 3ms
โœ… PlaybackRateTests testNearest_ExactIntermediateValues_ReturnExactCase 5ms
โœ… PlaybackRateTests testNearest_ExactPresetValues_ReturnExactCase 3ms
โœ… PlaybackRateTests testNearest_ValueBetweenSteps_SnapsToNearest 4ms
โœ… PlaybackRateTests testNearest_clampsOutOfRangeValuesToBounds 5ms
โœ… PlaybackRateTests testPresets_ContainsAllNamedRates 5ms
โœ… PlaybackRateTests testPresets_DoesNotContain1p25x 3ms
โœ… PlaybackRateTests testPresets_DoesNotContainIntermediateCases 5ms
โœ… PlaybackRateTests testPresets_MultipliersAreExactly_0p75_1p0_1p2_1p5_2p0 4ms
โœ… PlaybackRateTests testPresets_isExactly_0p75_1p0_1p2_1p5_2p0_inAscendingOrder 3ms
โœ… PlaybackRateTests testSteps_isMonotonicLadderFromThreeQuartersToDoubleIn0Point05Increments 3ms
โœ… PlaybackTrackingRegressionTests testMultiplePlaybackStartedCalls_doesNotOvercount 30ms
โœ… PlaybackTrackingRegressionTests testMultipleStopStartCycles_preservesAllTime 33ms
โœ… PlaybackTrackingRegressionTests testPlaybackStopped_savesAccumulatedTime 21ms
โœ… PlaybackTrackingRegressionTests testRapidStartStopCycles_countsCorrectly 25ms
โœ… PlaybackTrackingRegressionTests testSleepTimerPause_savesAllAccumulatedTime 19ms
โœ… PositionPersistenceLogicTests testCriticalSave_onTermination_mustBypassSuppression 2ms
โœ… PositionPersistenceLogicTests testNewPersistLocation_bypassesSuppression 6ms
โœ… PositionPersistenceLogicTests testNoSuppression_allowsSave 4ms
โœ… PositionPersistenceLogicTests testOldBehavior_suppressionBlocksSave 4ms
โœ… PositionPersistenceLogicTests testSuppressionExpired_allowsSave 5ms
โœ… PositionPersistenceLogicTests testSuppressionWindow_threeSeconds_blocksAndThenAllows 3ms
โœ… PositionPersistenceTests testBookRegistry_setLocation_updatesPosition 4ms
โœ… PositionPersistenceTests testBookRegistry_storesLocation 3ms
โœ… PositionSyncServiceTests testClearAll 16ms
โœ… PositionSyncServiceTests testClearPositionsForBook 15ms
โœ… PositionSyncServiceTests testLatestPositionAnyFormat 42ms
โœ… PositionSyncServiceTests testNoSyncOfferForUnknownBook 42ms
โœ… PositionSyncServiceTests testNoSyncOfferWhenCurrentFormatIsMoreRecent 26ms
โœ… PositionSyncServiceTests testPersistenceAcrossInstances 27ms
โœ… PositionSyncServiceTests testPositionRecordedEventPublished 46ms
โœ… PositionSyncServiceTests testRecordAudiobookPosition 9ms
โœ… PositionSyncServiceTests testRecordEpubPosition 237ms
โœ… PositionSyncServiceTests testRecordPdfPosition 14ms
โœ… PositionSyncServiceTests testSetAndRetrieveMapping 27ms
โœ… PositionSyncServiceTests testSyncAvailableEventPublished 23ms
โœ… PositionSyncServiceTests testSyncOfferWhenOtherFormatIsMoreRecent 32ms
โœ… PositionSyncTests testSyncIsPossibleAndPermitted_checksSyncState 28ms
โœ… PositionSyncTests testTPPBookLocation_creation 6ms
โœ… PositionSyncTests testTPPBookLocation_equality 18ms
โœ… PositionSyncTests testTPPBookLocation_withEmptyString_createsLocation 5ms
โœ… PositionSyncTests testTPPBookmarkR3Location_storesResourceIndex 16ms
โœ… PositionWriterContractTests test_backgroundTask_postCompletes_aroundNetworkPost 25ms
โœ… PositionWriterContractTests test_cancel_clearsState_thenSaveAgainPostsImmediately 7ms
โœ… PositionWriterContractTests test_load_callsFetch 18ms
โœ… PositionWriterContractTests test_save_firstSnapshot_postsImmediately 21ms
โœ… PositionWriterContractTests test_save_secondWithinThrottle_queuesAndReturnsNil 5ms
โœ… PositionWriterContractTests test_save_throttleElapsed_postsQueued 9ms
โœ… PostUpdateMigrationTests testMigrate_doesNotCrash 18ms
โœ… PostUpdateMigrationTests testMigrate_updatesStoredVersion 24ms
โœ… PostUpdateMigrationTests testPostUpdateDetection_differentBuild_isDetected 6ms
โœ… PostUpdateMigrationTests testPostUpdateDetection_firstLaunch_isNotUpdate 6ms
โœ… PostUpdateMigrationTests testPostUpdateDetection_sameBuild_isNotDetected 9ms
โœ… ProblemDocumentContractTests testAllProblemDocuments_Parse 5ms
โœ… ProblemDocumentContractTests testAllProblemTypes_HaveDistinctTypeURIs 8ms
โœ… ProblemDocumentContractTests testInvalidCredentials_HasExpectedShape 4ms
โœ… ProblemDocumentContractTests testLoanLimitReached_HasExpectedShape 6ms
โœ… ProblemDocumentLoanExpiryTests testDetailLoanTermLimitReached_detectedInRealServerDetail 3ms
โœ… ProblemDocumentLoanExpiryTests testDetailLoanTermLimitReached_hasExpectedValue 2ms
โœ… ProblemDocumentLoanExpiryTests testDetailLoanTermLimitReached_notDetectedInUnrelatedDetail 2ms
โœ… ProblemDocumentLoanExpiryTests testLoanTermLimitReached_detectedFromErrorDictionary 3ms
โœ… ProblemDocumentLoanExpiryTests testNoActiveLoan_doesNotMatchTermLimitCheck 7ms
โœ… ProblemDocumentTests testBorrowError_credentialsSuspended_extractsDetails 3ms
โœ… ProblemDocumentTests testBorrowError_loanLimitReached_extractsDetails 4ms
โœ… ProblemDocumentTests testNSError_problemDocument_extractsCorrectly 5ms
โœ… ProblemDocumentTests testNSError_withoutProblemDocument_hasNilProperties 19ms
โœ… ProblemDocumentTests testProblemDocumentTypes_areCorrect 2ms
โœ… ProblemDocumentTests testProblemDocument_fromData_parsesCorrectly 7ms
โœ… ProblemDocumentTests testProblemDocument_fromDictionary_parsesCorrectly 18ms
โœ… ProblemDocumentTests testProblemDocument_fromResponseError_extractsFromNSError 3ms
โœ… ProblemDocumentTests testProblemDocument_fromResponseError_fallsBackToData 6ms
โœ… ProblemDocumentTests testProblemDocument_fromResponseError_returnsNilWhenNoDocument 12ms
โœ… ProblemDocumentTests testProblemDocument_stringValue_combinesTitleAndDetail 3ms
โœ… ProblemDocumentTests testProblemDocument_stringValue_handlesMissingTitle 4ms
โœ… ProblemReportEmailTests testGenerateBody_containsDeviceIdiom 2ms
โœ… ProblemReportEmailTests testGenerateBody_includesEnvironmentFieldsInExpectedStructure 2ms
โœ… ProblemReportEmailTests testGenerateBody_withBook_containsBookInfo 5ms
โœ… ProblemReportEmailTests testGenerateBody_withoutBook_doesNotContainBookInfo 2ms
โœ… ProblemReportEmailTests testPP3651_generateBody_doesNotLeakOtherLibrarysPatronIDWhenNilPassed 2ms
โœ… ProblemReportEmailTests testPP3651_generateBody_includesPatronIDOnlyWhenProvided 2ms
โœ… ProblemReportEmailTests testPP3651_generateBody_patronID_appearsAfterSeparator 5ms
โœ… ProblemReportEmailTests testPP3651_generateBody_withBookAndPatronID_containsBothBookAndPatronInfo 8ms
โœ… ReachabilityTests testDetailedStatus_expensiveAndConstrained_appendBothFlags 11ms
โœ… ReachabilityTests testDetailedStatus_expensiveOnly_appendsExpensiveNotConstrained 2ms
โœ… ReachabilityTests testDetailedStatus_requiresConnection_reportsPending 2ms
โœ… ReachabilityTests testDetailedStatus_satisfiedCellular_reportsConnectedViaCellular 2ms
โœ… ReachabilityTests testDetailedStatus_satisfiedEthernet_reportsConnectedViaEthernet 4ms
โœ… ReachabilityTests testDetailedStatus_satisfiedUnknownInterface_reportsUnknownType 2ms
โœ… ReachabilityTests testDetailedStatus_satisfiedWiFi_reportsConnectedViaWiFi 4ms
โœ… ReachabilityTests testDetailedStatus_unsatisfied_reportsNoConnection 5ms
โœ… ReachabilityTests testDetailedStatus_wifiTakesPrecedenceOverCellular 3ms
โœ… ReachabilityTests testGetDetailedConnectivityStatus_returnsNonEmptyFields 5ms
โœ… Reader2BookmarkContractTests test_bookmarkDelete_removesFromRegistry_thenAnnotationsDelete 8ms
โœ… Reader2BookmarkContractTests test_bookmarkSave_locatorFactoryRejects_doesNotEnqueueAnnotation 9ms
โœ… Reader2BookmarkContractTests test_bookmarkSave_writesToRegistry_thenAnnotations 19ms
โœ… Reader2PositionAdapterContractTests test_epubPoster_storeReadPosition_serializesLocator_callsWriterSave 1.51s
โŠ˜ Reader2PositionAdapterContractTests test_epubSynchronizer_sync_remoteDifferentDevice_loadsThenReturns 49ms
โœ… Reader2PositionAdapterContractTests test_epubSynchronizer_sync_sameDevice_returnsNil 22ms
โœ… Reader2PositionAdapterContractTests test_pdf_setCurrentPage_callsRegistryThenWriter 142ms
โœ… Reader2PositionResumeContractTests test_positionSave_writesRegistryThenSyncQueue 400ms
โœ… Reader2PositionResumeContractTests test_readerResume_loadsRegistryThenSynchronizer 5ms
โœ… Reader2PositionResumeContractTests test_readerResume_synchronizerSamePayload_noopShortCircuits 8ms
โœ… ReaderAccessibilityTests testBookmarkToggleLabels_areDistinctAndDescriptive 2ms
โœ… ReaderAccessibilityTests testBookmarksTabLabel_isDescriptive 3ms
โœ… ReaderAccessibilityTests testChapterNavigationLabels_areDistinct 14ms
โœ… ReaderAccessibilityTests testCloseSampleLabel_isDescriptive 3ms
โœ… ReaderAccessibilityTests testPDFPickerSegmentLabels_areDistinct 5ms
โœ… ReaderAccessibilityTests testPagePreviewsLabel_isDescriptive 3ms
โœ… ReaderAccessibilityTests testTableOfContentsLabel_isDescriptive 5ms
โœ… ReaderEditingActionsTests testResolve_appendsCustomActions_forNonDRMBook 7ms
โœ… ReaderEditingActionsTests testResolve_returnsDefaultActions_forNonDRMBook 7ms
โœ… ReaderEditingActionsTests testResolve_returnsEmpty_forDRMBook 2ms
โœ… ReaderEditingActionsTests testResolve_returnsEmpty_forDRMBook_evenWithCustomActions 5ms
โœ… ReaderEditingActionsTests testResolve_treatsSampleOfDRMBook_asNonDRM 6ms
โœ… ReaderErrorTests testEpubNotValid_conformsToLocalizedError 14ms
โœ… ReaderErrorTests testEpubNotValid_hasErrorDescription 19ms
โœ… ReaderErrorTests testErrors_haveDifferentDescriptions 14ms
โœ… ReaderErrorTests testFormatNotSupported_conformsToLocalizedError 5ms
โœ… ReaderErrorTests testFormatNotSupported_hasErrorDescription 8ms
โœ… ReaderNavBarVoiceOverTests testUpdateNavigationBar_keepsNavBarVisibleWhenVoiceOverIsRunning 4ms
โœ… ReaderNavBarVoiceOverTests testViewDidAppear_reAppliesNavBarVisibilityWhenVoiceOverIsRunning 12ms
โœ… ReaderServiceSyncTests testLastReadPositionSynchronizer_canBeCreated 18ms
โœ… ReaderServiceSyncTests testLastReadPositionSynchronizer_syncDoesNotCrash_withDeviceID 8ms
โœ… ReaderServiceSyncTests testLastReadPositionSynchronizer_syncReturns_whenNoServerPosition 26ms
โœ… ReaderThemeTests testAllCases_containsExactly5Themes 6ms
โœ… ReaderThemeTests testAllCases_containsExpectedThemes 2ms
โœ… ReaderThemeTests testAllThemes_haveCSSHexBackgrounds 2ms
โœ… ReaderThemeTests testAllThemes_haveCSSHexTextColors 6ms
โœ… ReaderThemeTests testAllThemes_haveValidBackgroundColors 5ms
โœ… ReaderThemeTests testAllThemes_haveValidTextColors 13ms
โœ… ReaderThemeTests testCSSHex_matchesExpectedFormat 8ms
โœ… ReaderThemeTests testCodable_preservesAllProperties 3ms
โœ… ReaderThemeTests testCodable_roundTrip 8ms
โœ… ReaderThemeTests testDarkTheme_darkBackground 3ms
โœ… ReaderThemeTests testDarkTheme_hasDarkBackground 4ms
โœ… ReaderThemeTests testDarkTheme_hasLightText 5ms
โœ… ReaderThemeTests testEachThemeID_isUnique 23ms
โœ… ReaderThemeTests testEquatable_differentThemesAreNotEqual 3ms
โœ… ReaderThemeTests testEquatable_sameThemesAreEqual 7ms
โœ… ReaderThemeTests testLightTheme_hasDarkText 32ms
โœ… ReaderThemeTests testLightTheme_hasLightBackground 2ms
โœ… ReaderThemeTests testLightTheme_whiteBackground 4ms
โœ… ReaderThemeTests testNightTheme_hasDarkBackground 5ms
โœ… ReaderThemeTests testNightTheme_hasLightText 2ms
โœ… ReaderThemeTests testNightTheme_nearBlackBackground 33ms
โœ… ReaderThemeTests testSepiaTheme_hasDarkText 38ms
โœ… ReaderThemeTests testSepiaTheme_hasLightBackground 4ms
โœ… ReaderThemeTests testSolarizedTheme_hasLightBackground 14ms
โœ… ReadingPositionTests testAudiobookPosition_CodableRoundTrip 3ms
โœ… ReadingPositionTests testAudiobookPosition_NegativeTimeOffset_ClampedToZero 3ms
โœ… ReadingPositionTests testAudiobookPosition_SetsFormatAndFields 5ms
โœ… ReadingPositionTests testAudiobookPosition_ZeroTimeOffset 2ms
โœ… ReadingPositionTests testDeviceID_IsPopulated 65ms
โœ… ReadingPositionTests testDisplayDescription_Audiobook 6ms
โœ… ReadingPositionTests testDisplayDescription_Epub 3ms
โœ… ReadingPositionTests testDisplayDescription_Pdf 3ms
โœ… ReadingPositionTests testEpubPosition_CodableRoundTrip 103ms
โœ… ReadingPositionTests testEpubPosition_ProgressBoundary0 6ms
โœ… ReadingPositionTests testEpubPosition_ProgressBoundary1 6ms
โœ… ReadingPositionTests testEpubPosition_ProgressClampedAbove1 23ms
โœ… ReadingPositionTests testEpubPosition_ProgressClampedBelow0 110ms
โœ… ReadingPositionTests testEpubPosition_SetsFormatAndFields 2ms
โœ… ReadingPositionTests testEquality_DifferentChapter_NotEqual 23ms
โœ… ReadingPositionTests testEquality_DifferentFormat_NotEqual 2ms
โœ… ReadingPositionTests testEquality_SamePosition 39ms
โœ… ReadingPositionTests testPdfPosition_CodableRoundTrip 13ms
โœ… ReadingPositionTests testPdfPosition_NegativePageNumber_ClampedTo1 5ms
โœ… ReadingPositionTests testPdfPosition_PageNumberClampedToMinimum1 2ms
โœ… ReadingPositionTests testPdfPosition_SetsFormatAndFields 3ms
โœ… ReadingPositionTests testReadingFormat_CodableRoundTrip 31ms
โœ… ReadingSessionTrackerTests testActiveBookID_NilInitially 2ms
โœ… ReadingSessionTrackerTests testEndSession_FiltersBriefSessions 11ms
โœ… ReadingSessionTrackerTests testEndSession_StopsTracking 27ms
โœ… ReadingSessionTrackerTests testEndSession_WithoutStartSession_DoesNotCrash 4ms
โœ… ReadingSessionTrackerTests testEndSession_WithoutStartSession_DoesNotRecordSession 150ms
โœ… ReadingSessionTrackerTests testIsTracking_FalseInitially 24ms
โœ… ReadingSessionTrackerTests testMultipleCycles_WorkCorrectly 3ms
โœ… ReadingSessionTrackerTests testPageCount_ResetsBetweenSessions 8ms
โœ… ReadingSessionTrackerTests testRecordBookFinished_RecordsCompletion 58ms
โœ… ReadingSessionTrackerTests testRecordBookFinished_TriggersBadgeRefresh 56ms
โœ… ReadingSessionTrackerTests testRecordPageTurn_IncrementsPageCount 2ms
โœ… ReadingSessionTrackerTests testStartSession_BeginsTracking 2ms
โœ… ReadingSessionTrackerTests testStartSession_EndsExistingSession 3ms
โœ… ReadingStatsServiceTests testAggregateStats 23ms
โœ… ReadingStatsServiceTests testAggregateStatsTimePeriodFilter 83ms
โœ… ReadingStatsServiceTests testChartDataEmpty 4ms
โœ… ReadingStatsServiceTests testChartDataWeek 76ms
โœ… ReadingStatsServiceTests testDuplicateCompletionIgnored 6ms
โœ… ReadingStatsServiceTests testRecordBookCompletion 5ms
โœ… ReadingStatsServiceTests testRecordMultipleSessions 8ms
โœ… ReadingStatsServiceTests testRecordSession 4ms
โœ… ReadingStatsServiceTests testRecordSessionIgnoresZeroDuration 7ms
โœ… ReadingStatsServiceTests testStreakRecalculation 14ms
โœ… ReadingStatsServiceTests testStreakResetsAfterGap 8ms
โœ… ReadingStatsServiceTests testStreakUpdatesOnSession 5ms
โœ… ReadingStatsStoreTests testClearAll 6ms
โœ… ReadingStatsStoreTests testLoadSessionsEmpty 6ms
โœ… ReadingStatsStoreTests testLoadStreakDefault 10ms
โœ… ReadingStatsStoreTests testMigrationSetsVersion 4ms
โœ… ReadingStatsStoreTests testMultipleSessions 43ms
โœ… ReadingStatsStoreTests testSaveAndLoadCompletions 19ms
โœ… ReadingStatsStoreTests testSaveAndLoadEarnedBadges 7ms
โœ… ReadingStatsStoreTests testSaveAndLoadSessions 7ms
โœ… ReadingStatsStoreTests testSaveAndLoadStreak 17ms
โœ… RedirectHandlingIntegrationTests testRedirect_attemptsCleared_afterCompletion 3ms
โœ… RedirectHandlingIntegrationTests testRedirect_httpsToHttp_blockedForSecurity 3ms
โœ… RedirectHandlingIntegrationTests testRedirect_httpsToHttps_allowed 2ms
โœ… RedirectHandlingIntegrationTests testRedirect_maxAttempts_enforced 4ms
โœ… RedirectPolicyTests testDecide_AboveMax_StillReturnsNil 5ms
โœ… RedirectPolicyTests testDecide_AtMaxAttempts_ReturnsNilAndDoesNotIncrement 3ms
โœ… RedirectPolicyTests testDecide_CounterIsPerTask 10ms
โœ… RedirectPolicyTests testDecide_CustomMaxAttempts_Honored 68ms
โœ… RedirectPolicyTests testDecide_HTTPSToHTTPS_Allowed 3ms
โœ… RedirectPolicyTests testDecide_HTTPSToHTTP_ReturnsNilButHasIncremented 5ms
โœ… RedirectPolicyTests testDecide_HTTPToAnything_NotADowngrade 24ms
โœ… RedirectPolicyTests testDecide_NilOriginalScheme_NotTreatedAsDowngrade 7ms
โœ… RedirectPolicyTests testDecide_OneBelowMax_AllowsAndIncrements 3ms
โœ… RemoteFeatureFlagsGapTests testRemoteFeatureFlags_convenienceProperties_dontCrash 17ms
โœ… RemoteFeatureFlagsGapTests testRemoteFeatureFlags_fetchIfNeeded_completesWithoutCrashing 17ms
โœ… RemoteFeatureFlagsGapTests testRemoteFeatureFlags_isFeatureEnabled_returnsBoolean 3ms
โœ… RemoteFeatureFlagsGapTests testRemoteFeatureFlags_shared_isAccessible 5ms
โœ… RemoteFeatureFlagsTests testFeatureFlag_allCases_haveNonEmptyRawValues 10ms
โœ… RemoteFeatureFlagsTests testFeatureFlag_defaultValues_areDefined 6ms
โœ… RemoteFeatureFlagsTests testFetchIfNeeded_doesNotCrash 5ms
โœ… RemoteFeatureFlagsTests testGetDeviceInfo_containsVersionInfo 4ms
โœ… RemoteFeatureFlagsTests testGetDeviceInfo_returnsNonEmptyDict 2ms
โœ… RemoteFeatureFlagsTests testIsCarPlayEnabledCached_returnsBool 6ms
โœ… RemoteFeatureFlagsTests testIsFeatureEnabled_withoutFirebase_returnsDefault 5ms
โœ… RemoteFeatureFlagsTests testShared_isNotNil 2ms
โœ… RemoteFeatureFlagsTests testShared_returnsSameInstance 3ms
โœ… ResourcePropertiesLengthTests testLength_isNilWhenUnset 2ms
โœ… ResourcePropertiesLengthTests testLength_roundTripsLargeValueWithoutTruncation 3ms
โœ… ResourcePropertiesLengthTests testLength_zeroRoundTrips 3ms
โœ… RetryClassificationTests testAudiobookErrors_notRetryable 2ms
โœ… RetryClassificationTests testAudiobookErrors_retryable 2ms
โœ… RetryClassificationTests testAuthErrors_notRetryable 2ms
โœ… RetryClassificationTests testAuthErrors_retryable 3ms
โœ… RetryClassificationTests testBookRegistryErrors_notRetryable 2ms
โœ… RetryClassificationTests testBookRegistryErrors_retryable 2ms
โœ… RetryClassificationTests testDRMErrors_notRetryable 2ms
โœ… RetryClassificationTests testDownloadErrors_notRetryable 2ms
โœ… RetryClassificationTests testDownloadErrors_retryable 3ms
โœ… RetryClassificationTests testNSURLError_notRetryable 2ms
โœ… RetryClassificationTests testNSURLError_retryable 2ms
โœ… RetryClassificationTests testNetworkErrors_notRetryable 2ms
โœ… RetryClassificationTests testNetworkErrors_retryable 2ms
โœ… RetryClassificationTests testParsingErrors_notRetryable 2ms
โœ… RetryClassificationTests testParsingErrors_retryable 2ms
โœ… RetryClassificationTests testStorageErrors_notRetryable 2ms
โœ… RetryClassificationTests testUnknownError_notRetryable 2ms
โœ… ReturnFlowTests testRetryTracker_limitsRetries 25ms
โœ… RightsManagementDetectionTests testMimeType_adobeAdept_detectsAdobeRights 292ms
โœ… RightsManagementDetectionTests testMimeType_bearerToken_detectsBearerTokenRights 28ms
โœ… RightsManagementDetectionTests testMimeType_epubZip_detectsNoRights 6ms
โœ… RightsManagementDetectionTests testMimeType_lcpLicense_detectsLCPRights 5ms
โœ… RightsManagementDetectionTests testMimeType_unknown_detectsUnknown 6ms
โœ… RightsManagementDispatcherTests testDispatch_adobePDF_returnsFailureWithIgnoreError 10ms
โœ… RightsManagementDispatcherTests testDispatch_bearerToken_invalidJSON_failsWithAlert 11ms
โœ… RightsManagementDispatcherTests testDispatch_bearerToken_missingFile_failsWithAlert 8ms
โœ… RightsManagementDispatcherTests testDispatch_bearerToken_validJSON_registersNewTaskInState 16ms
โœ… RightsManagementDispatcherTests testDispatch_lcp_callsLcpFulfillmentAndDoesNotFlagFailure 6ms
โœ… RightsManagementDispatcherTests testDispatch_none_moveFileFails_flagsFailure 6ms
โœ… RightsManagementDispatcherTests testDispatch_none_moveFileSuccess_doesNotFlagFailure 6ms
โœ… RightsManagementDispatcherTests testDispatch_overdrive_replaceBookFails_flagsFailure 6ms
โœ… RightsManagementDispatcherTests testDispatch_overdrive_replaceBookSuccess_doesNotFlagFailure 8ms
โœ… RightsManagementDispatcherTests testDispatch_unknown_logsAndFlagsFailure 14ms
โœ… SAMLCookieSyncTests testCookieSyncToSharedStorage 4ms
โœ… SAMLCookieSyncTests testCookieSync_emptyCookies_doesNotCrash 2ms
โœ… SAMLCookieSyncTests testCookieSync_multipleCookies 3ms
โœ… SAMLCookieSyncTests testCookieSync_replacesExistingCookie 3ms
โœ… SAMLCookieSyncTests testRequestCreation_includesCookieHeader 3ms
โœ… SAMLLogoutCallbackDetectionTests testCallbackSchemeError_DetectedAsSuccess 15ms
โœ… SAMLLogoutCallbackDetectionTests testCallbackSchemeError_PartialStatus_AlsoDetected 4ms
โœ… SAMLLogoutCallbackDetectionTests testOIDCCallbackScheme_NotSAMLDetected 3ms
โœ… SAMLLogoutCallbackDetectionTests testUnrelatedError_NotDetected 3ms
โœ… SAMLLogoutLinkParsingTests testRegression_OIDCLogoutHref_StillPopulated 88ms
โœ… SAMLLogoutLinkParsingTests testSAMLAuth_ParsesLogoutHrefIsTemplated_True 3ms
โœ… SAMLLogoutLinkParsingTests testSAMLAuth_ParsesLogoutHref_FromAuthDocument 8ms
โœ… SAMLLogoutLinkParsingTests testSAMLAuth_WithoutLogoutLink_LeavesHrefNil 5ms
โœ… SAMLLogoutLinkParsingTests testSAMLLogoutHref_IsNil_ForBasicAuth 4ms
โœ… SAMLLogoutURLTests testSAMLLogoutURL_CallbackSchemeIsPalaceSAML 3ms
โœ… SAMLLogoutURLTests testSAMLLogoutURL_ExpandsTemplateWithRedirectURI 4ms
โœ… SAMLLogoutURLTests testSAMLLogoutURL_InvalidTemplate_ReturnsNil 4ms
โœ… SAMLLogoutURLTests testSAMLLogoutURL_NonTemplated_UsedAsIs 3ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_AuthRequiredError_SAML_Credentials_Book_ReturnsTrue 154ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_BasicAuth_ReturnsFalse 142ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_NilCurrentBook_ReturnsFalse 145ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_NilError_ReturnsFalse 147ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_NoCredentials_ReturnsFalse 152ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_OAuthAccount_ReturnsFalse 148ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_WrongErrorCode_ReturnsFalse 127ms
โœ… SAMLPlusBiblioBoardExpirationTests testShouldTriggerSAMLReauth_WrongErrorDomain_ReturnsFalse 279ms
โœ… SEMigrationsTests testMigrate2_oldCacheFiles_areRemoved 32ms
โœ… SEMigrationsTests testMigrate3_1_0_backupExclusion_isDispatchedForOldVersion 15ms
โœ… SEMigrationsTests testMigrate3_1_0_backupExclusion_isSkippedForCurrentVersion 10ms
โœ… SEMigrationsTests testRunMigrations_doesNotCrashAndDoesNotMutateAppVersionWhenNoMigrationsApply 11ms
โœ… SEMigrationsTests testRunMigrations_multipleCallsAreSafe 12ms
โœ… SEMigrationsTests testRunMigrations_nilOrEmptyVersion_handlesGracefullyWithoutCrashing 43ms
โœ… SafeDictionaryTests testAllPairs_returnsAllKeyValuePairs 6ms
โœ… SafeDictionaryTests testCompactMapValues_removesNils 8ms
โœ… SafeDictionaryTests testContains_existingKey_returnsTrue 3ms
โœ… SafeDictionaryTests testCount_reflectsEntries 28ms
โœ… SafeDictionaryTests testFilter_selectsMatchingEntries 5ms
โœ… SafeDictionaryTests testGetMetrics_returnsMetricsDictionary 5ms
โœ… SafeDictionaryTests testGet_missingKey_returnsNil 3ms
โœ… SafeDictionaryTests testInit_withInitialValues 3ms
โœ… SafeDictionaryTests testIsEmpty_noEntries_returnsTrue 6ms
โœ… SafeDictionaryTests testKeys_returnsAllKeys 17ms
โœ… SafeDictionaryTests testMapValues_transformsValues 52ms
โœ… SafeDictionaryTests testModify_createsNewValue 52ms
โœ… SafeDictionaryTests testModify_updatesExistingValue 4ms
โœ… SafeDictionaryTests testRemoveAll_clearsEverything 5ms
โœ… SafeDictionaryTests testRemoveMultiple_removesSpecifiedKeys 5ms
โœ… SafeDictionaryTests testRemove_deletesEntry 3ms
โœ… SafeDictionaryTests testRemove_missingKey_returnsNil 2ms
โœ… SafeDictionaryTests testSet_andGet_returnsValue 4ms
โœ… SafeDictionaryTests testSet_overwrite_updatesValue 45ms
โœ… SafeDictionaryTests testUpdateMultiple_addsAllEntries 29ms
โœ… SafeDictionaryTests testValues_returnsAllValues 12ms
โœ… SamplePlayerErrorTests testFileSaveFailed_WithUnderlyingError 3ms
โœ… SamplePlayerErrorTests testFileSaveFailed_WithoutUnderlyingError 4ms
โœ… SamplePlayerErrorTests testNoSampleAvailable_IsError 5ms
โœ… SamplePlayerErrorTests testSampleDownloadFailed_WithUnderlyingError 4ms
โœ… SamplePlayerErrorTests testSampleDownloadFailed_WithoutUnderlyingError 2ms
โœ… SampleTypeTests testNeedsDownload_EpubZip_ReturnsTrue 6ms
โœ… SampleTypeTests testNeedsDownload_OpenAccessAudiobook_ReturnsFalse 4ms
โœ… SampleTypeTests testNeedsDownload_OverdriveAudiobookMpeg_ReturnsTrue 4ms
โœ… SampleTypeTests testNeedsDownload_OverdriveAudiobookWaveFile_ReturnsTrue 9ms
โœ… SampleTypeTests testNeedsDownload_OverdriveWeb_ReturnsFalse 4ms
โœ… SampleTypeTests testRawValue_ContentTypeEpubZip 3ms
โœ… SampleTypeTests testRawValue_OpenAccessAudiobook 39ms
โœ… SampleTypeTests testRawValue_OverdriveWeb 9ms
โœ… SceneDelegateTests testSceneDelegate_HasMainSceneConnected_IsConsistent 6ms
โœ… ScopedResetTests testHostMatches_emptyHostSet_neverMatches 7ms
โœ… ScopedResetTests testHostMatches_exactHost_matches 2ms
โœ… ScopedResetTests testHostMatches_leadingDotCookieDomain_matches 3ms
โœ… ScopedResetTests testHostMatches_parentDomainCookieCoveringHost_matches 2ms
โœ… ScopedResetTests testHostMatches_rawSuffixWithoutDotBoundary_doesNotMatch 2ms
โœ… ScopedResetTests testHostMatches_siblingHostOnSharedBaseDomain_doesNotMatch 6ms
โœ… ScopedResetTests testHostMatches_unrelatedDomain_doesNotMatch 2ms
โœ… ScopedResetTests testPerformScopedReset_resetsActiveLibraryOnly_andSkipsDRMDeauthorize 346ms
โœ… ScopedResetTests testWebHostsToClear_nilAccount_isEmpty 6ms
โœ… SearchAccessibilityTests testClearSearchLabel_isDescriptive 3ms
โœ… SearchAccessibilityTests testClearSearchLabel_isLocalized 3ms
โœ… SearchAccessibilityTests testGoBackLabel_isDescriptive 4ms
โœ… SearchAccessibilityTests testSearchBooksLabel_exists 14ms
โœ… SearchAccessibilityTests testSearchCatalogLabel_differsFromSearchInBook 3ms
โœ… SearchAccessibilityTests testSearchInBookLabel_isDescriptive 6ms
โœ… SearchFlowIntegrationTests testSearchCancellation_StopsPendingRequest 66ms
โœ… SearchFlowIntegrationTests testSearchDebouncing_PreventsExcessiveRequests 11ms
โœ… SearchFlowIntegrationTests testSearchQuery_DispatchesToCatalogRepository 16ms
โœ… SearchFlowIntegrationTests testSearchResults_ContainExpectedBookData 8ms
โœ… SearchFlowIntegrationTests testSearchWithEmptyQuery_ReturnsNilResult 7ms
โœ… SearchFlowIntegrationTests testSearchWithNetworkError_PropagatesError 16ms
โœ… SearchFlowIntegrationTests testSearchWithServerError_PropagatesServerError 10ms
โœ… SearchFlowIntegrationTests testSequentialSearches_TrackAllQueries 10ms
โœ… SettingsViewModelComputedPropertyTests testAccountCount_ReflectsSettingsAccountsList 5ms
โœ… SettingsViewModelComputedPropertyTests testDuplicateWrite_DoesNotTriggerSettingsUpdate 4ms
โœ… SettingsViewModelComputedPropertyTests testIsUsingCustomFeed_AfterClear_ReturnsFalse 10ms
โœ… SettingsViewModelComputedPropertyTests testIsUsingCustomRegistry_AfterClear_ReturnsFalse 6ms
โœ… SettingsViewModelComputedPropertyTests testShowDeveloperSettings_CanBeToggled 6ms
โœ… SettingsViewModelComputedPropertyTests testShowDeveloperSettings_DefaultsFalse 13ms
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_InitWithPartialSettings_HandlesGracefully 1.77s
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_MultipleRapidChanges_MaintainsConsistency 789ms
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_ResetThenModify_WorksCorrectly 1.10s
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_SetCustomFeedURL_LocalhostHTTP_ReturnsTrue 917ms
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_SetCustomFeedURL_URLWithFragment_ReturnsTrue 1.07s
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_SetCustomFeedURL_URLWithPort_ReturnsTrue 832ms
โœ… SettingsViewModelEdgeCaseTests testSettingsViewModel_SetCustomFeedURL_URLWithQueryParams_ReturnsTrue 902ms
โœ… SettingsViewModelGapTests testSettingsViewModel_refreshAccountsList_updatesProperty 27ms
โœ… SettingsViewModelSyncTests testResetToDefaults_ClearsAllSettings 212ms
โœ… SettingsViewModelSyncTests testResetToDefaults_UpdatesSettingsProvider 460ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithEmptyString_ClearsURL 151ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithInvalidURL_ReturnsFalse 432ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithNil_ClearsURL 93ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithNonHttpScheme_ReturnsFalse 637ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithValidHttpURL_ReturnsTrue 207ms
โœ… SettingsViewModelSyncTests testSetCustomFeedURL_WithValidHttpsURL_ReturnsTrue 182ms
โœ… SettingsViewModelSyncTests testSetCustomRegistryServer_WithEmptyString_ReturnsTrueAndClears 141ms
โœ… SettingsViewModelSyncTests testSetCustomRegistryServer_WithNil_ClearsServer 126ms
โœ… SettingsViewModelSyncTests testSetCustomRegistryServer_WithValidURL_ReturnsTrue 1.46s
โœ… SettingsViewModelSyncTests testSettingsViewModel_BidirectionalSync_SettingsToViewModelViaRefresh 395ms
โœ… SettingsViewModelSyncTests testSettingsViewModel_BidirectionalSync_ViewModelToSettings 112ms
โœ… SettingsViewModelSyncTests testSettingsViewModel_ExternalSettingsChange_RequiresRefresh 174ms
โœ… SettingsViewModelTests testSettingsViewModel_AcceptEULA_SetsTrue 14ms
โœ… SettingsViewModelTests testSettingsViewModel_ClearCustomFeedURL_ClearsURL 22ms
โœ… SettingsViewModelTests testSettingsViewModel_ClearCustomRegistryServer_ClearsServer 13ms
โœ… SettingsViewModelTests testSettingsViewModel_CustomMainFeedURL_PublishesChanges 22ms
โœ… SettingsViewModelTests testSettingsViewModel_FormattedAppVersion_ReturnsFormattedString 31ms
โœ… SettingsViewModelTests testSettingsViewModel_Init_DefaultsAreCorrect 12ms
โœ… SettingsViewModelTests testSettingsViewModel_Init_ReadsSettingsFromProvider 11ms
โœ… SettingsViewModelTests testSettingsViewModel_IsUsingCustomFeed_FalseWhenURLNil 11ms
โœ… SettingsViewModelTests testSettingsViewModel_IsUsingCustomFeed_TrueWhenURLSet 26ms
โœ… SettingsViewModelTests testSettingsViewModel_IsUsingCustomRegistry_FalseWhenServerEmpty 13ms
โœ… SettingsViewModelTests testSettingsViewModel_IsUsingCustomRegistry_FalseWhenServerNil 10ms
โœ… SettingsViewModelTests testSettingsViewModel_IsUsingCustomRegistry_TrueWhenServerSet 11ms
โœ… SettingsViewModelTests testSettingsViewModel_MarkAgeCheckPresented_SetsTrue 16ms
โœ… SettingsViewModelTests testSettingsViewModel_RefreshSettings_ReloadsFromProvider 19ms
โœ… SettingsViewModelTests testSettingsViewModel_ResetToDefaults_ResetsAllSettings 50ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_EmptyString_ClearsURL 21ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_InvalidScheme_ReturnsFalse 11ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_InvalidURL_ReturnsFalse 16ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_Nil_ClearsURL 11ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_ValidHTTPS_ReturnsTrue 33ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomFeedURL_ValidHTTP_ReturnsTrue 32ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomRegistryServer_EmptyString_ClearsServer 15ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomRegistryServer_InvalidURL_ReturnsFalse 260ms
โœ… SettingsViewModelTests testSettingsViewModel_SetCustomRegistryServer_ValidURL_ReturnsTrue 332ms
โœ… SettingsViewModelTests testSettingsViewModel_SetEnterLCPPassphraseManually_UpdatesSettings 72ms
โœ… SettingsViewModelTests testSettingsViewModel_SetSameValue_DoesNotWriteToSettings 68ms
โœ… SettingsViewModelTests testSettingsViewModel_SetUseBetaLibraries_UpdatesSettings 12ms
โœ… SettingsViewModelTests testSettingsViewModel_SetUserHasAcceptedEULA_UpdatesSettings 21ms
โœ… SettingsViewModelTests testSettingsViewModel_SetUserPresentedAgeCheck_UpdatesSettings 14ms
โœ… SettingsViewModelTests testSettingsViewModel_ToggleBetaLibraries_TogglesValue 16ms
โœ… SettingsViewModelTests testSettingsViewModel_ToggleLCPManualPassphrase_TogglesValue 20ms
โœ… SettingsViewModelTests testSettingsViewModel_UpdateAppVersion_UpdatesSettings 10ms
โœ… SettingsViewModelTests testSettingsViewModel_UseBetaLibraries_PublishesChanges 56ms
โœ… SignInModalLifecycleTests testPresenter_currentAccountIDNil_firesCompletionWithoutPublishingState 1.38s
โœ… SignInModalLifecycleTests testPresenter_currentAccountNeedsNoAuth_shortCircuitsWithoutPublishingState 1.31s
โœ… SignInModalLifecycleTests testPresenter_dismissAfterPresent_resetsPresentationState 1.45s
โœ… SignInModalLifecycleTests testPresenter_dismissedToIdle_secondPresentAfterFirstCompletes_publishesAgain 1.51s
โœ… SignInModalLifecycleTests testPresenter_idleToPresenting_publishesForCurrentAccountOnFirstPresent 1.46s
โœ… SignInModalLifecycleTests testPresenter_presentForCurrentAccount_publishesState_invokesDriver_clearsState_firesCompletion 1.20s
โœ… SignInModalLifecycleTests testPresenter_presentingToDismissed_clearsPresentationStateOnDriverCompletion 1.18s
โœ… SignInModalLifecycleTests testPresenter_singleFlight_secondPresentationBeforeFirstDismisses_isNoOp 1.42s
โœ… SignInModalLifecycleTests testReauth_TPPReauthenticator_authenticateIfNeeded_drivesSpyPresenterViaAppContainerSeam 197ms
โœ… SignInModalPredicateTests testShouldAutoDismiss_whenCredentialsStale_returnsFalse 3ms
โœ… SignInModalPredicateTests testShouldAutoDismiss_whenLoggedIn_returnsTrue 2ms
โœ… SignInModalPredicateTests testShouldAutoDismiss_whenLoggedOut_returnsFalse 5ms
โœ… SignInModalSAMLOIDCTests testBorrowReauthGuard_allBookStates 8ms
โœ… SignInModalSAMLOIDCTests testBorrowReauthGuard_downloadNeededBook_blocksReauth 2ms
โœ… SignInModalSAMLOIDCTests testBorrowReauthGuard_unregisteredBook_allowsReauth 4ms
โœ… SignInModalSAMLOIDCTests testNeedsAuth_allAuthTypes 2ms
โœ… SignInModalSAMLOIDCTests testNeedsAuth_consistencyBetweenTwoImplementations 3ms
โœ… SignInModalSAMLOIDCTests testSignInModalGuard_needsAuth_classifiesAuthTypesCorrectly 2ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_accessTokenButNoPatronInfo_routesToMissingPayloadBranch 85ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_accessTokenWithEqualsPadding_parsesCorrectly 85ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_authDataParseFail_synthesizesNonNilErrorWithTitleAndMessage 135ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_missingPayload_synthesizesNonNilErrorWithTitleAndMessage 93ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_notificationWithoutURL_synthesizesNonNilError 87ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_serverErrorWithoutDetail_fallsBackToGenericMessage 110ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_serverReturnsErrorInPayload_synthesizesErrorWithParsedTitleAndDetail 88ms
โœ… SignInOAuthErrorPropagationTests testHandleRedirectURL_successPath_completionFiresWithNilError 101ms
โœ… SignInToReadFlowIntegrationTests testAuthToken_AttachedToSubsequentRequest 102ms
โœ… SignInToReadFlowIntegrationTests testCatalogLoad_503ThenRetrySucceeds 148ms
โœ… SignInToReadFlowIntegrationTests testHappyPath_SignIn_Borrow_Download_ReaderOpens_AllStepsHappen 149ms
โœ… SignInToReadFlowIntegrationTests testNetworkDrop_DuringSignIn_SurfacesAsConnectivityError 118ms
โœ… SignInToReadFlowIntegrationTests testSignInFails_RegistryRemainsEmpty_AuthStateNotSignedIn 123ms
โœ… SignInWebSheetIntegrationTests test_initialLoad_injectsCookiesBeforeLoadingRequest 98ms
โœ… SignInWebSheetIntegrationTests test_loadingOverlay_startsTrueAndBecomesFalseOnNavigationFinish 745ms
โœ… SignInWebSheetIntegrationTests test_navigatingToUniversalLinksURL_firesLoginCompletionWithCookies 6.47s
โœ… SignInWebSheetViewModelTests test_autoPresentIfNeeded_canBeTrue 4ms
โœ… SignInWebSheetViewModelTests test_autoPresentIfNeeded_defaultsToFalse 6ms
โœ… SignInWebSheetViewModelTests test_bookFoundThenCancel_doesNotFireCancel 30ms
โœ… SignInWebSheetViewModelTests test_cancelThenLoginCompletion_doesNotFireLogin 5ms
โœ… SignInWebSheetViewModelTests test_cookieInjection_emptyCookies_loadsRequestImmediately 17ms
โœ… SignInWebSheetViewModelTests test_cookieInjection_loadHandlerOnlyFiresAfterAllCookiesInjected 9ms
โœ… SignInWebSheetViewModelTests test_cookieInjection_orderPreserved 13ms
โœ… SignInWebSheetViewModelTests test_decideAction_loginCompletionURL_isStillRecordedAsPreviousRequest 28ms
โœ… SignInWebSheetViewModelTests test_decideAction_navigationToOtherURL_returnsAllow 8ms
โœ… SignInWebSheetViewModelTests test_decideAction_navigationToUniversalLinksHostButDifferentPath_doesNotMatch 2ms
โœ… SignInWebSheetViewModelTests test_decideAction_navigationToUniversalLinksURL_returnsCompleteLogin 4ms
โœ… SignInWebSheetViewModelTests test_decideAction_recordsPreviousRequestForLaterBookFound 4ms
โœ… SignInWebSheetViewModelTests test_decideResponse_htmlMime_returnsAllow 3ms
โœ… SignInWebSheetViewModelTests test_decideResponse_nilMime_returnsAllow 3ms
โœ… SignInWebSheetViewModelTests test_decideResponse_problemJsonMime_returnsProblemFound 8ms
โœ… SignInWebSheetViewModelTests test_decideResponse_supportedBookMime_returnsBookFound 6ms
โœ… SignInWebSheetViewModelTests test_decideResponse_unsupportedTypeNotInBookList_returnsAllow 23ms
โœ… SignInWebSheetViewModelTests test_didFinishNavigation_setsLoadingFalse 2ms
โœ… SignInWebSheetViewModelTests test_didStartProvisionalNavigation_resetsLoadingTrue 3ms
โœ… SignInWebSheetViewModelTests test_isLoading_trueByDefault 36ms
โœ… SignInWebSheetViewModelTests test_loginCompletionThenCancel_doesNotFireCancel 6ms
โœ… SignInWebSheetViewModelTests test_problemThenCancel_doesNotFireCancel 2ms
โœ… SignInWebSheetViewModelTests test_recordBookFound_invokesHandlerOnceWithPreviousRequestAndCookies 5ms
โœ… SignInWebSheetViewModelTests test_recordBookFound_secondCallIgnored 6ms
โœ… SignInWebSheetViewModelTests test_recordCancel_invokesHandlerOnce 5ms
โœ… SignInWebSheetViewModelTests test_recordLoginCompletion_invokesHandlerOnceWithURLAndCookies 6ms
โœ… SignInWebSheetViewModelTests test_recordLoginCompletion_secondCallIgnored 8ms
โœ… SignInWebSheetViewModelTests test_recordProblem_invokesHandlerOnce 14ms
โœ… SignInWebSheetViewModelTests test_wasBookFound_falseAfterOnlyLoginCompletion 3ms
โœ… SignInWebSheetViewModelTests test_wasBookFound_falseInitially 32ms
โœ… SignInWebSheetViewModelTests test_wasBookFound_trueAfterRecordBookFound 5ms
โœ… SignOutCacheClearingTests testClearCache_doesNotCrash_andExecutorStaysReusable 3ms
โœ… SignOutCacheClearingTests testNetworkExecutorAndSharedCache_areSeparate 2ms
โœ… SignOutCacheClearingTests testURLCacheShared_clearIsIdempotentAndPreservesCapacity 3ms
โœ… SingletonResetRegistryTests testInvokeAll_reentrantRegisterDuringResetter_isDroppedWithWarning 6ms
โœ… SingletonResetRegistryTests testInvokeAll_resetterClosureCapturingNilWeakRef_doesNotCrash 7ms
โœ… SingletonResetRegistryTests testRegister_multipleThreadsConcurrently_yieldsConsistentSnapshot 102ms
โœ… SingletonResetRegistryTests testRegister_reRegisterSameName_overwritesInPlacePreservingOrder 3ms
โœ… SingletonResetRegistryTests testRegister_thenInvokeAll_callsResettersInRegistrationOrder 15ms
โœ… StatsViewModelTests testInitialState 2ms
โœ… StatsViewModelTests testLoadPopulatesChartData 6ms
โœ… StatsViewModelTests testLoadPopulatesStats 11ms
โœ… StatsViewModelTests testLoadPopulatesStreak 6ms
โœ… StatsViewModelTests testLongestStreakText 3ms
โœ… StatsViewModelTests testRecentBadgesAfterCompletion 7ms
โœ… StatsViewModelTests testRecentBadgesLimitedToFive 8ms
โœ… StatsViewModelTests testStreakDisplayTextActive 17ms
โœ… StatsViewModelTests testStreakDisplayTextNoStreak 2ms
โœ… StatsViewModelTests testTimePeriodChangeUpdatesData 209ms
โœ… StatusAnnouncementTests testPP3673_allAnnouncementTypes_areProgrammaticallyDeterminable 9ms
โœ… StatusAnnouncementTests testPP3673_borrowFailed_announces 7ms
โœ… StatusAnnouncementTests testPP3673_borrowLifecycle_producesSequentialAnnouncements 5ms
โœ… StatusAnnouncementTests testPP3673_borrowStarted_announces 10ms
โœ… StatusAnnouncementTests testPP3673_borrowSucceeded_announcesWithoutFocusShift 7ms
โœ… StatusAnnouncementTests testPP3673_differentMessages_allAnnounced 7ms
โœ… StatusAnnouncementTests testPP3673_downloadCompleted_announces 7ms
โœ… StatusAnnouncementTests testPP3673_downloadFailed_announces 6ms
โœ… StatusAnnouncementTests testPP3673_downloadStarted_announces 8ms
โœ… StatusAnnouncementTests testPP3673_errorAnnouncement_doesNotMoveFocus 11ms
โœ… StatusAnnouncementTests testPP3673_errorMessage_announcedViaVoiceOver 8ms
โœ… StatusAnnouncementTests testPP3673_quickSuccession_sameMessage_collapsed 7ms
โœ… StatusAnnouncementTests testPP3673_searchAnnouncement_usesAnnouncementNotification 13ms
โœ… StatusAnnouncementTests testPP3673_searchFailed_announces 7ms
โœ… StatusAnnouncementTests testPP3673_searchNoResults_announcesNoResults 10ms
โœ… StatusAnnouncementTests testPP3673_searchRerun_announcesNewStatus 12ms
โœ… StatusAnnouncementTests testPP3673_searchStrings_areLocalized 2ms
โœ… StatusAnnouncementTests testPP3673_searchWithResults_announcesResultsForQuery 13ms
โœ… StatusAnnouncementTests testPP3673_statusStrings_areUnderstandable 3ms
โœ… StatusAnnouncementTests testPP3673_statusWithTitleAndMessage_isClear 5ms
โœ… StatusAnnouncementTests testPP3673_updatedStatus_replacesOld 10ms
โœ… StatusAnnouncementTests testPP3673_voiceOverDisabled_noAnnouncements 2ms
โœ… StopPositionSaveTests testStop_bypassesSaveSuppression 7ms
โœ… StopPositionSaveTests testStop_savesEvenDuringActiveSuppression 6ms
โœ… StoreTests testEnvironment_substitution_changesEffectOutput 4ms
โœ… StoreTests testReducer_canBeExercisedWithoutAStore 2ms
โœ… StoreTests testSendAwait_runsEffectChainToCompletionBeforeReturning 3ms
โœ… StoreTests testSend_effect_feedsFollowupActionThroughReducer 24ms
โœ… StoreTests testSend_synchronousReducer_updatesStateBeforeReturning 3ms
โœ… StreamingReaderPresentationContractTests testStreamingReaderPresentation_handleActionReadStreaming_callSequence 11ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_read_malformedJSON_returnsNil 6ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_read_returnsNilForDifferentBookID 21ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_read_unknownBookID_returnsNil 11ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_save_doesNotOverwriteOtherBooks 6ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_save_usesPalaceStreamingReaderPrefix 10ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_writeThenRead_nilFragmentRoundTrips 11ms
โœ… StreamingReaderProgressStoreTests testStreamingReaderProgressStore_writeThenRead_returnsExactScrollOffset 6ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_whenActualWithinTolerance_doesNotRetry 73ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_whenJSReportsActualMatchesTarget_doesNotRetry 65ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_whenJSReportsActualMismatch_retriesUpToMax 114ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_whenJSResultMalformed_retriesUpToMax 85ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_withNoSavedScroll_doesNotInvokeScrollTo 271ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_withSavedScrollZero_doesNotInvokeScrollTo 343ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_didFinish_withSavedScroll_invokesScrollToInJS 324ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_parseActualY_returnsNilOnNonDictionary 306ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_parseActualY_returnsNilWhenActualMissing 3ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_parseActualY_returnsValueFromDouble 5ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_parseActualY_returnsValueFromInt 4ms
โœ… StreamingReaderViewControllerScrollRestoreTests testStreamingReaderViewController_parseActualY_returnsValueFromNSNumber 11ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_didDismiss_persistsScrollOffsetToStore 35ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_didDismiss_withoutPriorNavigation_doesNotSave 18ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_didNavigationFinish_thenDismiss_persistsLatestOffset 7ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_init_whenOffline_emitsOfflineState 8ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_init_withMalformedSavedProgress_doesNotCrashAndStaysReady 9ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_init_withSavedProgress_emitsReadyStateWithRestoredOffset 6ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_init_withoutSavedProgress_emitsReadyStateWithNilOffset 8ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_loadingThenReadyThenDismissed_persistsLastOffsetRoundtrip 13ms
โœ… StreamingReaderViewModelTests testStreamingReaderViewModel_reload_whenReachabilityRestored_emitsReadyState 15ms
โœ… StringExtensionTests testMd5hex_differsByInput 5ms
โœ… StringExtensionTests testMd5hex_emptyString 4ms
โœ… StringExtensionTests testMd5hex_length 5ms
โœ… StringExtensionTests testMd5hex_returnsConsistentHash 6ms
โœ… StringExtensionTests testParseJSONString_arrayJSON 7ms
โœ… StringExtensionTests testParseJSONString_emptyString 25ms
โœ… StringExtensionTests testParseJSONString_invalidJSON 5ms
โœ… StringExtensionTests testParseJSONString_validJSON 4ms
โœ… StringExtensionsTests testIsDate_delayBoundary_isStrictGreaterThan 9ms
โœ… StringExtensionsTests testIsDate_invalidOrEmptyStrings_returnFalse 18ms
โœ… StringExtensionsTests testIsDate_temporalDirection_acrossSecondsDaysAndYears 12ms
โœ… StringHTMLEntitiesTests testDecode_CommonHTMLEntities_DecodesCorrectly 5ms
โœ… StringHTMLEntitiesTests testDecode_NumericDecimal_DecodesCorrectly 2ms
โœ… StringHTMLEntitiesTests testDecode_NumericHex_DecodesCorrectly 2ms
โœ… StringHTMLEntitiesTests testDecode_XMLPredefinedEntities_DecodesCorrectly 26ms
โœ… StringHTMLEntitiesTests testDecode_malformedInputPreservedVerbatim 6ms
โœ… StringHTMLEntitiesTests testDecode_passThroughAndMixedContentEdgeCases 3ms
โœ… StringHTMLEntitiesTests testNSStringBridge_decodesEntitiesAndMixedContent 4ms
โœ… StringNYPLAdditionsTests testStringContains_caseInsensitive 7ms
โœ… StringNYPLAdditionsTests testStringIsEmpty_withWhitespace 2ms
โœ… StringNYPLAdditionsTests testStringPrefix_matching 2ms
โœ… StringNYPLAdditionsTests testStringSuffix_matching 5ms
โœ… String_NYPLAdditionsTests testFileSystemSafeBase64_encodeAndDecodeRoundTripWithoutUnsafeChars 5ms
โœ… String_NYPLAdditionsTests testMD5 4ms
โœ… String_NYPLAdditionsTests testSHA256 77ms
โœ… String_NYPLAdditionsTests testURLEncodingQueryParam 6ms
โœ… SupportSectionDecisionTests testDecide_botDisabled_withAccountEmail_usesAccountEmail 5ms
โœ… SupportSectionDecisionTests testDecide_botDisabled_withEmptyEmail_usesGeneralFallback 2ms
โœ… SupportSectionDecisionTests testDecide_botDisabled_withoutAccountEmail_usesGeneralFallback 156ms
โœ… SupportSectionDecisionTests testDecide_botEnabled_choosesTriageBot_regardlessOfEmail 240ms
โœ… SupportSectionDecisionTests testEmailAddress_isNilForTriageBot_andResolvedForLegacy 6ms
โœ… SyncConflictResolutionTests testConflictResolution_localNewer_usesLocal 5ms
โœ… SyncConflictResolutionTests testConflictResolution_sameTimestamp_usesHigherProgress 6ms
โœ… SyncConflictResolutionTests testConflictResolution_serverNewer_usesServer 36ms
โœ… SyncDeletionGuardTests testVersionComparison_emptyIsLessThan 97ms
โœ… SyncDeletionGuardTests testVersionComparison_equal_returnsFalse 6ms
โœ… SyncDeletionGuardTests testVersionComparison_sameMajor 5ms
โœ… SyncDeletionGuardTests testVersionComparison_shorterIsLess 8ms
โœ… SyncDeletionGuardTests testVersionComparison_shorterIsNotLess_ifZero 13ms
โœ… SyncDeletionRatioTests testCompleteFeed_noDeletions 7ms
โœ… SyncDeletionRatioTests testEmptyFeedWithLocalBooks_shouldSkipDeletion 4ms
โœ… SyncDeletionRatioTests testEmptyFeedWithNoLocalBooks_shouldNotSkip 2ms
โœ… SyncDeletionRatioTests testNormalSync_singleBookRemoved_noWarning 3ms
โœ… SyncDeletionRatioTests testPartialFeed_shouldWarnButNotSkip 4ms
โœ… SyncDeletionRatioTests testSmallLibrary_noProtection 3ms
โœ… SyncPermissionTests testAccountDetails_nilDetails_makesSyncPropertiesFalse 100ms
โœ… SyncPermissionTests testAccountDetails_syncProperties_matchExpectations 111ms
โœ… SyncPermissionTests testSyncIsPossibleAndPermitted_doesNotCrash 3ms
โœ… SyncPermissionTests testSyncIsPossible_withCredentials_dependsOnCurrentAccountDetails 2ms
โœ… SyncPermissionTests testSyncIsPossible_withoutCredentials_returnsFalse 3ms
โœ… TPPAccountAuthStateEnumTests testCodable_encodesAndDecodesCorrectly 7ms
โœ… TPPAccountAuthStateEnumTests testDescription_returnsCorrectStrings 3ms
โœ… TPPAccountAuthStateEnumTests testHasAdobeActivation_trueForLoggedInAndStale 3ms
โœ… TPPAccountAuthStateEnumTests testHasStoredCredentials_falseOnlyForLoggedOut 7ms
โœ… TPPAccountAuthStateEnumTests testNeedsReauthentication_trueForLoggedOutAndStale 19ms
โœ… TPPAccountListDataSourceTests testLoadData_MixedCaseLibraryNames_SortsCaseInsensitively 3ms
โœ… TPPAccountListDataSourceTests testLoadData_WithFilter_FiltersCaseInsensitively 2ms
โœ… TPPAccountListDataSourceTests testLoadData_WithNationalAccounts_SeparatesAndSortsCaseInsensitively 2ms
โœ… TPPAdobeActivationSkipTests testShouldSkipAdobeActivation_falseWhenLoggedIn 117ms
โœ… TPPAdobeActivationSkipTests testShouldSkipAdobeActivation_falseWhenLoggedOut 103ms
โœ… TPPAdobeActivationSkipTests testShouldSkipAdobeActivation_falseWhenStaleButAdobeNotAuthorized 129ms
โœ… TPPAdobeActivationSkipTests testShouldSkipAdobeActivation_falseWhenStaleButNoAdobeCredentials 86ms
โœ… TPPAdobeActivationSkipTests testShouldSkipAdobeActivation_trueWhenStaleAndAdobeAuthorized 102ms
โœ… TPPAdobeActivationSkipTests testUpdateUserAccount_marksLoggedIn 118ms
โœ… TPPAgeCheckCompletionTests test_didComplete_birthYear14YearsAgo_marksAboveAgeLimit 193ms
โœ… TPPAgeCheckCompletionTests test_didComplete_birthYear5YearsAgo_marksBelowAgeLimit 91ms
โœ… TPPAgeCheckCompletionTests test_didComplete_birthYearExactly13YearsAgo_marksBelowAgeLimit 115ms
โœ… TPPAgeCheckCompletionTests test_didComplete_setsUserPresentedAgeCheckTrue 81ms
โœ… TPPAgeCheckCompletionTests test_didFail_doesNotSetUserPresentedAgeCheck 80ms
โœ… TPPAgeCheckIsValidTests test_birthYearList_spansMinToCurrentInclusive 3ms
โœ… TPPAgeCheckIsValidTests test_isValid_aboveCurrentYear_isRejected 9ms
โœ… TPPAgeCheckIsValidTests test_isValid_belowMinYear_isRejected 8ms
โœ… TPPAgeCheckIsValidTests test_isValid_currentYear_isAdmitted 2ms
โœ… TPPAgeCheckIsValidTests test_isValid_minYear_isAdmitted 3ms
โœ… TPPAgeCheckStateMachineTests testAgeCheck_blocksUntilLoaded_thenVerifies 284ms
โœ… TPPAgeCheckStateMachineTests testAgeCheck_evictedDetails_completionFalse 78ms
โœ… TPPAgeCheckStateMachineTests testAgeCheck_failedDetailsLoad_completionFalse 75ms
โœ… TPPAgeCheckStateMachineTests testAgeCheck_nilCurrentAccount_completionFalse 78ms
โœ… TPPAgeCheckTests testAge0 95ms
โœ… TPPAgeCheckTests testAge100 88ms
โœ… TPPAgeCheckTests testAge12 97ms
โœ… TPPAgeCheckTests testAge13 127ms
โœ… TPPAgeCheckTests testAge14 85ms
โœ… TPPAgeCheckTests testAgeCheckFailed 1.09s
โœ… TPPAgeCheckVerifyDecisionTests test_verify_needsAuthTrue_admitsUserWithoutPrompt 127ms
โœ… TPPAgeCheckVerifyDecisionTests test_verify_nilCompletion_doesNotCrash 137ms
โœ… TPPAgeCheckVerifyDecisionTests test_verify_nilCurrentAccount_blocksDefensively 4ms
โœ… TPPAgeCheckVerifyDecisionTests test_verify_userAboveAgeLimitTrue_admitsImmediately 132ms
โœ… TPPAgeCheckVerifyDecisionTests test_verify_userPresentedAgeCheckAndBelowLimit_blocksWithoutReprompt 104ms
โœ… TPPAlertUtilsTests testAlertTitleMessageError_withMessage_prefersMessageOverError 4ms
โœ… TPPAlertUtilsTests testAlertTitleMessageError_withNilMessage_fallsBackToError 9ms
โœ… TPPAlertUtilsTests testAlertWithDetails_hasOKAction 11ms
โœ… TPPAlertUtilsTests testAlertWithDetails_hasTwoActions 8ms
โœ… TPPAlertUtilsTests testAlertWithDetails_hasViewDetailsAction 9ms
โœ… TPPAlertUtilsTests testAlertWithDetails_plainMessageWithProblemDoc_includesDetail 6ms
โœ… TPPAlertUtilsTests testAlertWithDetails_retryAction_invokesClosure 12ms
โœ… TPPAlertUtilsTests testAlertWithDetails_withError_buildsAlert 16ms
โœ… TPPAlertUtilsTests testAlertWithDetails_withProblemDocument_doesNotDuplicateDetail 9ms
โœ… TPPAlertUtilsTests testAlertWithDetails_withRetryAction_hasRetryAndCancelNoOK 9ms
โœ… TPPAlertUtilsTests testAlertWithDetails_withoutRetry_okActionIsDefaultStyle 7ms
โœ… TPPAlertUtilsTests testAlert_cancelStyle_okActionIsCancel 6ms
โœ… TPPAlertUtilsTests testAlert_customStyle_usesProvidedStyle 5ms
โœ… TPPAlertUtilsTests testAlert_defaultStyle_okActionIsDefaultStyle 6ms
โœ… TPPAlertUtilsTests testAlert_destructiveStyle_okActionIsDestructive 6ms
โœ… TPPAlertUtilsTests testAlert_emptyMessage_returnsEmptyMessage 4ms
โœ… TPPAlertUtilsTests testAlert_emptyTitle_substitutesAlertDefault 6ms
โœ… TPPAlertUtilsTests testAlert_hasOKAction 5ms
โœ… TPPAlertUtilsTests testAlert_nilMessage_substitutesEmpty 4ms
โœ… TPPAlertUtilsTests testAlert_nilTitle_substitutesDefault 4ms
โœ… TPPAlertUtilsTests testAlert_titleAndMessage_createsAlert 5ms
โœ… TPPAlertUtilsTests testAlert_veryLongMessage_preservesContent 7ms
โœ… TPPAlertUtilsTests testAlert_withError_createsAlert 15ms
โœ… TPPAlertUtilsTests testAlert_withNSURLErrorCancelled_setsMessage 9ms
โœ… TPPAlertUtilsTests testAlert_withNSURLErrorNotConnected_setsMessage 67ms
โœ… TPPAlertUtilsTests testAlert_withNSURLErrorTimedOut_setsMessage 21ms
โœ… TPPAlertUtilsTests testAlert_withNSURLErrorUnknownCode_setsUnknownRequestMessage 8ms
โœ… TPPAlertUtilsTests testAlert_withNSURLErrorUnsupportedURL_setsMessage 12ms
โœ… TPPAlertUtilsTests testAlert_withNilError_createsAlert 10ms
โœ… TPPAlertUtilsTests testAlert_withUnknownDomainAndLocalizedDescription_usesDescription 10ms
โœ… TPPAlertUtilsTests testAlert_withUnknownDomainNoDescription_usesGenericFallback 9ms
โœ… TPPAlertUtilsTests testBorrowErrorPipeline_doesNotDuplicateProblemDocDetail 13ms
โœ… TPPAlertUtilsTests testCrashlyticsFE741015_PresentAlertWhileAlertShowing_DoesNotCrash 65ms
โœ… TPPAlertUtilsTests testPresentAlert_WhenNoAlertShowing_PresentsSuccessfully 51ms
โœ… TPPAlertUtilsTests testRetryPresentation_AfterFirstAlertDismisses_PresentsSecond 93ms
โœ… TPPAlertUtilsTests testRetryPresentation_ExceedsMaxRetries_DropsAlertWithCompletion 252ms
โœ… TPPAlertUtilsTests testSetProblemDocument_appendMode_appendsDetailAfterExisting 4ms
โœ… TPPAlertUtilsTests testSetProblemDocument_appendMode_titleAndDetailBothAppended 7ms
โœ… TPPAlertUtilsTests testSetProblemDocument_appendsToMessage 6ms
โœ… TPPAlertUtilsTests testSetProblemDocument_emptyAlertTitle_fillsFromDoc 4ms
โœ… TPPAlertUtilsTests testSetProblemDocument_nilController_doesNotCrash 4ms
โœ… TPPAlertUtilsTests testSetProblemDocument_nilDocument_doesNotCrash 5ms
โœ… TPPAlertUtilsTests testSetProblemDocument_replaceMode_setsTitleAndDetail 4ms
โœ… TPPAlertUtilsTests testSetProblemDocument_replaceMode_titleOnly_fillsMessageFromDetail 7ms
โœ… TPPAlertUtilsTests testSetProblemDocument_replacesMessage 6ms
โœ… TPPAnnotationsHermeticTests testAnnotationsURL_WhenMainFeedURLPresent_EndsInAnnotationsPath 7ms
โœ… TPPAnnotationsHermeticTests testDeleteBookmark_InvalidURLString_ReturnsFalseWithoutNetwork 31ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_NetworkErrorWithQueueOfflineTrue_DoesNotCrashAndReportsFailure 15ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_NetworkError_ReturnsFailure 10ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Non200StatusCode_ReturnsFailure 5ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_NonHTTPURLResponse_ReturnsFailure 6ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_NotFound404_ReturnsFailure 4ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_RequestShape_PreservesMethodHeadersTimeoutAndBody 5ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Success200WithFullPayload_ReturnsIdAndTimestamp 4ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Success200WithMalformedJSON_ReturnsNilIdAndTimestamp 14ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Success200WithMissingBodyKey_ReturnsNilTimestamp 5ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Success200WithMissingIdKey_ReturnsNilId 10ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Success200WithNilData_ReturnsNilIdAndTimestamp 12ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_Unauthorized401_ReturnsFailure 6ms
โœ… TPPAnnotationsHermeticTests testPostAnnotation_UsesExecutorOverride_NotShared 10ms
โœ… TPPAnnotationsOverrideTests testAnnotationDevice_FirebaseOverride_IsClearedAfterReset 2ms
โœ… TPPAnnotationsOverrideTests testAnnotationDevice_FirebaseOverride_IsUsedWhenAdobeIDIsAbsent 3ms
โœ… TPPAnnotationsOverrideTests testSyncIsPossible_ExplicitProviderArgumentBeatsOverride 193ms
โœ… TPPAnnotationsOverrideTests testSyncIsPossible_RoutesThroughAccountsManagerOverride 73ms
โœ… TPPAnnotationsTests testAnnotationResponse_HandlesNilValues 140ms
โœ… TPPAnnotationsTests testAnnotationResponse_StoresValues 198ms
โœ… TPPAnnotationsTests testTPPAnnotationsWrapper_isUsablePolymorphicallyThroughProtocolWithStableValue 190ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteAllBookmarks_CompletesImmediately 194ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteBookmark_Handles404AsSuccess 226ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteBookmark_HandlesServerError 173ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteBookmark_HandlesSuccessfulDeletion 184ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteBookmark_ReturnsFalseForInvalidURL 156ms
โœ… TPPAnnotationsTests testTPPAnnotations_DeleteBookmarks_HandlesArray 150ms
โœ… TPPAnnotationsTests testTPPAnnotations_GetServerBookmarks_ParsesValidResponse 192ms
โœ… TPPAnnotationsTests testTPPAnnotations_GetServerBookmarks_ReturnsNilForNilBook 165ms
โœ… TPPAnnotationsTests testTPPAnnotations_GetServerBookmarks_ReturnsNilForNilURL 122ms
โœ… TPPAnnotationsTests testTPPAnnotations_GetServerBookmarks_ReturnsNilWhenSyncNotPermitted 205ms
โœ… TPPAnnotationsTests testTPPAnnotations_HandlesConcurrentRequests 183ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAnnotation_CreatesCorrectRequestFormat 224ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAnnotation_HandlesInvalidJSONGracefully 211ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAnnotation_HandlesNetworkError 259ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAnnotation_HandlesNon200StatusCode 230ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAnnotation_HandlesSuccessResponse 458ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostAudiobookBookmark_ThrowsOnFailure 159ms
โœ… TPPAnnotationsTests testTPPAnnotations_PostListeningPosition_CallsPostReadingPosition 169ms
โœ… TPPAnnotationsTests testTPPAnnotations_SyncIsPossible_ReturnsFalseWithoutCredentials 207ms
โœ… TPPAnnotationsTests testTPPAnnotations_SyncIsPossible_ReturnsTrueWithCredentialsAndSyncSupport 235ms
โœ… TPPAnnotationsTests testTPPAnnotations_SyncReadingPosition_ReturnsNilWhenNotPermitted 145ms
โœ… TPPAnnotationsTests testTPPAnnotations_UploadLocalBookmarks_SkipsAlreadySyncedBookmarks 223ms
โœ… TPPAnnotationsTests testTPPBookmarkFactory_FiltersBookmarksByMotivation 288ms
โœ… TPPAnnotationsTests testTPPBookmarkFactory_RejectsBookmarksForWrongBook 171ms
โœ… TPPAnnotationsTests testTPPBookmarkSpec_ReadingProgressMotivation 128ms
โœ… TPPAnnotationsTests testTPPBookmarkSpec_SerializesToValidJSON 212ms
โœ… TPPAnnouncementManagerTests testAddPresentedAnnouncement 10ms
โœ… TPPAnnouncementManagerTests testDeletePresentedAnnouncement 9ms
โœ… TPPAnnouncementManagerTests testShouldPresentAnnouncement 12ms
โœ… TPPAuthDocumentContractTests testCoverageTable_CoversEveryKnownAuthType 14ms
โœ… TPPAuthDocumentContractTests testEveryAdvertisedRel_HasAClientSideHandler 10ms
โœ… TPPAuthDocumentContractTests testLogoutRel_OnAuthWithLogoutLink_IsCapturedAsHref 4ms
โœ… TPPBackgroundExecutorTests testExecutorCallsSetUpWorkItem 9ms
โœ… TPPBackgroundExecutorTests testExecutorDoesNotRetainOwner 11ms
โœ… TPPBackgroundExecutorTests testExecutorHandlesNilWorkItem 8ms
โœ… TPPBadgeImageGapTests testTPPBadgeImageView_audiobook_initSucceeds 14ms
โœ… TPPBadgeImageGapTests testTPPBadgeImage_audiobook_assetNameReturnsAudiobookBadge 3ms
โœ… TPPBaseReaderViewControllerInitialLocationTests testGate_afterReady_invokesGoOnce 4ms
โœ… TPPBaseReaderViewControllerInitialLocationTests testGate_beforeReady_doesNotInvokeGo 4ms
โœ… TPPBaseReaderViewControllerInitialLocationTests testGate_noInitialLocation_neverInvokesGo 6ms
โœ… TPPBaseReaderViewControllerInitialLocationTests testGate_readyBeforeAttach_navigatesWhenAttachLands 23ms
โœ… TPPBaseReaderViewControllerInitialLocationTests testGate_secondReadySignal_doesNotDuplicateGo 4ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withEmptyCredentials_usesCredential 2ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withMultipleFailures_cancelsChallenge 2ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withNilPassword_cancelsChallenge 2ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withNilUsername_cancelsChallenge 2ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withPreviousFailure_cancelsChallenge 2ms
โœ… TPPBasicAuthTests testHandleChallenge_basicAuth_withValidCredentials_usesCredential 2ms
โœ… TPPBasicAuthTests testHandleChallenge_clientCertificate_rejectsProtectionSpace 2ms
โœ… TPPBasicAuthTests testHandleChallenge_credentials_noPersistence 67ms
โœ… TPPBasicAuthTests testHandleChallenge_serverTrust_performsDefaultHandling 2ms
โœ… TPPBasicAuthTests testHandleChallenge_unknownMethod_rejectsProtectionSpace 2ms
โœ… TPPBasicAuthTests testInit_createsInstance 2ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_audiobook_authorOnly_includesFormatAndAuthor 4ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_audiobook_narratorOnly_omitsAuthorPhrase 2ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_audiobook_neitherAuthorNorNarrator_titlePlusFormat 3ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_audiobook_withNarrator_includesNarrator 3ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_ebook_blankAuthor_titleOnly 6ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_ebook_noAuthor_titleOnly 7ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_ebook_titleByAuthor 9ms
โœ… TPPBookAccessibilityLabelTests testVoiceOverLabel_neverIncludesSummary 6ms
โœ… TPPBookAuthorCoverageTests testBookAuthor_NilURL_IsDistinctFromEmptyURL 2ms
โœ… TPPBookAuthorCoverageTests testBookAuthor_initWithNameAndURL 3ms
โœ… TPPBookAuthorCoverageTests testBookAuthor_initWithNilURL 3ms
โœ… TPPBookAuthorTests testInit_EmptyName_AllowsEmptyString 2ms
โœ… TPPBookAuthorTests testInit_WithNameAndURL_SetsProperties 3ms
โœ… TPPBookAuthorTests testInit_WithNilURL_SetsURLToNil 3ms
โœ… TPPBookAuthorTests testIsKindOfClass_NSObject 5ms
โœ… TPPBookAuthorTests test_differentName_haveDifferentProperties 71ms
โœ… TPPBookAuthorTests test_sameNameAndURL_haveMatchingProperties 2ms
โœ… TPPBookBearerTokenTests testBearerToken_clearWithNil 7ms
โœ… TPPBookBearerTokenTests testBearerToken_defaultsToNil 10ms
โœ… TPPBookBearerTokenTests testBearerToken_writeAndRead 19ms
โœ… TPPBookBearerTokenTests testFulfillURL_clearWithNil 26ms
โœ… TPPBookBearerTokenTests testFulfillURL_defaultsToNil 8ms
โœ… TPPBookBearerTokenTests testFulfillURL_independentPerBook 24ms
โœ… TPPBookBearerTokenTests testFulfillURL_overwrite 10ms
โŠ˜ TPPBookBearerTokenTests testFulfillURL_persistsAcrossNewBookInstances 17ms
โœ… TPPBookBearerTokenTests testFulfillURL_writeAndRead 12ms
โœ… TPPBookButtonsStateTests testAllFiveAvailabilityKindsProduceDistinctStates_exceptLimitedAndUnlimited 3ms
โœ… TPPBookButtonsStateTests testStateForLimited_returnsCanBorrow 6ms
โœ… TPPBookButtonsStateTests testStateForNilAvailability_returnsUnsupported 4ms
โœ… TPPBookButtonsStateTests testStateForReady_returnsHoldingFOQ 3ms
โœ… TPPBookButtonsStateTests testStateForReserved_returnsHolding 4ms
โœ… TPPBookButtonsStateTests testStateForUnavailable_returnsCanHold 2ms
โœ… TPPBookButtonsStateTests testStateForUnlimited_returnsCanBorrow 4ms
โœ… TPPBookContentMetadataFilesHelperTests testCurrentAccountDirectory_returnsURLOrNil 4ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_containsBundleIdentifier 3ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_differentAccounts_returnDifferentPaths 3ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_emptyString_handlesGracefully 3ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_longAccountId_handlesGracefully 3ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_pathContainsApplicationSupport 2ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_sameAccount_returnsSamePath 9ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_specialCharacters_handlesGracefully 4ms
โœ… TPPBookContentMetadataFilesHelperTests testDirectory_validAccountId_returnsURL 2ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests testTPPBookContentTypeConverter_stringValue_allCases_returnDistinctNonEmptyTokens 117ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests testTPPBookContentTypeConverter_stringValue_streamingHTML_returnsExpectedToken 3ms
โœ… TPPBookContentTypeConverterTests testStringValue_audiobook 4ms
โœ… TPPBookContentTypeConverterTests testStringValue_epub 2ms
โœ… TPPBookContentTypeConverterTests testStringValue_pdf 7ms
โœ… TPPBookContentTypeConverterTests testStringValue_unsupported 2ms
โœ… TPPBookContentTypeExtendedTests testFromMimeType_empty 3ms
โœ… TPPBookContentTypeExtendedTests testFromMimeType_epubAndPdfMappedCorrectly 34ms
โœ… TPPBookContentTypeExtendedTests testFromMimeType_nil 6ms
โœ… TPPBookContentTypeExtendedTests testFromMimeType_unknown 5ms
โœ… TPPBookContentTypeTests test_converter_audiobook_returnsAudioBook 3ms
โœ… TPPBookContentTypeTests test_converter_epub_returnsEpub 2ms
โœ… TPPBookContentTypeTests test_converter_pdf_returnsPDF 2ms
โœ… TPPBookContentTypeTests test_converter_unsupported_returnsUnsupported 19ms
โœ… TPPBookContentTypeTests test_from_audiobookJsonMimeType_returnsAudiobook 2ms
โœ… TPPBookContentTypeTests test_from_emptyMimeType_returnsUnsupported 2ms
โœ… TPPBookContentTypeTests test_from_epubZipMimeType_returnsEpub 3ms
โœ… TPPBookContentTypeTests test_from_nilMimeType_returnsUnsupported 2ms
โœ… TPPBookContentTypeTests test_from_octetStreamMimeType_returnsEpub 2ms
โœ… TPPBookContentTypeTests test_from_pdfMimeType_returnsPdf 3ms
โœ… TPPBookContentTypeTests test_from_unknownMimeType_returnsUnsupported 3ms
โœ… TPPBookContentTypeTests test_opdsPublicationType_isInSupportedTypes 4ms
โœ… TPPBookContentTypeTests test_opdsPublicationType_withDirectEpubIndirect_producesEpubPath 3ms
โœ… TPPBookContentTypeTests test_opdsPublicationType_withLCPEpubIndirect_producesEpubPath 3ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_DecodesJPEGAtTargetSize 49ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_DecodesPNGData 74ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_EmptyDataReturnsNil 21ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_InvalidDataReturnsNil 14ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_MemoryEfficiency_LargeImage 245ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_PreservesAspectRatio 33ms
โœ… TPPBookCoverRegistryTests testDownsampleImage_SmallImageNotUpscaled 5ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_NilHostHandledGracefully 4ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_RecordsFailureAndSkips 9ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_ResetClearsAll 6ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_ResetsAfterCooldown 213ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_SuccessClearsFailure 10ms
โœ… TPPBookCoverRegistryTests testHostFailureTracker_TracksHostsIndependently 4ms
โœ… TPPBookCoverRegistryTests testRegistry_UsesCustomImageSession 3ms
โœ… TPPBookCreationTests testBookCreationViaDictionary 21ms
โœ… TPPBookCreationTests testBookCreationViaFactoryMethod 11ms
โœ… TPPBookCreationTests testBookCreationViaMemberWiseInitializer 9ms
โœ… TPPBookCreationTests testBookCreation_FromEntry_AudienceAbsent 8ms
โœ… TPPBookCreationTests testBookCreation_FromEntry_PopulatesAudienceAndLanguage 9ms
โœ… TPPBookCreationTests testBookCreation_RoundTripsAudienceAndLanguageThroughDictionary 13ms
โœ… TPPBookCreationTests testMergingPreservingMetadata_PrefersFreshThenSelf 11ms
โœ… TPPBookExtensionsTests test_format_forAudiobook_matchesLocalizedString 3ms
โœ… TPPBookExtensionsTests test_format_forEpub_matchesLocalizedString 3ms
โœ… TPPBookExtensionsTests test_format_forPDF_matchesLocalizedString 4ms
โœ… TPPBookExtensionsTests test_format_forUnsupported_matchesLocalizedString 2ms
โœ… TPPBookExtensionsTests test_format_isNonEmptyAndDistinguishableAcrossContentTypes 13ms
โœ… TPPBookExtensionsTests test_hasAudiobookSample_audiobookWithSample_returnsTrue 4ms
โœ… TPPBookExtensionsTests test_hasAudiobookSample_audiobookWithoutSample_returnsFalse 4ms
โœ… TPPBookExtensionsTests test_hasAudiobookSample_epubWithSample_returnsFalse 4ms
โœ… TPPBookExtensionsTests test_hasAudiobookSample_pdfWithSample_returnsFalse 4ms
โœ… TPPBookExtensionsTests test_hasSample_returnsTrueOnlyWhenSampleIsPresent_andDistinguishesAudiobook 3ms
โœ… TPPBookExtensionsTests test_hasSample_withMockerHasSampleFalse_returnsFalse 6ms
โœ… TPPBookExtensionsTests test_hasSample_withMockerHasSampleTrue_returnsTrue 5ms
โœ… TPPBookExtensionsTests test_loggableDictionary_containsExpectedKeys 3ms
โœ… TPPBookExtensionsTests test_loggableShortString_containsTitleAndId 3ms
โœ… TPPBookExtensionsTests test_sample_nilForUnsupportedContentType 3ms
โœ… TPPBookExtensionsTests test_sample_preservesURL 10ms
โœ… TPPBookExtensionsTests test_sample_returnsNilWhenNoSampleIsAvailable 4ms
โœ… TPPBookExtensionsTests test_sample_withAudiobookSample_returnsAudiobookSample 6ms
โœ… TPPBookExtensionsTests test_sample_withEpubSample_returnsEpubSample 8ms
โœ… TPPBookExtensionsTests test_showAudiobookToolbar_falseForEpubEvenWithSample 6ms
โœ… TPPBookExtensionsTests test_showAudiobookToolbar_falseWhenNoSample 5ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_falseForBookWithNoAcquisitions 2ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_falseForOpenAccessAudiobook 3ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_falseForOpenAccessEpub 4ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_falseForOpenAccessPdf 4ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_trueForAdobeAdeptEpub 2ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_trueForLCPAudiobook 3ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_trueForLCPEpub 3ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_trueForLCPPdf 3ms
โœ… TPPBookIsDRMProtectedTests testIsDRMProtected_trueForOPDSFixtureEntry 8ms
โœ… TPPBookLocationCoverageTests testBookLocation_dictionaryRoundTrip 8ms
โœ… TPPBookLocationCoverageTests testBookLocation_initWithDictionary 6ms
โœ… TPPBookLocationCoverageTests testBookLocation_initWithEmptyDictionary 5ms
โœ… TPPBookLocationCoverageTests testBookLocation_initWithIncompleteDictionary 3ms
โœ… TPPBookLocationCoverageTests testBookLocation_initWithStrings 5ms
โœ… TPPBookLocationCoverageTests testBookLocation_locationStringMutation_ReflectsInDictionary 20ms
โœ… TPPBookLocationCoverageTests testBookLocation_rendererMutation_ReflectsInDictionary 4ms
โœ… TPPBookLocationEdgeCaseTests test_bookLocationData_stringForKey_missingKey_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_bookLocationData_stringForKey_returnsValue 2ms
โœ… TPPBookLocationEdgeCaseTests test_bookLocationData_stringForKey_wrongType_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_dictionaryRepresentation_containsExpectedKeys 2ms
โœ… TPPBookLocationEdgeCaseTests test_dictionaryRepresentation_preservesJSONContent 2ms
โœ… TPPBookLocationEdgeCaseTests test_dictionaryRepresentation_roundTrips 2ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_emptyDictionary_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_extraKeys_ignoresExtras 2ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_missingLocationString_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_missingRenderer_returnsNil 5ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_withValidData_createsLocation 3ms
โœ… TPPBookLocationEdgeCaseTests test_initFromDictionary_wrongTypes_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_init_withEmptyLocationString_createsLocation 2ms
โœ… TPPBookLocationEdgeCaseTests test_init_withEmptyRenderer_createsLocation 2ms
โœ… TPPBookLocationEdgeCaseTests test_init_withLongJSON_createsLocation 3ms
โœ… TPPBookLocationEdgeCaseTests test_init_withValidStringAndRenderer_createsLocation 3ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_differentContent_returnsFalse 10ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_differentRenderer_returnsFalse 8ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_identicalLocations_returnsTrue 2ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_ignoresAnnotationIdDifferences 3ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_ignoresTimeStampDifferences 2ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_nonJSONLocationString_returnsFalse 2ms
โœ… TPPBookLocationEdgeCaseTests test_isSimilarTo_sameContentDifferentTimeStampAndAnnotationId_returnsTrue 2ms
โœ… TPPBookLocationEdgeCaseTests test_locationStringDictionary_arrayJSON_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_locationStringDictionary_emptyString_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_locationStringDictionary_invalidJSON_returnsNil 2ms
โœ… TPPBookLocationEdgeCaseTests test_locationStringDictionary_validJSON_returnsParsedDictionary 2ms
โœ… TPPBookLocationKeyTests testBookLocationData_stringAccessor 5ms
โœ… TPPBookLocationKeyTests testBookLocationData_stringAccessorWrongType 8ms
โœ… TPPBookLocationKeyTests testBookLocationKey_MatchesDictionaryRepresentationKeys 7ms
โœ… TPPBookLocationTests testDictionaryRepresentation_ContainsAllFields 3ms
โœ… TPPBookLocationTests testInit_FromDictionary_Succeeds 8ms
โœ… TPPBookLocationTests testInit_FromDictionary_WithMissingLocationString_ReturnsNil 2ms
โœ… TPPBookLocationTests testInit_FromDictionary_WithMissingRenderer_ReturnsNil 2ms
โœ… TPPBookLocationTests testInit_WithValidParams_Succeeds 3ms
โœ… TPPBookLocationTests testIsSimilarTo_IgnoresAnnotationId 3ms
โœ… TPPBookLocationTests testIsSimilarTo_IgnoresTimestamp 17ms
โœ… TPPBookLocationTests testIsSimilarTo_WithDifferentRenderer_ReturnsFalse 3ms
โœ… TPPBookLocationTests testIsSimilarTo_WithSameContent_ReturnsTrue 3ms
โœ… TPPBookLocationTests testLocationStringDictionary_ParsesValidJSON 3ms
โœ… TPPBookLocationTests testLocationStringDictionary_WithInvalidJSON_ReturnsNil 9ms
โœ… TPPBookModelGapTests testTPPBook_bookWithMetadata_returnsBookWithUpdatedMetadata 12ms
โœ… TPPBookModelGapTests testTPPBook_dictionaryRepresentation_producesNonEmptyDict 5ms
โœ… TPPBookModelGapTests testTPPBook_dictionaryRepresentation_roundTripPreservesKeyProperties 8ms
โœ… TPPBookModelGapTests testTPPBook_sameIdentifier_comparableEquivalent 8ms
โœ… TPPBookRegistryAsyncReadinessTests testIntegration_underDetailsFailed_throwsAccountNotFound 176ms
โœ… TPPBookRegistryAsyncReadinessTests testReadiness_underDetailsFailed_gateThrows 143ms
โœ… TPPBookRegistryAsyncReadinessTests testReadiness_underDetailsLoading_gateBlocksUntilTransition 233ms
โœ… TPPBookRegistryAtomicWriteTests testAsyncSave_EventuallyProducesValidFile 38ms
โœ… TPPBookRegistryAtomicWriteTests testConcurrentSaves_EveryDiskStateBetweenSaves_IsValidJSON 213ms
โœ… TPPBookRegistryAtomicWriteTests testSaveSync_FileSizeNonZero_AndJSONComplete 232ms
โœ… TPPBookRegistryAtomicWriteTests testSaveSync_LeavesNoStagingArtifactsInRegistryDir 27ms
โœ… TPPBookRegistryAtomicWriteTests testSaveSync_OverlappingSaves_FinalContentsOnly 390ms
โœ… TPPBookRegistryAtomicWriteTests testSaveSync_ProducesCompleteParseableJSON 85ms
โœ… TPPBookRegistryAtomicWriteTests testSave_AfterDirectoryDeleted_DoesNotLeaveCorruptedFile 151ms
โœ… TPPBookRegistryBookRetrievalTests testAllBooks_ReturnsRegisteredBooks 32ms
โœ… TPPBookRegistryBookRetrievalTests testBook_ForEmptyIdentifier_ReturnsNil 37ms
โœ… TPPBookRegistryBookRetrievalTests testBook_ForNilIdentifier_ReturnsNil 20ms
โœ… TPPBookRegistryBookRetrievalTests testBook_ForNonExistentIdentifier_ReturnsNil 6ms
โœ… TPPBookRegistryBookRetrievalTests testBook_ForValidIdentifier_ReturnsBook 9ms
โœ… TPPBookRegistryBookRetrievalTests testHeldBooks_ReturnsOnlyHoldingBooks 39ms
โœ… TPPBookRegistryBookRetrievalTests testMyBooks_ReturnsDownloadRelatedBooks 19ms
โœ… TPPBookRegistryBookmarkTests testAddGenericBookmark_AppendsToList 32ms
โœ… TPPBookRegistryBookmarkTests testAddOrReplaceGenericBookmark_ReplacesExisting 19ms
โœ… TPPBookRegistryBookmarkTests testAddReadiumBookmark_AppendsToList 20ms
โœ… TPPBookRegistryBookmarkTests testDeleteGenericBookmark_RemovesFromList 22ms
โœ… TPPBookRegistryBookmarkTests testDeleteReadiumBookmark_RemovesFromList 22ms
โœ… TPPBookRegistryBookmarkTests testReadiumBookmarks_SortedByProgress 20ms
โœ… TPPBookRegistryBookmarkTests testReplaceGenericBookmark_UpdatesBookmark 24ms
โœ… TPPBookRegistryCorruptedDataTests testRecordInit_WithCorruptedBookmarks_SkipsInvalid 8ms
โœ… TPPBookRegistryCorruptedDataTests testRecordInit_WithInvalidState_ReturnsNil 5ms
โœ… TPPBookRegistryCorruptedDataTests testRecordInit_WithMissingBook_ReturnsNil 5ms
โœ… TPPBookRegistryCorruptedDataTests testRecordInit_WithMissingOptionalFields_Succeeds 7ms
โœ… TPPBookRegistryCorruptedDataTests testRecordInit_WithMissingState_ReturnsNil 9ms
โœ… TPPBookRegistryDataTests testArrayForKey_ReturnsArray 3ms
โœ… TPPBookRegistryDataTests testObjectForKey_ReturnsDictionary 20ms
โœ… TPPBookRegistryDataTests testSetValue_SetsValue 3ms
โœ… TPPBookRegistryDataTests testValueForKey_ReturnsValue 4ms
โœ… TPPBookRegistryDependencyTests testAppContainer_constructionDoesNotDeadlock 7ms
โœ… TPPBookRegistryDependencyTests testAppContainer_returnsSameRegistryInstance 9ms
โœ… TPPBookRegistryDependencyTests testInit_takesAccountsManagerExplicitly 13ms
โœ… TPPBookRegistryDependencyTests testWithAccount_inheritsParentAccountsManager 44ms
โœ… TPPBookRegistryFulfillmentIdTests testFulfillmentId_ForEmptyIdentifier_ReturnsNil 20ms
โœ… TPPBookRegistryFulfillmentIdTests testFulfillmentId_ForNilIdentifier_ReturnsNil 4ms
โœ… TPPBookRegistryFulfillmentIdTests testFulfillmentId_ForNonExistentBook_ReturnsNil 12ms
โœ… TPPBookRegistryFulfillmentIdTests testSetFulfillmentId_UpdatesFulfillmentId 19ms
โœ… TPPBookRegistryLargeCorpusTests testLoad_5000Books_CompletesUnderTimeBudget 39.53s
โœ… TPPBookRegistryLargeCorpusTests testLoad_5000Books_ProducesExactCount 29.98s
โœ… TPPBookRegistryLargeCorpusTests testLookupByIdentifier_5000Books_AllUnique 28.88s
โœ… TPPBookRegistryLargeCorpusTests testRoundTrip_5000Books_AllFieldsPreserved 43.46s
โœ… TPPBookRegistryLargeCorpusTests testSave_5000Books_FileContainsAllRecords 2.48s
โœ… TPPBookRegistryLoadReentrancyTests testLoad_EmitsBookStateEventsForAllBooks 6ms
โœ… TPPBookRegistryLoadReentrancyTests testLoad_RapidCallsForSameAccount_DoesNotCrash 26ms
โœ… TPPBookRegistryLocationTests testLocation_ForNonExistentBook_ReturnsNil 11ms
โœ… TPPBookRegistryLocationTests testSetLocationSync_UpdatesSynchronously 10ms
โœ… TPPBookRegistryLocationTests testSetLocation_UpdatesLocation 14ms
โœ… TPPBookRegistryLocationTests testSetLocation_WithNil_ClearsLocation 44ms
โœ… TPPBookRegistryMigrationTests testDuplicateIdentifiersOnDisk_CollapseToOneRecord 122ms
โœ… TPPBookRegistryMigrationTests testLookupByIdentifier_IsUnique_AfterLoad 177ms
โœ… TPPBookRegistryMigrationTests testRecordLevelFulfillmentId_IsPreservedAcrossLoad 120ms
โœ… TPPBookRegistryMigrationTests testRecordMissingAudienceAndLanguage_FillsNilDefaults 117ms
โœ… TPPBookRegistryMigrationTests testRecordMissingCategoriesField_DefaultsToEmptyArray 136ms
โœ… TPPBookRegistryMigrationTests testRecordMissingMetadataField_Dropped 129ms
โœ… TPPBookRegistryMigrationTests testRecordMissingStateField_Dropped 120ms
โœ… TPPBookRegistryMigrationTests testRecordWithLegacyISO8601DateOnlyUpdated_StillParses 133ms
โœ… TPPBookRegistryMigrationTests testRecordWithMalformedUpdated_FallsBackToDistantPast_StillLoads 128ms
โœ… TPPBookRegistryMigrationTests testRecordWithUnknownFutureFields_FieldDroppedButRecordSurvives 125ms
โœ… TPPBookRegistryMigrationTests testRecordWithUnknownState_DroppedFromRegistry 116ms
โœ… TPPBookRegistryMigrationTests testSavedFile_StateField_IsStringValueNotInteger 17ms
โœ… TPPBookRegistryMigrationTests testSavedFile_TopLevelShape_IsRecordsArray 16ms
โœ… TPPBookRegistryMigrationTests testV1AcquisitionsLackingIndirectKey_StillParses 123ms
โœ… TPPBookRegistryMigrationTests testV1SingularAcquisitionKey_IsIgnoredButRecordIsPreserved 116ms
โœ… TPPBookRegistryMigrationTests testV2BaselineRoundTrip_LoadsAndPreservesIdentifierAndState 136ms
โœ… TPPBookRegistryPersistenceTests testAccountIsolation_AccountADoesNotLeakIntoAccountB 227ms
โœ… TPPBookRegistryPersistenceTests testBookStatePublisher_DoesNotFireOnNoOpUpdateBook 720ms
โœ… TPPBookRegistryPersistenceTests testBookStatePublisher_FiresOnDownloadingToDownloadedTransition 19ms
โœ… TPPBookRegistryPersistenceTests testConcurrentSaves_ProduceValidJSONOnDisk 214ms
โœ… TPPBookRegistryPersistenceTests testLoad_WithCorruptedJSON_RegistryIsEmpty_DoesNotCrash 251ms
โœ… TPPBookRegistryPersistenceTests testLoad_WithJSONMissingRecordsKey_RegistryIsEmpty 115ms
โœ… TPPBookRegistryPersistenceTests testLoad_WithTruncatedJSON_RegistryIsEmpty_DoesNotCrash 123ms
โœ… TPPBookRegistryPersistenceTests testRegistryUrl_DiffersAcrossAccounts 6ms
โœ… TPPBookRegistryPersistenceTests testSave_OverwritesPreviousSave_NotAppends 134ms
โœ… TPPBookRegistryPersistenceTests testSave_ThenColdStartLoad_PreservesRecord 123ms
โœ… TPPBookRegistryProcessingTests testSetProcessing_False_ClearsProcessingState 5ms
โœ… TPPBookRegistryProcessingTests testSetProcessing_TracksProcessingState 16ms
โœ… TPPBookRegistryPublisherTests testBookStatePublisher_EmitsOnBookAdd 100ms
โœ… TPPBookRegistryPublisherTests testBookStatePublisher_EmitsOnBookRemove 83ms
โœ… TPPBookRegistryPublisherTests testBookStatePublisher_EmitsOnStateChange 82ms
โœ… TPPBookRegistryPublisherTests testBookStatePublisher_MultipleStateChanges_EmitsAll 602ms
โœ… TPPBookRegistryPublisherTests testRegistryPublisher_EmitsOnBookAdd 73ms
โœ… TPPBookRegistryPublisherTests testRegistryPublisher_EmitsOnBookRemove 46ms
โœ… TPPBookRegistryRecordPersistenceTests testAllStatesSerializeCorrectly 18ms
โœ… TPPBookRegistryRecordPersistenceTests testDictionaryRepresentation_ContainsAllFields 12ms
โœ… TPPBookRegistryRecordPersistenceTests testDictionaryRoundTrip_PreservesData 7ms
โœ… TPPBookRegistryRecordTests testAllStatesCanBePreserved 3ms
โœ… TPPBookRegistryRecordTests testDeriveInitialStateForBookWithoutAcquisition 3ms
โœ… TPPBookRegistryRecordTests testDeriveInitialStateForBorrowableBook 3ms
โœ… TPPBookRegistryRecordTests testDictionaryRepresentationPreservesState 5ms
โœ… TPPBookRegistryRecordTests testInitFromDictionaryPreservesState 11ms
โœ… TPPBookRegistryRecordTests testInitPreservesDownloadFailedState 5ms
โœ… TPPBookRegistryRecordTests testInitPreservesDownloadSuccessfulState 4ms
โœ… TPPBookRegistryRecordTests testInitPreservesDownloadingState 3ms
โœ… TPPBookRegistryRecordTests testInitPreservesHoldingState 3ms
โœ… TPPBookRegistryRecordTests testInitPreservesUsedState 3ms
โœ… TPPBookRegistryStateManagementTests testAddBook_NewBook_RegistersWithCorrectState 1.17s
โœ… TPPBookRegistryStateManagementTests testAddBook_WithBookmarks_StoresBookmarks 1.18s
โœ… TPPBookRegistryStateManagementTests testAddBook_WithFulfillmentId_StoresFulfillmentId 1.20s
โœ… TPPBookRegistryStateManagementTests testAddBook_WithLocation_StoresLocation 1.20s
โœ… TPPBookRegistryStateManagementTests testRemoveBook_RemovesFromRegistry 1.11s
โœ… TPPBookRegistryStateManagementTests testRemoveBook_WithEmptyIdentifier_DoesNotCrash 3.41s
โœ… TPPBookRegistryStateManagementTests testSetState_ForUnregisteredBook_DoesNotCrash 1.17s
โœ… TPPBookRegistryStateManagementTests testSetState_TransitionsCorrectly 1.09s
โœ… TPPBookRegistryStateManagementTests testStateFor_EmptyIdentifier_ReturnsUnregistered 2.10s
โœ… TPPBookRegistryStateManagementTests testStateFor_NilIdentifier_ReturnsUnregistered 2.24s
โœ… TPPBookRegistryStateManagementTests testStateFor_NonExistentBook_ReturnsUnregistered 2.66s
โœ… TPPBookRegistryThreadSafetyTests testCrashlytics30c41d7e_ConcurrentAddAndUpdate_DoNotCrash 125ms
โœ… TPPBookRegistryThreadSafetyTests testCrashlytics30c41d7e_RapidRegistryMutations_DoNotCrashPublisher 270ms
โœ… TPPBookRegistryThreadSafetyTests testRegistryPublisher_EmitsConsistentSnapshots_DuringRapidMutations 259ms
โœ… TPPBookRegistryUpdateAndRemoveTests testUpdateAndRemoveBook_SetsStateToUnregistered 27ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_falseForLCPBook 9ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_falseForOpenAccessAudiobook 4ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_falseForOpenAccessBook 4ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_falseWhenNoAdobeAcquisitionsPresent 3ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_trueForAdobeAdeptBook 6ms
โœ… TPPBookRequiresAdobeDRMTests testRequiresAdobeDRM_trueForOPDSFixtureEntry 5ms
โœ… TPPBookSerializationTests test_categoryStrings_returnsCategories 4ms
โœ… TPPBookSerializationTests test_comparable_sortsAlphabeticallyByTitle 10ms
โœ… TPPBookSerializationTests test_defaultBookContentType_forAudiobook_returnsAudiobook 10ms
โœ… TPPBookSerializationTests test_defaultBookContentType_forEpub_returnsEpub 8ms
โœ… TPPBookSerializationTests test_dictionaryRoundTrip_preservesAllFields 7ms
โœ… TPPBookSerializationTests test_dictionaryRoundTrip_preservesIdentifier 9ms
โœ… TPPBookSerializationTests test_dictionaryRoundTrip_preservesUpdatedTimestamp 8ms
โœ… TPPBookSerializationTests test_initFromDictionary_missingCategories_usesEmptyArray 6ms
โœ… TPPBookSerializationTests test_initFromDictionary_missingId_returnsNil 11ms
โœ… TPPBookSerializationTests test_initFromDictionary_missingTitle_returnsNil 4ms
โœ… TPPBookSerializationTests test_initFromDictionary_missingUpdated_fallsBackToDistantPast 9ms
โœ… TPPBookSerializationTests test_initFromDictionary_updatedBareDate_parsesSuccessfully 7ms
โœ… TPPBookSerializationTests test_initFromDictionary_updatedFullRFC3339Datetime_parsesSuccessfully 18ms
โœ… TPPBookStateInitializationTests testStateInit_FromInvalidString_ReturnsNil 5ms
โœ… TPPBookStateInitializationTests testStateInit_FromValidStrings 2ms
โœ… TPPBookStateInitializationTests testStateRoundTrip_AllStates 2ms
โœ… TPPBookStateInitializationTests testStateStringValue_ReturnsCorrectString 4ms
โœ… TPPBookStateTests testAllBookState 3ms
โœ… TPPBookStateTests testBookStateFromString 3ms
โœ… TPPBookStateTests testInitWithString 21ms
โœ… TPPBookStateTests testStringValue 4ms
โœ… TPPBookTests testTPPBook_isStreamingHTML_epubOnly_returnsFalse 4ms
โœ… TPPBookTests testTPPBook_isStreamingHTML_streamingMediaOnly_returnsTrue 3ms
โœ… TPPBookTests testTPPBook_isStreamingHTML_unsupported_returnsFalse 3ms
โœ… TPPBookTests test_authorLinkArray_excludesNilURLs 3ms
โœ… TPPBookTests test_authorLinkArray_returnsURLStrings 2ms
โœ… TPPBookTests test_authorNameArray_nilWhenNoAuthors 2ms
โœ… TPPBookTests test_authorNameArray_returnsNames 2ms
โœ… TPPBookTests test_authors_joinsNamesWithSemicolon 2ms
โœ… TPPBookTests test_authors_nilWhenNoAuthors 3ms
โœ… TPPBookTests test_authors_singleAuthor 2ms
โœ… TPPBookTests test_availabilityDetails_defaultValues 2ms
โœ… TPPBookTests test_bookWithMetadata_preservesSelfIdentifierAndAcquisitions 16ms
โœ… TPPBookTests test_bookWithMetadata_preservesSelfRevokeReportAndTimeTrackingURLs 3ms
โœ… TPPBookTests test_bookWithMetadata_takesImageURLsFromMetadataBook 17ms
โœ… TPPBookTests test_bookWithMetadata_takesMetadataFromOtherBook 3ms
โœ… TPPBookTests test_bookWithMetadata_takesSeriesNameFromMetadataBook 3ms
โœ… TPPBookTests test_categories_joinsWithSemicolon 2ms
โœ… TPPBookTests test_categories_nilWhenNil 5ms
โœ… TPPBookTests test_categoryStringsFromCategories_emptyArrayReturnsEmpty 3ms
โœ… TPPBookTests test_categoryStringsFromCategories_extractsLabelsFromSimplifiedScheme 20ms
โœ… TPPBookTests test_categoryStringsFromCategories_filtersOutUnknownSchemes 3ms
โœ… TPPBookTests test_categoryStringsFromCategories_includesCategoriesWithNilScheme 3ms
โœ… TPPBookTests test_categoryStringsFromCategories_usesTermWhenNoLabel 2ms
โœ… TPPBookTests test_clearCachedImages_removesAllKeysFromCache 3ms
โœ… TPPBookTests test_comparable_equalIdentifiersNotLessThan 3ms
โœ… TPPBookTests test_comparable_ordersById 22ms
โœ… TPPBookTests test_comparable_sortingMultipleBooks 7ms
โœ… TPPBookTests test_defaultAcquisitionIfBorrow_nilWhenOpenAccess 3ms
โœ… TPPBookTests test_defaultAcquisitionIfBorrow_returnsAcquisitionWhenBorrow 3ms
โœ… TPPBookTests test_defaultAcquisitionIfOpenAccess_nilWhenBorrow 3ms
โœ… TPPBookTests test_defaultAcquisitionIfOpenAccess_returnsWhenOpenAccess 2ms
โœ… TPPBookTests test_defaultBookContentType_audiobook 4ms
โœ… TPPBookTests test_defaultBookContentType_epub 4ms
โœ… TPPBookTests test_defaultBookContentType_pdf 17ms
โœ… TPPBookTests test_defaultBookContentType_unsupportedWhenNoAcquisitions 2ms
โœ… TPPBookTests test_dictionaryInit_handlesFlatAuthorArrayFormat 3ms
โœ… TPPBookTests test_dictionaryInit_handlesNestedAuthorArrayFormat 7ms
โœ… TPPBookTests test_dictionaryInit_nilWhenMissingId 6ms
โœ… TPPBookTests test_dictionaryInit_nilWhenMissingTitle 2ms
โœ… TPPBookTests test_dictionaryInit_readsSeriesNameFromSeriesNameKey 3ms
โœ… TPPBookTests test_dictionaryInit_salvagesWhenCategoriesMissing 3ms
โœ… TPPBookTests test_dictionaryInit_salvagesWhenUpdatedMissing 6ms
โœ… TPPBookTests test_dictionaryInit_seriesNameNilWhenKeyAbsent 3ms
โœ… TPPBookTests test_dictionaryRepresentation_containsRequiredKeys 4ms
โœ… TPPBookTests test_dictionaryRepresentation_writesSeriesNameUnderSeriesNameKey 2ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesAuthors 7ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesCategories 5ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesDistributor 3ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesIdentifierAndTitle 3ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesOptionalURLs 9ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesSeriesName 4ms
โœ… TPPBookTests test_dictionaryRoundTrip_preservesSubtitleAndSummary 4ms
โœ… TPPBookTests test_getAvailabilityDetails_nilForUnlimitedAvailability 10ms
โœ… TPPBookTests test_getAvailabilityDetails_populatesForLimitedAvailability 7ms
โœ… TPPBookTests test_getExpirationDate_nilForUnlimitedAvailability 3ms
โœ… TPPBookTests test_getExpirationDate_returnsDateForLimitedAvailability 4ms
โœ… TPPBookTests test_getExpirationDate_returnsRawUntilDate_andIsExpiredFlagsPastDates 2ms
โœ… TPPBookTests test_getReservationDetails_populatesFromReservedAvailability 5ms
โœ… TPPBookTests test_getReservationDetails_timeUnitPluralForMultipleDays 2ms
โœ… TPPBookTests test_getReservationDetails_timeUnitSingularForOneDay 3ms
โœ… TPPBookTests test_getReservationDetails_zeroValuesForUnlimitedAvailability 4ms
โœ… TPPBookTests test_hasDuration_falseWhenDurationEmpty 2ms
โœ… TPPBookTests test_hasDuration_falseWhenDurationNil 3ms
โœ… TPPBookTests test_hasDuration_trueWhenDurationSet 3ms
โœ… TPPBookTests test_identifiable_conformance 5ms
โœ… TPPBookTests test_isAudiobook_falseForEpub 2ms
โœ… TPPBookTests test_isAudiobook_falseForPDF 4ms
โœ… TPPBookTests test_isAudiobook_trueForAudiobookContentType 4ms
โœ… TPPBookTests test_isExpired_falseWhenNoExpiration 2ms
โœ… TPPBookTests test_mergingPreservingMetadata_carriesCoverImageFromSelf 3ms
โœ… TPPBookTests test_mergingPreservingMetadata_fallsBackToFreshCoverImage 3ms
โœ… TPPBookTests test_mergingPreservingMetadata_preservesRichSelfFieldsWhenFreshIsEmpty 3ms
โœ… TPPBookTests test_mergingPreservingMetadata_preservesSelfAuthorsWhenFreshIsEmpty 2ms
โœ… TPPBookTests test_mergingPreservingMetadata_preservesSelfAuthorsWhenFreshIsNil 3ms
โœ… TPPBookTests test_mergingPreservingMetadata_preservesSelfIdentifier 3ms
โœ… TPPBookTests test_mergingPreservingMetadata_preservesSelfSeriesNameWhenFreshIsEmpty 2ms
โœ… TPPBookTests test_mergingPreservingMetadata_takesFreshAuthorsWhenPresent 2ms
โœ… TPPBookTests test_mergingPreservingMetadata_takesFreshSeriesNameWhenPresent 4ms
โœ… TPPBookTests test_mergingPreservingMetadata_usesFreshUpdatedTimestamp 7ms
โœ… TPPBookTests test_narrators_joinsContributorsNrt 7ms
โœ… TPPBookTests test_narrators_nilWhenNoContributors 2ms
โœ… TPPBookTests test_narrators_nilWhenNoNrtKey 3ms
โœ… TPPBookTests test_ordinalString_eleventh 4ms
โœ… TPPBookTests test_ordinalString_first 7ms
โœ… TPPBookTests test_ordinalString_hundredAndFirst 3ms
โœ… TPPBookTests test_ordinalString_second 5ms
โœ… TPPBookTests test_ordinalString_third 4ms
โœ… TPPBookTests test_ordinalString_thirteenth 3ms
โœ… TPPBookTests test_ordinalString_twelfth 2ms
โœ… TPPBookTests test_ordinalString_twentyFirst 3ms
โœ… TPPBookTests test_reservationDetails_defaultValues 2ms
โœ… TPPBookTests test_sampleAcquisition_nilWhenNoSampleOrPreview 25ms
โœ… TPPBookTests test_sampleAcquisition_returnsPreviewLinkAsFallback 4ms
โœ… TPPBookmarkDeletionLogTests testClearAllDeletions_OnlyAffectsSpecifiedBook 53ms
โœ… TPPBookmarkDeletionLogTests testClearAllDeletions_RemovesAllForBook 9ms
โœ… TPPBookmarkDeletionLogTests testClearDeletion_RemovesSpecificAnnotation 8ms
โœ… TPPBookmarkDeletionLogTests testLogDeletion_AddsToPendingDeletions 10ms
โœ… TPPBookmarkDeletionLogTests testLogDeletion_HandlesDuplicates 5ms
โœ… TPPBookmarkDeletionLogTests testLogDeletion_IgnoresEmptyAnnotationId 13ms
โœ… TPPBookmarkDeletionLogTests testLogDeletion_MultipleDeletionsForSameBook 7ms
โœ… TPPBookmarkDeletionLogTests testPP3555_ClearAllDeletionsOnBookReturn 10ms
โœ… TPPBookmarkDeletionLogTests testPP3555_DeletionLogTracksBookmarksForServerDeletion 5ms
โœ… TPPBookmarkDeletionLogTests testPendingDeletions_ReturnsEmptyForUnknownBook 5ms
โœ… TPPBookmarkDeletionLogTests testThreadSafety_ConcurrentWrites 49ms
โœ… TPPBookmarkFactoryInitTests testInit_StoresProperties 3ms
โœ… TPPBookmarkFactoryInitTests testInit_WithNilDeviceId_CreatesFactory 8ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests testMakeFromServerAnnotation_DoubleProgressValue_ConvertsToFloat 5ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests testMakeFromServerAnnotation_EmptyHref_CreatesBookmarkWithEmptyHref 24ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests testMakeFromServerAnnotation_MissingProgressValues_UsesDefaults 3ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests testMakeFromServerAnnotation_ProgressFromBodyFallback 6ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests testMakeFromServerAnnotation_WithReadingOrderItem_IncludesIt 20ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_ExtractsChapterTitle 6ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_InvalidSelectorJSON_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MismatchedBookId_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MismatchedMotivation_ReturnsNil 4ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MissingAnnotationId_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MissingBody_ReturnsNil 13ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MissingSelector_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_MissingTarget_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_ReadingProgress_CreatesBookmark 4ms
โœ… TPPBookmarkFactoryTests testMakeFromServerAnnotation_ValidBookmark_CreatesBookmark 3ms
โœ… TPPBookmarkFactoryTests testMake_FromR3Location_CreatesBookmark 18ms
โœ… TPPBookmarkFactoryTests testMake_FromR3Location_GeneratesLocationFromLocator 7ms
โœ… TPPBookmarkFactoryTests testMake_FromR3Location_UsesCreationDate 5ms
โœ… TPPBookmarkFactoryTests testMake_FromR3Location_WithNilProgression_ReturnsNil 3ms
โœ… TPPBookmarkFactoryTests testMake_FromR3Location_WithPagePosition_IncludesPage 7ms
โœ… TPPBookmarkR3ConversionTests testConvertToR3_bookmarkNotInPublication_returnsNil 3ms
โœ… TPPBookmarkR3ConversionTests testConvertToR3_parsesTimeCorrectly 11ms
โœ… TPPBookmarkR3ConversionTests testConvertToR3_preservesChapterTitle 3ms
โœ… TPPBookmarkR3ConversionTests testConvertToR3_preservesProgressionValues 4ms
โœ… TPPBookmarkR3ConversionTests testConvertToR3_validBookmark_createsR3Location 3ms
โœ… TPPBookmarkR3LocationTests testFrom_emptyReadingOrder_returnsNil 2ms
โœ… TPPBookmarkR3LocationTests testFrom_firstChapter_returnsIndexZero 2ms
โœ… TPPBookmarkR3LocationTests testFrom_lastChapter_returnsCorrectIndex 3ms
โœ… TPPBookmarkR3LocationTests testFrom_locatorNotInPublication_returnsNil 2ms
โœ… TPPBookmarkR3LocationTests testFrom_locatorWithDifferentMediaType_findsMatchByHref 2ms
โœ… TPPBookmarkR3LocationTests testFrom_validLocatorInPublication_createsLocation 2ms
โœ… TPPBookmarkR3LocationTests testFrom_withCustomCreationDate_usesProvidedDate 2ms
โœ… TPPBookmarkR3LocationTests testInit_preservesResourceIndex 2ms
โœ… TPPBookmarkR3LocationTests testInit_withDefaultCreationDate_usesCurrentDate 2ms
โœ… TPPBookmarkR3LocationTests testInit_withValidParameters_createsLocation 3ms
โœ… TPPBookmarkR3LocationTests testLocator_preservesMediaType 2ms
โœ… TPPBookmarkR3LocationTests testLocator_preservesProgression 2ms
โœ… TPPBookmarkR3LocationTests testLocator_preservesTitle 2ms
โœ… TPPBookmarkSpecTests testBookmarkMotivationKeyword 7ms
โœ… TPPCachingTests testMaxAgeExtraction 4ms
โœ… TPPCachingTests testResponseModification 8ms
โœ… TPPCachingTests testSufficientCacheHeaders 9ms
โœ… TPPCapturedCredentialsTests testFinalizeSignIn_fallsBackToUIDelegate_whenCapturedNil 2.55s
โœ… TPPCapturedCredentialsTests testFinalizeSignIn_usesCapturedCredentials_whenUIDelegateCleared 1.46s
โœ… TPPCapturedCredentialsTests testLogIn_refreshesCapturedCredentials_onSubsequentAttempts 192ms
โœ… TPPCapturedCredentialsTests testUpdateUserAccount_usesAtomicUpdateWithCorrectLibraryUUID 1.05s
โœ… TPPCapturedCredentialsTests testUpdateUserAccount_withAuthToken_savesAllCredentials 492ms
โœ… TPPConfigurationTests test_accentColor_returnsValidUIColor 2ms
โœ… TPPConfigurationTests test_appearanceWithBackgroundColor_usesProvidedColor 8ms
โœ… TPPConfigurationTests test_backgroundColor_returnsValidUIColor 4ms
โœ… TPPConfigurationTests test_backgroundMediaOverlayHighlightColor_returnsValidUIColor 3ms
โœ… TPPConfigurationTests test_betaUrlHash_isNonEmpty 2ms
โœ… TPPConfigurationTests test_betaUrl_isValid 2ms
โœ… TPPConfigurationTests test_boldSystemFontName_returnsNonEmptyString 2ms
โœ… TPPConfigurationTests test_defaultAppearance_returnsConfiguredAppearance 2ms
โœ… TPPConfigurationTests test_defaultBookmarkRowHeight_returnsPositiveValue 2ms
โœ… TPPConfigurationTests test_defaultTOCRowHeight_returnsPositiveValue 3ms
โœ… TPPConfigurationTests test_mainColor_returnsValidUIColor 3ms
โœ… TPPConfigurationTests test_palaceRed_returnsValidUIColor 4ms
โœ… TPPConfigurationTests test_prodUrlHash_isDeterministic 2ms
โœ… TPPConfigurationTests test_prodUrlHash_isNonEmpty 10ms
โœ… TPPConfigurationTests test_prodUrl_isValid 2ms
โœ… TPPConfigurationTests test_readerBackgroundColor_returnsValidUIColor 2ms
โœ… TPPConfigurationTests test_readerBackgroundDarkColor_returnsValidUIColor 3ms
โœ… TPPConfigurationTests test_readerBackgroundSepiaColor_returnsValidUIColor 2ms
โœ… TPPConfigurationTests test_semiBoldSystemFontName_returnsNonEmptyString 2ms
โœ… TPPConfigurationTests test_systemFontFamilyName_returnsNonEmptyString 2ms
โœ… TPPConfigurationTests test_systemFontFamilyName_returnsOpenSans 2ms
โœ… TPPConfigurationTests test_systemFontName_returnsNonEmptyString 2ms
โœ… TPPContentTypeTests testFrom_EmptyString_ReturnsUnsupported 2ms
โœ… TPPContentTypeTests testFrom_EpubZip_ReturnsEpub 3ms
โœ… TPPContentTypeTests testFrom_NilMimeType_ReturnsUnsupported 5ms
โœ… TPPContentTypeTests testFrom_OctetStream_ReturnsEpub 2ms
โœ… TPPContentTypeTests testFrom_OpenAccessAudiobook_ReturnsAudiobook 2ms
โœ… TPPContentTypeTests testFrom_OpenAccessPDF_ReturnsPDF 6ms
โœ… TPPContentTypeTests testFrom_UnknownMimeType_ReturnsUnsupported 4ms
โœ… TPPContentTypeTests testTPPBookContentType_from_plainTextHtml_returnsUnsupported 4ms
โœ… TPPContentTypeTests testTPPBookContentType_from_streamingMediaMIME_returnsStreamingHTML 3ms
โœ… TPPCredentialConcurrencyTests testAtomicUpdate_writesAreVisibleInSnapshot 3ms
โœ… TPPCredentialConcurrencyTests testConcurrentRefreshCredentials_doesNotCrash 7ms
โœ… TPPCredentialConcurrencyTests testConcurrentSnapshots_returnConsistentData 4ms
โŠ˜ TPPCredentialIsolationE2ETests testMarkCredentialsStale_doesNotAffectOtherAccount 36ms
โŠ˜ TPPCredentialIsolationE2ETests testRapidSwitching_500Iterations_noContamination 37ms
โŠ˜ TPPCredentialIsolationE2ETests testSignInA_switchB_signInB_signOutB_verifyAIntact 33ms
โŠ˜ TPPCredentialIsolationE2ETests testSignInA_switchToB_signInB_verifyAIntact 40ms
โŠ˜ TPPCredentialIsolationE2ETests testThreeLibraries_allIsolated 34ms
โœ… TPPCredentialPersistenceTests testFullSignInFlow_authStateIsLoggedIn 111ms
โœ… TPPCredentialPersistenceTests testFullSignInFlow_completionCalledOnce 95ms
โœ… TPPCredentialPersistenceTests testFullSignInFlow_credentialsRemainAccessible 117ms
โœ… TPPCredentialPersistenceTests testUpdateUserAccount_basicAuth_setsCredentialsAndAuthState 94ms
โœ… TPPCredentialPersistenceTests testUpdateUserAccount_credentialsPersistedAndRefreshable 80ms
โœ… TPPCredentialPersistenceTests testUpdateUserAccount_noSelectedAuth_stillMarksLoggedIn 92ms
โŠ˜ TPPCredentialSnapshotCoherenceTests testCredentialSnapshot_AuthStateTransitions_ArePeerVisible 42ms
โŠ˜ TPPCredentialSnapshotCoherenceTests testCredentialSnapshot_ReflectsRemoveAllFromPeerInstance 1.82s
โŠ˜ TPPCredentialSnapshotCoherenceTests testCredentialSnapshot_ReflectsWriteFromPeerInstance 493ms
โœ… TPPCredentialSnapshotTests testSnapshot_identifiesTokenCredentials 2ms
โœ… TPPCredentialSnapshotTests testSnapshot_isSignedInLogic_OAuth_stale 3ms
โœ… TPPCredentialSnapshotTests testSnapshot_isSignedInLogic_basicAuth 2ms
โœ… TPPCredentialSnapshotTests testSnapshot_isSignedInLogic_basicAuth_stale 4ms
โœ… TPPCredentialSnapshotTests testSnapshot_isSignedInLogic_loggedOut 3ms
โœ… TPPCredentialSnapshotTests testSnapshot_reportsNoCredentials 3ms
โœ… TPPCredentialSnapshotTests testSnapshot_returnsAuthState 2ms
โœ… TPPCredentialSnapshotTests testSnapshot_returnsCredentialsAfterSet 3ms
โœ… TPPCredentialsCoverageTests testBarcodeAndPin_codableRoundTrip 2ms
โœ… TPPCredentialsCoverageTests testBarcodeAndPin_storesFields 5ms
โœ… TPPCredentialsCoverageTests testCookies_codableRoundTrip 4ms
โœ… TPPCredentialsCoverageTests testCookies_storesCookies 3ms
โœ… TPPCredentialsCoverageTests testToken_codableRoundTrip 2ms
โœ… TPPCredentialsCoverageTests testToken_nilOptionals_codableRoundTrip 4ms
โœ… TPPCredentialsCoverageTests testToken_optionalDefaults 3ms
โœ… TPPCredentialsCoverageTests testToken_storesFields 12ms
โœ… TPPCredentialsCoverageTests testTypeID_rawValues 3ms
โœ… TPPCredentialsTests testBarcodeAndPin_WithEmptyValues_StoresEmptyStrings 3ms
โœ… TPPCredentialsTests testBarcodeAndPin_WithSpecialCharacters_PreservesCharacters 2ms
โœ… TPPCredentialsTests testBarcodeAndPin_WithValidData_StoresValues 2ms
โœ… TPPCredentialsTests testCookies_WithEmptyArray_StoresEmptyArray 2ms
โœ… TPPCredentialsTests testCookies_WithMultipleCookies_StoresAllCookies 3ms
โœ… TPPCredentialsTests testCookies_WithValidCookies_StoresCookies 2ms
โœ… TPPCredentialsTests testDecode_WithInvalidTypeID_ThrowsError 4ms
โœ… TPPCredentialsTests testDecode_WithMissingType_ThrowsError 3ms
โœ… TPPCredentialsTests testEncodeDecode_BarcodeAndPin_PreservesValues 46ms
โœ… TPPCredentialsTests testEncodeDecode_BarcodeAndPin_WithEmptyStrings 2ms
โœ… TPPCredentialsTests testEncodeDecode_BarcodeAndPin_WithLongStrings 2ms
โœ… TPPCredentialsTests testEncodeDecode_Cookies_WithEmptyArray 3ms
โœ… TPPCredentialsTests testEncodeDecode_Cookies_WithMultipleCookies 8ms
โœ… TPPCredentialsTests testEncodeDecode_Cookies_WithValidCookies 25ms
โœ… TPPCredentialsTests testEncodeDecode_Token_ExpirationDatePrecision 4ms
โœ… TPPCredentialsTests testEncodeDecode_Token_WithAllProperties 6ms
โœ… TPPCredentialsTests testEncodeDecode_Token_WithEmptyAuthToken 3ms
โœ… TPPCredentialsTests testEncodeDecode_Token_WithNilOptionals 3ms
โœ… TPPCredentialsTests testEncodeDecode_Token_WithSpecialCharacters 6ms
โœ… TPPCredentialsTests testEncodeDecode_Token_WithUnicodeCharacters 4ms
โœ… TPPCredentialsTests testToken_WithAllProperties_StoresValues 3ms
โœ… TPPCredentialsTests testToken_WithEmptyAuthToken_StoresEmptyString 3ms
โœ… TPPCredentialsTests testToken_WithOnlyAuthToken_StoresNilOptionals 4ms
โœ… TPPCredentialsTests testTypeID_BarcodeAndPinHasCorrectRawValue 3ms
โœ… TPPCredentialsTests testTypeID_CookiesHasCorrectRawValue 10ms
โœ… TPPCredentialsTests testTypeID_TokenHasCorrectRawValue 7ms
โœ… TPPCrossLibrarySignOutTests testMultiLibraryMock_returnsSeparateAccountsPerUUID 112ms
โœ… TPPCrossLibrarySignOutTests testSequentialSignOuts_ofMultipleLibraries_clearCorrectCredentials 131ms
โœ… TPPCrossLibrarySignOutTests testSignOut_ofNonActiveLibrary_doesNotClearActiveLibraryCredentials 344ms
โœ… TPPCrossLibrarySignOutTests testSignOut_ofNonActiveOAuthLibrary_doesNotClearActiveLibraryToken 173ms
โœ… TPPCrossLibrarySignOutTests testSignOut_ofNonActiveSAMLLibrary_doesNotClearActiveLibraryCookies 140ms
โœ… TPPCrossLibrarySignOutTests testUserAccount_isScopedToLibraryAccountID 94ms
โœ… TPPDRMFailureCredentialPreservationTests testUpdateUserAccount_drmFailure_doesNotChangeAuthState 106ms
โœ… TPPDRMFailureCredentialPreservationTests testUpdateUserAccount_drmFailure_doesNotWipeExistingCredentials 147ms
โœ… TPPDRMFailureCredentialPreservationTests testUpdateUserAccount_drmFailure_noExistingCredentials_noWipe 105ms
โœ… TPPDRMFailureCredentialPreservationTests testUpdateUserAccount_drmSuccess_doesSaveCredentials 87ms
โœ… TPPErrorLoggerTests testClientDomain_isCorrect 3ms
โœ… TPPErrorLoggerTests testErrorCode_appLaunchAndRegistryCodesAreDistinct 5ms
โœ… TPPErrorLoggerTests testErrorCode_drmCodesAreSeparateFromNetworking 2ms
โœ… TPPErrorLoggerTests testErrorCode_ignoreProducesNoError 12ms
โœ… TPPErrorLoggerTests testErrorCode_imageLoadingCodesAreUnique 3ms
โœ… TPPErrorLoggerTests testErrorCode_networkingCodesAreUnique 2ms
โœ… TPPErrorLoggerTests testErrorCode_parseAndImageGroupsDoNotOverlap 3ms
โœ… TPPErrorLoggerTests testErrorCode_parseFailureCodesAreUnique 17ms
โœ… TPPErrorLoggerTests testErrorCode_signInCodesAreDistinct 2ms
โœ… TPPErrorLoggerTests testErrorCodes_areUnique 10ms
โœ… TPPErrorLoggerTests testImageDecodeFail_doesNotCrash 34ms
โœ… TPPErrorLoggerTests testImageHostFailure_isThrottled 28ms
โœ… TPPErrorLoggerTests testLogBarcodeException_doesNotCrash 22ms
โœ… TPPErrorLoggerTests testLogError_withCodeAndSummary_doesNotCrash 12ms
โœ… TPPErrorLoggerTests testLogError_withErrorAndSummary_doesNotCrash 11ms
โœ… TPPErrorLoggerTests testLogInvalidLicensor_doesNotCrash 17ms
โœ… TPPErrorLoggerTests testLogInvalidLicensor_withNilAccountID_doesNotCrash 47ms
โœ… TPPErrorLoggerTests testLogLocalAuthFailed_doesNotCrash 13ms
โœ… TPPErrorLoggerTests testLogLoginError_withProblemDocument_doesNotCrash 49ms
โœ… TPPErrorLoggerTests testLogNetworkError_doesNotCrash 28ms
โœ… TPPErrorLoggerTests testLogNetworkError_withIgnoreCode_usesApiCallCode 8ms
โœ… TPPErrorLoggerTests testLogNetworkError_withNilSummary_usesDefault 37ms
โœ… TPPErrorLoggerTests testLogProblemDocumentParseError_doesNotCrash 8ms
โœ… TPPErrorLoggerTests testLogProblemDocumentParseError_withNilData_doesNotCrash 47ms
โœ… TPPErrorLoggerTests testSeverity_errorStringValue 5ms
โœ… TPPErrorLoggerTests testSeverity_infoStringValue 4ms
โœ… TPPErrorLoggerTests testSeverity_warningStringValue 5ms
โœ… TPPIdleSignOutRegressionTests testCancelPendingSignOut_preventsCredentialCleanup 82ms
โœ… TPPIdleSignOutRegressionTests testNormalSignOut_stillClearsCredentials 87ms
โœ… TPPIdleSignOutRegressionTests testOAuthSignOut401_clearsTokenCredentials 113ms
โœ… TPPIdleSignOutRegressionTests testRaceCondition_signInDuringPendingDeauth_preservesNewCredentials 97ms
โœ… TPPIdleSignOutRegressionTests testRapidSignOutSignInCycles_doNotCorruptState 106ms
โœ… TPPIdleSignOutRegressionTests testSignOut401_clearsCredentials 107ms
โœ… TPPIdleSignOutRegressionTests testSignOut401_deauthorizesDeviceWithLicensor 103ms
โœ… TPPIdleSignOutRegressionTests testSignOut401_doesNotShowUnexpectedCredentialsError 82ms
โœ… TPPIdleSignOutRegressionTests testSignOut500_showsErrorToUser 147ms
โœ… TPPIdleSignOutRegressionTests testSignOutSignInCycle_licensorPreservedForBorrow 85ms
โœ… TPPIdleSignOutRegressionTests testSignOut_alwaysCallsDidFinishDeauthorizing 83ms
โœ… TPPIdleSignOutRegressionTests testSignOut_withNoDRMAuthorizer_completes 130ms
โœ… TPPIdleSignOutRegressionTests testStaleSignOut_stillCallsDidFinishDeauthorizing 84ms
โœ… TPPJWKConversionTest testJWKConversion 23ms
โœ… TPPKeychainManagerTests testLogKeychainError_doesNotCrash_withEmptyMessage 14ms
โœ… TPPKeychainManagerTests testLogKeychainError_doesNotCrash_withEmptyVendor 4ms
โœ… TPPKeychainManagerTests testLogKeychainError_doesNotCrash_withKnownStatuses 7ms
โœ… TPPKeychainManagerTests testLogKeychainError_doesNotCrash_withUnknownStatus 7ms
โœ… TPPKeychainManagerTests testSecClassItems_coversAllExpectedTypes 2ms
โœ… TPPLastReadPositionPosterTests testShouldStore_cssSelectorWithRenderedZeroProgression_stores 6ms
โœ… TPPLastReadPositionPosterTests testShouldStore_meaningfulProgression_stores 4ms
โœ… TPPLastReadPositionPosterTests testShouldStore_positionGreaterThanZero_stores 3ms
โœ… TPPLastReadPositionPosterTests testShouldStore_positionZero_doesNotStore 4ms
โœ… TPPLastReadPositionPosterTests testShouldStore_progressionExactlyZero_doesNotStore 3ms
โœ… TPPLastReadPositionPosterTests testShouldStore_progressionNil_doesNotStore 5ms
โœ… TPPLastReadPositionPosterTests testShouldStore_progressionPositiveButTinyAndRendered_stores 4ms
โœ… TPPLastReadPositionPosterTests testStoreReadPosition_multipleCalls_eachDelegatesToWriter 109ms
โœ… TPPLastReadPositionPosterTests testStoreReadPosition_validLocator_savesLocally_andDelegatesToWriter 57ms
โœ… TPPLastReadPositionPosterTests testStoreReadPosition_writerThrows_doesNotCrash_localStateUnaffected 59ms
โœ… TPPLastReadPositionPosterTests testStoreReadPosition_zeroProgressionNoCssSelector_doesNotStore 103ms
โœ… TPPLastReadPositionPosterTests testStoreReadPosition_zeroProgressionWithCssSelector_storesLocally_andDelegates 65ms
โœ… TPPLastReadPositionPosterTests testThrottlingInterval_isLockedAtFifteenSeconds 3ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests testRealSynchronizer_Init_Succeeds 2ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests testRealSynchronizer_MultipleBooks_IndependentLocations 3ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests testRealSynchronizer_WithEmptyRegistry_DoesNotCrash 6ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests testRealSynchronizer_WithManyBooks_PerformsEfficiently 31ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests testRealSynchronizer_WithRegistryContainingBook_AccessesLocation 2ms
โœ… TPPLastReadPositionSynchronizerTests testBookRegistry_GetLocation_ForNonexistentBook_ReturnsNil 5ms
โœ… TPPLastReadPositionSynchronizerTests testBookRegistry_SetLocationToNil_ClearsPosition 4ms
โœ… TPPLastReadPositionSynchronizerTests testBookRegistry_SetLocation_UpdatesPosition 3ms
โœ… TPPLastReadPositionSynchronizerTests testBookRegistry_StoresLocation 5ms
โœ… TPPLastReadPositionSynchronizerTests testBookRegistry_UpdateLocation_OverwritesPrevious 3ms
โœ… TPPLastReadPositionSynchronizerTests testReadiumBookmark_StoresAllProperties 4ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenBothDeviceIDsNilButLocalExists_ReturnsTrue 4ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenDifferentDeviceWithDifferentPosition_ReturnsTrue 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenDifferentDeviceWithNoLocalPosition_ReturnsTrue 8ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenNilLocalDeviceIDAndServerHasDevice_ReturnsTrue 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenPositionsMatchExactly_RegardlessOfDevice_ReturnsFalse 12ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenSameDeviceWithLocalPosition_ReturnsFalse 5ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenSameDeviceWithNoLocalPosition_ReturnsTrue 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerBookmarkHasEmptyDevice_AndLocalDeviceEmpty_ReturnsFalse 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerDeviceIsNilAndLocalDeviceIDEmpty_ReturnsFalse 4ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerHasNoPositionAndNilDeviceID_ReturnsFalse 20ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerHasNoPositionAndNoLocalPosition_ReturnsFalse 2ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerHasNoPosition_ReturnsFalse 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerPositionMatchesLocal_ReturnsFalse 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WhenServerReturnsNilOnError_ReturnsFalse 3ms
โœ… TPPLastReadPositionSynchronizerTests testSyncDecision_WithMatchingLocation_StillComparesAsStrings 8ms
โœ… TPPLastReadPositionSynchronizerTests testSynchronizer_Init_AcceptsDifferentRegistryImplementations 2ms
โœ… TPPLastReadPositionSynchronizerTests testSynchronizer_Init_StoresBookRegistry 2ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests testBehavior_DifferentDevice_UserShouldBePrompted 8ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests testBehavior_FreshDevice_ShouldSyncFromServer 7ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests testBehavior_IdenticalPositions_NoPromptNeeded 8ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests testBehavior_NoServerPosition_NoSync 3ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests testBehavior_SameDevice_LocalPositionIsAuthoritative 4ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_Creation_WithValidParameters 3ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_DictionaryRepresentation_ContainsRequiredKeys 4ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_DifferentLocationStrings_AreNotEqual 4ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_EmptyLocationString_IsValid 4ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_FromDictionary_CreatesValidLocation 6ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_FromDictionary_WithMissingKeys_ReturnsNil 2ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_LocationStringEquality_MatchesExactly 3ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_R3Renderer_HasCorrectValue 2ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests testTPPBookLocation_VeryLongLocationString_IsHandled 2ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests testConcurrentLocationUpdates_DoNotCrash 9ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests testConcurrentSyncDecisions_AreConsistent 9ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests testMultipleSynchronizersWithSameRegistry_DoNotConflict 5ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_DeviceProperty_WithNilDevice_ReturnsNil 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_DictionaryRepresentation_ContainsAllKeys 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_Equality_SameAnnotationId 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_FullProgress_FormatsAs100 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_Init_WithNilHref_ReturnsNil 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_Init_WithValidParameters 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_PercentInBook_FormatsCorrectly 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_PercentInChapter_FormatsCorrectly 3ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests testReadiumBookmark_ZeroProgress_FormatsAsZero 3ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_DeviceCheckTakesPrecedenceOverLocationMatch 3ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_DeviceIDCaseSensitivity 3ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_DeviceIDWithSpecialCharacters 4ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_LocationMatchPreventsSync_EvenFromDifferentDevice 9ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_LocationWithWhitespace_ExactMatchRequired 7ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_ProgressAtExactBoundaries 3ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_SameBookmarkLocation_ExactStringMatch 3ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_SameLocationString_HandledGracefully 5ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_VeryLongDeviceID 2ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests testSyncLogic_VerySmallProgressDifference 6ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests testSync_sameDevice_andLocalExists_skipsAlertPath 7ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests testSync_serverEqualsLocal_skipsAlertPath 3ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests testSync_writerReturnsNil_callsLoadOnce_noAlertPath 5ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests testSync_writerThrows_logsAndReturnsWithoutAlert 7ms
โœ… TPPLoginNoActivationTests testValidateCredentials_doesNotTriggerAdobeActivation 115ms
โœ… TPPLoginNoActivationTests testValidateCredentials_savesLicensorForLaterUse 276ms
โœ… TPPLoginNoActivationTests testValidateCredentials_withStaleCredentials_doesNotActivate 123ms
โœ… TPPMainThreadCheckerTests testAsyncIfNeeded_FromBackgroundThread_DispatchesAsyncToMain 29ms
โœ… TPPMainThreadCheckerTests testAsyncIfNeeded_FromMainThread_ExecutesSynchronously 8ms
โœ… TPPMainThreadCheckerTests testSync_FromBackgroundThread_DispatchesToMainThread 25ms
โœ… TPPMainThreadCheckerTests testSync_FromMainThread_ExecutesSynchronously 4ms
โœ… TPPMigrationManagerTests testVersion_emptyA_nonEmptyB_returnsTrue 2ms
โœ… TPPMigrationManagerTests testVersion_emptyA_zeroB_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_emptyA_zeroZeroB_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_emptyArrays_returnsFalse 11ms
โœ… TPPMigrationManagerTests testVersion_equalVersions_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_longerA_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_majorGreaterThan_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_majorLessThan_returnsTrue 2ms
โœ… TPPMigrationManagerTests testVersion_minorGreaterThan_returnsFalse 2ms
โœ… TPPMigrationManagerTests testVersion_minorLessThan_returnsTrue 4ms
โœ… TPPMigrationManagerTests testVersion_patchLessThan_returnsTrue 2ms
โœ… TPPMigrationManagerTests testVersion_shorterA_withNonZeroRemainder_returnsTrue 2ms
โœ… TPPMigrationManagerTests testVersion_shorterA_withZeroRemainder_returnsFalse 5ms
โœ… TPPMigrationManagerTests testVersion_singleComponent_equal 2ms
โœ… TPPMigrationManagerTests testVersion_singleComponent_lessThan 2ms
โœ… TPPNetworkExecutorAPITests testBearerAuthorized_preservesExistingHeaders 6ms
โœ… TPPNetworkExecutorAPITests testBearerAuthorized_setsAuthorizationHeader 6ms
โœ… TPPNetworkExecutorAPITests testCancelNonEssentialTasks_doesNotCrash 9ms
โœ… TPPNetworkExecutorAPITests testClearCache_doesNotCrash 17ms
โœ… TPPNetworkExecutorAPITests testInit_withCachingStrategy_doesNotCrash 4ms
โœ… TPPNetworkExecutorAPITests testInit_withCustomSessionConfiguration 2ms
โœ… TPPNetworkExecutorAPITests testInit_withDefaultCachingStrategy 3ms
โœ… TPPNetworkExecutorAPITests testInit_withFallbackCachingStrategy 4ms
โœ… TPPNetworkExecutorAPITests testPauseAllTasks_doesNotCrash 7ms
โœ… TPPNetworkExecutorAPITests testRequest_forURL_createsValidRequest 19ms
โœ… TPPNetworkExecutorAPITests testRequest_forURL_setsAcceptLanguageEmpty 50ms
โœ… TPPNetworkExecutorAPITests testRequest_forURL_setsUserAgent 16ms
โœ… TPPNetworkExecutorAPITests testResumeAllTasks_doesNotCrash 6ms
โœ… TPPNetworkExecutorAPITests testShared_isNotNil 2ms
โœ… TPPNetworkExecutorStubbedTests testAddBearerAndExecute_setsAuthHeader 23ms
โœ… TPPNetworkExecutorStubbedTests testDELETE_async_success 32ms
โœ… TPPNetworkExecutorStubbedTests testDELETE_nilCompletion_doesNotCrash 13ms
โœ… TPPNetworkExecutorStubbedTests testDELETE_setsMethodToDELETE 10ms
โœ… TPPNetworkExecutorStubbedTests testDownload_createsDownloadTask 18ms
โœ… TPPNetworkExecutorStubbedTests testGET_async_success 17ms
โœ… TPPNetworkExecutorStubbedTests testGET_async_withRequest 15ms
โœ… TPPNetworkExecutorStubbedTests testGET_correctsHTTPMethodIfNotGET 10ms
โœ… TPPNetworkExecutorStubbedTests testGET_objcAPI_success 20ms
โœ… TPPNetworkExecutorStubbedTests testGET_serverError_returnsFailure 83ms
โœ… TPPNetworkExecutorStubbedTests testGET_success_returnsData 19ms
โœ… TPPNetworkExecutorStubbedTests testPOST_async_success 14ms
โœ… TPPNetworkExecutorStubbedTests testPOST_nilCompletion_doesNotCrash 11ms
โœ… TPPNetworkExecutorStubbedTests testPOST_setsMethodToPOST 9ms
โœ… TPPNetworkExecutorStubbedTests testPUT_async_success 25ms
โœ… TPPNetworkExecutorStubbedTests testPUT_correctsHTTPMethodIfNotPUT 11ms
โœ… TPPNetworkExecutorStubbedTests testPUT_setsMethodToPUT 34ms
โœ… TPPNetworkExecutorTests testExecutor_conformsToProtocol 3ms
โœ… TPPNetworkExecutorTests testExecutor_hasCorrectTimeout 4ms
โœ… TPPNetworkExecutorTests testExecutor_usesEphemeralCaching 7ms
โœ… TPPNetworkResponderAuthCoordinatorTests testClassifier_seam_401_crossDomain_returnsOk_preservingResponderCDNGuard 3ms
โœ… TPPNetworkResponderAuthCoordinatorTests testClassifier_seam_401_foreignHost_returnsOk_preservingResponderForeignHostGuard 3ms
โœ… TPPNetworkResponderAuthCoordinatorTests testResponder_200_doesNotConsumeRetryBudget_andCompletionSucceeds 8ms
โœ… TPPNetworkResponderAuthCoordinatorTests testResponder_401_completion_fires_underBudget_andPreservesRetryTrackingShape 8ms
โœ… TPPNetworkResponderAuthCoordinatorTests testResponder_401_whenURLAlreadyRetried_completionFiresWithFailure 7ms
โœ… TPPNetworkResponderTests testAddCompletionStoresTaskInfo 2ms
โœ… TPPNetworkResponderTests testCanRetryReturnsFalseAfterMarkRetried 5ms
โœ… TPPNetworkResponderTests testCanRetryReturnsFalseForNilURL 3ms
โœ… TPPNetworkResponderTests testCanRetryReturnsTrueForFreshURL 9ms
โœ… TPPNetworkResponderTests testClearAllRetriesResetsEverything 6ms
โœ… TPPNetworkResponderTests testClearRetryResetsURL 159ms
โœ… TPPNetworkResponderTests testInitWithCredentialsProvider 14ms
โœ… TPPNetworkResponderTests testInitWithFallbackCachingDisabledByDefault 3ms
โœ… TPPNetworkResponderTests testMarkRetriedWithNilURL_isNoOp_andLeavesRealURLTrackingIntact 4ms
โœ… TPPNetworkResponderTests testMultipleURLsTrackedIndependently 3ms
โœ… TPPNetworkResponderTests testSessionInvalidationCallsPendingCompletionsWithCancelError 5ms
โœ… TPPNetworkResponderTests testUpdateCompletionIdTransfersInfo 4ms
โœ… TPPOPDSAcquisitionPathTests testSampleLinkInAcquisitions 26ms
โœ… TPPOPDSAcquisitionPathTests testSimplifiedAdeptEpubAcquisition 6ms
โœ… TPPOPDSAcquisitionPathTests testSupportedAcquisitionPaths_borrowToStreamingHTMLIndirect_producesStreamingPath 5ms
โœ… TPPOPDSAcquisitionPathTests testTPPOPDSAcquisitionPath_supportedSubtypes_forOPDSPublication_containsStreamingHTML 5ms
โœ… TPPOPDSAcquisitionPathTests testTPPOPDSAcquisitionPath_supportedTypes_containsStreamingHTML 5ms
โœ… TPPOPDSEntryTests testAuthorStrings 3ms
โœ… TPPOPDSEntryTests testEntryFromSingleEntryFixture_parsesAllScalarFields 11ms
โœ… TPPOPDSEntryTests testGroupAttributes 8ms
โœ… TPPOPDSEntryTests testInit_returnsNilWhenRequiredIdElementIsMissing 10ms
โœ… TPPOPDSEntryTests testUpdated 4ms
โœ… TPPOPDSFeedTests testFeedFromMainFixture_parsesAllTopLevelFields 126ms
โœ… TPPOPDSFeedTests testInit_nilXMLYieldsNil_validXMLYieldsParsedFeed 162ms
โœ… TPPOPDSFeedTests testUpdated 142ms
โœ… TPPOPDSGroupSwiftTests testInitStoresEntries 5ms
โœ… TPPOPDSGroupSwiftTests testInitStoresProperties 5ms
โœ… TPPOPDSGroupSwiftTests testInitWithDifferentHref_storesDifferentHref 3ms
โœ… TPPOPDSLinkTests testCount 4ms
โœ… TPPOPDSLinkTests testHandlesNilInit 8ms
โœ… TPPOPDSLinkTests testLink0 6ms
โœ… TPPOPDSLinkTests testLink1 4ms
โœ… TPPOPDSLinkTests testLink2 11ms
โœ… TPPOPDSLinkTests testLink3 6ms
โœ… TPPOPDSLinkTests testLink4 7ms
โœ… TPPOpenSearchDescriptionExpandedTests test_initWithTitle_emptyBooks_setsEmptyBooks 2ms
โœ… TPPOpenSearchDescriptionExpandedTests test_initWithTitle_setsDescriptionAndBooks 2ms
โœ… TPPOpenSearchDescriptionExpandedTests test_initWithXML_missingDescription_returnsNil 5ms
โœ… TPPOpenSearchDescriptionExpandedTests test_initWithXML_missingOPDSUrl_returnsNil 7ms
โœ… TPPOpenSearchDescriptionExpandedTests test_initWithXML_validOpenSearchXML_returnsNonNil 2ms
โœ… TPPOpenSearchDescriptionExpandedTests test_opdsURLForSearching_emptyString_returnsURL 2ms
โœ… TPPOpenSearchDescriptionExpandedTests test_opdsURLForSearching_encodesAmpersand 5ms
โœ… TPPOpenSearchDescriptionExpandedTests test_opdsURLForSearching_encodesSpecialCharacters 9ms
โœ… TPPOpenSearchDescriptionExpandedTests test_opdsURLForSearching_encodesUnicode 2ms
โœ… TPPOpenSearchDescriptionExpandedTests test_opdsURLForSearching_preservesEntrypoint 2ms
โœ… TPPOpenSearchDescriptionTests testOPDSURLSearch 5ms
โœ… TPPPDFDocumentMetadataTests testAddBookmark_AtCurrentPage_WhenNilPassed_UsesCurrentPage 11ms
โœ… TPPPDFDocumentMetadataTests testAddBookmark_AtPageZero_HandlesCorrectly 13ms
โœ… TPPPDFDocumentMetadataTests testAddBookmark_AtSpecificPage_AddsToBookmarks 5ms
โœ… TPPPDFDocumentMetadataTests testAddBookmark_DuplicatePage_DoesNotDuplicate 4ms
โœ… TPPPDFDocumentMetadataTests testAddBookmark_MultipleTimes_AddsAllBookmarks 5ms
โœ… TPPPDFDocumentMetadataTests testBookmarks_IsPublished_EmitsChanges 4ms
โœ… TPPPDFDocumentMetadataTests testCurrentPage_IsPublished_EmitsChanges 64ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WhenPageInBookmarks_ReturnsTrue 7ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WhenPageNotInBookmarks_ReturnsFalse 7ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WithEmptyBookmarks_ReturnsFalse 4ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WithLargePageNumber_HandlesCorrectly 4ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WithNilPage_ChecksCurrentPage 24ms
โœ… TPPPDFDocumentMetadataTests testIsBookmarked_WithZeroPage_HandlesCorrectly 8ms
โœ… TPPPDFDocumentMetadataTests testRemoveBookmark_NonexistentPage_DoesNotCrash 10ms
โœ… TPPPDFDocumentMetadataTests testRemoveBookmark_RemovesFromBookmarks 8ms
โœ… TPPPDFDocumentTests testPDFDocument_delegateCanBeSet 2ms
โœ… TPPPDFDocumentTests testPDFDocument_initFromData_exposesData 2ms
โœ… TPPPDFDocumentTests testPDFDocument_labelReturnsNilForInvalidPage 6ms
โœ… TPPPDFDocumentTests testPDFDocument_pageCountForInvalidData 2ms
โœ… TPPPDFDocumentTests testPDFDocument_previewReturnsNilForInvalidPage 2ms
โœ… TPPPDFDocumentTests testPDFDocument_sizeReturnsNilForInvalidPage 2ms
โœ… TPPPDFDocumentTests testPDFDocument_tableOfContentsEmptyForInvalidData 2ms
โœ… TPPPDFDocumentTests testPDFDocument_thumbnailReturnsNilForInvalidPage 2ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_defaultLevelIsZero 3ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_differentLocations_differentIds 3ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_id_encodesAllFields 3ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_id_handlesNils 21ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_identifiableId_isDeterministic 7ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_initWithAllParameters 2ms
โœ… TPPPDFLocationCoverageTests testPDFLocation_nilProperties 2ms
โœ… TPPPDFLocationTests testId_ContainsPageNumber 2ms
โœ… TPPPDFLocationTests testId_HandlesNilValues_WithEmptyStrings 2ms
โœ… TPPPDFLocationTests testId_SameForIdenticalLocations 30ms
โœ… TPPPDFLocationTests testId_UniqueForDifferentLevels 2ms
โœ… TPPPDFLocationTests testId_UniqueForDifferentPageLabels 2ms
โœ… TPPPDFLocationTests testId_UniqueForDifferentPages 2ms
โœ… TPPPDFLocationTests testId_UniqueForDifferentSubtitles 2ms
โœ… TPPPDFLocationTests testId_UniqueForDifferentTitles 13ms
โœ… TPPPDFLocationTests testInit_AllParameters_SetsProperties 5ms
โœ… TPPPDFLocationTests testInit_NilOptionals_DefaultsLevelToZero 28ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_annotationIdCanBeSet 2ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_annotationIdDefaultsToNil 3ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_codableRoundTrip 20ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_conformsToBookmark 3ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_decodesFromJSON 4ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_encodesAtTypeKey 2ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_initSetsPage 2ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_isNSObject 6ms
โœ… TPPPDFPageBookmarkTests testPageBookmark_typeIsLocatorPage 13ms
โœ… TPPPDFPageTests testPDFPage_codableRoundTrip 3ms
โœ… TPPPDFPageTests testPDFPage_decodesFromJSON 6ms
โœ… TPPPDFPageTests testPDFPage_encodesToExpectedJSON 8ms
โœ… TPPPDFPageTests testPDFPage_initStoresPageNumber 2ms
โœ… TPPPDFPageTests testPDFPage_zeroPageNumber 6ms
โœ… TPPPDFReaderModeTests testReaderMode_allCasesHaveUniqueValues 4ms
โœ… TPPPDFReaderModeTests testReaderMode_bookmarksValue 3ms
โœ… TPPPDFReaderModeTests testReaderMode_previewsValue 2ms
โœ… TPPPDFReaderModeTests testReaderMode_readerValue 3ms
โœ… TPPPDFReaderModeTests testReaderMode_searchValue 39ms
โœ… TPPPDFReaderModeTests testReaderMode_tocValue 8ms
โŠ˜ TPPPerAccountIsolationTests testConcurrentAccess_noContamination 27ms
โŠ˜ TPPPerAccountIsolationTests testConcurrentSnapshots_returnCorrectData 29ms
โŠ˜ TPPPerAccountIsolationTests testCredentialIsolation_bothAccountsHoldIndependentCredentials 28ms
โŠ˜ TPPPerAccountIsolationTests testCredentialIsolation_tokenCredentials 29ms
โŠ˜ TPPPerAccountIsolationTests testCredentialIsolation_writeToA_doesNotAffectB 28ms
โŠ˜ TPPPerAccountIsolationTests testCredentialSnapshot_perAccountIsolation 27ms
โŠ˜ TPPPerAccountIsolationTests testInstanceCache_isStableSameUUID_distinctDifferentUUIDs_andPreservesBinding 28ms
โŠ˜ TPPPerAccountIsolationTests testRemoveAll_doesNotAffectOtherAccount 59ms
โœ… TPPPreferredAuthSelectionTests testAfterAutoSelection_SelectedAuthIsSaml_forMultiAuthLibrary 102ms
โœ… TPPPreferredAuthSelectionTests testPrecondition_NYPLFixtureHasMultipleAuthMethods 130ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_AutoSelectsSoleSAMLIDP 145ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_DoesNotOverrideExplicitChoice 132ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_DoesNotOverrideExplicitIDPChoice 160ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_IsIdempotent 175ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_NoOp_ForSingleAuthLibrary 136ms
โœ… TPPPreferredAuthSelectionTests testSelectPreferredAuth_PicksSAML_WhenMultipleAuthsAndNoneSelected 137ms
โœ… TPPProblemDocumentCacheManagerTests testCacheMultipleDocuments_lastEntryRetrievable 5ms
โœ… TPPProblemDocumentCacheManagerTests testCacheProblemDocument_andRetrieve 9ms
โœ… TPPProblemDocumentCacheManagerTests testCacheProblemDocument_postsNotification 6ms
โœ… TPPProblemDocumentCacheManagerTests testCacheSize_isFive 4ms
โœ… TPPProblemDocumentCacheManagerTests testCache_exceedingSize_evictsOldestEntry 3ms
โœ… TPPProblemDocumentCacheManagerTests testClearCachedDoc_nonexistentKey_doesNotCrash 23ms
โœ… TPPProblemDocumentCacheManagerTests testClearCachedDoc_preventsRetrieval 7ms
โœ… TPPProblemDocumentCacheManagerTests testClearThenReCache_works 4ms
โœ… TPPProblemDocumentCacheManagerTests testConcurrentCacheAndClear_sameKey_doesNotCrash 8ms
โœ… TPPProblemDocumentCacheManagerTests testConcurrentReadWrite_doesNotCrash 13ms
โœ… TPPProblemDocumentCacheManagerTests testGetLastCachedDoc_unknownKey_returnsNil 4ms
โœ… TPPProblemDocumentCacheManagerTests testSharedInstance_returnsSameObject 4ms
โœ… TPPProblemDocumentTests testAccountStatusTypeConstants 4ms
โœ… TPPProblemDocumentTests testCodableRoundTrip 12ms
โœ… TPPProblemDocumentTests testDictionaryValue_roundTrip 2ms
โœ… TPPProblemDocumentTests testForExpiredOrMissing_hasCredentials 4ms
โœ… TPPProblemDocumentTests testForExpiredOrMissing_noCredentials 19ms
โœ… TPPProblemDocumentTests testFromData_invalidJSON 5ms
โœ… TPPProblemDocumentTests testFromData_validJSON 3ms
โœ… TPPProblemDocumentTests testFromDictionary_createsDocument 5ms
โœ… TPPProblemDocumentTests testFromProblemResponseData_invalidData 4ms
โœ… TPPProblemDocumentTests testFromProblemResponseData_nonProblemJSON 2ms
โœ… TPPProblemDocumentTests testFromProblemResponseData_validData 2ms
โœ… TPPProblemDocumentTests testFromResponseError_nilErrorNilData 4ms
โœ… TPPProblemDocumentTests testFromResponseError_withResponseData 5ms
โœ… TPPProblemDocumentTests testIsRecoverableAuthError 5ms
โœ… TPPProblemDocumentTests testIsUnrecoverableAuthError 4ms
โœ… TPPProblemDocumentTests testNilType_authChecks 2ms
โœ… TPPProblemDocumentTests testNonAuthError 4ms
โœ… TPPProblemDocumentTests testStaticTypeConstants 3ms
โœ… TPPProblemDocumentTests testStringValue_format 6ms
โœ… TPPProblemDocumentTests testStringValue_noDetail 3ms
โœ… TPPProblemDocumentTests testStringValue_noTitle 4ms
โœ… TPPReaderAppearanceTests testAssociatedColors_blackOnWhite_hasLightBackground 4ms
โœ… TPPReaderAppearanceTests testBlackOnSepia_hasCorrectPropertyIndex 2ms
โœ… TPPReaderAppearanceTests testBlackOnWhite_hasCorrectPropertyIndex 3ms
โœ… TPPReaderAppearanceTests testWhiteOnBlack_hasCorrectPropertyIndex 5ms
โœ… TPPReaderBookmarksBusinessLogicTests testBookmarkAtIndex_WithEmptyBookmarks_ReturnsNil 92ms
โœ… TPPReaderBookmarksBusinessLogicTests testBookmarkAtIndex_WithValidIndex_ReturnsBookmark 120ms
โœ… TPPReaderBookmarksBusinessLogicTests testBookmarkAtIndex_returnsNilForOutOfRangeIndicesEmptyOrPopulated 117ms
โœ… TPPReaderBookmarksBusinessLogicTests testDeleteBookmarkAtIndex_WithInvalidIndex_ReturnsNil 127ms
โœ… TPPReaderBookmarksBusinessLogicTests testDeleteBookmarkAtIndex_WithValidIndex_RemovesAndReturns 93ms
โœ… TPPReaderBookmarksBusinessLogicTests testDeleteBookmark_RemovesFromList 126ms
โœ… TPPReaderBookmarksBusinessLogicTests testPP3555_OldBookmarksDoNotReappearAfterReborrow 135ms
โœ… TPPReaderBookmarksBusinessLogicTests testReadOnlySurfaces_noBookmarksText_shouldSelect_isBookmarkExisting 140ms
โœ… TPPReaderBookmarksBusinessLogicTests testUpdateLocalBookmarksWithDuplicatedLocalBookmarks 122ms
โœ… TPPReaderBookmarksBusinessLogicTests testUpdateLocalBookmarksWithExtraLocalBookmarks 119ms
โœ… TPPReaderBookmarksBusinessLogicTests testUpdateLocalBookmarksWithFailedUploadBookmarks 130ms
โœ… TPPReaderBookmarksBusinessLogicTests testUpdateLocalBookmarksWithNoLocalBookmarks 116ms
โœ… TPPReaderBookmarksReadinessTests testReadiness_underDetailsFailed_gateThrowsForBookmarkTask 113ms
โœ… TPPReaderBookmarksReadinessTests testReadiness_underDetailsLoading_gateConsumedByPostBookmark 92ms
โœ… TPPReaderFontTests testDyslexic_hasPropertyIndex 6ms
โœ… TPPReaderFontTests testOriginal_hasCorrectPropertyIndex 7ms
โœ… TPPReaderFontTests testSansSerif_hasPropertyIndex 4ms
โœ… TPPReaderFontTests testSerif_hasPropertyIndex 6ms
โœ… TPPReaderPreferencesLoadTests testTPPReaderPreferencesLoad_disablesPublisherStyles 4ms
โœ… TPPReaderPreferencesLoadTests testTPPReaderPreferencesLoad_returnsValidPreferences 4ms
โœ… TPPReaderPreferencesLoadTests testTPPReaderPreferencesLoad_setsDefaultTheme 17ms
โœ… TPPReaderSettingsTests testCanDecreaseFontSize_falseAtMinimum 4ms
โœ… TPPReaderSettingsTests testCanIncreaseFontSize_trueWhenBelowMax 7ms
โœ… TPPReaderSettingsTests testChangeAppearance_updatesColors 25ms
โœ… TPPReaderSettingsTests testChangeAppearance_updatesIndex 5ms
โœ… TPPReaderSettingsTests testChangeFontFamily_updatesIndex 11ms
โœ… TPPReaderSettingsTests testDecreaseFontSize_decreasesByStep 7ms
โœ… TPPReaderSettingsTests testDecreaseFontSize_respectsMinimum 4ms
โœ… TPPReaderSettingsTests testIncreaseFontSize_increasesByStep 55ms
โœ… TPPReaderSettingsTests testIncreaseFontSize_respectsMaximum 12ms
โœ… TPPReaderSettingsTests testInit_getsScreenBrightness 4ms
โœ… TPPReaderSettingsTests testInit_setsDefaultAppearanceIndex 6ms
โœ… TPPReaderSettingsTests testInit_setsDefaultFontFamilyIndex 6ms
โœ… TPPReaderSettingsTests testInit_setsDefaultFontSize 4ms
โœ… TPPReaderSettingsTests testLoadPreferences_returnsPreferences 17ms
โœ… TPPReaderSettingsTests testMapAppearanceToIndex_dark 3ms
โœ… TPPReaderSettingsTests testMapAppearanceToIndex_light 53ms
โœ… TPPReaderSettingsTests testMapAppearanceToIndex_sepia 6ms
โœ… TPPReaderSettingsTests testMapFontFamilyToIndex_nil 5ms
โœ… TPPReaderSettingsTests testMapFontFamilyToIndex_openDyslexic 4ms
โœ… TPPReaderSettingsTests testMapFontFamilyToIndex_sansSerif 4ms
โœ… TPPReaderSettingsTests testMapFontFamilyToIndex_serif 6ms
โœ… TPPReaderSettingsTests testMapIndexToAppearance_dark 2ms
โœ… TPPReaderSettingsTests testMapIndexToAppearance_default 3ms
โœ… TPPReaderSettingsTests testMapIndexToAppearance_sepia 2ms
โœ… TPPReaderSettingsTests testMapIndexToFontFamily_default 6ms
โœ… TPPReaderSettingsTests testMapIndexToFontFamily_dyslexic 10ms
โœ… TPPReaderSettingsTests testMapIndexToFontFamily_sansSerif 7ms
โœ… TPPReaderSettingsTests testMapIndexToFontFamily_serif 10ms
โœ… TPPReaderTOCBusinessLogicTests testInit_withCurrentLocation_storesLocation 3ms
โœ… TPPReaderTOCBusinessLogicTests testInit_withPublication_initializesCorrectly 22ms
โœ… TPPReaderTOCBusinessLogicTests testIsCurrentChapterTitled_caseInsensitiveMatch_returnsTrue 3ms
โœ… TPPReaderTOCBusinessLogicTests testIsCurrentChapterTitled_withDifferentTitle_returnsFalse 2ms
โœ… TPPReaderTOCBusinessLogicTests testIsCurrentChapterTitled_withMatchingTitle_returnsTrue 2ms
โœ… TPPReaderTOCBusinessLogicTests testIsCurrentChapterTitled_withNilCurrentLocation_returnsFalse 3ms
โœ… TPPReaderTOCBusinessLogicTests testIsCurrentChapterTitled_withNilLocationTitle_returnsFalse 7ms
โœ… TPPReaderTOCBusinessLogicTests testShouldSelectTOCItem_invalidIndex_returnsFalse 5ms
โœ… TPPReaderTOCBusinessLogicTests testTitleAndLevel_forValidIndex_returnsTitleAndLevel 1.05s
โœ… TPPReaderTOCBusinessLogicTests testTitleForHref_existingHref_returnsTitle 1.03s
โœ… TPPReaderTOCBusinessLogicTests testTitleForHref_nonExistentHref_returnsNil 1.07s
โœ… TPPReaderTOCBusinessLogicTests testTocDisplayTitle_returnsLocalizedString 24ms
โœ… TPPReaderTOCBusinessLogicTests testTocElements_initiallyEmpty_beforeAsyncLoad 7ms
โœ… TPPReaderTOCBusinessLogicTests testTocLocator_negativeIndex_returnsNil 5ms
โœ… TPPReaderTOCBusinessLogicTests testTocLocator_outOfBoundsIndex_returnsNil 3ms
โœ… TPPReaderTOCFlattenTests testFlatten_emptyTOC_producesEmptyElements 7ms
โœ… TPPReaderTOCFlattenTests testFlatten_nestedTOC_assignsCorrectLevels 1.02s
โœ… TPPReadiumBookmarkLocationMatchingTests testLocationMatches_differentChapterProgress_returnsFalse 7ms
โœ… TPPReadiumBookmarkLocationMatchingTests testLocationMatches_differentTotalProgress_returnsFalse 7ms
โœ… TPPReadiumBookmarkLocationMatchingTests testLocationMatches_exactProgress_returnsTrue 8ms
โœ… TPPReadiumBookmarkLocationMatchingTests testLocationMatches_matchingProgress_returnsTrue 3ms
โœ… TPPReadiumBookmarkLocationMatchingTests testLocationMatches_nilLocatorProgress_matchesZeroBookmarkProgress 14ms
โœ… TPPReadiumBookmarkTests testDescription_returnsNonEmptyString 4ms
โœ… TPPReadiumBookmarkTests testDictionaryRepresentation_containsAllFields 5ms
โœ… TPPReadiumBookmarkTests testInit_dictionary_withBothOffsetAndChapterProgress_prefersExplicitChapterProgress 36ms
โœ… TPPReadiumBookmarkTests testInit_dictionary_withOnlyChapterProgress_preservesValue 12ms
โœ… TPPReadiumBookmarkTests testInit_dictionary_withOnlyReadingOrderItemOffset_preservesValue 2ms
โœ… TPPReadiumBookmarkTests testInit_fromDictionary_createsBookmark 2ms
โœ… TPPReadiumBookmarkTests testInit_fromDictionary_withEmptyAnnotationId_setsNil 2ms
โœ… TPPReadiumBookmarkTests testInit_fromDictionary_withMissingRequiredFields_returnsNil 82ms
โœ… TPPReadiumBookmarkTests testInit_withDefaultTime_usesCurrentTime 2ms
โœ… TPPReadiumBookmarkTests testInit_withNilHref_returnsNil 1.99s
โœ… TPPReadiumBookmarkTests testInit_withValidParameters_createsBookmark 19ms
โœ… TPPReadiumBookmarkTests testIsEqual_differentHref_returnsFalse 3ms
โœ… TPPReadiumBookmarkTests testIsEqual_differentProgress_returnsFalse 13ms
โœ… TPPReadiumBookmarkTests testIsEqual_sameAnnotationId_returnsTrue 14ms
โœ… TPPReadiumBookmarkTests testIsEqual_sameProgress_noAnnotationId_returnsTrue 3ms
โœ… TPPReadiumBookmarkTests testIsEqual_withNonBookmarkObject_returnsFalse 3ms
โœ… TPPReadiumBookmarkTests testPercentInBook_formatsCorrectly 6ms
โœ… TPPReadiumBookmarkTests testPercentInBook_fullProgress_showsHundred 3ms
โœ… TPPReadiumBookmarkTests testPercentInChapter_formatsCorrectly 147ms
โœ… TPPReadiumBookmarkTests testPercentInChapter_zeroProgress_showsZero 2ms
โœ… TPPReadiumBookmarkTests testToJSONDictionary_includesLocationFields 6ms
โœ… TPPReauthenticatorMockTests testMockReauthenticator_callsCompletion 4ms
โœ… TPPReauthenticatorMockTests testMockReauthenticator_tracksReauthPerformed 22ms
โœ… TPPReauthenticatorTests testAuthenticateIfNeeded_withNilCompletion_doesNotCrash 13ms
โœ… TPPReauthenticatorTests testInit_conformsToReauthenticatorProtocol 9ms
โœ… TPPReauthenticatorTests testInit_createsDistinctInstances 2ms
โœ… TPPReauthenticatorTests testInit_isNSObjectSubclass 2ms
โœ… TPPReturnPromptHelperTests testAudiobookPrompt_createsAlertController 5ms
โœ… TPPReturnPromptHelperTests testAudiobookPrompt_hasExactlyKeepAndReturnActionsWithTitles 4ms
โœ… TPPReturnPromptHelperTests testAudiobookPrompt_hasKeepAction_withCancelStyle 6ms
โœ… TPPReturnPromptHelperTests testAudiobookPrompt_hasReturnAction_withDefaultStyle 9ms
โœ… TPPReturnPromptHelperTests testAudiobookPrompt_hasTitleAndMessage 4ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_allCookiesExpired_filtersAllAndProceedsWithEmptyArray 3ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_allCookiesExpired_proceedsWithEmpty 4ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_cookieExpiringInFuture_isKept 3ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_filtersExpiredCookies 3ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_keepsSessionCookiesWithoutExpiry 2ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_mixOfExpiredAndValid_onlyPassesValid 2ms
โœ… TPPSAMLCookieExpirationTests testSAMLLogin_mixedExpiredAndValidCookies_filtersOnlyExpired_passesValid 14ms
โœ… TPPSAMLFlowTests testSAMLHelper_initRequiresContext_andStartsWithCleanCookieState 7ms
โœ… TPPSAMLFlowTests testSAMLLogin_callsPresenterNotUIKit 4ms
โœ… TPPSAMLFlowTests testSAMLLogin_cancelCallsCancelHandler 3ms
โœ… TPPSAMLFlowTests testSAMLLogin_completionCallsHandleRedirect 4ms
โœ… TPPSAMLFlowTests testSAMLLogin_dismissCalledAfterCompletion 4ms
โœ… TPPSAMLFlowTests testSAMLLogin_dismissCalledWithError 3ms
โœ… TPPSAMLFlowTests testSAMLLogin_passesCorrectURLPreservesExistingQueryParams 4ms
โœ… TPPSAMLFlowTests testSAMLLogin_passesCorrectURLWithRedirectURI 7ms
โœ… TPPSAMLFlowTests testSAMLLogin_passesSavedCookiesToPresenter 14ms
โœ… TPPSAMLFlowTests testSAMLLogin_withNilIDP_doesNotCallPresenter 3ms
โœ… TPPSAMLReauthFlowTests testFreshLogin_callsAdobeActivation 120ms
โœ… TPPSAMLReauthFlowTests testSAMLReauthFlow_skipsAdobeActivation 129ms
โœ… TPPSAMLRegressionTests testOAuthFlow_unaffectedBySAMLRefactor 188ms
โœ… TPPSAMLRegressionTests testSAMLAuthType_matchesCMValue 178ms
โœ… TPPSAMLRegressionTests testSAMLIdPParsing_fromAuthDocumentLinks 147ms
โœ… TPPSAMLRegressionTests testSAMLRedirectURL_matchesCMExpectedPattern 4ms
โœ… TPPSAMLSignInTests testAuthState_transitionsFromLoggedOutToLoggedIn 145ms
โœ… TPPSAMLSignInTests testCredentialsStale_PP418_userStillHasCredentials 168ms
โœ… TPPSAMLSignInTests testCredentialsStale_hasCredentialsReturnsTrue 128ms
โœ… TPPSAMLSignInTests testCredentialsStale_preservesCookies 169ms
โœ… TPPSAMLSignInTests testCredentialsStale_reAuthClearsStaleState 157ms
โœ… TPPSAMLSignInTests testRefreshCredentialsFromKeychain_returnsFalseWhenNoCredentials 139ms
โœ… TPPSAMLSignInTests testRefreshCredentialsFromKeychain_returnsTrueWhenCredentialsExist 128ms
โœ… TPPSAMLSignInTests testSAMLReauth_usesSavedCookiesForIDPSession 129ms
โœ… TPPSAMLSignInTests testSAMLSignIn_PP418_credentialsArePersisted 146ms
โœ… TPPSAMLSignInTests testSAMLSignIn_cookiesAreStored 122ms
โœ… TPPSAMLSignInTests testSAMLSignIn_drmFailurePreventsCredentialStorage 194ms
โœ… TPPSAMLSignInTests testSAMLSignIn_hasCredentialsReturnsTrue 136ms
โœ… TPPSAMLSignInTests testSAMLSignIn_patronInfoIsStored 173ms
โœ… TPPSAMLSignInTests testSAMLSignIn_setsAuthStateToLoggedIn 218ms
โœ… TPPSAMLSignInTests testSAMLSignIn_stateTransitions 140ms
โœ… TPPSAMLSignInTests testSAMLSignIn_usesCorrectLibraryUUID 161ms
โœ… TPPSAMLSignInTests testSAMLSignIn_worksWithoutCookies 111ms
โœ… TPPSAMLSignInTests testSAMLSignIn_worksWithoutPatronInfo 175ms
โœ… TPPSAMLSignInTests testSAMLSignOut_clearsAllCredentials 114ms
โœ… TPPSAMLSignInTests testSetAuthToken_clearsStaleState 112ms
โœ… TPPSAMLSignInTests testSignIn_callsBusinessLogicDidCompleteSignIn 146ms
โœ… TPPSAMLSignInTests testSignIn_callsBusinessLogicWillSignIn 131ms
โœ… TPPSAMLSignInTests testSignIn_cancelledSetsLoadingFalse 185ms
โœ… TPPSAMLSignInTests testSignIn_loadingStateTransitions 111ms
โœ… TPPSAMLSignInTests testTokenRefresh_settingsScreenShowsSignedIn 139ms
โœ… TPPSAMLSignInTests testTokenRefresh_transitionsFromStaleToLoggedIn 121ms
โœ… TPPSAMLStateIsolationTests testNonSAMLLibrary_noSAMLHelperCreated 90ms
โœ… TPPSAMLStateIsolationTests testSAMLCookies_storedOnHelper_notBusinessLogic 4ms
โœ… TPPSAMLStateIsolationTests testSAMLLibrary_helperCreatedOnDemand 114ms
โœ… TPPSAMLStateIsolationTests testSignOut_clearsSAMLState 3ms
โœ… TPPSAMLStateMachineTests testFinalizeSignIn_transitionsToLoggedIn 75ms
โœ… TPPSAMLStateMachineTests testIsSignedIn_returnsFalseWhenCredentialsStale 73ms
โœ… TPPSAMLStateMachineTests testIsSignedIn_returnsFalseWhenLoggedOut 115ms
โœ… TPPSAMLStateMachineTests testIsSignedIn_returnsTrueWhenLoggedIn 113ms
โœ… TPPSAMLStateMachineTests testRefreshAuth_SAMLClearsSelectedAuth 101ms
โœ… TPPSAMLStateMachineTests testRefreshAuth_transitionsToCredentialsStale 92ms
โœ… TPPSettingsTests testAccountMainFeedURL_setToSameValue_doesNotPostNotification 31ms
โœ… TPPSettingsTests testCustomMainFeedURL_publishesViaSettingsDidChange 49ms
โœ… TPPSettingsTests testCustomMainFeedURL_setToDifferentValue_postsNotification 12ms
โœ… TPPSettingsTests testCustomMainFeedURL_setToSameValue_doesNotPostNotification 32ms
โœ… TPPSettingsTests testUseBetaLibraries_postsNotification 83ms
โœ… TPPSettingsTests testUseBetaLibraries_publishesViaCombine 3.13s
โœ… TPPSignInAdobeSkipTests testEnsureAuthDocLoaded_callsCompletionImmediatelyWhenDetailsExist 112ms
โœ… TPPSignInAdobeSkipTests testEnsureAuthDocLoaded_setsLoadingFlag 89ms
โœ… TPPSignInAdobeSkipTests testIgnoreSignedInState_affectsIsSignedIn 121ms
โœ… TPPSignInAdobeSkipTests testLogIn_capturedBarcode_nilWhenUIDelegateHasNilUsername 86ms
โœ… TPPSignInAdobeSkipTests testLogIn_capturesBarcodeAndPIN 152ms
โœ… TPPSignInAdobeSkipTests testLogIn_notifiesUIDelegateWillSignIn 169ms
โœ… TPPSignInAdobeSkipTests testLogIn_postsSigningInNotification 89ms
โœ… TPPSignInAdobeSkipTests testLogIn_withNoSelectedAuth_doesNotCrash 175ms
โœ… TPPSignInAdobeSkipTests testMakeRequest_prefersBusinessLogicToken_overUserAccountToken 126ms
โœ… TPPSignInAdobeSkipTests testMakeRequest_withOAuthButNoToken_logsError 173ms
โœ… TPPSignInAdobeSkipTests testRefreshAuthIfNeeded_returnsFalseWithNoAuthDefinition 100ms
โœ… TPPSignInAdobeSkipTests testRefreshAuthIfNeeded_setsRefreshAuthCompletion 104ms
โœ… TPPSignInAdobeSkipTests testShouldSkipAdobeActivation_falseWhenNotStale 126ms
โœ… TPPSignInAdobeSkipTests testShouldSkipAdobeActivation_falseWithoutAdobeCredentials 83ms
โœ… TPPSignInAuthStateTransitionTests testReauth_transitionsFromStaleToLoggedIn 112ms
โœ… TPPSignInAuthStateTransitionTests testSignIn_isSignedInConditionMet 84ms
โœ… TPPSignInAuthStateTransitionTests testSignIn_transitionsFromLoggedOutToLoggedIn 101ms
โœ… TPPSignInBusinessLogicExtendedTests testCanResetPassword_dependsOnLibraryConfig 149ms
โœ… TPPSignInBusinessLogicExtendedTests testCurrentAccount_matchesLibraryAccount 115ms
โœ… TPPSignInBusinessLogicExtendedTests testEnsureAuthDoc_setsAndClearsLoadingFlag 130ms
โœ… TPPSignInBusinessLogicExtendedTests testEnsureAuthenticationDocumentIsLoaded_whenDetailsAlreadyLoaded_firesCompletionSync 137ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_authTokenNilByDefault 178ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_cookiesNilByDefault 148ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_defaultsIgnoreSignedInStateToFalse 169ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_defaultsNotLoggingInAfterSignUp 125ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_defaultsNotValidatingCredentials 133ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_patronNilByDefault 136ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_setsCorrectLibraryAccountID 117ms
โœ… TPPSignInBusinessLogicExtendedTests testInitialization_setsUIDelegate 203ms
โœ… TPPSignInBusinessLogicExtendedTests testIsAuthenticationDocumentLoading_defaultsFalse 187ms
โœ… TPPSignInBusinessLogicExtendedTests testIsLoggingInAfterSignUp_setterRoutesThroughReducer 262ms
โœ… TPPSignInBusinessLogicExtendedTests testIsNetworkConnectivityError_NonURLDomain_ReturnsFalse 390ms
โœ… TPPSignInBusinessLogicExtendedTests testIsSamlPossible_trueWhenLibrarySupports 120ms
โœ… TPPSignInBusinessLogicExtendedTests testIsSignedIn_falseWhenIgnoreSignedInStateTrue 533ms
โœ… TPPSignInBusinessLogicExtendedTests testIsSignedIn_falseWhenNoCredentials 238ms
โœ… TPPSignInBusinessLogicExtendedTests testIsSignedIn_trueWhenHasCredentials 117ms
โœ… TPPSignInBusinessLogicExtendedTests testLibraryAccount_returnsCorrectAccount 118ms
โœ… TPPSignInBusinessLogicExtendedTests testLibrarySupportsBarcodeDisplay_WithoutAuthorizationIdentifier_ReturnsFalse 119ms
โœ… TPPSignInBusinessLogicExtendedTests testLibrarySupportsBarcodeDisplay_falseWithoutCredentials 134ms
โœ… TPPSignInBusinessLogicExtendedTests testLibrarySupportsBarcodeDisplay_requiresAuthorizationIdentifier 134ms
โœ… TPPSignInBusinessLogicExtendedTests testLogIn_initiatesSignIn 164ms
โœ… TPPSignInBusinessLogicExtendedTests testLogIn_preventsMultipleSimultaneousCalls 150ms
โœ… TPPSignInBusinessLogicExtendedTests testLogIn_withBasicAuth_validatesCredentials 127ms
โœ… TPPSignInBusinessLogicExtendedTests testMakeRequest_forBasicAuth_noAuthorizationHeader 320ms
โœ… TPPSignInBusinessLogicExtendedTests testMakeRequest_forOAuth_hasBearerToken 116ms
โœ… TPPSignInBusinessLogicExtendedTests testMakeRequest_forSAML_hasBearerToken 116ms
โœ… TPPSignInBusinessLogicExtendedTests testMakeRequest_signOut_usesCorrectURL 160ms
โœ… TPPSignInBusinessLogicExtendedTests testRefreshAuthIfNeeded_basicAuthWithoutSavedCredentials_returnsTrue 106ms
โœ… TPPSignInBusinessLogicExtendedTests testRefreshAuthIfNeeded_oauthFreshFlow_marksCredentialsStaleButKeepsSelection 154ms
โœ… TPPSignInBusinessLogicExtendedTests testRefreshAuthIfNeeded_returnsFalseWhenNoAuthDefinition 134ms
โœ… TPPSignInBusinessLogicExtendedTests testRefreshAuthIfNeeded_samlAuthFreshFlow_marksCredentialsStale 125ms
โœ… TPPSignInBusinessLogicExtendedTests testRegistrationIsPossible_falseWhenSignedIn 153ms
โœ… TPPSignInBusinessLogicExtendedTests testRegistrationIsPossible_notSignedInAndLibraryHasSignUpUrl_returnsTrue 139ms
โœ… TPPSignInBusinessLogicExtendedTests testSelectPreferredAuthIfNeeded_WithExistingSelection_DoesNotOverride 148ms
โœ… TPPSignInBusinessLogicExtendedTests testSelectedAuthentication_canBeSetToBasic 132ms
โœ… TPPSignInBusinessLogicExtendedTests testSelectedAuthentication_canBeSetToOAuth 129ms
โœ… TPPSignInBusinessLogicExtendedTests testSelectedAuthentication_canBeSetToSAML 267ms
โœ… TPPSignInBusinessLogicExtendedTests testSelectedAuthentication_nilByDefault 118ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldShowEULALink_basedOnLibraryDetails 119ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldShowSyncButton_PP3252_usesCurrentAccountIdNotCurrentAccountUuid 183ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldShowSyncButton_falseWhenDifferentLibrary 173ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldShowSyncButton_falseWhenNoCredentials 153ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldSkipAdobeActivation_WhenMissingAdobeCredentials_ReturnsFalse 147ms
โœ… TPPSignInBusinessLogicExtendedTests testShouldSkipAdobeActivation_WhenNotCredentialsStale_ReturnsFalse 144ms
โœ… TPPSignInBusinessLogicExtendedTests testSignOut_PP418_clearsWebViewDataBeforeCompletion 185ms
โœ… TPPSignInBusinessLogicExtendedTests testSignOut_sequencesCookieClearingBeforeCompletionCallback 200ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_clearsCapturedCredentials 132ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_clearsIgnoreSignedInState 204ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_clearsInFlightAuthToken 130ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_setsAuthDefinition 132ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_withBasicAuth_setsBarcodePIN 109ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_withOAuth_setsAuthToken 142ms
โœ… TPPSignInBusinessLogicExtendedTests testUpdateUserAccount_withSAML_setsCookies 189ms
โœ… TPPSignInBusinessLogicExtendedTests testValidateCredentials_setsIsValidatingCredentialsTrue 163ms
โœ… TPPSignInBusinessLogicExtendedTests testValidateCredentials_setsValidatingFlag 122ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_baseTokenWithEqualsSign_isPreservedIntact 101ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_missingAccessToken_skipsValidationAndReportsParseError 97ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_missingPatronInfo_skipsValidationAndReportsParseError 94ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_nonURLObject_reportsErrorWithoutSideEffects 128ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_serverError_surfacesProblemDocumentTitle 89ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_validPayload_storesAuthTokenAndPatron 129ms
โœ… TPPSignInBusinessLogicOAuthTests test_handleRedirectURL_wrongPrefix_skipsParseAndReportsMissingPayload 96ms
โœ… TPPSignInBusinessLogicOAuthTests test_makeRequest_OAuth_fallsBackToPersistedToken 119ms
โœ… TPPSignInBusinessLogicOAuthTests test_makeRequest_OAuth_includesBearerHeaderFromInFlightToken 101ms
โœ… TPPSignInBusinessLogicOAuthTests test_makeRequest_signIn_returnsNilWhenNoUserProfileURL 100ms
โœ… TPPSignInBusinessLogicOAuthTests test_oauthRedirectObserver_registersAndRemovesItself_viaInjectedCenter 128ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_401Response_doesNotShowSignOutErrorToUser 117ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_500Response_surfacesSignOutErrorAndStillCleansUp 105ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_callsWillSignOutBeforeDeauthorize 100ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_clearsCredentialsFromKeychainAfterDeauthorize 114ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_clearsSAMLHelperState 143ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_clearsSelectedIDP 114ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_invokesDRMDeauthorizeExactlyOnce 105ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_preservesAdobeActivation_whenStaleCallbackArrives 186ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_preservesNewCredentials_whenUserReauthenticatesDuringSignOut 179ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_reentrantCall_isCoalesced 175ms
โœ… TPPSignInBusinessLogicSignOutTests test_signOut_resetsBookRegistry 124ms
โœ… TPPSignInBusinessLogicStateMachineTests testIsSamlAuth_failedDetailsLoad_returnsFalse 101ms
โœ… TPPSignInBusinessLogicStateMachineTests testIsSamlPossible_loaded_returnsTrueWhenSamlAuthPresent 105ms
โœ… TPPSignInBusinessLogicStateMachineTests testRegistrationIsPossible_loaded_returnsTrueWhenSignUpUrlPresent 103ms
โœ… TPPSignInBusinessLogicStateMachineTests testSelectPreferredAuthIfNeeded_loaded_picksSamlOverDefault 108ms
โœ… TPPSignInBusinessLogicStateMachineTests testSelectPreferredAuthIfNeeded_loading_doesNotMutate 103ms
โœ… TPPSignInBusinessLogicStateMachineTests testSelectedAuthentication_loading_returnsNil 104ms
โœ… TPPSignInBusinessLogicStateMachineTests testShouldShowEULALink_loaded_reflectsEulaUrlAndSignInState 104ms
โœ… TPPSignInBusinessLogicStateMachineTests testSignIn_blocksUntilLoaded_thenProceeds 101ms
โœ… TPPSignInBusinessLogicStateMachineTests testSignIn_failedDetailsLoad_surfacesError 126ms
โœ… TPPSignInBusinessLogicTests testIsNetworkConnectivityError_OnlyRecognizesURLErrorDomain 126ms
โœ… TPPSignInBusinessLogicTests testIsTransientServerError_classification 121ms
โœ… TPPSignInBusinessLogicTests testLogInFlow 117ms
โœ… TPPSignInBusinessLogicTests testMakeSignInRequest 141ms
โœ… TPPSignInBusinessLogicTests testShouldShowEULALink_WhenCredentialsStale_ReturnsTrue 128ms
โœ… TPPSignInBusinessLogicTests testShouldShowEULALink_WhenSignedIn_ReturnsFalse 220ms
โœ… TPPSignInBusinessLogicTests testShouldShowEULALink_WhenSignedOutAndEULAURLAvailable_ReturnsTrue 111ms
โœ… TPPSignInBusinessLogicTests testUpdateUserAccountWithBarcodeAuthentication 118ms
โœ… TPPSignInBusinessLogicTests testUpdateUserAccountWithCleverAuthentication 152ms
โœ… TPPSignInBusinessLogicTests testUpdateUserAccountWithNoSelectedAuthentication 161ms
โœ… TPPSignInBusinessLogicTests testUpdateUserAccountWithSAMLAuthentication 221ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_ConnectionLost_ReturnsNetworkMessage 121ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_NoInternet_ReturnsNetworkMessage 126ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_NonURLErrorDomain_ReturnsInvalidCredentials 116ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_ProblemDocument_TakesPrecedenceOverNetworkError 126ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_Timeout_ReturnsNetworkMessage 131ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_TokenRequest401_StillReturnsInvalidCredentials 133ms
โœ… TPPSignInBusinessLogicTests testUserFacingSignInError_TransientServer5xx_ReturnsTryAgain_Not_InvalidCredentials 115ms
โœ… TPPSignInBusinessLogicTokenFlowTests test_getBearerToken_emptyUsername_failsImmediatelyWithoutNetwork 106ms
โœ… TPPSignInBusinessLogicTokenFlowTests test_getBearerToken_failure_doesNotStoreTokenAndSurfacesError 152ms
โœ… TPPSignInBusinessLogicTokenFlowTests test_getBearerToken_success_persistsTokenViaTokenRefresher 88ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests test_validateCredentials_basicAuthFailure_doesNotFireReceiveCredentialsCallback 139ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests test_validateCredentials_basicAuthSuccess_firesDidReceiveCredentialsCallback 162ms
โœ… TPPSignInErrorHandlingTests testValidateCredentials_withSelectedAuth_doesNotCrash 86ms
โœ… TPPSignInErrorHandlingTests testValidateCredentials_withoutSelectedAuth_doesNotCrash 84ms
โœ… TPPSignInProfileDocEdgeCaseTests testSignIn_invalidProfileDoc_credentialsPreserved 142ms
โœ… TPPSignInProfileDocEdgeCaseTests testSignIn_noDRMInProfileDoc_credentialsPreserved 128ms
โœ… TPPSignInProfileDocEdgeCaseTests testSignIn_validDRMProfileDoc_savesCredentialsAndDRM 139ms
โœ… TPPSignedInStateProviderTests testIsSignedIn_AfterRemoveAll_ReturnsFalse 2ms
โœ… TPPSignedInStateProviderTests testIsSignedIn_WhenCredentialsPresent_ReturnsTrue 8ms
โœ… TPPSignedInStateProviderTests testIsSignedIn_WhenNoCredentials_ReturnsFalse 2ms
โœ… TPPUserAccountAuthStateTests testAuthState_defaultIsLoggedOut_andDerivesFromCredentialsWhenNotExplicit 2ms
โœ… TPPUserAccountAuthStateTests testMarkCredentialsStale_doesNotTransitionFromLoggedOut 2ms
โœ… TPPUserAccountAuthStateTests testMarkCredentialsStale_transitionsFromLoggedInToStale 8ms
โœ… TPPUserAccountAuthStateTests testMarkLoggedIn_transitionsFromAnyReauthenticatableStateToLoggedIn 4ms
โœ… TPPUserAccountAuthStateTests testRemoveAll_resetsStateToLoggedOut 2ms
โœ… TPPUserAccountAuthStateTests testSetAuthToken_transitionsFromCredentialsStaleToLoggedIn 3ms
โœ… TPPUserAccountGapTests testTPPUserAccount_basicPropertyAccessors_dontCrash 2ms
โœ… TPPUserAccountGapTests testTPPUserAccount_hasAuthToken_returnsFalseWhenNoToken 3ms
โœ… TPPUserAccountGapTests testTPPUserAccount_hasBarcodeAndPIN_returnsFalseWhenNoCredentials 2ms
โœ… TPPUserAccountGapTests testTPPUserAccount_sharedAccount_isAccessible 5ms
โœ… TPPUserAccountIsolationLintTests testLintCatchesSyntheticViolator 2ms
โœ… TPPUserAccountIsolationLintTests testNoSharedAccountOutsideWhitelist 793ms
โœ… TPPUserAccountIsolationLintTests testResetterIsRegisteredAfterFactoryUse 2ms
โŠ˜ TPPUserAccountTestFactoryTests testFactory_neverWritesToProductionKeychain 10ms
โŠ˜ TPPUserAccountTestFactoryTests testFactory_registersResetterUnderStableName 12ms
โŠ˜ TPPUserAccountTestFactoryTests testMakeIsolated_doesNotPolluteSharedCache 10ms
โŠ˜ TPPUserAccountTestFactoryTests testMakeIsolated_eachCallReturnsDistinctLibraryUUID 5ms
โŠ˜ TPPUserAccountTestFactoryTests testMakeIsolated_honorsExplicitLibraryUUID 8ms
โŠ˜ TPPUserAccountTestFactoryTests testMakeIsolated_reRegistersResetter_afterRegistryCleared 6ms
โŠ˜ TPPUserAccountTestFactoryTests testResetter_clearsKeychainResidue 31ms
โœ… TPPUserFriendlyErrorTests testDefaultImplementation_messageIsNil 2ms
โœ… TPPUserFriendlyErrorTests testDefaultImplementation_titleIsNil 6ms
โœ… TPPUserFriendlyErrorTests testMakeFromProblemDocument_preservesExistingUserInfo 14ms
โœ… TPPUserFriendlyErrorTests testMakeFromProblemDocument_setsDomainAndCode 3ms
โœ… TPPUserFriendlyErrorTests testMakeFromProblemDocument_storesProblemDocument 6ms
โœ… TPPUserFriendlyErrorTests testNSError_withProblemDocument_hasFriendlyMessage 3ms
โœ… TPPUserFriendlyErrorTests testNSError_withProblemDocument_hasFriendlyTitle 7ms
โœ… TPPUserFriendlyErrorTests testNSError_withoutProblemDocument_messageIsLocalizedDescription 4ms
โœ… TPPUserFriendlyErrorTests testNSError_withoutProblemDocument_noUserInfo_messageIsNil 6ms
โœ… TPPUserFriendlyErrorTests testNSError_withoutProblemDocument_titleIsNil 2ms
โœ… TPPUserFriendlyErrorTests testProblemDocument_accessor_returnsStoredDocument 6ms
โœ… TPPUserNotificationsTests testBackgroundFetchIsNeeded_returnsBasedOnHeldBooksCount 7ms
โœ… TPPUserNotificationsTests testCompareAvailability_detectsTransitionFromReservedToReady 21ms
โœ… TPPUserNotificationsTests testCompareAvailability_doesNotCrashWithValidInputs 9ms
โœ… TPPUserNotificationsTests testCompareAvailability_doesNotNotifyWhenStillReserved 23ms
โœ… TPPUserNotificationsTests testCompareAvailability_handlesNilAvailability 5ms
โœ… TPPUserNotificationsTests testRequestAuthorization_isExposedAsObjcSelectorOnService 4ms
โœ… TPPUserNotificationsTests testSharedInstance_isStableAcrossCallsAndConcurrentAccess 7ms
โœ… TPPUserNotificationsTests testUpdateAppIconBadge_countsOnlyReadyBooks 33ms
โœ… TPPUserNotificationsTests testUpdateAppIconBadge_withBooks_processesWithoutCrash 17ms
โœ… TPPUserNotificationsTests testUpdateAppIconBadge_withEmptyArray_isIdempotentAndCrashFree 27ms
โœ… TPPXMLSwiftTests test_attributes_emptyAttributes_returnsEmptyDictionary 6ms
โœ… TPPXMLSwiftTests test_attributes_withAttributes_returnsDictionary 4ms
โœ… TPPXMLSwiftTests test_childrenWithName_nonexistentName_returnsEmptyArray 4ms
โœ… TPPXMLSwiftTests test_childrenWithName_returnsMatchingChildren 4ms
โœ… TPPXMLSwiftTests test_firstChildWithName_nonexistent_returnsNil 6ms
โœ… TPPXMLSwiftTests test_firstChildWithName_returnsFirstMatch 7ms
โœ… TPPXMLSwiftTests test_parseEmptyData_returnsNil 4ms
โœ… TPPXMLSwiftTests test_parseInlineXML_simpleElement 7ms
โœ… TPPXMLSwiftTests test_parseInvalidXML_returnsNil 6ms
โœ… TPPXMLSwiftTests test_parseNilData_returnsNil 6ms
โœ… TPPXMLSwiftTests test_parseValidXML_rootHasNoParent 4ms
โœ… TPPXMLSwiftTests test_parseValidXML_rootHasThreeChildren 31ms
โœ… TPPXMLSwiftTests test_parseValidXML_rootName_isFoo 6ms
โœ… TPPXMLSwiftTests test_parseValidXML_rootNamespaceURI_isCorrect 6ms
โœ… TPPXMLSwiftTests test_parseValidXML_rootQualifiedName 5ms
โœ… TPPXMLSwiftTests test_value_returnsTextContent 4ms
โœ… TPPXMLTests testInvalid 6ms
โœ… TPPXMLTests testNoData 5ms
โœ… TPPXMLTests testValid 17ms
โœ… TearDownRequiredLintTests testBaselineFileIsLoaded 6ms
โœ… TearDownRequiredLintTests testLintAcceptsExplicitTearDown 3ms
โœ… TearDownRequiredLintTests testLintAcceptsInheritedTearDown 4ms
โœ… TearDownRequiredLintTests testLintCatchesSyntheticViolator 2ms
โœ… TearDownRequiredLintTests testTearDownRequired_runsAgainstPalaceTestsTree 1.88s
โœ… TestAppContainerFactoryTests testMakeTestAppContainer_acceptsBookRegistryOverride 35ms
โœ… TestAppContainerFactoryTests testMakeTestAppContainer_acceptsExplicitDependencyOverrides 7ms
โœ… TestAppContainerFactoryTests testMakeTestAppContainer_doesNotMutateProductionCache 26ms
โœ… TestAppContainerFactoryTests testMakeTestAppContainer_doesNotSpawnLoadCatalogsTask 7ms
โœ… TestAppContainerFactoryTests testMakeTestAppContainer_returnsDistinctInstancesPerCall 17ms
โœ… TimeEntryTests testTimeEntry_creation 6ms
โœ… TimeEntryTests testTimeEntry_durationLimit 3ms
โœ… TimeEntryTests testTimeEntry_utcFormat 7ms
โŒ TokenRefreshAndRetryQueueTests First Run 713ms
โœ… TokenRefreshAndRetryQueueTests Retry 1 653ms
โœ… TokenRefreshAndRetryQueueTests testConcurrentRefreshes_OnlyOneTokenRequestFires 2.13s
โœ… TokenRefreshAndRetryQueueTests testDELETE_401_DoesNotTriggerRefresh 683ms
โœ… TokenRefreshAndRetryQueueTests testQueuedRequest_AfterRefresh_RetriesWithNewBearer 430ms
โœ… TokenRefreshAndRetryQueueTests testQueuedRequest_CompletionFiresWithRetryBodyAfterRetry 180ms
โœ… TokenRefreshAndRetryQueueTests testRefresh_SuccessWithoutTask_FiresSuccessCompletion 635ms
โœ… TokenRefreshAndRetryQueueTests testRefresh_Success_ReleasesSingleFlightSlot 1.16s
โœ… TokenRefreshAndRetryQueueTests testRefresh_TokenEndpointNetworkError_DoesNotMarkCredentialsStale 2.38s
โœ… TokenRefreshAndRetryQueueTests testRefresh_TokenEndpointReturns401_MarksCredentialsStaleAndDoesNotLoop 174ms
โœ… TokenRefreshAndRetryQueueTests testRefresh_WithoutCredentials_FailsImmediatelyAndReleasesSlot 148ms
โœ… TokenRefreshIntegrationTests testExecuteTokenRefresh_EmptyUsername_NeverHitsNetwork 15ms
โœ… TokenRefreshIntegrationTests testExecuteTokenRefresh_ValidatesBasicAuthHeaderOnWire 239ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_401_OAuthIntermediary_doesNotInvokeCoordinator_fallsToTokenRefreshPath 543ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_401_OIDC_doesNotRouteThroughCoordinator 688ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_401_SAML_dispatchesViaCoordinator_andSetsSAMLStarted 548ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_401_SAML_userCancel_doesNotRetry_butStillFlipsPerBookState 545ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_handleProblem_browserSAML_dispatchesViaCoordinator 563ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testCoordinator_noActiveLoan_SAML_dispatchesViaCoordinator_andSetsSAMLStarted 545ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testForeignHost_401_SAML_doesNotMarkCredentialsStale_doesNotDispatchCoordinator 547ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests testForeignHost_401_SAML_withNilProvider_fallsBackToLegacyDispatch 553ms
โœ… TokenRefreshInterceptorTests testHandleBorrowInvalidCredentials_firstAttempt_triggersReauth 8ms
โœ… TokenRefreshInterceptorTests testHandleBorrowInvalidCredentials_nilDelegate_doesNotCrash 9ms
โœ… TokenRefreshInterceptorTests testHandleBorrowInvalidCredentials_secondAttempt_showsAlert 117ms
โœ… TokenRefreshInterceptorTests testHandleBorrowInvalidCredentials_successfulReauth_startsDownload 516ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_OIDC_401_marksCredentialsStale 7ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_OIDC_401_triggersReauthViaSignInModal 1.04s
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_OIDC_cancelledReauth_doesNotRetry 1.03s
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_OIDC_successfulReauth_retriesDownload 1.03s
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_SAML_401_legacyPath_retriesViaSAMLNotBrowserModal 519ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_SAML_noActiveLoan_legacyPath_retriesViaSAMLNotBrowserModal 517ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_hasCredentials_noLoginRequired_returnsFalse 9ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_noActiveLoan_OIDC_triggersReauth 1.02s
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_noActiveLoan_SAML_treatAsSessionExpiry 8ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_noActiveLoan_nonSAML_autoBorrows 8ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_noCredentialsLoginRequired_triggersSignIn 7ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_noDelegateReturnsFalse 10ms
โœ… TokenRefreshInterceptorTests testHandleDownloadFailure_nonAuthRelatedError_returnsFalse 6ms
โœ… TokenRefreshInterceptorTests testHandleProblem_SAMLStartedState_circuitBreaker 11ms
โœ… TokenRefreshInterceptorTests testHandleProblem_SAMLWithCredentials_retriesWithSAML 518ms
โœ… TokenRefreshInterceptorTests testHandleProblem_authenticatedUser_noReauth 317ms
โœ… TokenRefreshInterceptorTests testHandleProblem_nilDelegate_doesNotCrash 7ms
โœ… TokenRefreshInterceptorTests testHandleProblem_noCredentials_triggersReauth 16ms
โœ… TokenRefreshInterceptorTests testInit_defaultState 3ms
โœ… TokenRefreshInterceptorTests testInit_withCustomReauthenticator 3ms
โœ… TokenRefreshOnForegroundTests test_ConcurrentForegroundRequests_ProduceOneTokenRefresh 111ms
โœ… TokenRefreshOnForegroundTests test_ForegroundRefreshFailure_StillResolvesCaller 1.41s
โœ… TokenRefreshOnForegroundTests test_HealthyToken_NoProactiveRefresh 405ms
โœ… TokenRefreshOnForegroundTests test_NearExpiryToken_GETBlocksOnRefresh 140ms
โœ… TokenRefreshOnForegroundTests test_NearExpiryToken_OnForeground_FiresTokenRefreshBeforeUserRequest 99ms
โœ… TokenRefreshOnForegroundTests test_NearExpiryToken_RetriedRequest_UsesFreshBearer 108ms
โœ… TokenRefreshOnForegroundTests test_POSTBody_PreservedAcrossProactiveRefresh 145ms
โœ… TokenRefreshOnForegroundTests test_SAMLAuth_DoesNotTriggerProactiveTokenRefresh 96ms
โœ… TokenRefreshOnForegroundTests test_TokenAtExactExpiryThreshold_IsConsideredNearExpiry 91ms
โœ… TokenRefreshOnForegroundTests test_UseTokenIfAvailableFalse_BypassesProactiveRefresh 95ms
โœ… TokenRefreshTests testBearerAuthorized_AddsAuthorizationHeader 28ms
โœ… TokenRefreshTests testBearerAuthorized_EmptyTokenSetsEmptyHeader 3ms
โœ… TokenRefreshTests testMockExecutor_HandlesEmptyURL 5ms
โœ… TokenRefreshTests testMockExecutor_Returns404ForUnknownURL 5ms
โœ… TokenRefreshTests testMockExecutor_ReturnsConfiguredResponse 7ms
โœ… TokenRefreshTests testNYPLResult_FailureCase 3ms
โœ… TokenRefreshTests testNYPLResult_FailureWithNilResponse 3ms
โœ… TokenRefreshTests testNYPLResult_SuccessCase 2ms
โœ… TokenRefreshTests testNYPLResult_SuccessWithNilResponse 2ms
โœ… TokenRefreshTests testRequestTimeout_DefaultValue 3ms
โœ… TokenRefreshTests testRequestTimeout_StaticDefault 3ms
โœ… TokenRefreshTests testTPPErrorCode_InvalidCredentialsValue 2ms
โœ… TokenRefreshTests testTokenRequest_EmptyPassword 3ms
โœ… TokenRefreshTests testTokenRequest_EmptyUsername 3ms
โœ… TokenRefreshTests testTokenRequest_InitializesCorrectly 2ms
โœ… TokenRefreshTests testTokenRequest_SpecialCharactersInCredentials 2ms
โœ… TokenRefreshTests testTokenResponse_DecodesFromJSON 3ms
โœ… TokenRefreshTests testTokenResponse_DifferentTokenTypes 3ms
โœ… TokenRefreshTests testTokenResponse_EncodesToJSON 2ms
โœ… TokenRefreshTests testTokenResponse_ExpirationDateCalculation 2ms
โœ… TokenRefreshTests testTokenResponse_LargeExpiresIn 2ms
โœ… TokenRefreshTests testTokenResponse_NegativeExpiresIn 2ms
โœ… TokenRefreshTests testTokenResponse_RoundTrip 8ms
โœ… TokenRefreshTests testTokenResponse_SmallExpiresIn 2ms
โœ… TokenRefreshTests testTokenResponse_ZeroExpiresIn 3ms
โœ… TokenRequestCredentialGuardTests testExecute_BothEmpty_ReturnsFailureWithoutNetworkCall 7ms
โœ… TokenRequestCredentialGuardTests testExecute_ColonInPassword_EncodesCorrectly 10ms
โœ… TokenRequestCredentialGuardTests testExecute_EmptyCredentials_ErrorDomain 9ms
โœ… TokenRequestCredentialGuardTests testExecute_EmptyPassword_PinlessLogin_MakesNetworkCall 25ms
โœ… TokenRequestCredentialGuardTests testExecute_EmptyUsername_ReturnsFailureWithoutNetworkCall 9ms
โœ… TokenRequestCredentialGuardTests testExecute_SendsPOSTMethod 6ms
โœ… TokenRequestCredentialGuardTests testExecute_ServerReturns400_ReturnsFailureWithStatusCode 7ms
โœ… TokenRequestCredentialGuardTests testExecute_ServerReturns401_ReturnsFailureWithStatusCode 38ms
โœ… TokenRequestCredentialGuardTests testExecute_ServerReturnsIncompleteJSON_ReturnsDecodingError 16ms
โœ… TokenRequestCredentialGuardTests testExecute_ServerReturnsNonJSON_ReturnsDecodingError 12ms
โœ… TokenRequestCredentialGuardTests testExecute_SpecialCharactersInCredentials_EncodesCorrectly 16ms
โœ… TokenRequestCredentialGuardTests testExecute_ValidCredentials_MakesNetworkCall 5ms
โœ… TokenRequestCredentialGuardTests testExecute_ValidCredentials_SendsCorrectBasicAuthHeader 14ms
โœ… TokenRequestTests testExecute403WithNonJSONBody_FallsBackToGenericError 35ms
โœ… TokenRequestTests testExecute403WithProblemDocument_EmbedsProblemDocInError 6ms
โœ… TokenRequestTests testExecuteInvalidJSONReturnsDecodingError 20ms
โœ… TokenRequestTests testExecuteNon200StatusReturnsFailure 11ms
โœ… TokenRequestTests testExecuteSendsBasicAuthHeader 5ms
โœ… TokenRequestTests testExecuteSuccessReturnsToken 32ms
โœ… TokenRequestTests testExecuteUsesPOSTMethod 6ms
โœ… TokenRequestTests testTokenRequestInitProperties 2ms
โœ… TokenRequestTests testTokenResponseDecodableFromJSON 4ms
โœ… TokenRequestTests testTokenResponseExpirationDate 3ms
โœ… TokenRequestTests testTokenResponseInitProperties 2ms
โœ… TokenResponseTests testAccessToken_WithSpecialCharacters 2ms
โœ… TokenResponseTests testAccessToken_WithUnicodeCharacters 2ms
โœ… TokenResponseTests testDecode_WithDifferentTokenType_ParsesCorrectly 2ms
โœ… TokenResponseTests testDecode_WithExtraFields_IgnoresExtraFields 2ms
โœ… TokenResponseTests testDecode_WithLargeExpiresIn_ParsesCorrectly 2ms
โœ… TokenResponseTests testDecode_WithMissingAccessToken_ThrowsError 6ms
โœ… TokenResponseTests testDecode_WithMissingExpiresIn_ThrowsError 2ms
โœ… TokenResponseTests testDecode_WithMissingTokenType_ThrowsError 3ms
โœ… TokenResponseTests testDecode_WithValidJSON_ParsesCorrectly 4ms
โœ… TokenResponseTests testDecode_WithWrongTypeForExpiresIn_ThrowsError 2ms
โœ… TokenResponseTests testEncodeDecode_RoundTrip_PreservesValues 2ms
โœ… TokenResponseTests testEncode_ProducesValidJSON 5ms
โœ… TokenResponseTests testExpirationDate_CalculatesCorrectInterval 2ms
โœ… TokenResponseTests testExpirationDate_WithNegativeExpiresIn_ReturnsDateInPast 2ms
โœ… TokenResponseTests testExpirationDate_WithPositiveExpiresIn_ReturnsDateInFuture 4ms
โœ… TokenResponseTests testExpirationDate_WithZeroExpiresIn_ReturnsCurrentTime 5ms
โœ… TokenResponseTests testExpiresIn_WithMaxInt32Value 3ms
โœ… TokenResponseTests testInit_WithEmptyToken_StoresEmptyString 2ms
โœ… TokenResponseTests testInit_WithNegativeExpiresIn_StoresNegativeValue 2ms
โœ… TokenResponseTests testInit_WithValidParameters_StoresValues 3ms
โœ… TokenResponseTests testInit_WithZeroExpiresIn_StoresZero 2ms
โœ… TypographyPresetTests testAllPresetFontSizesInRange 2ms
โœ… TypographyPresetTests testAllPresetLetterSpacingsInRange 5ms
โœ… TypographyPresetTests testAllPresetLineSpacingsInRange 6ms
โœ… TypographyPresetTests testAllPresetWordSpacingsInRange 13ms
โœ… TypographyPresetTests testAllPresetsProduceCSS 6ms
โœ… TypographyPresetTests testClassicCSSContainsGeorgia 3ms
โœ… TypographyPresetTests testClassicPreset 2ms
โœ… TypographyPresetTests testCozyPreset 3ms
โœ… TypographyPresetTests testDensePreset 2ms
โœ… TypographyPresetTests testDyslexiaCSSContainsOpenDyslexic 4ms
โœ… TypographyPresetTests testDyslexiaFriendlyPreset 17ms
โœ… TypographyPresetTests testModernCSSContainsSFPro 3ms
โœ… TypographyPresetTests testModernPreset 2ms
โœ… TypographyPresetTests testNightReaderCSSHasBlackBackground 4ms
โœ… TypographyPresetTests testNightReaderPreset 5ms
โœ… TypographyPresetTests testPresetCount 278ms
โœ… TypographyPresetTests testPresetLookupById 22ms
โœ… TypographyPresetTests testPresetLookupByInvalidId 5ms
โœ… TypographyPresetTests testPresetSettingsAreCodable 275ms
โœ… TypographyPresetTests testPresetsHaveUniqueIds 6ms
โœ… TypographyPresetTests testPresetsHaveUniqueNames 5ms
โœ… TypographyServiceTests testApplyPreset 3ms
โœ… TypographyServiceTests testApplyPresetClearsPreviousCustomization 4ms
โœ… TypographyServiceTests testCSSContainsBackgroundColor 3ms
โœ… TypographyServiceTests testCSSContainsFontFamily 8ms
โœ… TypographyServiceTests testCSSContainsFontSize 7ms
โœ… TypographyServiceTests testCSSContainsLetterSpacing 11ms
โœ… TypographyServiceTests testCSSContainsLineSpacing 5ms
โœ… TypographyServiceTests testCSSContainsMargins 5ms
โœ… TypographyServiceTests testCSSContainsParagraphSpacing 11ms
โœ… TypographyServiceTests testCSSContainsTextAlignment 4ms
โœ… TypographyServiceTests testCSSContainsWordSpacing 17ms
โœ… TypographyServiceTests testCSSDisablesHyphensForLeftAligned 41ms
โœ… TypographyServiceTests testCSSEnablesHyphensForJustifiedText 2ms
โœ… TypographyServiceTests testCSSForArbitrarySettings 3ms
โœ… TypographyServiceTests testCSSForDarkTheme 18ms
โœ… TypographyServiceTests testCSSForSepiaTheme 6ms
โœ… TypographyServiceTests testDefaultSettingsLoadClassicPreset 2ms
โœ… TypographyServiceTests testResetToPresetRestoresOriginal 3ms
โœ… TypographyServiceTests testResetToPresetWithNoPresetResetsToClassic 5ms
โœ… TypographyServiceTests testSettingsPersistedAfterDebounce 1.08s
โœ… TypographyServiceTests testSettingsPublisherEmitsOnChange 7ms
โœ… TypographyServiceTests testUpdateFontFamily 6ms
โœ… TypographyServiceTests testUpdateFontSizeClampsToRange 7ms
โœ… TypographyServiceTests testUpdateLetterSpacingClampsToRange 3ms
โœ… TypographyServiceTests testUpdateLineSpacingClampsToRange 4ms
โœ… TypographyServiceTests testUpdateMarginLevel 4ms
โœ… TypographyServiceTests testUpdateParagraphSpacing 6ms
โœ… TypographyServiceTests testUpdateSettingsReplacesAll 6ms
โœ… TypographyServiceTests testUpdateTextAlignment 3ms
โœ… TypographyServiceTests testUpdateTheme 3ms
โœ… TypographyServiceTests testUpdateWordSpacingClampsToRange 10ms
โœ… TypographySettingsViewModelTests testAlignmentGetterMatchesSettings 18ms
โœ… TypographySettingsViewModelTests testAvailableFontsNotEmpty 5ms
โœ… TypographySettingsViewModelTests testFontSizeGetterMatchesSettings 248ms
โœ… TypographySettingsViewModelTests testHasCustomOverridesIsFalseForPreset 29ms
โœ… TypographySettingsViewModelTests testHasCustomOverridesIsTrueAfterChange 28ms
โœ… TypographySettingsViewModelTests testHasCustomOverridesIsTrueWithNoPreset 169ms
โœ… TypographySettingsViewModelTests testInitialPresetIsClassic 10ms
โœ… TypographySettingsViewModelTests testInitialStateMatchesService 7ms
โœ… TypographySettingsViewModelTests testPreviewCSSChangesWithSettings 21ms
โœ… TypographySettingsViewModelTests testPreviewCSSNotEmpty 7ms
โœ… TypographySettingsViewModelTests testPreviewTextNotEmpty 6ms
โœ… TypographySettingsViewModelTests testRapidChangesSettleCorrectly 24ms
โœ… TypographySettingsViewModelTests testResetToPresetAfterCustomization 37ms
โœ… TypographySettingsViewModelTests testResetWithNoPresetResetsToClassic 28ms
โœ… TypographySettingsViewModelTests testSelectAllPresetsInSequence 83ms
โœ… TypographySettingsViewModelTests testSelectPresetUpdatesService 116ms
โœ… TypographySettingsViewModelTests testSelectPresetUpdatesSettings 17ms
โœ… TypographySettingsViewModelTests testServiceChangesReflectedInViewModel 4ms
โœ… TypographySettingsViewModelTests testUpdateFontFamily 18ms
โœ… TypographySettingsViewModelTests testUpdateFontSize 160ms
โœ… TypographySettingsViewModelTests testUpdateLetterSpacing 17ms
โœ… TypographySettingsViewModelTests testUpdateLineSpacing 15ms
โœ… TypographySettingsViewModelTests testUpdateMarginLevel 17ms
โœ… TypographySettingsViewModelTests testUpdateParagraphSpacing 13ms
โœ… TypographySettingsViewModelTests testUpdateTextAlignment 18ms
โœ… TypographySettingsViewModelTests testUpdateTheme 15ms
โœ… TypographySettingsViewModelTests testUpdateWordSpacing 15ms
โœ… UIAlertCACommitGuardTests testAlertTitleError_WithCancelledNetworkError_DoesNotCrash 7ms
โœ… UIAlertCACommitGuardTests testAlertTitleError_WithNilError_ProducesGenericMessage 6ms
โœ… UIAlertCACommitGuardTests testAlertTitleError_WithUnknownDomain_ProducesGenericMessage 10ms
โœ… UIAlertCACommitGuardTests testAlertTitleMessage_WithEmptyMessage_DoesNotCrashAndStillUsable 5ms
โœ… UIAlertCACommitGuardTests testAlertTitleMessage_WithNonEmptyArgs_ProducesValidController 9ms
โœ… UIAlertCACommitGuardTests testPresentFromViewControllerOrNil_WithNilController_DoesNothing 207ms
โœ… UIAlertCACommitGuardTests testSetProblemDocument_WithNilController_DoesNothing 2ms
โœ… UIAlertCACommitGuardTests testSetProblemDocument_WithNilDocument_DoesNothing 6ms
โœ… UIColor_NYPLAdditionsTests testExample 3ms
โœ… URLBackupExclusionTests test_excludeFromBackup_returnsFalse_whenURLDoesNotExist 8ms
โœ… URLBackupExclusionTests test_excludeFromBackup_setsFlag_onExistingDirectory 5ms
โœ… URLBackupExclusionTests test_excludeFromBackup_setsFlag_onExistingFile 6ms
โœ… URLExtensionTests testAppendingPathComponent 4ms
โœ… URLExtensionTests testAppendingPathExtension 36ms
โœ… URLExtensionTests testFileURL_deletingLastPathComponent 3ms
โœ… URLExtensionTests testFileURL_isFileURL 2ms
โœ… URLExtensionTests testFileURL_lastPathComponent 16ms
โœ… URLExtensionTests testFileURL_pathExtension 5ms
โœ… URLExtensionTests testHTTPURL_isNotFileURL 16ms
โœ… URLExtensionTests testURLComponents_fragment 52ms
โœ… URLExtensionTests testURLComponents_host 3ms
โœ… URLExtensionTests testURLComponents_path 3ms
โœ… URLExtensionTests testURLComponents_query 68ms
โœ… URLExtensionTests testURLComponents_scheme 2ms
โœ… URLExtensionTests testURLEncoding_spaceInQuery 9ms
โœ… URLExtensionTests testURLEncoding_specialCharacters 2ms
โœ… URLExtensionTests testURLQueryItems_building 2ms
โœ… URLExtensionTests testURLQueryItems_parsing 3ms
โœ… URLExtensionsTests testReplacingScheme_HttpToHttps_ReplacesScheme 2ms
โœ… URLExtensionsTests testReplacingScheme_HttpsToHttp_ReplacesScheme 11ms
โœ… URLExtensionsTests testReplacingScheme_PreservesFragment 5ms
โœ… URLExtensionsTests testReplacingScheme_PreservesPort 2ms
โœ… URLExtensionsTests testReplacingScheme_PreservesUserInfo 3ms
โœ… URLExtensionsTests testReplacingScheme_ToCustomScheme_Works 2ms
โœ… URLRequestExtensionsCoverageTests testURLRequest_applyCustomUserAgent 3ms
โœ… URLRequestExtensionsCoverageTests testURLRequest_customUserAgent 2ms
โœ… URLRequestExtensionsCoverageTests testURLRequest_noCustomUserAgent_doesNotSetUserAgentHeader 3ms
โœ… URLRequestExtensionsTests testApplyCustomUserAgent_ReturnsSelf 5ms
โœ… URLRequestExtensionsTests testApplyCustomUserAgent_SetsHeader 6ms
โœ… URLRequestExtensionsTests testInit_WithCustomUserAgent_PreservesURL 6ms
โœ… URLRequestExtensionsTests testInit_WithCustomUserAgent_SetsUserAgentHeader 7ms
โœ… URLRequestExtensionsTests testInit_WithoutCustomUserAgent_NoUserAgentHeader 10ms
โœ… URLRequestExtensionsTests testIsTokenAuthorized_NoAuthHeader_ReturnsFalse 7ms
โœ… URLRequestExtensionsTests testIsTokenAuthorized_WithBasicAuth_ReturnsFalse 5ms
โœ… URLRequestExtensionsTests testIsTokenAuthorized_WithBearerToken_ReturnsTrue 3ms
โœ… URLRequestExtensionsTests testLoggableString_ContainsMethodAndURL 2ms
โœ… URLRequestExtensionsTests testLoggableString_ExcludesAuthorizationHeader 8ms
โœ… URLRequestExtensionsTests testLoggableString_IncludesNonSensitiveHeaders 3ms
โœ… URLRequestNYPLAdditionsTests testPostParams_bodyContainsParams 2ms
โœ… URLRequestNYPLAdditionsTests testPostParams_boundaryConsistencyBetweenHeaderAndBody 5ms
โœ… URLRequestNYPLAdditionsTests testPostParams_emptyParams_doesNotCrash 4ms
โœ… URLRequestNYPLAdditionsTests testPostParams_producesMultipartFormPOSTRequest 3ms
โœ… URLRequestNYPLAdditionsTests testPostParams_setsContentLength 4ms
โœ… URLRequestNYPLAdditionsTests testPostParams_withImage_bodyContainsImageData 6ms
โœ… URLRequestNYPLAdditionsTests testPostParams_withNilImage_bodyLacksImageSection 2ms
โœ… URLRequestNYPLAdditionsTests testPostProblemDocument_producesCompliantProblemJSONRequest 2ms
โœ… URLRequestNYPLAdditionsTests testPostProblemDocument_setsBody 3ms
โœ… URLRequestNYPLAdditionsTests testPostProblemDocument_setsContentLength 3ms
โœ… URLRequestNYPLAdditionsTests testPostProblemDocument_usesTransportDefaultsForReporting 52ms
โœ… URLRequest_NYPLTests testAuthorizationHeaderStrip 4ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_with200StatusCode_returnsFalse 3ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_with401StatusCode_returnsTrue 6ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_with403StatusCode_returnsFalse 3ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_withApiProblemMimeType_andInvalidCredentials_returnsTrue 2ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_withInvalidCredentialsProblemDoc_returnsTrue 2ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_withOPDSAuthMimeType_and200Status_returnsFalse 2ms
โœ… URLResponseAuthenticationTests testHTTPURLResponse_withOPDSAuthMimeType_andNon2xxStatus_returnsTrue 2ms
โœ… URLResponseAuthenticationTests testURLResponse_withInvalidCredentialsProblemDoc_returnsTrue 2ms
โœ… URLResponseAuthenticationTests testURLResponse_withNilProblemDoc_returnsFalse 4ms
โœ… URLResponseAuthenticationTests testURLResponse_withNonProblemMimeType_returnsFalse 2ms
โœ… URLResponseNYPLTests testIsProblemDocument_WithApiProblemJsonMime_ReturnsTrue 18ms
โœ… URLResponseNYPLTests testIsProblemDocument_WithHtmlMime_ReturnsFalse 3ms
โœ… URLResponseNYPLTests testIsProblemDocument_WithNilMime_ReturnsFalse 4ms
โœ… URLResponseNYPLTests testIsProblemDocument_WithProblemJsonMime_ReturnsTrue 6ms
โœ… URLResponseNYPLTests testIsProblemDocument_WithRegularJsonMime_ReturnsFalse 7ms
โœ… URLResponseNYPLTests testIsSuccess_199_ReturnsFalse 2ms
โœ… URLResponseNYPLTests testIsSuccess_200_ReturnsTrue 3ms
โœ… URLResponseNYPLTests testIsSuccess_201Created_ReturnsTrue 7ms
โœ… URLResponseNYPLTests testIsSuccess_204NoContent_ReturnsTrue 2ms
โœ… URLResponseNYPLTests testIsSuccess_299_ReturnsTrue 2ms
โœ… URLResponseNYPLTests testIsSuccess_300Redirect_ReturnsFalse 3ms
โœ… URLResponseNYPLTests testIsSuccess_400BadRequest_ReturnsFalse 7ms
โœ… URLResponseNYPLTests testIsSuccess_401Unauthorized_ReturnsFalse 2ms
โœ… URLResponseNYPLTests testIsSuccess_500ServerError_ReturnsFalse 2ms
โœ… URLSessionCredentialStorageTests testMakeURLSessionConfiguration_Default_DisablesCredentialStorage 6ms
โœ… URLSessionCredentialStorageTests testMakeURLSessionConfiguration_Ephemeral_ReturnsEphemeralConfig 36ms
โœ… URLSessionCredentialStorageTests testMakeURLSessionConfiguration_Fallback_DisablesCredentialStorage 7ms
โœ… URLSessionStubbingResetTests testResetStubbedSession_inFlightTaskOnOldSession_completesGracefully 8ms
โœ… URLSessionStubbingResetTests testResetStubbedSession_returnsDistinctSessionInstance 3ms
โœ… URLTypeTests testURLType_HasAllExpectedCases 6ms
โœ… URLTypeTests testURLType_RawValues_AreDistinct 2ms
โœ… URLValidationTests testEmptyString_returnsNil 2ms
โœ… URLValidationTests testFileURL_alwaysValid 2ms
โœ… URLValidationTests testInvalidURL_handledByURLInit 2ms
โœ… URLValidationTests testURLWithSpaces_handledCorrectly 2ms
โœ… URLValidationTests testValidHTTPURL 2ms
โœ… UnifiedOPDSServiceStateMachineTests testFetchLoansFeed_blocksUntilLoaded_thenFetches 251ms
โœ… UnifiedOPDSServiceStateMachineTests testFetchLoansFeed_failedDetailsLoad_throws 250ms
โœ… UserAccountPublisherAuthStateTests testAuthStateDidChangePublisher_firesOnStateChanges 23ms
โœ… UserAccountPublisherAuthStateTests testCredentialsStalePublisher_firesWhenStateBecomesStale 17ms
โœ… UserAccountPublisherAuthStateTests testInitialState_isLoggedOut_andMarkCredentialsStaleFromLoggedOutIsNoOp 36ms
โœ… UserAccountPublisherAuthStateTests testMarkCredentialsStale_updatesState 9ms
โœ… UserAccountPublisherAuthStateTests testSignOut_resetsToLoggedOut 7ms
โœ… UserAccountPublisherTests testAuthStateDidChangePublisher_emitsStateChanges 7ms
โœ… UserAccountPublisherTests testCredentialsDidChangePublisher_emitsOnChange 5ms
โœ… UserAccountPublisherTests testCredentialsStalePublisher_emitsWhenStale 13ms
โœ… UserAccountPublisherTests testDidSignOutPublisher_emitsOnSignOut 8ms
โœ… UserAccountPublisherTests testInit_hasCorrectDefaults 6ms
โœ… UserAccountPublisherTests testMarkCredentialsStale_fromLoggedIn_setsStaleState 7ms
โœ… UserAccountPublisherTests testMarkCredentialsStale_fromLoggedOut_doesNotChange 12ms
โœ… UserAccountPublisherTests testMarkLoggedIn_setsLoggedInState 6ms
โœ… UserAccountPublisherTests testShared_returnsSameInstance 8ms
โœ… UserAccountPublisherTests testSignOut_calledTwice_cancelsFirstResetTask 585ms
โœ… UserAccountPublisherTests testSignOut_deferredResetTask_isRetained 19ms
โœ… UserAccountPublisherTests testSignOut_deinit_cancelsPendingReset 46ms
โœ… UserAccountPublisherTests testSignOut_resetsAllState 5ms
โœ… UserAccountPublisherTests testSignOut_resetsIsSigningOutAfterDelay 306ms
โœ… UserAccountValidationTests testAcceptsASCIICharacters 91ms
โœ… UserAccountValidationTests testAcceptsEmptyReplacementString 84ms
โœ… UserAccountValidationTests testAcceptsPINAtExactlyAuthPasscodeLength 175ms
โœ… UserAccountValidationTests testAcceptsUsernameAtExactly25Characters 105ms
โœ… UserAccountValidationTests testRejectsNonASCIICharacters 83ms
โœ… UserAccountValidationTests testRejectsPINLongerThanAuthPasscodeLength 173ms
โœ… UserAccountValidationTests testRejectsUsernameLongerThan25Characters 87ms
โœ… UserAccountValidationTests testRejectsUsernameRangeOutsideTextBounds 114ms
โœ… UserAccountValidationTests testShouldBeginEditingWhenForceEditabilityIsTrue 83ms
โœ… UserAccountValidationTests testShouldBeginEditingWhenNoBusinessLogic 89ms
โœ… UserAccountValidationTests testShouldNotBeginEditingWhenBusinessLogicHasBarcodeAndPIN 188ms
โœ… UserDefaultsIsolationLintTests testLintCatchesSyntheticViolatorIfStrictModeEnabled 3ms
โœ… UserDefaultsIsolationLintTests testWarnsOnUserDefaultsStandardOutsideWhitelist 761ms
โœ… UserProfileDocumentTests testParse 3ms
โœ… UserProfileDocumentTests testParseJSONExtraProperty 26ms
โœ… UserProfileDocumentTests testParseJSONInvalid 9ms
โœ… UserProfileDocumentTests testParseJSONMissingProperty 2ms
โœ… UserProfileDocumentTests testParseJSONNilValue 6ms
โœ… UserProfileDocumentTests testParseJSONTypeMismatch 4ms
โœ… UserProfileDocumentTests testParseProfileDocCausingSIMPLY2491 9ms
โœ… UserRetryTrackerTests testCanRetry_afterFiveRetries_returnsFalse 61ms
โœ… UserRetryTrackerTests testCanRetry_afterFourRetries_returnsTrue 8ms
โœ… UserRetryTrackerTests testCanRetry_afterOneRetry_returnsTrue 2ms
โœ… UserRetryTrackerTests testCanRetry_newOperation_returnsTrue 3ms
โœ… UserRetryTrackerTests testClearRetries_onlyAffectsSpecifiedOperation 3ms
โœ… UserRetryTrackerTests testClearRetries_resetsCount 4ms
โœ… UserRetryTrackerTests testConcurrentAccess_doesNotCrash 7ms
โœ… UserRetryTrackerTests testRecordRetry_afterMax_returnsZero 13ms
โœ… UserRetryTrackerTests testRecordRetry_returnsRemainingCount 91ms
โœ… UserRetryTrackerTests testSeparateOperations_trackIndependently 3ms
โœ… XCTestCase_testUserDefaultsTests testTestUserDefaults_resetterClearsSuiteOnTestEnd 14ms
โœ… XCTestCase_testUserDefaultsTests testTestUserDefaults_returnsIsolatedSuite 18ms
โœ… XCTestCase_testUserDefaultsTests testTestUserDefaults_writesDoNotLeakToStandard 11ms
โœ… iPadOnMacRMSDKGuardTests testProcessInfoExposes_isiOSAppOnMac_OnSupportedSDKs 6ms