๐Ÿงช Palace iOS Test Report

Generated: 2026-06-12 22:05:52 UTC | Commit: 57cebfc75f79 | Branch: fix/regression-clone-tag-strip-ipad

โœ… ALL TESTS PASSED

7205 tests completed in 16m 57s

7205
Total Tests
7096
Passed
0
Failed
109
Skipped
16m 57s
Duration
45.8%
Coverage

๐Ÿ“Š Tests by Class

Class Total Passed Failed Duration
โœ… AccessLintComplianceTests 11 11 0 83ms
โœ… AccessibilityAnnouncementCenterTests 20 20 0 1.65s
โœ… AccessibilityLabelTests 9 9 0 60ms
โœ… AccessibilityPreferencesTests 26 26 0 117ms
โœ… AccessibilityServiceTests 11 11 0 120ms
โœ… AccountAuthDocCarryoverTests 5 5 0 681ms
โœ… AccountAuthSurfaceHostsTests 7 7 0 362ms
โœ… AccountAwareNetworkTests 10 10 0 260ms
โœ… AccountDetailCredentialStateTests 7 0 0 202ms
โœ… AccountDetailPINVisibilityTests 25 0 0 374ms
โœ… AccountDetailSignOutConfirmationTests 2 0 0 39ms
โœ… AccountDetailViewModelGapTests 1 1 0 246ms
โœ… AccountDetailViewModelTests 19 0 0 233ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests 10 10 0 677ms
โœ… AccountDetailsNeedsAuthAggregateTests 10 10 0 24ms
โœ… AccountDetailsURLTests 17 17 0 119ms
โœ… AccountModelGapTests 9 9 0 1.21s
โœ… AccountModelTests 20 20 0 97ms
โœ… AccountProfileDocumentTests 3 3 0 19ms
โœ… AccountStateMachineTests 10 10 0 108ms
โœ… AccountSwitchCleanupTests 8 8 0 206ms
โœ… AccountSwitchIntegrationTests 8 8 0 195ms
โœ… AccountSwitchLifecycleTests 9 0 0 91ms
โœ… AccountsManagerCacheTests 16 16 0 565ms
โœ… AccountsManagerCancellationTests 5 5 0 535ms
โœ… AccountsManagerGapTests 3 3 0 18ms
โœ… AccountsManagerHelpersTests 12 12 0 462ms
โœ… AccountsManagerIsolationLintTests 2 2 0 884ms
โœ… AccountsManagerStateMachineWiringTests 13 13 0 5.04s
โœ… AccountsManagerTests 51 51 0 10.13s
โœ… ActiveSessionsViewModelTests 12 12 0 297ms
โœ… AdobeActivationTests 6 6 0 32ms
โœ… AdobeCertificateGapTests 7 7 0 194ms
โœ… AdobeDRMCharacterizationTests 21 21 0 340ms
โœ… AdobeDRMErrorGapTests 3 3 0 14ms
โœ… AdobeDRMHandlerTests 12 12 0 179ms
โœ… AdobeDRMServiceGapTests 2 2 0 14ms
โœ… AlertModelCoverageTests 6 6 0 19ms
โœ… AlertModelRetryTests 7 7 0 16ms
โœ… AlertModelTests 2 2 0 11ms
โœ… AlertUtilsTests 20 20 0 732ms
โœ… AnnotationContractTests 3 3 0 41ms
โœ… AnnotationDeviceIDTests 2 2 0 18ms
โœ… AnnotationPostResponseContractTests 1 1 0 6ms
โœ… AnnouncementChainTests 5 5 0 11ms
โœ… AnnouncementTests 3 3 0 23ms
โœ… AnonymousBorrowBaselineFixtureTests 13 13 0 107ms
โœ… AnonymousBorrowCandidateFixtureTests 6 6 0 56ms
โœ… AnonymousBorrowDeltaTests 2 2 0 27ms
โœ… AppContainerAudiobookFactoryTests 3 3 0 11ms
โœ… AppContainerAuthCoordinatorRegistrationTests 3 3 0 12ms
โœ… AppContainerImageLoaderInjectionTests 4 4 0 179ms
โœ… AppContainerIsolationLintTests 5 5 0 1.76s
โœ… AppContainerResetTests 5 5 0 275ms
โœ… AppContainerTests 4 4 0 15ms
โœ… AppContainerWithSignInModalSheetPresenterTests 2 2 0 11ms
โœ… AppHealthViewModelTests 8 8 0 1.36s
โœ… AppLaunchTrackerExtendedTests 16 16 0 2.77s
โœ… AppLaunchTrackerTests 10 10 0 318ms
โœ… AppRouteTests 5 5 0 20ms
โœ… AppTabHostMiniPlayerIntegrationTests 6 6 0 1.24s
โœ… AppTabHostViewBadgeCountTests 10 10 0 66ms
โœ… AppTabRouterCoverageTests 4 4 0 9ms
โœ… AppTabRouterGapTests 3 3 0 30ms
โœ… ArrayExtensionsTests 6 6 0 47ms
โœ… AudioBookmarkGapTests 6 6 0 16ms
โœ… AudioEngineWrapperTests 8 8 0 345ms
โœ… AudioInterruptionLogicTests 6 6 0 24ms
โœ… AudioSessionActivatorTests 8 8 0 63ms
โœ… AudiobookAccessibilityTests 7 7 0 22ms
โœ… AudiobookBackgroundAudioTests 2 2 0 53ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests 6 6 0 573ms
โœ… AudiobookBookmarkBusinessLogicTests 21 21 0 4.96s
โœ… AudiobookChapterTOCNormalizationTests 6 6 0 34ms
โœ… AudiobookCrossVendorSmokeTests 4 4 0 173ms
โœ… AudiobookDataManagerEmptyQueueTests 1 1 0 26ms
โœ… AudiobookDataManagerErrorHandlingTests 5 5 0 10.19s
โœ… AudiobookDataManagerModelsTests 20 20 0 335ms
โœ… AudiobookDataManagerNetworkSyncTests 5 5 0 5.23s
โœ… AudiobookDataManagerSaveTests 4 4 0 45ms
โœ… AudiobookDataManagerStoreRecoveryTests 5 5 0 2.04s
โœ… AudiobookFileLoggerTests 14 14 0 531ms
โœ… AudiobookFirstOpenHangTests 9 9 0 1.93s
โœ… AudiobookFullPlayerCoverContainerTests 9 9 0 157ms
โœ… AudiobookLoadFailureSAMLReauthTests 10 10 0 1.16s
โœ… AudiobookLoaderDispatchTests 7 7 0 2.15s
โœ… AudiobookLoaderFinalizeBuildTests 9 9 0 110ms
โœ… AudiobookLoaderOPDSShapeMatrixTests 6 0 0 248ms
โœ… AudiobookLoaderPredicateTests 11 11 0 319ms
โœ… AudiobookLoaderTests 2 2 0 92ms
โœ… AudiobookMiniPlayerViewTests 13 13 0 208ms
โœ… AudiobookNetworkValidationTests 3 3 0 12ms
โœ… AudiobookOpenStateRaceTests 3 3 0 551ms
โœ… AudiobookPhoneAlertContentTests 3 3 0 13ms
โœ… AudiobookPlaybackStateTests 3 3 0 47ms
โœ… AudiobookPlaybackTests 26 26 0 306ms
โœ… AudiobookPlaytimesLifecycleTests 6 6 0 924ms
โœ… AudiobookPositionAdapterContractTests 3 3 0 90ms
โœ… AudiobookPositionPolicyValidatorTests 14 14 0 270ms
โœ… AudiobookPositionRestoreTests 11 11 0 19.44s
โœ… AudiobookSAMLReauthTests 6 6 0 35ms
โœ… AudiobookSessionErrorDescriptionTests 4 4 0 10ms
โœ… AudiobookSessionErrorExtTests 4 4 0 34ms
โœ… AudiobookSessionErrorTests 2 2 0 31ms
โœ… AudiobookSessionManagerErrorMappingTests 6 6 0 30ms
โœ… AudiobookSessionManagerFlagGatePresentationTests 4 4 0 206ms
โœ… AudiobookSessionManagerPresenterMigrationTests 8 8 0 8.12s
โœ… AudiobookSessionManagerShutdownTests 8 8 0 71ms
โœ… AudiobookSessionPresenterTests 16 16 0 1.17s
โœ… AudiobookSessionStateTests 6 6 0 58ms
โœ… AudiobookSessionStateTransitionTests 18 18 0 16.67s
โœ… AudiobookSleepTimerIntegrationTests 5 5 0 901ms
โœ… AudiobookStorageLocationTests 3 3 0 113ms
โœ… AudiobookTOCTests 18 18 0 600ms
โœ… AudiobookTimeEntryTests 6 6 0 41ms
โœ… AudiobookTimeTrackerEdgeTests 8 8 0 187ms
โœ… AudiobookTimeTrackerLifecycleTests 5 5 0 1.25s
โœ… AudiobookTimeTrackerTests 9 9 0 237ms
โœ… AudiobookTrackCompletionTests 2 2 0 34ms
โœ… AudiobookTypeRoutingTests 5 5 0 23ms
โœ… AudiobookVendorAdapterTests 5 5 0 87ms
โœ… AudiobookmarkTests 4 4 0 34ms
โœ… AuthCoordinatorTelemetryTests 5 5 0 63ms
โœ… AuthDecisionEventEmissionTests 7 7 0 65ms
โœ… AuthDocumentContractTests 2 2 0 97ms
โœ… AuthDocumentVariantsContractTests 5 5 0 248ms
โœ… AuthErrorCategoryTests 12 12 0 51ms
โœ… AuthErrorProblemDocSeamTests 6 6 0 203ms
โœ… AuthFlowSecurityTests 3 0 0 58ms
โœ… AuthReducerTests 21 21 0 126ms
โœ… AuthTypeTests 7 7 0 39ms
โœ… AuthenticationTests 16 16 0 57ms
โœ… BackgroundDownloadHandlerTests 28 28 0 265ms
โœ… BackgroundListenerTests 2 2 0 57ms
โœ… BackupExclusionMigrationTests 3 3 0 22ms
โœ… BadgeDefinitionTests 33 33 0 276ms
โœ… BadgeServiceTests 16 16 0 220ms
โœ… BadgesViewModelTests 14 14 0 106ms
โœ… BasicAuthEmptyCredentialTests 4 4 0 15ms
โœ… BearerTokenAdapterTests 5 4 0 389ms
โœ… BearerTokenFulfillFlowTests 4 4 0 21ms
โœ… BearerTokenRefreshTests 4 4 0 137ms
โœ… BearerTokenResponseDetectionTests 7 7 0 29ms
โœ… BeginningPositionPolicyTests 8 8 0 72ms
โœ… BookAvailabilityFormatterTests 18 18 0 71ms
โœ… BookButtonMapperHoldReadyTests 10 10 0 487ms
โœ… BookButtonMapperTests 21 21 0 76ms
โœ… BookButtonMapperViewModelTests 18 18 0 68ms
โœ… BookButtonStateTests 8 8 0 37ms
โœ… BookButtonTypeMetaTests 4 4 0 37ms
โœ… BookButtonTypeTests 13 13 0 120ms
โœ… BookCellModelActionTests 18 18 0 2.70s
โœ… BookCellModelCacheInvalidationTests 8 8 0 272ms
โœ… BookCellModelCachePrefetchSafetyTests 9 9 0 406ms
โœ… BookCellModelCacheTests 22 22 0 19.88s
โœ… BookCellModelComputedPropertyTests 19 19 0 309ms
โœ… BookCellModelOfflineTests 9 9 0 1.01s
โœ… BookCellModelRegistryBindingTests 4 4 0 3.93s
โœ… BookCellModelStateTests 16 16 0 953ms
โœ… BookCellModelStreamingHTMLTests 2 2 0 215ms
โœ… BookCellStateComprehensiveTests 14 14 0 91ms
โœ… BookContentResetServiceTests 2 2 0 10ms
โœ… BookDetailMetadataHydrationTests 6 6 0 130ms
โœ… BookDetailViewModelTests 87 87 0 2.16s
โœ… BookFileManagerTests 8 8 0 46ms
โœ… BookListViewAccessibilityTests 9 9 0 45ms
โœ… BookPreviewTests 4 4 0 19ms
โœ… BookRegistryStoreTests 26 26 0 851ms
โœ… BookRegistrySyncReadinessTests 3 2 0 369ms
โœ… BookRegistrySyncTests 24 22 0 1.22s
โœ… BookReturnCleverReauthTests 1 1 0 50ms
โœ… BookReturnServiceAuthCoordinatorTests 3 3 0 416ms
โœ… BookReturnServiceContractTests 5 5 0 17.53s
โœ… BookReturnServiceTests 14 14 0 493ms
โœ… BookSignInRedirectHandlerTests 8 8 0 251ms
โœ… BookStateIntegrationTests 8 8 0 142ms
โœ… BookmarkBusinessLogicExtendedTests 6 6 0 484ms
โœ… BookmarkDeletionLogTests 3 3 0 350ms
โœ… BookmarkDeviceIdMatchingTests 3 3 0 347ms
โœ… BookmarkExistenceTests 4 4 0 383ms
โœ… BookmarkManagerTests 24 24 0 480ms
โœ… BookmarkSortingTests 1 1 0 122ms
โœ… BookmarkSyncTests 3 3 0 413ms
โœ… BorrowAndDownloadIntegrationTests 7 7 0 227ms
โœ… BorrowErrorMessageTests 13 13 0 49ms
โœ… BorrowErrorPresenterTests 6 6 0 542ms
โœ… BorrowOperationAuthCoordinatorTests 6 6 0 4.32s
โœ… BorrowOperationCleverReauthTests 2 2 0 359ms
โœ… BorrowOperationContractTests 6 6 0 1.30s
โœ… BorrowOperationStreamingHTMLTests 3 3 0 379ms
โœ… BorrowOperationTests 13 13 0 1.93s
โœ… BorrowOperationTimeoutTests 3 3 0 164ms
โœ… BorrowReducerContractTests 2 2 0 21ms
โœ… BorrowReducerTests 21 21 0 51ms
โœ… BundledRegistrySnapshotTests 5 5 0 691ms
โœ… ButtonStateTests 16 16 0 175ms
โœ… ButtonStyleTypeTests 2 2 0 81ms
โœ… C64ConversionTests 6 6 0 22ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests 2 2 0 38ms
โœ… CarPlayAuthHelperReadinessTests 3 3 0 348ms
โœ… CarPlayChapterListTests 3 3 0 77ms
โœ… CarPlayIntegrationTests 2 2 0 22ms
โœ… CarPlayLibraryRefreshTests 3 3 0 11ms
โœ… CarPlayNowPlayingTemplateTests 4 4 0 569ms
โœ… CarPlayOpenAppAlertTests 6 6 0 62ms
โœ… CarPlayPlaybackErrorTests 8 8 0 59ms
โœ… CarPlayTests 12 12 0 141ms
โœ… CarPlayTimeTrackingTests 3 3 0 68ms
โœ… CatalogAPIDedupeTests 3 3 0 446ms
โœ… CatalogAPIEntryPointTests 1 1 0 7ms
โœ… CatalogAccessibilityTests 8 8 0 51ms
โœ… CatalogCacheKeyAndIsolationTests 12 12 0 463ms
โœ… CatalogCacheMetadataExactBoundaryTests 4 4 0 277ms
โœ… CatalogCacheMetadataTests 21 21 0 106ms
โœ… CatalogFeedModelTests 4 4 0 31ms
โœ… CatalogFilterGroupModelTests 17 17 0 226ms
โœ… CatalogFilterModelTests 17 17 0 80ms
โœ… CatalogFilterServiceTests 29 29 0 281ms
โœ… CatalogFilterTests 1 1 0 3ms
โœ… CatalogLaneAssemblyTests 7 7 0 77ms
โœ… CatalogLaneModelStructTests 18 18 0 322ms
โœ… CatalogLaneModelTests 1 1 0 6ms
โœ… CatalogLaneMoreFilterStateTests 8 8 0 101ms
โœ… CatalogLaneMoreViewModelTests 43 43 0 270ms
โœ… CatalogLaneRowViewAccessibilityTests 11 11 0 254ms
โœ… CatalogLaneSortingTests 5 5 0 126ms
โœ… CatalogLoadIntegrationTests 6 6 0 134ms
โœ… CatalogOPDS2NegotiationTests 12 12 0 179ms
โœ… CatalogPreloaderTests 6 6 0 97ms
โœ… CatalogProblemDocumentTests 6 6 0 35ms
โœ… CatalogRepositoryCoreTests 9 9 0 286ms
โœ… CatalogRepositoryStaleWhileRevalidateTests 12 12 0 884ms
โœ… CatalogRepositoryTests 19 19 0 299ms
โœ… CatalogSearchViewModelRegistryUpdateTests 5 5 0 367ms
โœ… CatalogSearchViewModelTests 67 67 0 7.83s
โœ… CatalogSelectorsTests 2 2 0 5ms
โœ… CatalogSortServiceTests 14 14 0 154ms
โœ… CatalogStateTests 7 7 0 39ms
โœ… CatalogViewContinueRowsIntegrationTests 3 3 0 60ms
โœ… CatalogViewModelStateMachineTests 10 10 0 173ms
โœ… ChaosFaultInjectionTests 5 5 0 457ms
โœ… ChapterChangeDetectorTests 5 5 0 16ms
โœ… ChapterTOCNormalizerTests 7 7 0 50ms
โœ… CirculationAnalyticsTests 4 4 0 47ms
โœ… ColdStartResumeIntegrationTests 10 10 0 1.75s
โœ… ColorExtensionTests 5 5 0 331ms
โœ… ConcurrentBookStateTests 3 3 0 47ms
โœ… ConcurrentDownloadStateTests 3 3 0 26ms
โœ… ConcurrentTokenRefreshTests 2 2 0 35ms
โœ… ContinueRowSectionTests 6 6 0 65ms
โœ… ContinuousPlaybackTrackingTests 3 3 0 655ms
โœ… CookiePersistenceTests 10 10 0 1.21s
โœ… CrawlStateTests 16 16 0 61ms
โœ… CrawlableFeedAnalysisTests 17 17 0 113ms
โœ… CrawlerFallbackTests 12 12 0 214ms
โœ… CredentialEdgeCaseTests 6 6 0 36ms
โœ… CredentialPrivacyTests 4 4 0 74ms
โœ… CredentialPromptCoordinatorTests 4 4 0 399ms
โœ… CrossDeviceBookmarkSyncTests 12 12 0 44ms
โœ… CrossDeviceSyncE2ETests 5 5 0 1.43s
โœ… CrossDomain401Tests 8 8 0 29ms
โœ… CrossFormatMappingTests 14 14 0 267ms
โœ… DPLAErrorTests 3 3 0 9ms
โœ… DRMAdversarialTests 4 1 0 48ms
โœ… DRMFulfilledPublicationTests 6 6 0 16ms
โœ… DataBase64Tests 3 3 0 8ms
โœ… DataReceptionComparisonTests 2 2 0 89ms
โœ… DateExtensionTests 9 9 0 367ms
โœ… DateFormattingTests 4 4 0 33ms
โœ… Date_NYPLAdditionsTests 7 7 0 1.20s
โœ… DebugSettingsTests 27 27 0 720ms
โœ… DefaultCatalogAPITests 31 31 0 357ms
โœ… DefaultRecentlyReadingServiceTests 12 12 0 47ms
โœ… DeriveInitialStateTests 4 4 0 28ms
โœ… DeveloperSettingsTierTests 4 4 0 33ms
โœ… DeviceLogCollectorGapTests 2 2 0 33.65s
โœ… DeviceLogCollectorTests 9 9 0 4m 26s
โœ… DeviceOrientationTests 7 7 0 32ms
โœ… DeviceSpecificErrorMonitorTests 11 11 0 44ms
โœ… DictionaryExtensionsTests 5 5 0 61ms
โœ… DiskBudgetManagerTests 7 7 0 23ms
โœ… DiskBudgetTests 2 2 0 31ms
โœ… DownloadAlertPresenterTests 8 8 0 267ms
โœ… DownloadAnnouncementServiceTests 12 12 0 431ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests 6 6 0 2.73s
โœ… DownloadAuthRetryHandlerTaskLifecycleTests 4 4 0 477ms
โœ… DownloadAuthRetryHandlerTests 17 17 0 2.00s
โœ… DownloadCancellationHandlerTests 5 5 0 299ms
โœ… DownloadCompletionParserTests 9 9 0 324ms
โœ… DownloadCoordinatorIntegrationTests 10 10 0 101ms
โœ… DownloadCoordinatorTests 11 11 0 98ms
โœ… DownloadDiskSpaceTests 2 2 0 5ms
โœ… DownloadErrorInfoTests 3 3 0 12ms
โœ… DownloadErrorRecoveryPolicyTests 11 11 0 116ms
โœ… DownloadErrorRecoveryTests 3 3 0 267ms
โœ… DownloadFreeSpaceExhaustionTests 11 11 0 81ms
โœ… DownloadInfoTests 5 5 0 72ms
โœ… DownloadIntegrityTests 10 10 0 91ms
โœ… DownloadOnlyOnWiFiTests 10 10 0 154ms
โœ… DownloadPersistenceStoreTests 5 5 0 61ms
โœ… DownloadProgressPublisherCoreTests 19 19 0 708ms
โœ… DownloadProgressPublisherTests 2 2 0 1.57s
โœ… DownloadQueueIntegrationTests 3 3 0 61ms
โœ… DownloadQueueOrchestratorTests 9 9 0 8.67s
โœ… DownloadRMSDKHandoffTests 1 1 0 3ms
โœ… DownloadRedirectTests 7 7 0 46ms
โœ… DownloadResumeAfterKillTests 7 7 0 87ms
โœ… DownloadSlotManagementTests 5 5 0 844ms
โœ… DownloadStartCoordinatorContractTests 5 5 0 103ms
โœ… DownloadStartCoordinatorTests 9 9 0 239ms
โœ… DownloadStartDispatcherTests 26 26 0 235ms
โœ… DownloadStateMachineIntegrationTests 15 15 0 131ms
โœ… DownloadStateMachineTests 5 5 0 75ms
โœ… DownloadStateManagerTests 16 16 0 174ms
โœ… DownloadTaskLifecycleServiceTests 9 9 0 497ms
โœ… DownloadThrottlingServiceTests 10 10 0 782ms
โœ… DownloadWatchdogTests 3 3 0 14ms
โœ… EPUBKeyCommandsPP4289Tests 4 4 0 34ms
โœ… EPUBModuleTests 4 4 0 130ms
โœ… EPUBPositionTests 10 10 0 102ms
โœ… EPUBSearchViewModelTests 18 18 0 1.28s
โœ… EPUBToolbarToggleTests 11 11 0 40ms
โœ… EmailAddressTests 16 16 0 209ms
โœ… EpubSampleFactoryTests 5 5 0 31ms
โœ… ErrorActivityTrackerTests 12 12 0 168ms
โœ… ErrorDetailTests 12 12 0 80ms
โœ… ErrorDetailViewControllerGapTests 3 3 0 504ms
โœ… ErrorDetailViewControllerTests 14 14 0 489ms
โœ… ErrorLogExporterTests 5 5 0 56ms
โœ… ExpiredLoanStringsTests 5 5 0 11ms
โœ… FacetEnumTests 3 3 0 7ms
โœ… FacetToolbarAccessibilityTests 5 5 0 12ms
โœ… FacetViewModelLogoDelegateTests 4 4 0 178ms
โœ… FacetViewModelTests 18 18 0 83ms
โœ… FetchManifestWithBearerTokenLCPSafetyTests 1 1 0 21ms
โœ… FetchManifestWithBearerTokenTests 9 9 0 159ms
โœ… FetchOpenAccessManifestLCPSafetyTests 4 4 0 22ms
โœ… FileURLGenerationTests 3 3 0 34ms
โœ… FindawayChapterStatusGuardTests 1 1 0 7ms
โœ… FloatTPPAdditionsTests 5 5 0 17ms
โœ… FocusIndicationTests 7 7 0 80ms
โœ… FontManagerTests 17 17 0 305ms
โœ… ForceResetTests 6 6 0 81ms
โœ… GeneralCacheTests 20 20 0 5.55s
โœ… GroupEnumTests 1 1 0 11ms
โœ… HTMLTextViewTests 70 70 0 27.37s
โœ… HoldNotificationClassificationTests 2 2 0 8ms
โœ… HoldsBadgeCountTests 9 9 0 1.40s
โœ… HoldsBookViewModelTests 8 8 0 43ms
โœ… HoldsReducerTests 11 11 0 107ms
โœ… HoldsSyncFailureTests 12 12 0 175ms
โœ… HoldsViewModelTests 23 23 0 1.24s
โœ… ImageCacheContinuationTests 1 1 0 374ms
โœ… ImageCacheTypeTests 1 1 0 3ms
โœ… ImageLoaderTests 11 11 0 399ms
โœ… IntExtensionsTests 4 4 0 36ms
โœ… IsReaderActiveTrackingModifierTests 4 4 0 258ms
โœ… KeyboardNavigationFKATests 11 11 0 356ms
โœ… KeyboardNavigationHandlerTests 16 16 0 225ms
โœ… KeyboardVoiceOverTests 5 5 0 27ms
โœ… LCPAcquisitionPredicateTests 4 4 0 16ms
โœ… LCPAdapterTests 8 8 0 168ms
โœ… LCPAudiobookURLSchemeTests 4 4 0 43ms
โœ… LCPAudiobooksTests 21 21 0 211ms
โœ… LCPBotanCRLGuardTests 5 5 0 20ms
โœ… LCPCharacterizationTests 31 31 0 447ms
โœ… LCPClientTests 8 8 0 105ms
โœ… LCPFulfillmentHandlerTests 8 8 0 2.12s
โœ… LCPKeychainMigrationTests 3 3 0 45ms
โœ… LCPLibraryServiceTests 20 20 0 211ms
โœ… LCPLicenseDocumentDetectionTests 5 5 0 23ms
โœ… LCPLicenseFilePathTests 3 3 0 30ms
โœ… LCPOrphanedDownloadRegistryTests 4 4 0 42ms
โœ… LCPPDFAcquisitionPredicateTests 5 5 0 28ms
โœ… LCPPDFDiskExtractTests 5 5 0 161ms
โœ… LCPPDFOpenProgressTests 13 13 0 80ms
โœ… LCPPassphraseReadinessTests 2 2 0 546ms
โœ… LCPSessionIdentifierTests 3 3 0 24ms
โœ… LegacySAMLProblemDocumentPropagationTests 7 7 0 925ms
โœ… LibrariesSectionViewModelTests 11 11 0 155ms
โœ… LibraryCatalogMergerTests 9 9 0 35ms
โœ… LibraryRegistryCrawlerTests 14 14 0 128ms
โœ… LicensesServiceTests 4 4 0 23ms
โœ… LiveCrawlableParsingTest 4 0 0 18ms
โœ… LocalBookContentServiceTests 7 7 0 66ms
โœ… LocalFileAdapterTests 6 5 0 67ms
โœ… LogTests 14 14 0 584ms
โœ… LoginKeyboardTests 8 8 0 41ms
โœ… MainActorHelpersTests 22 22 0 667ms
โœ… MappedCatalogBridgeTests 3 3 0 16ms
โœ… MappedCatalogModelTests 11 11 0 1.01s
โœ… MockBackendExpiredCredentialsTests 3 3 0 138ms
โœ… MockBackendIntegrationTests 4 4 0 404ms
โœ… MockBackendLoanLimitTests 2 2 0 60ms
โœ… MockBackendRouteMatchingTests 4 4 0 16ms
โœ… MockBackendServerDownTests 1 1 0 11ms
โœ… MockIsolationLintTests 5 5 0 1.99s
โœ… MultiLibraryTokenIsolationTests 14 14 0 241ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests 6 6 0 60ms
โœ… MyBooksDownloadCenterAdeptGapTests 3 3 0 36ms
โœ… MyBooksDownloadCenterConcurrencyTests 21 21 0 414ms
โœ… MyBooksDownloadCenterEvictionTests 7 7 0 263ms
โœ… MyBooksDownloadCenterOfflineTests 8 8 0 568ms
โœ… MyBooksDownloadSessionInvalidationTests 3 3 0 23ms
โœ… MyBooksSimplifiedBearerTokenTests 17 17 0 55ms
โœ… MyBooksViewModelBooksPublisherTests 3 3 0 4.48s
โœ… MyBooksViewModelConcurrencyTests 4 4 0 76ms
โœ… MyBooksViewModelDownloadStateTests 3 3 0 58ms
โœ… MyBooksViewModelEmptyArrayTests 3 3 0 38ms
โœ… MyBooksViewModelEmptyStateTests 4 4 0 33ms
โœ… MyBooksViewModelExtendedTests 15 15 0 504ms
โœ… MyBooksViewModelFacetIntegrationTests 4 4 0 22ms
โœ… MyBooksViewModelFacetPublisherTests 3 3 0 36ms
โœ… MyBooksViewModelFilterSortInteractionTests 2 2 0 17ms
โœ… MyBooksViewModelFilterTests 9 9 0 182ms
โœ… MyBooksViewModelGuardConditionsTests 2 2 0 41ms
โœ… MyBooksViewModelLargeDatasetTests 2 2 0 578ms
โœ… MyBooksViewModelLoadAccountTests 2 2 0 442ms
โœ… MyBooksViewModelLoginStateTests 4 4 0 363ms
โœ… MyBooksViewModelMultipleAuthorSortingTests 3 3 0 77ms
โœ… MyBooksViewModelNotificationTests 4 4 0 366ms
โœ… MyBooksViewModelOfflineFilteringTests 3 3 0 38ms
โœ… MyBooksViewModelPublisherTests 7 7 0 93ms
โœ… MyBooksViewModelSearchEdgeCaseTests 6 6 0 94ms
โœ… MyBooksViewModelSearchQueryTests 3 3 0 33ms
โœ… MyBooksViewModelSortPersistenceTests 3 3 0 25ms
โœ… MyBooksViewModelSortingIntegrationTests 5 5 0 58ms
โœ… MyBooksViewModelSortingTests 6 6 0 43ms
โœ… MyBooksViewModelStateTransitionTests 3 3 0 396ms
โœ… MyBooksViewModelUIBindingTests 3 3 0 398ms
โœ… NSErrorAdditionsTests 7 7 0 26ms
โœ… NSNotificationTPPTests 3 3 0 12ms
โœ… NavigationCoordinatorTests 17 17 0 108ms
โœ… NavigationFreezePreventionTests 5 5 0 9ms
โœ… NetworkExecutorCredentialGuardTests 8 8 0 444ms
โœ… NetworkExecutorResponseRegressionTests 4 4 0 144ms
โœ… NetworkExecutorTaskTypeTests 3 3 0 433ms
โœ… NetworkOfflineDetectionTests 3 3 0 13ms
โœ… NetworkQueueTests 11 11 0 178ms
โœ… NetworkRequestQueueTests 2 2 0 10.12s
โœ… NetworkRetryLogicTests 7 7 0 257ms
โœ… NetworkTimeoutTests 2 2 0 421ms
โœ… NotificationEventTypeContractTests 7 7 0 36ms
โœ… NotificationPayloadContractTests 10 10 0 50ms
โœ… NotificationServiceStateMachineTests 9 9 0 2.41s
โœ… NotificationServiceTests 16 16 0 269ms
โœ… NotificationServiceTokenTests 13 13 0 71ms
โœ… NotificationSyncThrottleTests 5 5 0 66ms
โœ… NotificationTokenDataTests 4 4 0 33ms
โœ… NotificationTokenRegistrationTests 10 10 0 32ms
โœ… NowPlayingCoordinatorBackgroundTests 6 6 0 2.34s
โœ… NowPlayingCoordinatorTests 19 19 0 222ms
โœ… OAuthSAMLRedirectRegressionTests 4 4 0 632ms
โœ… OIDCAuthDocumentParsingTests 4 4 0 630ms
โœ… OIDCAuthTypeTests 5 5 0 21ms
โœ… OIDCAuthenticationPropertyTests 8 8 0 665ms
โœ… OIDCCallbackEdgeCaseTests 9 9 0 732ms
โœ… OIDCCallbackHandlingTests 5 5 0 494ms
โœ… OIDCCallbackSchemeTests 3 3 0 35ms
โœ… OIDCIsolationRegressionTests 6 6 0 2.40s
โœ… OIDCLoginRoutingTests 3 3 0 637ms
โœ… OIDCMakeRequestTests 3 3 0 388ms
โœ… OIDCNSCodingTests 1 1 0 150ms
โœ… OIDCNetworkLayer401Tests 5 5 0 655ms
โœ… OIDCReauthOnExpiredTokenTests 5 5 0 451ms
โœ… OIDCRedirectURIConstructionTests 6 6 0 698ms
โœ… OIDCRegressionTests 9 9 0 712ms
โœ… OIDCSelectedAuthenticationTests 2 2 0 442ms
โœ… OIDCSignOutRegressionTests 6 6 0 1.00s
โœ… OIDCTokenRefreshRegressionTests 6 6 0 1.38s
โœ… OIDCUpdateUserAccountTests 5 5 0 1.14s
โœ… OIDCViewModelRegressionTests 1 1 0 133ms
โœ… OIDCViewModelSignInTests 2 2 0 50ms
โœ… OPDS1BorrowEntryContractTests 4 4 0 37ms
โœ… OPDS1CatalogGroupedContractTests 3 3 0 42ms
โœ… OPDS1HoldEntriesContractTests 4 4 0 60ms
โœ… OPDS1LoansFeedContractTests 6 6 0 72ms
โœ… OPDS1ParsingTests 34 34 0 262ms
โœ… OPDS1RevokeResponseContractTests 2 2 0 28ms
โœ… OPDS2AuthenticationDocumentTests 18 18 0 143ms
โœ… OPDS2AvailabilityTests 4 4 0 29ms
โœ… OPDS2BookBridgeTests 44 44 0 164ms
โœ… OPDS2BorrowResponseContractTests 3 3 0 8ms
โœ… OPDS2CatalogWiringTests 21 21 0 340ms
โœ… OPDS2CatalogsFeedTests 3 3 0 282ms
โœ… OPDS2ContributorTests 2 2 0 6ms
โœ… OPDS2EmptyFeedContractTests 1 1 0 20ms
โœ… OPDS2FeedContractTests 4 4 0 236ms
โœ… OPDS2FeedParsingTests 11 11 0 621ms
โœ… OPDS2FeedTests 13 13 0 46ms
โœ… OPDS2FullMetadataTests 4 4 0 46ms
โœ… OPDS2FullPublicationTests 13 13 0 42ms
โœ… OPDS2IntegrationTests 18 18 0 166ms
โœ… OPDS2LinkArrayTests 5 5 0 58ms
โœ… OPDS2LinkComputedPropertyTests 20 20 0 155ms
โœ… OPDS2LinkRelTests 1 1 0 9ms
โœ… OPDS2LinkTests 2 2 0 218ms
โœ… OPDS2ParsingTests 38 38 0 703ms
โœ… OPDS2PublicationExtendedTests 53 53 0 462ms
โœ… OPDS2PublicationImageTests 6 6 0 15ms
โœ… OPDS2PublicationNarratorTests 3 3 0 24ms
โœ… OPDS2PublicationTests 2 2 0 197ms
โœ… OPDS2SamlIDPTests 6 6 0 15ms
โœ… OPDS2SearchResultsContractTests 3 3 0 25ms
โœ… OPDS2SubjectTests 2 2 0 6ms
โœ… OPDS2SupportingTypesTests 5 5 0 59ms
โœ… OPDSAcquisitionPathExpandedTests 15 15 0 619ms
โœ… OPDSFeedCacheTests 14 14 0 745ms
โœ… OPDSFeedMigrationTests 11 11 0 288ms
โœ… OPDSFeedParsingTests 2 2 0 158ms
โœ… OPDSFeedServiceStateMachineTests 3 3 0 483ms
โœ… OPDSFeedServiceTests 2 2 0 11ms
โœ… OPDSFormatTests 13 13 0 126ms
โœ… OPDSParserCoreTests 4 4 0 44ms
โœ… OPDSParserTests 4 4 0 102ms
โœ… OPDSParsingTests 57 57 0 5.79s
โœ… OfflineActionTests 29 29 0 90ms
โœ… OfflineQueueServiceExtendedTests 13 13 0 5.51s
โœ… OfflineQueueServiceTests 17 17 0 6.94s
โœ… OpenAccessAdapterTests 6 6 0 76ms
โœ… OverdriveDeferredFulfillmentTests 6 6 0 16ms
โœ… OverdriveDownloadHandlerTests 9 9 0 256ms
โœ… OverdriveFulfillmentTests 14 13 0 100ms
โœ… PDFExtensionsTests 20 20 0 163ms
โœ… PDFReaderTests 12 12 0 145ms
โœ… PP3596RegressionTests 3 3 0 90ms
โœ… Palace 2 2 0 <1ms
โœ… PalaceCheckPropertyTests 8 8 0 205ms
โœ… PalaceErrorCategoryTests 20 20 0 46ms
โœ… PalaceErrorExtendedTests 23 23 0 120ms
โœ… PalaceErrorTests 11 11 0 58ms
โœ… PalacePDFViewTests 12 12 0 581ms
โœ… PalaceTestSetupObservationTests 4 4 0 65ms
โœ… PalaceWiringTestCaseTests 4 4 0 39ms
โœ… ParserFuzzTests 4 4 0 49.79s
โœ… PatronProfileContractTests 4 4 0 24ms
โœ… PerformanceMonitorTests 14 14 0 143ms
โœ… PerformanceReportTests 14 14 0 347ms
โœ… PersistentLoggerTests 9 9 0 1.76s
โœ… PlaybackBootstrapperTests 8 8 0 7.33s
โœ… PlaybackFailureRecordTests 5 5 0 16ms
โœ… PlaybackOpenPolicyTests 7 7 0 23ms
โœ… PlaybackRateTests 16 16 0 102ms
โœ… PlaybackTrackingRegressionTests 5 5 0 114ms
โœ… PositionPersistenceLogicTests 6 6 0 15ms
โœ… PositionPersistenceTests 2 2 0 6ms
โœ… PositionSyncServiceTests 13 13 0 222ms
โœ… PositionSyncTests 5 5 0 18ms
โœ… PositionWriterContractTests 6 6 0 125ms
โœ… PostUpdateMigrationTests 5 5 0 56ms
โœ… ProblemDocumentContractTests 4 4 0 23ms
โœ… ProblemDocumentLoanExpiryTests 5 5 0 51ms
โœ… ProblemDocumentTests 12 12 0 659ms
โœ… ProblemReportEmailTests 8 8 0 38ms
โœ… ReachabilityTests 10 10 0 189ms
โœ… Reader2BookmarkContractTests 3 3 0 35ms
โœ… Reader2PositionAdapterContractTests 4 3 0 240ms
โœ… Reader2PositionResumeContractTests 3 3 0 298ms
โœ… ReaderAccessibilityTests 7 7 0 17ms
โœ… ReaderEditingActionsTests 5 5 0 20ms
โœ… ReaderErrorTests 5 5 0 33ms
โœ… ReaderNavBarVoiceOverTests 2 2 0 9ms
โœ… ReaderServiceSyncTests 3 3 0 113ms
โœ… ReaderThemeTests 24 24 0 231ms
โœ… ReadingPositionTests 22 22 0 175ms
โœ… ReadingSessionTrackerTests 13 13 0 150ms
โœ… ReadingStatsServiceTests 12 12 0 172ms
โœ… ReadingStatsStoreTests 9 9 0 176ms
โœ… RedirectHandlingIntegrationTests 4 4 0 94ms
โœ… RedirectPolicyTests 9 9 0 38ms
โœ… RemoteFeatureFlagsGapTests 4 4 0 67ms
โœ… RemoteFeatureFlagsTests 11 11 0 261ms
โœ… ResourcePropertiesLengthTests 3 3 0 10ms
โœ… RetryClassificationTests 17 17 0 39ms
โœ… ReturnFlowTests 1 1 0 6ms
โœ… RightsManagementDetectionTests 5 5 0 38ms
โœ… RightsManagementDispatcherTests 10 10 0 147ms
โœ… RuntimeQuiescenceGateTests 8 8 0 1.10s
โœ… RuntimeQuiescenceLintTests 5 5 0 1.08s
โœ… SAMLCookieSyncTests 5 5 0 30ms
โœ… SAMLLogoutCallbackDetectionTests 4 4 0 35ms
โœ… SAMLLogoutLinkParsingTests 5 5 0 166ms
โœ… SAMLLogoutURLTests 4 4 0 19ms
โœ… SAMLPlusBiblioBoardExpirationTests 8 8 0 3.10s
โœ… SEMigrationsTests 6 6 0 134ms
โœ… SafeDictionaryTests 21 21 0 90ms
โœ… SamplePlayerErrorTests 5 5 0 30ms
โœ… SampleTypeTests 8 8 0 30ms
โœ… SceneDelegateTests 1 1 0 2ms
โœ… ScopedResetTests 9 9 0 123ms
โœ… SearchAccessibilityTests 6 6 0 42ms
โœ… SearchFlowIntegrationTests 8 8 0 97ms
โœ… SettingsViewModelComputedPropertyTests 6 6 0 6.86s
โœ… SettingsViewModelEdgeCaseTests 7 7 0 144ms
โœ… SettingsViewModelGapTests 1 1 0 8ms
โœ… SettingsViewModelSyncTests 14 14 0 309ms
โœ… SettingsViewModelTests 33 33 0 902ms
โœ… SignInModalLifecycleTests 9 9 0 7.05s
โœ… SignInModalPredicateTests 3 3 0 11ms
โœ… SignInModalSAMLOIDCTests 6 6 0 88ms
โœ… SignInOAuthErrorPropagationTests 8 8 0 746ms
โœ… SignInToReadFlowIntegrationTests 5 5 0 653ms
โœ… SignInWebSheetIntegrationTests 3 3 0 3.05s
โœ… SignInWebSheetViewModelTests 31 31 0 1.15s
โœ… SignOutCacheClearingTests 3 3 0 12ms
โœ… SingletonResetRegistryTests 5 5 0 111ms
โœ… StatsViewModelTests 10 10 0 451ms
โœ… StatusAnnouncementTests 22 22 0 80ms
โœ… StopPositionSaveTests 2 2 0 51ms
โœ… StoreTests 5 5 0 112ms
โœ… StreamingReaderPresentationContractTests 1 1 0 44ms
โœ… StreamingReaderProgressStoreTests 7 7 0 129ms
โœ… StreamingReaderViewControllerScrollRestoreTests 12 12 0 720ms
โœ… StreamingReaderViewModelTests 9 9 0 42ms
โœ… StringExtensionTests 8 8 0 28ms
โœ… StringExtensionsTests 3 3 0 164ms
โœ… StringHTMLEntitiesTests 7 7 0 33ms
โœ… StringNYPLAdditionsTests 4 4 0 16ms
โœ… String_NYPLAdditionsTests 4 4 0 22ms
โœ… SupportSectionDecisionTests 5 5 0 1.24s
โœ… SyncConflictResolutionTests 3 3 0 7ms
โœ… SyncDeletionGuardTests 5 5 0 16ms
โœ… SyncDeletionRatioTests 6 6 0 44ms
โœ… SyncPermissionTests 5 5 0 266ms
โœ… TPPAccountAuthStateEnumTests 5 5 0 17ms
โœ… TPPAccountListDataSourceTests 3 3 0 133ms
โœ… TPPAdobeActivationSkipTests 6 6 0 818ms
โœ… TPPAgeCheckCompletionTests 5 5 0 389ms
โœ… TPPAgeCheckIsValidTests 5 5 0 14ms
โœ… TPPAgeCheckStateMachineTests 4 4 0 813ms
โœ… TPPAgeCheckTests 6 6 0 1.69s
โœ… TPPAgeCheckVerifyDecisionTests 5 5 0 347ms
โœ… TPPAlertUtilsTests 45 45 0 1.34s
โœ… TPPAnnotationsHermeticTests 15 15 0 178ms
โœ… TPPAnnotationsOverrideTests 4 4 0 241ms
โœ… TPPAnnotationsTests 29 29 0 6.13s
โœ… TPPAnnouncementManagerTests 3 3 0 18ms
โœ… TPPAuthDocumentContractTests 3 3 0 62ms
โœ… TPPBackgroundExecutorTests 3 3 0 19ms
โœ… TPPBadgeImageGapTests 2 2 0 17ms
โœ… TPPBaseReaderViewControllerInitialLocationTests 5 5 0 125ms
โœ… TPPBasicAuthTests 11 11 0 154ms
โœ… TPPBookAccessibilityLabelTests 8 8 0 225ms
โœ… TPPBookAuthorCoverageTests 3 3 0 15ms
โœ… TPPBookAuthorTests 6 6 0 26ms
โœ… TPPBookBearerTokenTests 9 8 0 88ms
โœ… TPPBookButtonsStateTests 7 7 0 288ms
โœ… TPPBookContentMetadataFilesHelperTests 9 9 0 40ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests 2 2 0 9ms
โœ… TPPBookContentTypeConverterTests 4 4 0 9ms
โœ… TPPBookContentTypeExtendedTests 4 4 0 15ms
โœ… TPPBookContentTypeTests 14 14 0 4.04s
โœ… TPPBookCoverRegistryTests 14 14 0 855ms
โœ… TPPBookCreationTests 7 7 0 76ms
โœ… TPPBookExtensionsTests 21 21 0 257ms
โœ… TPPBookIsDRMProtectedTests 9 9 0 73ms
โœ… TPPBookLocationCoverageTests 7 7 0 23ms
โœ… TPPBookLocationEdgeCaseTests 27 27 0 3.10s
โœ… TPPBookLocationKeyTests 3 3 0 107ms
โœ… TPPBookLocationTests 11 11 0 100ms
โœ… TPPBookModelGapTests 4 4 0 695ms
โœ… TPPBookRegistryAsyncReadinessTests 3 3 0 497ms
โœ… TPPBookRegistryAtomicWriteTests 7 7 0 1.02s
โœ… TPPBookRegistryBookRetrievalTests 7 7 0 113ms
โœ… TPPBookRegistryBookmarkTests 7 7 0 8.47s
โœ… TPPBookRegistryCorruptedDataTests 5 5 0 42ms
โœ… TPPBookRegistryDataTests 4 4 0 20ms
โœ… TPPBookRegistryDependencyTests 4 4 0 38ms
โœ… TPPBookRegistryFulfillmentIdTests 4 4 0 31ms
โœ… TPPBookRegistryLargeCorpusTests 5 5 0 1m 19s
โœ… TPPBookRegistryLoadReentrancyTests 2 2 0 511ms
โœ… TPPBookRegistryLocationTests 4 4 0 5.62s
โœ… TPPBookRegistryMigrationTests 16 16 0 8.15s
โœ… TPPBookRegistryPersistenceTests 10 10 0 1.98s
โœ… TPPBookRegistryProcessingTests 2 2 0 15ms
โœ… TPPBookRegistryPublisherTests 6 6 0 138ms
โœ… TPPBookRegistryRecordPersistenceTests 3 3 0 42ms
โœ… TPPBookRegistryRecordTests 10 10 0 73ms
โœ… TPPBookRegistryStateManagementTests 11 11 0 13.89s
โœ… TPPBookRegistryThreadSafetyTests 3 3 0 489ms
โœ… TPPBookRegistryUpdateAndRemoveTests 1 1 0 26ms
โœ… TPPBookRequiresAdobeDRMTests 6 6 0 47ms
โœ… TPPBookSerializationTests 13 13 0 164ms
โœ… TPPBookStateInitializationTests 4 4 0 15ms
โœ… TPPBookStateTests 4 4 0 30ms
โœ… TPPBookTests 93 93 0 637ms
โœ… TPPBookmarkDeletionLogTests 11 11 0 164ms
โœ… TPPBookmarkFactoryInitTests 2 2 0 64ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests 5 5 0 74ms
โœ… TPPBookmarkFactoryTests 15 15 0 99ms
โœ… TPPBookmarkR3ConversionTests 5 5 0 195ms
โœ… TPPBookmarkR3LocationTests 13 13 0 45ms
โœ… TPPBookmarkSpecTests 1 1 0 12ms
โœ… TPPCachingTests 3 3 0 19ms
โœ… TPPCapturedCredentialsTests 5 5 0 786ms
โœ… TPPConfigurationTests 22 22 0 162ms
โœ… TPPContentTypeTests 9 9 0 38ms
โœ… TPPCredentialConcurrencyTests 3 3 0 13ms
โœ… TPPCredentialIsolationE2ETests 5 0 0 455ms
โœ… TPPCredentialPersistenceTests 6 6 0 975ms
โœ… TPPCredentialSnapshotCoherenceTests 3 0 0 20ms
โœ… TPPCredentialSnapshotTests 8 8 0 20ms
โœ… TPPCredentialsCoverageTests 9 9 0 72ms
โœ… TPPCredentialsTests 26 26 0 448ms
โœ… TPPCrossLibrarySignOutTests 6 6 0 3.02s
โœ… TPPDRMFailureCredentialPreservationTests 4 4 0 1.48s
โœ… TPPErrorLoggerTests 27 27 0 487ms
โœ… TPPIdleSignOutRegressionTests 13 13 0 1.67s
โœ… TPPJWKConversionTest 1 1 0 18ms
โœ… TPPKeychainManagerTests 5 5 0 892ms
โœ… TPPLastReadPositionPosterTests 13 13 0 372ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests 5 5 0 32ms
โœ… TPPLastReadPositionSynchronizerTests 23 23 0 79ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests 5 5 0 73ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests 9 9 0 55ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests 3 3 0 22ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests 9 9 0 49ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests 10 10 0 89ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests 4 4 0 24ms
โœ… TPPLoginNoActivationTests 3 3 0 620ms
โœ… TPPMainThreadCheckerTests 4 4 0 2.56s
โœ… TPPMigrationManagerTests 15 15 0 38ms
โœ… TPPNetworkExecutorAPITests 14 14 0 192ms
โœ… TPPNetworkExecutorStubbedTests 17 17 0 351ms
โœ… TPPNetworkExecutorTests 3 3 0 12ms
โœ… TPPNetworkResponderAuthCoordinatorTests 5 5 0 27ms
โœ… TPPNetworkResponderTests 12 12 0 2.78s
โœ… TPPOPDSAcquisitionPathTests 5 5 0 36ms
โœ… TPPOPDSEntryTests 5 5 0 57ms
โœ… TPPOPDSFeedTests 3 3 0 209ms
โœ… TPPOPDSGroupSwiftTests 3 3 0 42ms
โœ… TPPOPDSLinkTests 7 7 0 37ms
โœ… TPPOpenSearchDescriptionExpandedTests 10 10 0 37ms
โœ… TPPOpenSearchDescriptionTests 1 1 0 6ms
โœ… TPPPDFDocumentMetadataTests 15 15 0 128ms
โœ… TPPPDFDocumentTests 8 8 0 25ms
โœ… TPPPDFLocationCoverageTests 7 7 0 16ms
โœ… TPPPDFLocationTests 10 10 0 1.62s
โœ… TPPPDFPageBookmarkTests 9 9 0 59ms
โœ… TPPPDFPageTests 5 5 0 27ms
โœ… TPPPDFReaderModeTests 6 6 0 16ms
โœ… TPPPerAccountIsolationTests 8 0 0 288ms
โœ… TPPPreferredAuthSelectionTests 8 8 0 1.25s
โœ… TPPProblemDocumentCacheManagerTests 12 12 0 121ms
โœ… TPPProblemDocumentTests 21 21 0 95ms
โœ… TPPReaderAppearanceTests 4 4 0 39ms
โœ… TPPReaderBookmarksBusinessLogicTests 12 12 0 1.17s
โœ… TPPReaderBookmarksReadinessTests 2 2 0 191ms
โœ… TPPReaderFontTests 4 4 0 14ms
โœ… TPPReaderPreferencesLoadTests 3 3 0 37ms
โœ… TPPReaderSettingsTests 28 28 0 176ms
โœ… TPPReaderTOCBusinessLogicTests 15 15 0 3.45s
โœ… TPPReaderTOCFlattenTests 2 2 0 1.07s
โœ… TPPReadiumBookmarkLocationMatchingTests 5 5 0 16ms
โœ… TPPReadiumBookmarkTests 21 21 0 378ms
โœ… TPPReauthenticatorMockTests 2 2 0 5ms
โœ… TPPReauthenticatorTests 4 4 0 25ms
โœ… TPPReturnPromptHelperTests 5 5 0 121ms
โœ… TPPSAMLCookieExpirationTests 7 7 0 135ms
โœ… TPPSAMLFlowTests 10 10 0 46ms
โœ… TPPSAMLReauthFlowTests 2 2 0 202ms
โœ… TPPSAMLRegressionTests 4 4 0 367ms
โœ… TPPSAMLSignInTests 26 26 0 5.18s
โœ… TPPSAMLStateIsolationTests 4 4 0 985ms
โœ… TPPSAMLStateMachineTests 6 6 0 636ms
โœ… TPPSettingsTests 6 6 0 24.23s
โœ… TPPSignInAdobeSkipTests 14 14 0 2.64s
โœ… TPPSignInAuthStateTransitionTests 3 3 0 313ms
โœ… TPPSignInBusinessLogicExtendedTests 58 58 0 8.08s
โœ… TPPSignInBusinessLogicOAuthTests 11 11 0 2.41s
โœ… TPPSignInBusinessLogicSignOutTests 11 11 0 1.96s
โœ… TPPSignInBusinessLogicStateMachineTests 9 9 0 874ms
โœ… TPPSignInBusinessLogicTests 18 18 0 1.62s
โœ… TPPSignInBusinessLogicTokenFlowTests 3 3 0 308ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests 2 2 0 435ms
โœ… TPPSignInErrorHandlingTests 2 2 0 290ms
โœ… TPPSignInProfileDocEdgeCaseTests 3 3 0 430ms
โœ… TPPSignedInStateProviderTests 3 3 0 8ms
โœ… TPPUserAccountAuthStateTests 6 6 0 33ms
โœ… TPPUserAccountGapTests 4 4 0 20ms
โœ… TPPUserAccountIsolationLintTests 3 3 0 1.43s
โœ… TPPUserAccountTestFactoryTests 7 0 0 68ms
โœ… TPPUserFriendlyErrorTests 11 11 0 35ms
โœ… TPPUserNotificationsTests 10 10 0 220ms
โœ… TPPXMLSwiftTests 16 16 0 134ms
โœ… TPPXMLTests 3 3 0 25ms
โœ… TearDownRequiredLintTests 5 5 0 2.20s
โœ… TestAppContainerFactoryTests 5 5 0 5.80s
โœ… TimeEntryTests 3 3 0 23ms
โœ… TokenRefreshAndRetryQueueTests 9 9 0 7.74s
โœ… TokenRefreshIntegrationTests 2 2 0 68ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests 8 8 0 4.53s
โœ… TokenRefreshInterceptorTests 24 24 0 7.09s
โœ… TokenRefreshOnForegroundTests 10 10 0 2.43s
โœ… TokenRefreshTests 25 25 0 96ms
โœ… TokenRequestCredentialGuardTests 13 13 0 68ms
โœ… TokenRequestTests 11 11 0 250ms
โœ… TokenResponseTests 21 21 0 334ms
โœ… TriageBotKeyAdminTests 4 4 0 27ms
โœ… TypographyPresetTests 21 21 0 558ms
โœ… TypographyServiceTests 31 31 0 1.26s
โœ… TypographySettingsViewModelTests 27 27 0 530ms
โœ… UIAlertCACommitGuardTests 8 8 0 550ms
โœ… UIColor_NYPLAdditionsTests 1 1 0 3ms
โœ… URLBackupExclusionTests 3 3 0 9ms
โœ… URLExtensionTests 16 16 0 198ms
โœ… URLExtensionsTests 6 6 0 17ms
โœ… URLRequestExtensionsCoverageTests 3 3 0 8ms
โœ… URLRequestExtensionsTests 11 11 0 43ms
โœ… URLRequestNYPLAdditionsTests 11 11 0 28ms
โœ… URLRequest_NYPLTests 1 1 0 16ms
โœ… URLResponseAuthenticationTests 10 10 0 120ms
โœ… URLResponseNYPLTests 14 14 0 50ms
โœ… URLSessionCredentialStorageTests 3 3 0 13ms
โœ… URLSessionStubbingResetTests 2 2 0 20ms
โœ… URLTypeTests 2 2 0 10ms
โœ… URLValidationTests 5 5 0 11ms
โœ… UnifiedOPDSServiceStateMachineTests 2 2 0 333ms
โœ… UserAccountPublisherAuthStateTests 5 5 0 88ms
โœ… UserAccountPublisherTests 14 14 0 328ms
โœ… UserAccountValidationTests 11 11 0 4.93s
โœ… UserDefaultsIsolationLintTests 2 2 0 915ms
โœ… UserProfileDocumentTests 7 7 0 38ms
โœ… UserRetryTrackerTests 10 10 0 248ms
โœ… XCTestCase_testUserDefaultsTests 3 3 0 48ms
โœ… iPadOnMacRMSDKGuardTests 7 7 0 31ms

๐Ÿ“ˆ Code Coverage

Target Coverage Lines
Palace.app
45.8%
40974 / 89547

๐Ÿ“‹ All Tests

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