๐Ÿงช Palace iOS Test Report

Generated: 2026-06-10 15:01:45 UTC | Commit: 5ff9921ad664 | Branch: fix/pre-push-gate-worktree-git-env

โŒ 3 TEST(S) FAILED

7126 tests completed in 17m 21s

7126
Total Tests
7023
Passed
3
Failed
100
Skipped
17m 21s
Duration
46.0%
Coverage

โŒ Failed Tests

โŒ Palace.PalaceTests

Duration: <1ms

โŒ ErrorLogExporterTests.testPP3651_collectLogsForPreview_containsPatronIDField

Duration: 2m 0s

โŒ TokenRefreshAndRetryQueueTests.First Run

Duration: 665ms

๐Ÿ“Š Tests by Class

Class Total Passed Failed Duration
โœ… AccessLintComplianceTests 11 11 0 159ms
โœ… AccessibilityAnnouncementCenterTests 20 20 0 1.71s
โœ… AccessibilityLabelTests 9 9 0 211ms
โœ… AccessibilityPreferencesTests 26 26 0 90ms
โœ… AccessibilityServiceTests 11 11 0 173ms
โœ… AccountAuthDocCarryoverTests 5 5 0 720ms
โœ… AccountAuthSurfaceHostsTests 7 7 0 26ms
โœ… AccountAwareNetworkTests 10 10 0 300ms
โœ… AccountDetailCredentialStateTests 7 0 0 115ms
โœ… AccountDetailPINVisibilityTests 25 0 0 2.00s
โœ… AccountDetailSignOutConfirmationTests 2 0 0 172ms
โœ… AccountDetailViewModelGapTests 1 1 0 109ms
โœ… AccountDetailViewModelTests 19 0 0 142ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests 10 10 0 717ms
โœ… AccountDetailsNeedsAuthAggregateTests 10 10 0 91ms
โœ… AccountDetailsURLTests 17 17 0 159ms
โœ… AccountModelGapTests 9 9 0 1.24s
โœ… AccountModelTests 20 20 0 6.01s
โœ… AccountProfileDocumentTests 3 3 0 29ms
โœ… AccountStateMachineTests 10 10 0 119ms
โœ… AccountSwitchCleanupTests 8 8 0 146ms
โœ… AccountSwitchIntegrationTests 8 8 0 144ms
โœ… AccountSwitchLifecycleTests 9 0 0 99ms
โœ… AccountsManagerCacheTests 16 16 0 463ms
โœ… AccountsManagerCancellationTests 5 5 0 582ms
โœ… AccountsManagerGapTests 3 3 0 17ms
โœ… AccountsManagerHelpersTests 12 12 0 69ms
โœ… AccountsManagerIsolationLintTests 2 2 0 1.31s
โœ… AccountsManagerStateMachineWiringTests 13 13 0 16.41s
โœ… AccountsManagerTests 51 51 0 8.16s
โœ… ActiveSessionsViewModelTests 12 12 0 295ms
โœ… AdobeActivationTests 6 6 0 44ms
โœ… AdobeCertificateGapTests 7 7 0 704ms
โœ… AdobeDRMCharacterizationTests 21 21 0 114ms
โœ… AdobeDRMErrorGapTests 3 3 0 19ms
โœ… AdobeDRMHandlerTests 12 12 0 1.09s
โœ… AdobeDRMServiceGapTests 2 2 0 5ms
โœ… AlertModelCoverageTests 6 6 0 30ms
โœ… AlertModelRetryTests 7 7 0 16ms
โœ… AlertModelTests 2 2 0 7ms
โœ… AlertUtilsTests 20 20 0 813ms
โœ… AnnotationContractTests 3 3 0 51ms
โœ… AnnotationDeviceIDTests 2 2 0 5ms
โœ… AnnotationPostResponseContractTests 1 1 0 4ms
โœ… AnnouncementChainTests 5 5 0 41ms
โœ… AnnouncementTests 3 3 0 13ms
โœ… AnonymousBorrowBaselineFixtureTests 13 13 0 71ms
โœ… AnonymousBorrowCandidateFixtureTests 6 6 0 44ms
โœ… AnonymousBorrowDeltaTests 2 2 0 19ms
โœ… AppContainerAudiobookFactoryTests 3 3 0 15ms
โœ… AppContainerAuthCoordinatorRegistrationTests 3 3 0 16ms
โœ… AppContainerImageLoaderInjectionTests 4 4 0 115ms
โœ… AppContainerIsolationLintTests 5 5 0 1.49s
โœ… AppContainerResetTests 4 4 0 817ms
โœ… AppContainerTests 4 4 0 24ms
โœ… AppContainerWithSignInModalSheetPresenterTests 2 2 0 4ms
โœ… AppHealthViewModelTests 8 8 0 1.34s
โœ… AppLaunchTrackerExtendedTests 16 16 0 446ms
โœ… AppLaunchTrackerTests 10 10 0 332ms
โœ… AppRouteTests 5 5 0 61ms
โœ… AppTabHostMiniPlayerIntegrationTests 6 6 0 7.37s
โœ… AppTabHostViewBadgeCountTests 10 10 0 52ms
โœ… AppTabRouterCoverageTests 4 4 0 40ms
โœ… AppTabRouterGapTests 3 3 0 733ms
โœ… ArrayExtensionsTests 6 6 0 163ms
โœ… AudioBookmarkGapTests 6 6 0 22ms
โœ… AudioEngineWrapperTests 8 8 0 48ms
โœ… AudioInterruptionLogicTests 6 6 0 33ms
โœ… AudiobookAccessibilityTests 7 7 0 33ms
โœ… AudiobookBackgroundAudioTests 2 2 0 45ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests 6 6 0 1.06s
โœ… AudiobookBookmarkBusinessLogicTests 21 21 0 3.93s
โœ… AudiobookChapterTOCNormalizationTests 6 6 0 24ms
โœ… AudiobookCrossVendorSmokeTests 4 4 0 156ms
โœ… AudiobookDataManagerEmptyQueueTests 1 1 0 6ms
โœ… AudiobookDataManagerErrorHandlingTests 5 5 0 10.26s
โœ… AudiobookDataManagerModelsTests 20 20 0 196ms
โœ… AudiobookDataManagerNetworkSyncTests 5 5 0 5.17s
โœ… AudiobookDataManagerSaveTests 4 4 0 46ms
โœ… AudiobookDataManagerStoreRecoveryTests 5 5 0 2.08s
โœ… AudiobookFileLoggerTests 14 14 0 560ms
โœ… AudiobookFirstOpenHangTests 5 5 0 6.76s
โœ… AudiobookFullPlayerCoverContainerTests 9 9 0 128ms
โœ… AudiobookLoadFailureSAMLReauthTests 10 10 0 1.04s
โœ… AudiobookLoaderDispatchTests 7 7 0 107ms
โœ… AudiobookLoaderFinalizeBuildTests 9 9 0 667ms
โœ… AudiobookLoaderOPDSShapeMatrixTests 5 5 0 146ms
โœ… AudiobookLoaderPredicateTests 11 11 0 307ms
โœ… AudiobookLoaderTests 2 2 0 114ms
โœ… AudiobookMiniPlayerViewTests 13 13 0 130ms
โœ… AudiobookNetworkValidationTests 3 3 0 15ms
โœ… AudiobookOpenStateRaceTests 3 3 0 3.52s
โœ… AudiobookPhoneAlertContentTests 3 3 0 46ms
โœ… AudiobookPlaybackStateTests 3 3 0 69ms
โœ… AudiobookPlaybackTests 26 26 0 481ms
โœ… AudiobookPlaytimesLifecycleTests 6 6 0 1.05s
โœ… AudiobookPositionAdapterContractTests 3 3 0 103ms
โœ… AudiobookPositionPolicyValidatorTests 14 14 0 77ms
โœ… AudiobookSAMLReauthTests 6 6 0 86ms
โœ… AudiobookSessionErrorDescriptionTests 4 4 0 9ms
โœ… AudiobookSessionErrorExtTests 4 4 0 35ms
โœ… AudiobookSessionErrorTests 2 2 0 46ms
โœ… AudiobookSessionManagerErrorMappingTests 6 6 0 21ms
โœ… AudiobookSessionManagerFlagGatePresentationTests 4 4 0 49ms
โœ… AudiobookSessionManagerPresenterMigrationTests 8 8 0 9.42s
โœ… AudiobookSessionManagerShutdownTests 8 8 0 88ms
โœ… AudiobookSessionPresenterTests 16 16 0 832ms
โœ… AudiobookSessionStateTests 6 6 0 30ms
โœ… AudiobookSessionStateTransitionTests 18 18 0 323ms
โœ… AudiobookSleepTimerIntegrationTests 5 5 0 323ms
โœ… AudiobookStorageLocationTests 3 3 0 17ms
โœ… AudiobookTOCTests 18 18 0 347ms
โœ… AudiobookTimeEntryTests 6 6 0 38ms
โœ… AudiobookTimeTrackerEdgeTests 8 8 0 140ms
โœ… AudiobookTimeTrackerLifecycleTests 5 5 0 1.15s
โœ… AudiobookTimeTrackerTests 9 9 0 135ms
โœ… AudiobookTrackCompletionTests 2 2 0 37ms
โœ… AudiobookTypeRoutingTests 5 5 0 38ms
โœ… AudiobookVendorAdapterTests 5 5 0 38ms
โœ… AudiobookmarkTests 4 4 0 42ms
โœ… AuthCoordinatorTelemetryTests 5 5 0 264ms
โœ… AuthDecisionEventEmissionTests 7 7 0 31ms
โœ… AuthDocumentContractTests 2 2 0 25ms
โœ… AuthDocumentVariantsContractTests 5 5 0 37ms
โœ… AuthErrorCategoryTests 12 12 0 79ms
โœ… AuthErrorProblemDocSeamTests 6 6 0 51ms
โœ… AuthFlowSecurityTests 3 0 0 44ms
โœ… AuthReducerTests 21 21 0 994ms
โœ… AuthTypeTests 7 7 0 26ms
โœ… AuthenticationTests 16 16 0 374ms
โœ… BackgroundDownloadHandlerTests 28 28 0 137ms
โœ… BackgroundListenerTests 2 2 0 76ms
โœ… BackupExclusionMigrationTests 3 3 0 89ms
โœ… BadgeDefinitionTests 33 33 0 231ms
โœ… BadgeServiceTests 16 16 0 176ms
โœ… BadgesViewModelTests 14 14 0 466ms
โœ… BasicAuthEmptyCredentialTests 4 4 0 17ms
โœ… BearerTokenAdapterTests 5 4 0 77ms
โœ… BearerTokenFulfillFlowTests 4 4 0 82ms
โœ… BearerTokenRefreshTests 4 4 0 18ms
โœ… BearerTokenResponseDetectionTests 7 7 0 19ms
โœ… BeginningPositionPolicyTests 8 8 0 22ms
โœ… BookAvailabilityFormatterTests 18 18 0 366ms
โœ… BookButtonMapperHoldReadyTests 10 10 0 170ms
โœ… BookButtonMapperTests 21 21 0 86ms
โœ… BookButtonMapperViewModelTests 18 18 0 96ms
โœ… BookButtonStateTests 8 8 0 260ms
โœ… BookButtonTypeMetaTests 4 4 0 25ms
โœ… BookButtonTypeTests 13 13 0 149ms
โœ… BookCellModelActionTests 18 18 0 816ms
โœ… BookCellModelCacheInvalidationTests 8 8 0 112ms
โœ… BookCellModelCachePrefetchSafetyTests 9 9 0 307ms
โœ… BookCellModelCacheTests 22 22 0 791ms
โœ… BookCellModelComputedPropertyTests 19 19 0 497ms
โœ… BookCellModelOfflineTests 9 9 0 545ms
โœ… BookCellModelRegistryBindingTests 4 4 0 323ms
โœ… BookCellModelStateTests 16 16 0 726ms
โœ… BookCellModelStreamingHTMLTests 2 2 0 49ms
โœ… BookCellStateComprehensiveTests 14 14 0 63ms
โœ… BookContentResetServiceTests 2 2 0 14ms
โœ… BookDetailMetadataHydrationTests 6 6 0 110ms
โœ… BookDetailViewModelTests 87 87 0 1.87s
โœ… BookFileManagerTests 8 8 0 51ms
โœ… BookListViewAccessibilityTests 9 9 0 777ms
โœ… BookPreviewTests 4 4 0 14ms
โœ… BookRegistryStoreTests 26 26 0 1.10s
โœ… BookRegistrySyncReadinessTests 3 2 0 427ms
โœ… BookRegistrySyncTests 23 23 0 25.02s
โœ… BookReturnCleverReauthTests 1 1 0 51ms
โœ… BookReturnServiceAuthCoordinatorTests 3 3 0 415ms
โœ… BookReturnServiceContractTests 5 5 0 277ms
โœ… BookReturnServiceTests 12 12 0 16.77s
โœ… BookSignInRedirectHandlerTests 8 8 0 2.13s
โœ… BookStateIntegrationTests 8 8 0 71ms
โœ… BookmarkBusinessLogicExtendedTests 6 6 0 727ms
โœ… BookmarkDeletionLogTests 3 3 0 1.70s
โœ… BookmarkDeviceIdMatchingTests 3 3 0 301ms
โœ… BookmarkExistenceTests 4 4 0 498ms
โœ… BookmarkManagerTests 24 24 0 347ms
โœ… BookmarkSortingTests 1 1 0 106ms
โœ… BookmarkSyncTests 3 3 0 369ms
โœ… BorrowAndDownloadIntegrationTests 7 7 0 338ms
โœ… BorrowErrorMessageTests 13 13 0 84ms
โœ… BorrowErrorPresenterTests 6 6 0 565ms
โœ… BorrowOperationAuthCoordinatorTests 6 6 0 5.39s
โœ… BorrowOperationCleverReauthTests 2 2 0 382ms
โœ… BorrowOperationContractTests 6 6 0 586ms
โœ… BorrowOperationStreamingHTMLTests 3 3 0 390ms
โœ… BorrowOperationTests 12 12 0 1.62s
โœ… BorrowOperationTimeoutTests 3 3 0 176ms
โœ… BorrowReducerContractTests 2 2 0 19ms
โœ… BorrowReducerTests 21 21 0 98ms
โœ… BundledRegistrySnapshotTests 5 5 0 714ms
โœ… ButtonStateTests 16 16 0 82ms
โœ… ButtonStyleTypeTests 2 2 0 9ms
โœ… C64ConversionTests 6 6 0 32ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests 2 2 0 69ms
โœ… CarPlayAuthHelperReadinessTests 3 3 0 451ms
โœ… CarPlayChapterListTests 3 3 0 59ms
โœ… CarPlayIntegrationTests 2 2 0 56ms
โœ… CarPlayLibraryRefreshTests 3 3 0 24ms
โœ… CarPlayNowPlayingTemplateTests 4 4 0 591ms
โœ… CarPlayOpenAppAlertTests 4 4 0 18ms
โœ… CarPlayPlaybackErrorTests 8 8 0 126ms
โœ… CarPlayTests 12 12 0 85ms
โœ… CarPlayTimeTrackingTests 3 3 0 98ms
โœ… CatalogAPIDedupeTests 3 3 0 431ms
โœ… CatalogAPIEntryPointTests 1 1 0 5ms
โœ… CatalogAccessibilityTests 8 8 0 27ms
โœ… CatalogCacheKeyAndIsolationTests 12 12 0 448ms
โœ… CatalogCacheMetadataExactBoundaryTests 4 4 0 19ms
โœ… CatalogCacheMetadataTests 21 21 0 114ms
โœ… CatalogFeedModelTests 4 4 0 20ms
โœ… CatalogFilterGroupModelTests 17 17 0 112ms
โœ… CatalogFilterModelTests 17 17 0 184ms
โœ… CatalogFilterServiceTests 29 29 0 156ms
โœ… CatalogFilterTests 1 1 0 2ms
โœ… CatalogLaneAssemblyTests 7 7 0 45ms
โœ… CatalogLaneModelStructTests 18 18 0 496ms
โœ… CatalogLaneModelTests 1 1 0 2ms
โœ… CatalogLaneMoreFilterStateTests 8 8 0 89ms
โœ… CatalogLaneMoreViewModelTests 42 42 0 42.91s
โœ… CatalogLaneRowViewAccessibilityTests 11 11 0 70ms
โœ… CatalogLaneSortingTests 4 4 0 198ms
โœ… CatalogLoadIntegrationTests 6 6 0 70ms
โœ… CatalogOPDS2NegotiationTests 12 12 0 115ms
โœ… CatalogPreloaderTests 6 6 0 55ms
โœ… CatalogProblemDocumentTests 6 6 0 33ms
โœ… CatalogRepositoryCoreTests 9 9 0 2.20s
โœ… CatalogRepositoryStaleWhileRevalidateTests 12 12 0 416ms
โœ… CatalogRepositoryTests 19 19 0 209ms
โœ… CatalogSearchViewModelRegistryUpdateTests 5 5 0 771ms
โœ… CatalogSearchViewModelTests 67 67 0 7.46s
โœ… CatalogSelectorsTests 2 2 0 15ms
โœ… CatalogSortServiceTests 14 14 0 202ms
โœ… CatalogStateTests 7 7 0 52ms
โœ… CatalogViewContinueRowsIntegrationTests 3 3 0 49ms
โœ… CatalogViewModelStateMachineTests 10 10 0 91ms
โœ… ChaosFaultInjectionTests 5 5 0 163ms
โœ… ChapterChangeDetectorTests 5 5 0 506ms
โœ… ChapterTOCNormalizerTests 7 7 0 24ms
โœ… CirculationAnalyticsTests 4 4 0 15ms
โœ… ColdStartResumeIntegrationTests 10 10 0 1.23s
โœ… ColorExtensionTests 5 5 0 21ms
โœ… ConcurrentBookStateTests 3 3 0 45ms
โœ… ConcurrentDownloadStateTests 3 3 0 59ms
โœ… ConcurrentTokenRefreshTests 2 2 0 28ms
โœ… ContinueRowSectionTests 6 6 0 43ms
โœ… ContinuousPlaybackTrackingTests 3 3 0 407ms
โœ… CookiePersistenceTests 10 10 0 1.66s
โœ… CrawlStateTests 16 16 0 149ms
โœ… CrawlableFeedAnalysisTests 17 17 0 284ms
โœ… CrawlerFallbackTests 12 12 0 2.53s
โœ… CredentialEdgeCaseTests 6 6 0 37ms
โœ… CredentialPrivacyTests 4 4 0 25ms
โœ… CredentialPromptCoordinatorTests 4 4 0 289ms
โœ… CrossDeviceBookmarkSyncTests 12 12 0 102ms
โœ… CrossDeviceSyncE2ETests 5 5 0 756ms
โœ… CrossDomain401Tests 8 8 0 49ms
โœ… CrossFormatMappingTests 14 14 0 146ms
โœ… DPLAErrorTests 3 3 0 9ms
โœ… DRMAdversarialTests 4 1 0 36ms
โœ… DRMFulfilledPublicationTests 6 6 0 22ms
โœ… DataBase64Tests 3 3 0 11ms
โœ… DataReceptionComparisonTests 2 2 0 55ms
โœ… DateExtensionTests 9 9 0 59ms
โœ… DateFormattingTests 4 4 0 21ms
โœ… Date_NYPLAdditionsTests 7 7 0 641ms
โœ… DebugSettingsTests 27 27 0 273ms
โœ… DefaultCatalogAPITests 31 31 0 205ms
โœ… DefaultRecentlyReadingServiceTests 12 12 0 58ms
โœ… DeriveInitialStateTests 4 4 0 22ms
โœ… DeveloperSettingsTierTests 4 4 0 16ms
โœ… DeviceLogCollectorGapTests 2 2 0 9.81s
โœ… DeviceLogCollectorTests 9 9 0 27.16s
โœ… DeviceOrientationTests 7 7 0 35ms
โœ… DeviceSpecificErrorMonitorTests 11 11 0 508ms
โœ… DictionaryExtensionsTests 5 5 0 43ms
โœ… DiskBudgetManagerTests 7 7 0 85ms
โœ… DiskBudgetTests 2 2 0 25ms
โœ… DownloadAlertPresenterTests 8 8 0 272ms
โœ… DownloadAnnouncementServiceTests 12 12 0 92ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests 6 6 0 4.02s
โœ… DownloadAuthRetryHandlerTaskLifecycleTests 4 4 0 389ms
โœ… DownloadAuthRetryHandlerTests 14 14 0 1.57s
โœ… DownloadCancellationHandlerTests 5 5 0 358ms
โœ… DownloadCompletionParserTests 9 9 0 627ms
โœ… DownloadCoordinatorIntegrationTests 10 10 0 288ms
โœ… DownloadCoordinatorTests 11 11 0 156ms
โœ… DownloadDiskSpaceTests 2 2 0 10ms
โœ… DownloadErrorInfoTests 3 3 0 82ms
โœ… DownloadErrorRecoveryPolicyTests 11 11 0 131ms
โœ… DownloadErrorRecoveryTests 3 3 0 17ms
โœ… DownloadFreeSpaceExhaustionTests 11 11 0 162ms
โœ… DownloadInfoTests 5 5 0 14ms
โœ… DownloadIntegrityTests 10 10 0 124ms
โœ… DownloadOnlyOnWiFiTests 10 10 0 65ms
โœ… DownloadPersistenceStoreTests 5 5 0 272ms
โœ… DownloadProgressPublisherCoreTests 19 19 0 807ms
โœ… DownloadProgressPublisherTests 2 2 0 36ms
โœ… DownloadQueueIntegrationTests 3 3 0 1.73s
โœ… DownloadQueueOrchestratorTests 9 9 0 236ms
โœ… DownloadRMSDKHandoffTests 1 1 0 6ms
โœ… DownloadRedirectTests 7 7 0 26ms
โœ… DownloadResumeAfterKillTests 7 7 0 127ms
โœ… DownloadSlotManagementTests 5 5 0 31ms
โœ… DownloadStartCoordinatorContractTests 5 5 0 227ms
โœ… DownloadStartCoordinatorTests 9 9 0 246ms
โœ… DownloadStartDispatcherTests 26 26 0 1.59s
โœ… DownloadStateMachineIntegrationTests 15 15 0 104ms
โœ… DownloadStateMachineTests 5 5 0 43ms
โœ… DownloadStateManagerTests 16 16 0 208ms
โœ… DownloadTaskLifecycleServiceTests 9 9 0 180ms
โœ… DownloadThrottlingServiceTests 10 10 0 442ms
โœ… DownloadWatchdogTests 3 3 0 18ms
โœ… EPUBKeyCommandsPP4289Tests 4 4 0 29ms
โœ… EPUBModuleTests 4 4 0 23ms
โœ… EPUBPositionTests 10 10 0 67ms
โœ… EPUBSearchViewModelTests 18 18 0 188ms
โœ… EPUBToolbarToggleTests 11 11 0 96ms
โœ… EmailAddressTests 16 16 0 113ms
โœ… EpubSampleFactoryTests 5 5 0 2.76s
โœ… ErrorActivityTrackerTests 12 12 0 362ms
โœ… ErrorDetailTests 12 12 0 135ms
โœ… ErrorDetailViewControllerGapTests 3 3 0 206ms
โœ… ErrorDetailViewControllerTests 14 14 0 544ms
โŒ ErrorLogExporterTests 5 4 1 2m 0s
โœ… ExpiredLoanStringsTests 5 5 0 16ms
โœ… FacetEnumTests 3 3 0 6ms
โœ… FacetToolbarAccessibilityTests 5 5 0 17ms
โœ… FacetViewModelLogoDelegateTests 4 4 0 4.20s
โœ… FacetViewModelTests 18 18 0 284ms
โœ… FetchManifestWithBearerTokenLCPSafetyTests 1 1 0 19ms
โœ… FetchManifestWithBearerTokenTests 9 9 0 162ms
โœ… FetchOpenAccessManifestLCPSafetyTests 4 4 0 35ms
โœ… FileURLGenerationTests 3 3 0 33ms
โœ… FindawayChapterStatusGuardTests 1 1 0 7ms
โœ… FloatTPPAdditionsTests 5 5 0 26ms
โœ… FocusIndicationTests 7 7 0 80ms
โœ… FontManagerTests 17 17 0 1.04s
โœ… ForceResetTests 6 6 0 95ms
โœ… GeneralCacheTests 20 20 0 797ms
โœ… GroupEnumTests 1 1 0 13ms
โœ… HTMLTextViewTests 70 70 0 24.81s
โœ… HoldNotificationClassificationTests 2 2 0 10ms
โœ… HoldsBadgeCountTests 9 9 0 330ms
โœ… HoldsBookViewModelTests 8 8 0 125ms
โœ… HoldsReducerTests 11 11 0 57ms
โœ… HoldsSyncFailureTests 12 12 0 199ms
โœ… HoldsViewModelTests 23 23 0 25.88s
โœ… ImageCacheContinuationTests 1 1 0 241ms
โœ… ImageCacheTypeTests 1 1 0 4ms
โœ… ImageLoaderTests 11 11 0 99ms
โœ… IntExtensionsTests 4 4 0 31ms
โœ… IsReaderActiveTrackingModifierTests 4 4 0 22ms
โœ… KeyboardNavigationFKATests 11 11 0 194ms
โœ… KeyboardNavigationHandlerTests 16 16 0 79ms
โœ… KeyboardVoiceOverTests 5 5 0 60ms
โœ… LCPAcquisitionPredicateTests 4 4 0 225ms
โœ… LCPAdapterTests 8 8 0 62ms
โœ… LCPAudiobookURLSchemeTests 4 4 0 30ms
โœ… LCPAudiobooksTests 21 21 0 181ms
โœ… LCPBotanCRLGuardTests 5 5 0 216ms
โœ… LCPCharacterizationTests 31 31 0 2.96s
โœ… LCPClientTests 8 8 0 146ms
โœ… LCPFulfillmentHandlerTests 8 8 0 817ms
โœ… LCPKeychainMigrationTests 3 3 0 258ms
โœ… LCPLibraryServiceTests 20 20 0 144ms
โœ… LCPLicenseDocumentDetectionTests 5 5 0 18ms
โœ… LCPLicenseFilePathTests 3 3 0 10ms
โœ… LCPOrphanedDownloadRegistryTests 4 4 0 46ms
โœ… LCPPDFAcquisitionPredicateTests 5 5 0 44ms
โœ… LCPPDFDiskExtractTests 5 5 0 87ms
โœ… LCPPDFOpenProgressTests 13 13 0 482ms
โœ… LCPPassphraseReadinessTests 2 2 0 21ms
โœ… LCPSessionIdentifierTests 3 3 0 201ms
โœ… LegacySAMLProblemDocumentPropagationTests 7 7 0 1.10s
โœ… LibrariesSectionViewModelTests 11 11 0 43ms
โœ… LibraryCatalogMergerTests 9 9 0 75ms
โœ… LibraryRegistryCrawlerTests 14 14 0 540ms
โœ… LicensesServiceTests 4 4 0 37ms
โœ… LiveCrawlableParsingTest 4 0 0 37ms
โœ… LocalBookContentServiceTests 7 7 0 104ms
โœ… LocalFileAdapterTests 6 5 0 53ms
โœ… LogTests 14 14 0 770ms
โœ… LoginKeyboardTests 8 8 0 45ms
โœ… MainActorHelpersTests 22 22 0 637ms
โœ… MappedCatalogBridgeTests 3 3 0 12ms
โœ… MappedCatalogModelTests 11 11 0 821ms
โœ… MockBackendExpiredCredentialsTests 3 3 0 381ms
โœ… MockBackendIntegrationTests 4 4 0 92ms
โœ… MockBackendLoanLimitTests 2 2 0 54ms
โœ… MockBackendRouteMatchingTests 4 4 0 22ms
โœ… MockBackendServerDownTests 1 1 0 167ms
โœ… MockIsolationLintTests 5 5 0 2.15s
โœ… MultiLibraryTokenIsolationTests 14 14 0 263ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests 6 6 0 156ms
โœ… MyBooksDownloadCenterAdeptGapTests 3 3 0 16ms
โœ… MyBooksDownloadCenterConcurrencyTests 21 21 0 617ms
โœ… MyBooksDownloadCenterEvictionTests 7 7 0 438ms
โœ… MyBooksDownloadCenterOfflineTests 8 8 0 793ms
โœ… MyBooksDownloadSessionInvalidationTests 3 3 0 27ms
โœ… MyBooksSimplifiedBearerTokenTests 17 17 0 133ms
โœ… MyBooksViewModelBooksPublisherTests 3 3 0 46ms
โœ… MyBooksViewModelConcurrencyTests 4 4 0 83ms
โœ… MyBooksViewModelDownloadStateTests 3 3 0 61ms
โœ… MyBooksViewModelEmptyArrayTests 3 3 0 9ms
โœ… MyBooksViewModelEmptyStateTests 4 4 0 146ms
โœ… MyBooksViewModelExtendedTests 15 15 0 174ms
โœ… MyBooksViewModelFacetIntegrationTests 4 4 0 51ms
โœ… MyBooksViewModelFacetPublisherTests 3 3 0 95ms
โœ… MyBooksViewModelFilterSortInteractionTests 2 2 0 23ms
โœ… MyBooksViewModelFilterTests 9 9 0 133ms
โœ… MyBooksViewModelGuardConditionsTests 2 2 0 33ms
โœ… MyBooksViewModelLargeDatasetTests 2 2 0 602ms
โœ… MyBooksViewModelLoadAccountTests 2 2 0 2.54s
โœ… MyBooksViewModelLoginStateTests 4 4 0 357ms
โœ… MyBooksViewModelMultipleAuthorSortingTests 3 3 0 38ms
โœ… MyBooksViewModelNotificationTests 4 4 0 356ms
โœ… MyBooksViewModelOfflineFilteringTests 3 3 0 171ms
โœ… MyBooksViewModelPublisherTests 7 7 0 69ms
โœ… MyBooksViewModelSearchEdgeCaseTests 6 6 0 70ms
โœ… MyBooksViewModelSearchQueryTests 3 3 0 4.59s
โœ… MyBooksViewModelSortPersistenceTests 3 3 0 45ms
โœ… MyBooksViewModelSortingIntegrationTests 5 5 0 79ms
โœ… MyBooksViewModelSortingTests 6 6 0 71ms
โœ… MyBooksViewModelStateTransitionTests 3 3 0 356ms
โœ… MyBooksViewModelUIBindingTests 3 3 0 3.11s
โœ… NSErrorAdditionsTests 7 7 0 35ms
โœ… NSNotificationTPPTests 3 3 0 29ms
โœ… NavigationCoordinatorTests 17 17 0 105ms
โœ… NavigationFreezePreventionTests 5 5 0 24ms
โœ… NetworkExecutorCredentialGuardTests 8 8 0 169ms
โœ… NetworkExecutorResponseRegressionTests 4 4 0 51ms
โœ… NetworkExecutorTaskTypeTests 3 3 0 58ms
โœ… NetworkOfflineDetectionTests 3 3 0 13ms
โœ… NetworkQueueTests 11 11 0 152ms
โœ… NetworkRequestQueueTests 2 2 0 10.09s
โœ… NetworkRetryLogicTests 7 7 0 62ms
โœ… NetworkTimeoutTests 2 2 0 9ms
โœ… NotificationEventTypeContractTests 7 7 0 24ms
โœ… NotificationPayloadContractTests 10 10 0 97ms
โœ… NotificationServiceStateMachineTests 9 9 0 2.17s
โœ… NotificationServiceTests 16 16 0 1.47s
โœ… NotificationServiceTokenTests 13 13 0 121ms
โœ… NotificationSyncThrottleTests 5 5 0 29ms
โœ… NotificationTokenDataTests 4 4 0 30ms
โœ… NotificationTokenRegistrationTests 10 10 0 45ms
โœ… NowPlayingCoordinatorBackgroundTests 6 6 0 483ms
โœ… NowPlayingCoordinatorTests 19 19 0 2.71s
โœ… OAuthSAMLRedirectRegressionTests 4 4 0 441ms
โœ… OIDCAuthDocumentParsingTests 4 4 0 452ms
โœ… OIDCAuthTypeTests 5 5 0 23ms
โœ… OIDCAuthenticationPropertyTests 8 8 0 817ms
โœ… OIDCCallbackEdgeCaseTests 9 9 0 1.10s
โœ… OIDCCallbackHandlingTests 5 5 0 1.25s
โœ… OIDCCallbackSchemeTests 3 3 0 75ms
โœ… OIDCIsolationRegressionTests 6 6 0 1.13s
โœ… OIDCLoginRoutingTests 3 3 0 733ms
โœ… OIDCMakeRequestTests 3 3 0 384ms
โœ… OIDCNSCodingTests 1 1 0 91ms
โœ… OIDCNetworkLayer401Tests 5 5 0 602ms
โœ… OIDCReauthOnExpiredTokenTests 5 5 0 690ms
โœ… OIDCRedirectURIConstructionTests 6 6 0 20.55s
โœ… OIDCRegressionTests 9 9 0 1.04s
โœ… OIDCSelectedAuthenticationTests 2 2 0 245ms
โœ… OIDCSignOutRegressionTests 6 6 0 653ms
โœ… OIDCTokenRefreshRegressionTests 6 6 0 1.98s
โœ… OIDCUpdateUserAccountTests 5 5 0 650ms
โœ… OIDCViewModelRegressionTests 1 1 0 110ms
โœ… OIDCViewModelSignInTests 2 2 0 52ms
โœ… OPDS1BorrowEntryContractTests 4 4 0 39ms
โœ… OPDS1CatalogGroupedContractTests 3 3 0 26ms
โœ… OPDS1HoldEntriesContractTests 4 4 0 244ms
โœ… OPDS1LoansFeedContractTests 6 6 0 104ms
โœ… OPDS1ParsingTests 34 34 0 269ms
โœ… OPDS1RevokeResponseContractTests 2 2 0 17ms
โœ… OPDS2AuthenticationDocumentTests 18 18 0 294ms
โœ… OPDS2AvailabilityTests 4 4 0 42ms
โœ… OPDS2BookBridgeTests 44 44 0 362ms
โœ… OPDS2BorrowResponseContractTests 3 3 0 13ms
โœ… OPDS2CatalogWiringTests 17 17 0 1.05s
โœ… OPDS2CatalogsFeedTests 3 3 0 330ms
โœ… OPDS2ContributorTests 2 2 0 5ms
โœ… OPDS2EmptyFeedContractTests 1 1 0 6ms
โœ… OPDS2FeedContractTests 4 4 0 61ms
โœ… OPDS2FeedParsingTests 11 11 0 683ms
โœ… OPDS2FeedTests 13 13 0 84ms
โœ… OPDS2FullMetadataTests 4 4 0 33ms
โœ… OPDS2FullPublicationTests 13 13 0 83ms
โœ… OPDS2IntegrationTests 18 18 0 283ms
โœ… OPDS2LinkArrayTests 5 5 0 19ms
โœ… OPDS2LinkComputedPropertyTests 20 20 0 80ms
โœ… OPDS2LinkRelTests 1 1 0 3ms
โœ… OPDS2LinkTests 2 2 0 186ms
โœ… OPDS2ParsingTests 38 38 0 302ms
โœ… OPDS2PublicationExtendedTests 53 53 0 198ms
โœ… OPDS2PublicationImageTests 6 6 0 15ms
โœ… OPDS2PublicationNarratorTests 3 3 0 18ms
โœ… OPDS2PublicationTests 2 2 0 202ms
โœ… OPDS2SamlIDPTests 6 6 0 16ms
โœ… OPDS2SearchResultsContractTests 3 3 0 20ms
โœ… OPDS2SubjectTests 2 2 0 7ms
โœ… OPDS2SupportingTypesTests 5 5 0 37ms
โœ… OPDSAcquisitionPathExpandedTests 15 15 0 476ms
โœ… OPDSFeedCacheTests 14 14 0 158ms
โœ… OPDSFeedMigrationTests 11 11 0 48ms
โœ… OPDSFeedParsingTests 2 2 0 244ms
โœ… OPDSFeedServiceStateMachineTests 3 3 0 646ms
โœ… OPDSFeedServiceTests 2 2 0 12ms
โœ… OPDSFormatTests 13 13 0 56ms
โœ… OPDSParserCoreTests 4 4 0 23ms
โœ… OPDSParserTests 4 4 0 16ms
โœ… OPDSParsingTests 57 57 0 8.12s
โœ… OfflineActionTests 29 29 0 10.96s
โœ… OfflineQueueServiceExtendedTests 13 13 0 5.30s
โœ… OfflineQueueServiceTests 17 17 0 7.16s
โœ… OpenAccessAdapterTests 6 6 0 82ms
โœ… OverdriveDeferredFulfillmentTests 6 6 0 29ms
โœ… OverdriveDownloadHandlerTests 9 9 0 233ms
โœ… OverdriveFulfillmentTests 5 5 0 89ms
โœ… PDFExtensionsTests 20 20 0 106ms
โœ… PDFReaderTests 12 12 0 95ms
โœ… PP3596RegressionTests 3 3 0 311ms
โŒ Palace 2 1 1 <1ms
โœ… PalaceCheckPropertyTests 8 8 0 270ms
โœ… PalaceErrorCategoryTests 20 20 0 56ms
โœ… PalaceErrorExtendedTests 23 23 0 117ms
โœ… PalaceErrorTests 11 11 0 109ms
โœ… PalacePDFViewTests 12 12 0 143ms
โœ… PalaceTestSetupObservationTests 4 4 0 45ms
โœ… PalaceWiringTestCaseTests 4 4 0 22ms
โœ… ParserFuzzTests 4 4 0 46.46s
โœ… PatronProfileContractTests 4 4 0 20ms
โœ… PerformanceMonitorTests 14 14 0 134ms
โœ… PerformanceReportTests 14 14 0 94ms
โœ… PersistentLoggerTests 9 9 0 2.45s
โœ… PlaybackBootstrapperTests 8 8 0 130ms
โœ… PlaybackFailureRecordTests 5 5 0 28ms
โœ… PlaybackOpenPolicyTests 7 7 0 31ms
โœ… PlaybackRateTests 16 16 0 2.09s
โœ… PlaybackTrackingRegressionTests 5 5 0 219ms
โœ… PositionPersistenceLogicTests 6 6 0 45ms
โœ… PositionPersistenceTests 2 2 0 13ms
โœ… PositionSyncServiceTests 13 13 0 166ms
โœ… PositionSyncTests 5 5 0 32ms
โœ… PositionWriterContractTests 6 6 0 322ms
โœ… PostUpdateMigrationTests 5 5 0 57ms
โœ… ProblemDocumentContractTests 4 4 0 35ms
โœ… ProblemDocumentLoanExpiryTests 5 5 0 12ms
โœ… ProblemDocumentTests 12 12 0 57ms
โœ… ProblemReportEmailTests 8 8 0 47ms
โœ… ReachabilityTests 10 10 0 56ms
โœ… Reader2BookmarkContractTests 3 3 0 73ms
โœ… Reader2PositionAdapterContractTests 4 3 0 269ms
โœ… Reader2PositionResumeContractTests 3 3 0 204ms
โœ… ReaderAccessibilityTests 7 7 0 18ms
โœ… ReaderEditingActionsTests 5 5 0 44ms
โœ… ReaderErrorTests 5 5 0 68ms
โœ… ReaderNavBarVoiceOverTests 2 2 0 9ms
โœ… ReaderServiceSyncTests 3 3 0 34ms
โœ… ReaderThemeTests 24 24 0 317ms
โœ… ReadingPositionTests 22 22 0 404ms
โœ… ReadingSessionTrackerTests 13 13 0 159ms
โœ… ReadingStatsServiceTests 12 12 0 85ms
โœ… ReadingStatsStoreTests 9 9 0 118ms
โœ… RedirectHandlingIntegrationTests 4 4 0 13ms
โœ… RedirectPolicyTests 9 9 0 59ms
โœ… RemoteFeatureFlagsGapTests 4 4 0 29ms
โœ… RemoteFeatureFlagsTests 9 9 0 400ms
โœ… ResourcePropertiesLengthTests 3 3 0 11ms
โœ… RetryClassificationTests 17 17 0 117ms
โœ… ReturnFlowTests 1 1 0 2ms
โœ… RightsManagementDetectionTests 5 5 0 337ms
โœ… RightsManagementDispatcherTests 10 10 0 136ms
โœ… SAMLCookieSyncTests 5 5 0 24ms
โœ… SAMLLogoutCallbackDetectionTests 4 4 0 13ms
โœ… SAMLLogoutLinkParsingTests 5 5 0 416ms
โœ… SAMLLogoutURLTests 4 4 0 16ms
โœ… SAMLPlusBiblioBoardExpirationTests 8 8 0 918ms
โœ… SEMigrationsTests 6 6 0 131ms
โœ… SafeDictionaryTests 21 21 0 134ms
โœ… SamplePlayerErrorTests 5 5 0 34ms
โœ… SampleTypeTests 8 8 0 26ms
โœ… SceneDelegateTests 1 1 0 7ms
โœ… ScopedResetTests 9 9 0 173ms
โœ… SearchAccessibilityTests 6 6 0 71ms
โœ… SearchFlowIntegrationTests 8 8 0 276ms
โœ… SettingsViewModelComputedPropertyTests 6 6 0 62ms
โœ… SettingsViewModelEdgeCaseTests 7 7 0 300ms
โœ… SettingsViewModelGapTests 1 1 0 11ms
โœ… SettingsViewModelSyncTests 14 14 0 150ms
โœ… SettingsViewModelTests 33 33 0 389ms
โœ… SignInModalLifecycleTests 9 9 0 75ms
โœ… SignInModalPredicateTests 3 3 0 9ms
โœ… SignInModalSAMLOIDCTests 6 6 0 52ms
โœ… SignInOAuthErrorPropagationTests 8 8 0 1.73s
โœ… SignInToReadFlowIntegrationTests 5 5 0 739ms
โœ… SignInWebSheetIntegrationTests 3 3 0 4.73s
โœ… SignInWebSheetViewModelTests 31 31 0 141ms
โœ… SignOutCacheClearingTests 3 3 0 27ms
โœ… SingletonResetRegistryTests 5 5 0 107ms
โœ… StatsViewModelTests 10 10 0 696ms
โœ… StatusAnnouncementTests 22 22 0 394ms
โœ… StopPositionSaveTests 2 2 0 5ms
โœ… StoreTests 5 5 0 41ms
โœ… StreamingReaderPresentationContractTests 1 1 0 22ms
โœ… StreamingReaderProgressStoreTests 7 7 0 94ms
โœ… StreamingReaderViewControllerScrollRestoreTests 12 12 0 1.09s
โœ… StreamingReaderViewModelTests 9 9 0 327ms
โœ… StringExtensionTests 8 8 0 31ms
โœ… StringExtensionsTests 3 3 0 513ms
โœ… StringHTMLEntitiesTests 7 7 0 18ms
โœ… StringNYPLAdditionsTests 4 4 0 56ms
โœ… String_NYPLAdditionsTests 4 4 0 18ms
โœ… SyncConflictResolutionTests 3 3 0 11ms
โœ… SyncDeletionGuardTests 5 5 0 11ms
โœ… SyncDeletionRatioTests 6 6 0 20ms
โœ… SyncPermissionTests 5 5 0 2.46s
โœ… TPPAccountAuthStateEnumTests 5 5 0 20ms
โœ… TPPAccountListDataSourceTests 3 3 0 12ms
โœ… TPPAdobeActivationSkipTests 6 6 0 654ms
โœ… TPPAgeCheckCompletionTests 5 5 0 675ms
โœ… TPPAgeCheckIsValidTests 5 5 0 21ms
โœ… TPPAgeCheckStateMachineTests 4 4 0 688ms
โœ… TPPAgeCheckTests 6 6 0 1.74s
โœ… TPPAgeCheckVerifyDecisionTests 5 5 0 501ms
โœ… TPPAlertUtilsTests 45 45 0 730ms
โœ… TPPAnnotationsHermeticTests 15 15 0 179ms
โœ… TPPAnnotationsOverrideTests 4 4 0 306ms
โœ… TPPAnnotationsTests 29 29 0 3.81s
โœ… TPPAnnouncementManagerTests 3 3 0 25ms
โœ… TPPAuthDocumentContractTests 3 3 0 49ms
โœ… TPPBackgroundExecutorTests 3 3 0 277ms
โœ… TPPBadgeImageGapTests 2 2 0 13ms
โœ… TPPBaseReaderViewControllerInitialLocationTests 5 5 0 38ms
โœ… TPPBasicAuthTests 11 11 0 220ms
โœ… TPPBookAccessibilityLabelTests 8 8 0 49ms
โœ… TPPBookAuthorCoverageTests 3 3 0 10ms
โœ… TPPBookAuthorTests 6 6 0 24ms
โœ… TPPBookBearerTokenTests 9 8 0 106ms
โœ… TPPBookButtonsStateTests 7 7 0 40ms
โœ… TPPBookContentMetadataFilesHelperTests 9 9 0 51ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests 2 2 0 20ms
โœ… TPPBookContentTypeConverterTests 4 4 0 28ms
โœ… TPPBookContentTypeExtendedTests 4 4 0 20ms
โœ… TPPBookContentTypeTests 14 14 0 126ms
โœ… TPPBookCoverRegistryTests 14 14 0 490ms
โœ… TPPBookCreationTests 7 7 0 172ms
โœ… TPPBookExtensionsTests 21 21 0 176ms
โœ… TPPBookIsDRMProtectedTests 9 9 0 41ms
โœ… TPPBookLocationCoverageTests 7 7 0 34ms
โœ… TPPBookLocationEdgeCaseTests 27 27 0 131ms
โœ… TPPBookLocationKeyTests 3 3 0 9ms
โœ… TPPBookLocationTests 11 11 0 179ms
โœ… TPPBookModelGapTests 4 4 0 32ms
โœ… TPPBookRegistryAsyncReadinessTests 3 3 0 465ms
โœ… TPPBookRegistryAtomicWriteTests 7 7 0 1.92s
โœ… TPPBookRegistryBookRetrievalTests 7 7 0 104ms
โœ… TPPBookRegistryBookmarkTests 7 7 0 85ms
โœ… TPPBookRegistryCorruptedDataTests 5 5 0 1.27s
โœ… TPPBookRegistryDataTests 4 4 0 20ms
โœ… TPPBookRegistryDependencyTests 4 4 0 44ms
โœ… TPPBookRegistryFulfillmentIdTests 4 4 0 7.10s
โœ… TPPBookRegistryLargeCorpusTests 5 5 0 2m 2s
โœ… TPPBookRegistryLoadReentrancyTests 2 2 0 516ms
โœ… TPPBookRegistryLocationTests 4 4 0 121ms
โœ… TPPBookRegistryMigrationTests 16 16 0 2.70s
โœ… TPPBookRegistryPersistenceTests 10 10 0 2.54s
โœ… TPPBookRegistryProcessingTests 2 2 0 10ms
โœ… TPPBookRegistryPublisherTests 6 6 0 331ms
โœ… TPPBookRegistryRecordPersistenceTests 3 3 0 107ms
โœ… TPPBookRegistryRecordTests 10 10 0 108ms
โœ… TPPBookRegistryStateManagementTests 11 11 0 142ms
โœ… TPPBookRegistryThreadSafetyTests 3 3 0 442ms
โœ… TPPBookRegistryUpdateAndRemoveTests 1 1 0 8ms
โœ… TPPBookRequiresAdobeDRMTests 6 6 0 34ms
โœ… TPPBookSerializationTests 13 13 0 484ms
โœ… TPPBookStateInitializationTests 4 4 0 17ms
โœ… TPPBookStateTests 4 4 0 186ms
โœ… TPPBookTests 93 93 0 733ms
โœ… TPPBookmarkDeletionLogTests 11 11 0 691ms
โœ… TPPBookmarkFactoryInitTests 2 2 0 11ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests 5 5 0 56ms
โœ… TPPBookmarkFactoryTests 15 15 0 156ms
โœ… TPPBookmarkR3ConversionTests 5 5 0 22ms
โœ… TPPBookmarkR3LocationTests 13 13 0 46ms
โœ… TPPBookmarkSpecTests 1 1 0 20ms
โœ… TPPCachingTests 3 3 0 8ms
โœ… TPPCapturedCredentialsTests 5 5 0 833ms
โœ… TPPConfigurationTests 22 22 0 102ms
โœ… TPPContentTypeTests 9 9 0 50ms
โœ… TPPCredentialConcurrencyTests 3 3 0 34ms
โœ… TPPCredentialIsolationE2ETests 5 0 0 221ms
โœ… TPPCredentialPersistenceTests 6 6 0 1.21s
โœ… TPPCredentialSnapshotCoherenceTests 3 0 0 67ms
โœ… TPPCredentialSnapshotTests 8 8 0 16ms
โœ… TPPCredentialsCoverageTests 9 9 0 321ms
โœ… TPPCredentialsTests 26 26 0 425ms
โœ… TPPCrossLibrarySignOutTests 6 6 0 1.02s
โœ… TPPDRMFailureCredentialPreservationTests 4 4 0 732ms
โœ… TPPErrorLoggerTests 27 27 0 352ms
โœ… TPPIdleSignOutRegressionTests 13 13 0 2.12s
โœ… TPPJWKConversionTest 1 1 0 19ms
โœ… TPPKeychainManagerTests 5 5 0 133ms
โœ… TPPLastReadPositionPosterTests 13 13 0 378ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests 5 5 0 100ms
โœ… TPPLastReadPositionSynchronizerTests 23 23 0 124ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests 5 5 0 28ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests 9 9 0 43ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests 3 3 0 21ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests 9 9 0 46ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests 10 10 0 31ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests 4 4 0 220ms
โœ… TPPLoginNoActivationTests 3 3 0 605ms
โœ… TPPMainThreadCheckerTests 4 4 0 34ms
โœ… TPPMigrationManagerTests 15 15 0 54ms
โœ… TPPNetworkExecutorAPITests 14 14 0 145ms
โœ… TPPNetworkExecutorStubbedTests 17 17 0 231ms
โœ… TPPNetworkExecutorTests 3 3 0 17ms
โœ… TPPNetworkResponderAuthCoordinatorTests 5 5 0 91ms
โœ… TPPNetworkResponderTests 12 12 0 371ms
โœ… TPPOPDSAcquisitionPathTests 5 5 0 107ms
โœ… TPPOPDSEntryTests 5 5 0 32ms
โœ… TPPOPDSFeedTests 3 3 0 331ms
โœ… TPPOPDSGroupSwiftTests 3 3 0 11ms
โœ… TPPOPDSLinkTests 7 7 0 45ms
โœ… TPPOpenSearchDescriptionExpandedTests 10 10 0 53ms
โœ… TPPOpenSearchDescriptionTests 1 1 0 2ms
โœ… TPPPDFDocumentMetadataTests 15 15 0 132ms
โœ… TPPPDFDocumentTests 8 8 0 97ms
โœ… TPPPDFLocationCoverageTests 7 7 0 17ms
โœ… TPPPDFLocationTests 10 10 0 449ms
โœ… TPPPDFPageBookmarkTests 9 9 0 1.15s
โœ… TPPPDFPageTests 5 5 0 21ms
โœ… TPPPDFReaderModeTests 6 6 0 22ms
โœ… TPPPerAccountIsolationTests 8 0 0 200ms
โœ… TPPPreferredAuthSelectionTests 8 8 0 898ms
โœ… TPPProblemDocumentCacheManagerTests 12 12 0 89ms
โœ… TPPProblemDocumentTests 21 21 0 153ms
โœ… TPPReaderAppearanceTests 4 4 0 14ms
โœ… TPPReaderBookmarksBusinessLogicTests 12 12 0 1.31s
โœ… TPPReaderBookmarksReadinessTests 2 2 0 235ms
โœ… TPPReaderFontTests 4 4 0 14ms
โœ… TPPReaderPreferencesLoadTests 3 3 0 20ms
โœ… TPPReaderSettingsTests 28 28 0 167ms
โœ… TPPReaderTOCBusinessLogicTests 15 15 0 3.13s
โœ… TPPReaderTOCFlattenTests 2 2 0 1.06s
โœ… TPPReadiumBookmarkLocationMatchingTests 5 5 0 481ms
โœ… TPPReadiumBookmarkTests 21 21 0 290ms
โœ… TPPReauthenticatorMockTests 2 2 0 4ms
โœ… TPPReauthenticatorTests 4 4 0 31ms
โœ… TPPReturnPromptHelperTests 5 5 0 50ms
โœ… TPPSAMLCookieExpirationTests 7 7 0 49ms
โœ… TPPSAMLFlowTests 10 10 0 58ms
โœ… TPPSAMLReauthFlowTests 2 2 0 284ms
โœ… TPPSAMLRegressionTests 4 4 0 439ms
โœ… TPPSAMLSignInTests 26 26 0 3.49s
โœ… TPPSAMLStateIsolationTests 4 4 0 190ms
โœ… TPPSAMLStateMachineTests 6 6 0 1.28s
โœ… TPPSettingsTests 6 6 0 2m 3s
โœ… TPPSignInAdobeSkipTests 14 14 0 1.91s
โœ… TPPSignInAuthStateTransitionTests 3 3 0 473ms
โœ… TPPSignInBusinessLogicExtendedTests 58 58 0 10.99s
โœ… TPPSignInBusinessLogicOAuthTests 11 11 0 1.69s
โœ… TPPSignInBusinessLogicSignOutTests 11 11 0 2.05s
โœ… TPPSignInBusinessLogicStateMachineTests 9 9 0 1.28s
โœ… TPPSignInBusinessLogicTests 18 18 0 1.95s
โœ… TPPSignInBusinessLogicTokenFlowTests 3 3 0 393ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests 2 2 0 301ms
โœ… TPPSignInErrorHandlingTests 2 2 0 846ms
โœ… TPPSignInProfileDocEdgeCaseTests 3 3 0 513ms
โœ… TPPSignedInStateProviderTests 3 3 0 7ms
โœ… TPPUserAccountAuthStateTests 6 6 0 25ms
โœ… TPPUserAccountGapTests 4 4 0 36ms
โœ… TPPUserAccountIsolationLintTests 3 3 0 1.41s
โœ… TPPUserAccountTestFactoryTests 7 0 0 885ms
โœ… TPPUserFriendlyErrorTests 11 11 0 56ms
โœ… TPPUserNotificationsTests 10 10 0 120ms
โœ… TPPXMLSwiftTests 16 16 0 93ms
โœ… TPPXMLTests 3 3 0 23ms
โœ… TearDownRequiredLintTests 5 5 0 2.02s
โœ… TestAppContainerFactoryTests 5 5 0 35ms
โœ… TimeEntryTests 3 3 0 11ms
โŒ TokenRefreshAndRetryQueueTests 11 10 1 8.88s
โœ… TokenRefreshIntegrationTests 2 2 0 115ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests 8 8 0 4.26s
โœ… TokenRefreshInterceptorTests 22 22 0 5.79s
โœ… TokenRefreshOnForegroundTests 10 10 0 2.93s
โœ… TokenRefreshTests 25 25 0 555ms
โœ… TokenRequestCredentialGuardTests 13 13 0 523ms
โœ… TokenRequestTests 11 11 0 92ms
โœ… TokenResponseTests 21 21 0 273ms
โœ… TypographyPresetTests 21 21 0 647ms
โœ… TypographyServiceTests 31 31 0 2.28s
โœ… TypographySettingsViewModelTests 27 27 0 617ms
โœ… UIAlertCACommitGuardTests 8 8 0 706ms
โœ… UIColor_NYPLAdditionsTests 1 1 0 7ms
โœ… URLBackupExclusionTests 3 3 0 22ms
โœ… URLExtensionTests 16 16 0 63ms
โœ… URLExtensionsTests 6 6 0 49ms
โœ… URLRequestExtensionsCoverageTests 3 3 0 9ms
โœ… URLRequestExtensionsTests 11 11 0 38ms
โœ… URLRequestNYPLAdditionsTests 11 11 0 55ms
โœ… URLRequest_NYPLTests 1 1 0 3ms
โœ… URLResponseAuthenticationTests 10 10 0 100ms
โœ… URLResponseNYPLTests 14 14 0 89ms
โœ… URLSessionCredentialStorageTests 3 3 0 36ms
โœ… URLSessionStubbingResetTests 2 2 0 32ms
โœ… URLTypeTests 2 2 0 8ms
โœ… URLValidationTests 5 5 0 30ms
โœ… UnifiedOPDSServiceStateMachineTests 2 2 0 421ms
โœ… UserAccountPublisherAuthStateTests 5 5 0 50ms
โœ… UserAccountPublisherTests 14 14 0 451ms
โœ… UserAccountValidationTests 11 11 0 1.87s
โœ… UserDefaultsIsolationLintTests 2 2 0 949ms
โœ… UserProfileDocumentTests 7 7 0 29ms
โœ… UserRetryTrackerTests 10 10 0 55ms
โœ… XCTestCase_testUserDefaultsTests 3 3 0 45ms
โœ… iPadOnMacRMSDKGuardTests 1 1 0 3ms

๐Ÿ“ˆ Code Coverage

Target Coverage Lines
Palace.app
46.0%
40911 / 88916

๐Ÿ“‹ All Tests

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