๐Ÿงช Palace iOS Test Report

Generated: 2026-06-09 04:15:50 UTC | Commit: 89206bac45f5 | Branch: fix/pp4542-f012-support-fallback

โŒ 3 TEST(S) FAILED

7131 tests completed in 7m 43s

7131
Total Tests
7028
Passed
3
Failed
100
Skipped
7m 43s
Duration
46.0%
Coverage

โŒ Failed Tests

โŒ Palace.PalaceTests

Duration: <1ms

โŒ BookReturnServiceAuthCoordinatorTests.testService_authErrorOnReturn_withoutCoordinator_fallsBackToLegacyReauthenticator

Duration: <1ms

โŒ TokenRefreshAndRetryQueueTests.First Run

Duration: 1.33s

๐Ÿ“Š Tests by Class

Class Total Passed Failed Duration
โœ… AccessLintComplianceTests 11 11 0 87ms
โœ… AccessibilityAnnouncementCenterTests 20 20 0 1.57s
โœ… AccessibilityLabelTests 9 9 0 21ms
โœ… AccessibilityPreferencesTests 26 26 0 274ms
โœ… AccessibilityServiceTests 11 11 0 59ms
โœ… AccountAuthDocCarryoverTests 5 5 0 538ms
โœ… AccountAuthSurfaceHostsTests 7 7 0 75ms
โœ… AccountAwareNetworkTests 10 10 0 534ms
โœ… AccountDetailCredentialStateTests 7 0 0 51ms
โœ… AccountDetailPINVisibilityTests 25 0 0 991ms
โœ… AccountDetailSignOutConfirmationTests 2 0 0 38ms
โœ… AccountDetailViewModelGapTests 1 1 0 70ms
โœ… AccountDetailViewModelTests 19 0 0 102ms
โœ… AccountDetailsAuthenticationIsBrowserBasedTests 10 10 0 90ms
โœ… AccountDetailsNeedsAuthAggregateTests 10 10 0 29ms
โœ… AccountDetailsURLTests 17 17 0 102ms
โœ… AccountModelGapTests 9 9 0 692ms
โœ… AccountModelTests 20 20 0 59ms
โœ… AccountProfileDocumentTests 3 3 0 12ms
โœ… AccountStateMachineTests 10 10 0 104ms
โœ… AccountSwitchCleanupTests 8 8 0 91ms
โœ… AccountSwitchIntegrationTests 8 8 0 247ms
โœ… AccountSwitchLifecycleTests 9 0 0 112ms
โœ… AccountsManagerCacheTests 16 16 0 300ms
โœ… AccountsManagerCancellationTests 5 5 0 527ms
โœ… AccountsManagerGapTests 3 3 0 7ms
โœ… AccountsManagerHelpersTests 12 12 0 81ms
โœ… AccountsManagerIsolationLintTests 2 2 0 933ms
โœ… AccountsManagerStateMachineWiringTests 13 13 0 3.87s
โœ… AccountsManagerTests 51 51 0 9.90s
โœ… ActiveSessionsViewModelTests 12 12 0 251ms
โœ… AdobeActivationTests 6 6 0 24ms
โœ… AdobeCertificateGapTests 7 7 0 14ms
โœ… AdobeDRMCharacterizationTests 21 21 0 50ms
โœ… AdobeDRMErrorGapTests 3 3 0 9ms
โœ… AdobeDRMHandlerTests 12 12 0 97ms
โœ… AdobeDRMServiceGapTests 2 2 0 169ms
โœ… AlertModelCoverageTests 6 6 0 12ms
โœ… AlertModelRetryTests 7 7 0 24ms
โœ… AlertModelTests 2 2 0 4ms
โœ… AlertUtilsTests 20 20 0 402ms
โœ… AnnotationContractTests 3 3 0 15ms
โœ… AnnotationDeviceIDTests 2 2 0 5ms
โœ… AnnotationPostResponseContractTests 1 1 0 3ms
โœ… AnnouncementChainTests 5 5 0 480ms
โœ… AnnouncementTests 3 3 0 14ms
โœ… AnonymousBorrowBaselineFixtureTests 13 13 0 45ms
โœ… AnonymousBorrowCandidateFixtureTests 6 6 0 19ms
โœ… AnonymousBorrowDeltaTests 2 2 0 21ms
โœ… AppContainerAudiobookFactoryTests 3 3 0 9ms
โœ… AppContainerAuthCoordinatorRegistrationTests 3 3 0 10ms
โœ… AppContainerImageLoaderInjectionTests 4 4 0 100ms
โœ… AppContainerIsolationLintTests 5 5 0 1.09s
โœ… AppContainerResetTests 4 4 0 40ms
โœ… AppContainerTests 4 4 0 10ms
โœ… AppContainerWithSignInModalSheetPresenterTests 2 2 0 6ms
โœ… AppHealthViewModelTests 8 8 0 1.35s
โœ… AppLaunchTrackerExtendedTests 16 16 0 397ms
โœ… AppLaunchTrackerTests 10 10 0 345ms
โœ… AppRouteTests 5 5 0 30ms
โœ… AppTabHostMiniPlayerIntegrationTests 6 6 0 564ms
โœ… AppTabHostViewBadgeCountTests 10 10 0 76ms
โœ… AppTabRouterCoverageTests 4 4 0 12ms
โœ… AppTabRouterGapTests 3 3 0 16ms
โœ… ArrayExtensionsTests 6 6 0 13ms
โœ… AudioBookmarkGapTests 6 6 0 13ms
โœ… AudioEngineWrapperTests 8 8 0 176ms
โœ… AudioInterruptionLogicTests 6 6 0 12ms
โœ… AudiobookAccessibilityTests 7 7 0 35ms
โœ… AudiobookBackgroundAudioTests 2 2 0 58ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests 6 6 0 926ms
โœ… AudiobookBookmarkBusinessLogicTests 21 21 0 4.06s
โœ… AudiobookChapterTOCNormalizationTests 6 6 0 17ms
โœ… AudiobookCrossVendorSmokeTests 4 4 0 37ms
โœ… AudiobookDataManagerEmptyQueueTests 1 1 0 6ms
โœ… AudiobookDataManagerErrorHandlingTests 5 5 0 10.20s
โœ… AudiobookDataManagerModelsTests 20 20 0 51ms
โœ… AudiobookDataManagerNetworkSyncTests 5 5 0 5.14s
โœ… AudiobookDataManagerSaveTests 4 4 0 33ms
โœ… AudiobookDataManagerStoreRecoveryTests 5 5 0 2.05s
โœ… AudiobookFileLoggerTests 14 14 0 236ms
โœ… AudiobookFirstOpenHangTests 5 5 0 834ms
โœ… AudiobookFullPlayerCoverContainerTests 9 9 0 66ms
โœ… AudiobookLoadFailureSAMLReauthTests 10 10 0 1.95s
โœ… AudiobookLoaderDispatchTests 7 7 0 86ms
โœ… AudiobookLoaderFinalizeBuildTests 9 9 0 66ms
โœ… AudiobookLoaderOPDSShapeMatrixTests 5 5 0 65ms
โœ… AudiobookLoaderPredicateTests 11 11 0 42ms
โœ… AudiobookLoaderTests 2 2 0 69ms
โœ… AudiobookMiniPlayerViewTests 13 13 0 40ms
โœ… AudiobookNetworkValidationTests 3 3 0 18ms
โœ… AudiobookOpenStateRaceTests 3 3 0 374ms
โœ… AudiobookPhoneAlertContentTests 3 3 0 9ms
โœ… AudiobookPlaybackStateTests 3 3 0 44ms
โœ… AudiobookPlaybackTests 26 26 0 333ms
โœ… AudiobookPlaytimesLifecycleTests 6 6 0 1.01s
โœ… AudiobookPositionAdapterContractTests 3 3 0 76ms
โœ… AudiobookPositionPolicyValidatorTests 14 14 0 36ms
โœ… AudiobookSAMLReauthTests 6 6 0 39ms
โœ… AudiobookSessionErrorDescriptionTests 4 4 0 13ms
โœ… AudiobookSessionErrorExtTests 4 4 0 9ms
โœ… AudiobookSessionErrorTests 2 2 0 7ms
โœ… AudiobookSessionManagerErrorMappingTests 6 6 0 11ms
โœ… AudiobookSessionManagerFlagGatePresentationTests 4 4 0 116ms
โœ… AudiobookSessionManagerPresenterMigrationTests 8 8 0 93ms
โœ… AudiobookSessionManagerShutdownTests 8 8 0 69ms
โœ… AudiobookSessionPresenterTests 16 16 0 931ms
โœ… AudiobookSessionStateTests 6 6 0 17ms
โœ… AudiobookSessionStateTransitionTests 18 18 0 139ms
โœ… AudiobookSleepTimerIntegrationTests 5 5 0 177ms
โœ… AudiobookStorageLocationTests 3 3 0 8ms
โœ… AudiobookTOCTests 18 18 0 259ms
โœ… AudiobookTimeEntryTests 6 6 0 16ms
โœ… AudiobookTimeTrackerEdgeTests 8 8 0 82ms
โœ… AudiobookTimeTrackerLifecycleTests 5 5 0 1.11s
โœ… AudiobookTimeTrackerTests 9 9 0 115ms
โœ… AudiobookTrackCompletionTests 2 2 0 27ms
โœ… AudiobookTypeRoutingTests 5 5 0 25ms
โœ… AudiobookVendorAdapterTests 5 5 0 26ms
โœ… AudiobookmarkTests 4 4 0 48ms
โœ… AuthCoordinatorTelemetryTests 5 5 0 27ms
โœ… AuthDecisionEventEmissionTests 7 7 0 22ms
โœ… AuthDocumentContractTests 2 2 0 21ms
โœ… AuthDocumentVariantsContractTests 5 5 0 606ms
โœ… AuthErrorCategoryTests 12 12 0 45ms
โœ… AuthErrorProblemDocSeamTests 6 6 0 44ms
โœ… AuthFlowSecurityTests 3 0 0 27ms
โœ… AuthReducerTests 21 21 0 64ms
โœ… AuthTypeTests 7 7 0 33ms
โœ… AuthenticationTests 16 16 0 47ms
โœ… BackgroundDownloadHandlerTests 28 28 0 161ms
โœ… BackgroundListenerTests 2 2 0 21ms
โœ… BackupExclusionMigrationTests 3 3 0 22ms
โœ… BadgeDefinitionTests 33 33 0 575ms
โœ… BadgeServiceTests 16 16 0 130ms
โœ… BadgesViewModelTests 14 14 0 141ms
โœ… BasicAuthEmptyCredentialTests 4 4 0 14ms
โœ… BearerTokenAdapterTests 5 4 0 47ms
โœ… BearerTokenFulfillFlowTests 4 4 0 80ms
โœ… BearerTokenRefreshTests 4 4 0 9ms
โœ… BearerTokenResponseDetectionTests 7 7 0 15ms
โœ… BeginningPositionPolicyTests 8 8 0 17ms
โœ… BookAvailabilityFormatterTests 18 18 0 68ms
โœ… BookButtonMapperHoldReadyTests 10 10 0 521ms
โœ… BookButtonMapperTests 21 21 0 73ms
โœ… BookButtonMapperViewModelTests 18 18 0 36ms
โœ… BookButtonStateTests 8 8 0 21ms
โœ… BookButtonTypeMetaTests 4 4 0 16ms
โœ… BookButtonTypeTests 13 13 0 45ms
โœ… BookCellModelActionTests 18 18 0 657ms
โœ… BookCellModelCacheInvalidationTests 8 8 0 69ms
โœ… BookCellModelCachePrefetchSafetyTests 9 9 0 169ms
โœ… BookCellModelCacheTests 22 22 0 510ms
โœ… BookCellModelComputedPropertyTests 19 19 0 180ms
โœ… BookCellModelOfflineTests 9 9 0 447ms
โœ… BookCellModelRegistryBindingTests 4 4 0 281ms
โœ… BookCellModelStateTests 16 16 0 243ms
โœ… BookCellModelStreamingHTMLTests 2 2 0 86ms
โœ… BookCellStateComprehensiveTests 14 14 0 27ms
โœ… BookContentResetServiceTests 2 2 0 10ms
โœ… BookDetailMetadataHydrationTests 6 6 0 85ms
โœ… BookDetailViewModelTests 87 87 0 1.33s
โœ… BookFileManagerTests 8 8 0 52ms
โœ… BookListViewAccessibilityTests 9 9 0 51ms
โœ… BookPreviewTests 4 4 0 13ms
โœ… BookRegistryStoreTests 26 26 0 775ms
โœ… BookRegistrySyncReadinessTests 3 2 0 385ms
โœ… BookRegistrySyncTests 23 23 0 204ms
โœ… BookReturnCleverReauthTests 1 1 0 41ms
โŒ BookReturnServiceAuthCoordinatorTests 3 2 1 600ms
โœ… BookReturnServiceContractTests 5 5 0 792ms
โœ… BookReturnServiceTests 12 12 0 1.39s
โœ… BookSignInRedirectHandlerTests 8 8 0 237ms
โœ… BookStateIntegrationTests 8 8 0 37ms
โœ… BookmarkBusinessLogicExtendedTests 6 6 0 472ms
โœ… BookmarkDeletionLogTests 3 3 0 256ms
โœ… BookmarkDeviceIdMatchingTests 3 3 0 258ms
โœ… BookmarkExistenceTests 4 4 0 366ms
โœ… BookmarkManagerTests 24 24 0 333ms
โœ… BookmarkSortingTests 1 1 0 194ms
โœ… BookmarkSyncTests 3 3 0 307ms
โœ… BorrowAndDownloadIntegrationTests 7 7 0 292ms
โœ… BorrowErrorMessageTests 13 13 0 30ms
โœ… BorrowErrorPresenterTests 6 6 0 560ms
โœ… BorrowOperationAuthCoordinatorTests 6 6 0 4.31s
โœ… BorrowOperationCleverReauthTests 2 2 0 575ms
โœ… BorrowOperationContractTests 6 6 0 894ms
โœ… BorrowOperationStreamingHTMLTests 3 3 0 339ms
โœ… BorrowOperationTests 12 12 0 1.60s
โœ… BorrowOperationTimeoutTests 3 3 0 111ms
โœ… BorrowReducerContractTests 2 2 0 23ms
โœ… BorrowReducerTests 21 21 0 48ms
โœ… BundledRegistrySnapshotTests 5 5 0 548ms
โœ… ButtonStateTests 16 16 0 1.06s
โœ… ButtonStyleTypeTests 2 2 0 4ms
โœ… C64ConversionTests 6 6 0 22ms
โœ… CarPlayAudiobookBridgePresenterMigrationTests 2 2 0 132ms
โœ… CarPlayAuthHelperReadinessTests 3 3 0 332ms
โœ… CarPlayChapterListTests 3 3 0 24ms
โœ… CarPlayIntegrationTests 2 2 0 136ms
โœ… CarPlayLibraryRefreshTests 3 3 0 18ms
โœ… CarPlayNowPlayingTemplateTests 4 4 0 2.08s
โœ… CarPlayOpenAppAlertTests 4 4 0 10ms
โœ… CarPlayPlaybackErrorTests 8 8 0 28ms
โœ… CarPlayTests 12 12 0 243ms
โœ… CarPlayTimeTrackingTests 3 3 0 93ms
โœ… CatalogAPIDedupeTests 3 3 0 446ms
โœ… CatalogAPIEntryPointTests 1 1 0 4ms
โœ… CatalogAccessibilityTests 8 8 0 18ms
โœ… CatalogCacheKeyAndIsolationTests 12 12 0 350ms
โœ… CatalogCacheMetadataExactBoundaryTests 4 4 0 9ms
โœ… CatalogCacheMetadataTests 21 21 0 1.87s
โœ… CatalogFeedModelTests 4 4 0 17ms
โœ… CatalogFilterGroupModelTests 17 17 0 64ms
โœ… CatalogFilterModelTests 17 17 0 65ms
โœ… CatalogFilterServiceTests 29 29 0 61ms
โœ… CatalogFilterTests 1 1 0 3ms
โœ… CatalogLaneAssemblyTests 7 7 0 18ms
โœ… CatalogLaneModelStructTests 18 18 0 275ms
โœ… CatalogLaneModelTests 1 1 0 2ms
โœ… CatalogLaneMoreFilterStateTests 8 8 0 44ms
โœ… CatalogLaneMoreViewModelTests 42 42 0 3.01s
โœ… CatalogLaneRowViewAccessibilityTests 11 11 0 48ms
โœ… CatalogLaneSortingTests 4 4 0 77ms
โœ… CatalogLoadIntegrationTests 6 6 0 57ms
โœ… CatalogOPDS2NegotiationTests 12 12 0 100ms
โœ… CatalogPreloaderTests 6 6 0 31ms
โœ… CatalogProblemDocumentTests 6 6 0 28ms
โœ… CatalogRepositoryCoreTests 9 9 0 268ms
โœ… CatalogRepositoryStaleWhileRevalidateTests 12 12 0 521ms
โœ… CatalogRepositoryTests 19 19 0 208ms
โœ… CatalogSearchViewModelRegistryUpdateTests 5 5 0 473ms
โœ… CatalogSearchViewModelTests 67 67 0 7.04s
โœ… CatalogSelectorsTests 2 2 0 4ms
โœ… CatalogSortServiceTests 14 14 0 77ms
โœ… CatalogStateTests 7 7 0 24ms
โœ… CatalogViewContinueRowsIntegrationTests 3 3 0 30ms
โœ… CatalogViewModelStateMachineTests 10 10 0 536ms
โœ… ChaosFaultInjectionTests 5 5 0 84ms
โœ… ChapterChangeDetectorTests 5 5 0 10ms
โœ… ChapterTOCNormalizerTests 7 7 0 188ms
โœ… CirculationAnalyticsTests 4 4 0 12ms
โœ… ColdStartResumeIntegrationTests 10 10 0 914ms
โœ… ColorExtensionTests 5 5 0 13ms
โœ… ConcurrentBookStateTests 3 3 0 25ms
โœ… ConcurrentDownloadStateTests 3 3 0 24ms
โœ… ConcurrentTokenRefreshTests 2 2 0 11ms
โœ… ContinueRowSectionTests 6 6 0 170ms
โœ… ContinuousPlaybackTrackingTests 3 3 0 359ms
โœ… CookiePersistenceTests 10 10 0 867ms
โœ… CrawlStateTests 16 16 0 1.00s
โœ… CrawlableFeedAnalysisTests 17 17 0 40ms
โœ… CrawlerFallbackTests 12 12 0 107ms
โœ… CredentialEdgeCaseTests 6 6 0 13ms
โœ… CredentialPrivacyTests 4 4 0 38ms
โœ… CredentialPromptCoordinatorTests 4 4 0 347ms
โœ… CrossDeviceBookmarkSyncTests 12 12 0 35ms
โœ… CrossDeviceSyncE2ETests 5 5 0 3.81s
โœ… CrossDomain401Tests 8 8 0 27ms
โœ… CrossFormatMappingTests 14 14 0 47ms
โœ… DPLAErrorTests 3 3 0 7ms
โœ… DRMAdversarialTests 4 1 0 48ms
โœ… DRMFulfilledPublicationTests 6 6 0 44ms
โœ… DataBase64Tests 3 3 0 7ms
โœ… DataReceptionComparisonTests 2 2 0 35ms
โœ… DateExtensionTests 9 9 0 20ms
โœ… DateFormattingTests 4 4 0 12ms
โœ… Date_NYPLAdditionsTests 7 7 0 463ms
โœ… DebugSettingsTests 27 27 0 150ms
โœ… DefaultCatalogAPITests 31 31 0 161ms
โœ… DefaultRecentlyReadingServiceTests 12 12 0 40ms
โœ… DeriveInitialStateTests 4 4 0 17ms
โœ… DeveloperSettingsTierTests 4 4 0 11ms
โœ… DeviceLogCollectorGapTests 2 2 0 5.19s
โœ… DeviceLogCollectorTests 9 9 0 33.82s
โœ… DeviceOrientationTests 7 7 0 53ms
โœ… DeviceSpecificErrorMonitorTests 11 11 0 34ms
โœ… DictionaryExtensionsTests 5 5 0 11ms
โœ… DiskBudgetManagerTests 7 7 0 40ms
โœ… DiskBudgetTests 2 2 0 26ms
โœ… DownloadAlertPresenterTests 8 8 0 303ms
โœ… DownloadAnnouncementServiceTests 12 12 0 53ms
โœ… DownloadAuthRetryHandlerAuthCoordinatorTests 6 6 0 2.66s
โœ… DownloadAuthRetryHandlerTaskLifecycleTests 4 4 0 375ms
โœ… DownloadAuthRetryHandlerTests 14 14 0 1.51s
โœ… DownloadCancellationHandlerTests 5 5 0 271ms
โœ… DownloadCompletionParserTests 9 9 0 148ms
โœ… DownloadCoordinatorIntegrationTests 10 10 0 371ms
โœ… DownloadCoordinatorTests 11 11 0 56ms
โœ… DownloadDiskSpaceTests 2 2 0 5ms
โœ… DownloadErrorInfoTests 3 3 0 17ms
โœ… DownloadErrorRecoveryPolicyTests 11 11 0 93ms
โœ… DownloadErrorRecoveryTests 3 3 0 14ms
โœ… DownloadFreeSpaceExhaustionTests 11 11 0 84ms
โœ… DownloadInfoTests 5 5 0 12ms
โœ… DownloadIntegrityTests 10 10 0 176ms
โœ… DownloadOnlyOnWiFiTests 10 10 0 30ms
โœ… DownloadPersistenceStoreTests 5 5 0 126ms
โœ… DownloadProgressPublisherCoreTests 19 19 0 620ms
โœ… DownloadProgressPublisherTests 2 2 0 18ms
โœ… DownloadQueueIntegrationTests 3 3 0 91ms
โœ… DownloadQueueOrchestratorTests 9 9 0 171ms
โœ… DownloadRMSDKHandoffTests 1 1 0 2ms
โœ… DownloadRedirectTests 7 7 0 13ms
โœ… DownloadResumeAfterKillTests 7 7 0 94ms
โœ… DownloadSlotManagementTests 5 5 0 22ms
โœ… DownloadStartCoordinatorContractTests 5 5 0 61ms
โœ… DownloadStartCoordinatorTests 9 9 0 148ms
โœ… DownloadStartDispatcherTests 26 26 0 209ms
โœ… DownloadStateMachineIntegrationTests 15 15 0 101ms
โœ… DownloadStateMachineTests 5 5 0 22ms
โœ… DownloadStateManagerTests 16 16 0 119ms
โœ… DownloadTaskLifecycleServiceTests 9 9 0 77ms
โœ… DownloadThrottlingServiceTests 10 10 0 341ms
โœ… DownloadWatchdogTests 3 3 0 13ms
โœ… EPUBKeyCommandsPP4289Tests 4 4 0 9ms
โœ… EPUBModuleTests 4 4 0 31ms
โœ… EPUBPositionTests 10 10 0 36ms
โœ… EPUBSearchViewModelTests 18 18 0 126ms
โœ… EPUBToolbarToggleTests 11 11 0 30ms
โœ… EmailAddressTests 16 16 0 57ms
โœ… EpubSampleFactoryTests 5 5 0 19ms
โœ… ErrorActivityTrackerTests 12 12 0 45ms
โœ… ErrorDetailTests 12 12 0 103ms
โœ… ErrorDetailViewControllerGapTests 3 3 0 149ms
โœ… ErrorDetailViewControllerTests 14 14 0 98ms
โœ… ErrorLogExporterTests 5 5 0 2.16s
โœ… ExpiredLoanStringsTests 5 5 0 98ms
โœ… FacetEnumTests 3 3 0 6ms
โœ… FacetToolbarAccessibilityTests 5 5 0 11ms
โœ… FacetViewModelLogoDelegateTests 4 4 0 84ms
โœ… FacetViewModelTests 18 18 0 103ms
โœ… FetchManifestWithBearerTokenLCPSafetyTests 1 1 0 29ms
โœ… FetchManifestWithBearerTokenTests 9 9 0 60ms
โœ… FetchOpenAccessManifestLCPSafetyTests 4 4 0 10ms
โœ… FileURLGenerationTests 3 3 0 51ms
โœ… FindawayChapterStatusGuardTests 1 1 0 3ms
โœ… FloatTPPAdditionsTests 5 5 0 22ms
โœ… FocusIndicationTests 7 7 0 29ms
โœ… FontManagerTests 17 17 0 275ms
โœ… ForceResetTests 6 6 0 43ms
โœ… GeneralCacheTests 20 20 0 2.64s
โœ… GroupEnumTests 1 1 0 7ms
โœ… HTMLTextViewTests 70 70 0 10.31s
โœ… HoldNotificationClassificationTests 2 2 0 6ms
โœ… HoldsBadgeCountTests 9 9 0 61ms
โœ… HoldsBookViewModelTests 8 8 0 43ms
โœ… HoldsReducerTests 11 11 0 65ms
โœ… HoldsSyncFailureTests 12 12 0 826ms
โœ… HoldsViewModelTests 23 23 0 1.22s
โœ… ImageCacheContinuationTests 1 1 0 207ms
โœ… ImageCacheTypeTests 1 1 0 6ms
โœ… ImageLoaderTests 11 11 0 111ms
โœ… IntExtensionsTests 4 4 0 19ms
โœ… IsReaderActiveTrackingModifierTests 4 4 0 22ms
โœ… KeyboardNavigationFKATests 11 11 0 103ms
โœ… KeyboardNavigationHandlerTests 16 16 0 111ms
โœ… KeyboardVoiceOverTests 5 5 0 43ms
โœ… LCPAcquisitionPredicateTests 4 4 0 13ms
โœ… LCPAdapterTests 8 8 0 42ms
โœ… LCPAudiobookURLSchemeTests 4 4 0 8ms
โœ… LCPAudiobooksTests 21 21 0 2.11s
โœ… LCPBotanCRLGuardTests 5 5 0 449ms
โœ… LCPCharacterizationTests 31 31 0 124ms
โœ… LCPClientTests 8 8 0 62ms
โœ… LCPFulfillmentHandlerTests 8 8 0 715ms
โœ… LCPKeychainMigrationTests 3 3 0 37ms
โœ… LCPLibraryServiceTests 20 20 0 151ms
โœ… LCPLicenseDocumentDetectionTests 5 5 0 14ms
โœ… LCPLicenseFilePathTests 3 3 0 8ms
โœ… LCPOrphanedDownloadRegistryTests 4 4 0 17ms
โœ… LCPPDFAcquisitionPredicateTests 5 5 0 12ms
โœ… LCPPDFDiskExtractTests 5 5 0 43ms
โœ… LCPPDFOpenProgressTests 13 13 0 93ms
โœ… LCPPassphraseReadinessTests 2 2 0 16ms
โœ… LCPSessionIdentifierTests 3 3 0 16ms
โœ… LegacySAMLProblemDocumentPropagationTests 7 7 0 585ms
โœ… LibrariesSectionViewModelTests 11 11 0 117ms
โœ… LibraryCatalogMergerTests 9 9 0 30ms
โœ… LibraryRegistryCrawlerTests 14 14 0 118ms
โœ… LicensesServiceTests 4 4 0 22ms
โœ… LiveCrawlableParsingTest 4 0 0 14ms
โœ… LocalBookContentServiceTests 7 7 0 37ms
โœ… LocalFileAdapterTests 6 5 0 44ms
โœ… LogTests 14 14 0 337ms
โœ… LoginKeyboardTests 8 8 0 46ms
โœ… MainActorHelpersTests 22 22 0 593ms
โœ… MappedCatalogBridgeTests 3 3 0 9ms
โœ… MappedCatalogModelTests 11 11 0 400ms
โœ… MockBackendExpiredCredentialsTests 3 3 0 50ms
โœ… MockBackendIntegrationTests 4 4 0 81ms
โœ… MockBackendLoanLimitTests 2 2 0 20ms
โœ… MockBackendRouteMatchingTests 4 4 0 10ms
โœ… MockBackendServerDownTests 1 1 0 15ms
โœ… MockIsolationLintTests 5 5 0 1.28s
โœ… MultiLibraryTokenIsolationTests 14 14 0 160ms
โœ… MyBooksDownloadCenterAccountIdThreadingTests 6 6 0 40ms
โœ… MyBooksDownloadCenterAdeptGapTests 3 3 0 11ms
โœ… MyBooksDownloadCenterConcurrencyTests 21 21 0 579ms
โœ… MyBooksDownloadCenterEvictionTests 7 7 0 86ms
โœ… MyBooksDownloadCenterOfflineTests 8 8 0 639ms
โœ… MyBooksDownloadSessionInvalidationTests 3 3 0 40ms
โœ… MyBooksSimplifiedBearerTokenTests 17 17 0 236ms
โœ… MyBooksViewModelBooksPublisherTests 3 3 0 230ms
โœ… MyBooksViewModelConcurrencyTests 4 4 0 41ms
โœ… MyBooksViewModelDownloadStateTests 3 3 0 302ms
โœ… MyBooksViewModelEmptyArrayTests 3 3 0 8ms
โœ… MyBooksViewModelEmptyStateTests 4 4 0 43ms
โœ… MyBooksViewModelExtendedTests 15 15 0 119ms
โœ… MyBooksViewModelFacetIntegrationTests 4 4 0 55ms
โœ… MyBooksViewModelFacetPublisherTests 3 3 0 14ms
โœ… MyBooksViewModelFilterSortInteractionTests 2 2 0 15ms
โœ… MyBooksViewModelFilterTests 9 9 0 421ms
โœ… MyBooksViewModelGuardConditionsTests 2 2 0 2.24s
โœ… MyBooksViewModelLargeDatasetTests 2 2 0 331ms
โœ… MyBooksViewModelLoadAccountTests 2 2 0 2.00s
โœ… MyBooksViewModelLoginStateTests 4 4 0 445ms
โœ… MyBooksViewModelMultipleAuthorSortingTests 3 3 0 25ms
โœ… MyBooksViewModelNotificationTests 4 4 0 344ms
โœ… MyBooksViewModelOfflineFilteringTests 3 3 0 27ms
โœ… MyBooksViewModelPublisherTests 7 7 0 53ms
โœ… MyBooksViewModelSearchEdgeCaseTests 6 6 0 46ms
โœ… MyBooksViewModelSearchQueryTests 3 3 0 19ms
โœ… MyBooksViewModelSortPersistenceTests 3 3 0 18ms
โœ… MyBooksViewModelSortingIntegrationTests 5 5 0 33ms
โœ… MyBooksViewModelSortingTests 6 6 0 38ms
โœ… MyBooksViewModelStateTransitionTests 3 3 0 338ms
โœ… MyBooksViewModelUIBindingTests 3 3 0 14ms
โœ… NSErrorAdditionsTests 7 7 0 14ms
โœ… NSNotificationTPPTests 3 3 0 28ms
โœ… NavigationCoordinatorTests 17 17 0 47ms
โœ… NavigationFreezePreventionTests 5 5 0 22ms
โœ… NetworkExecutorCredentialGuardTests 8 8 0 52ms
โœ… NetworkExecutorResponseRegressionTests 4 4 0 832ms
โœ… NetworkExecutorTaskTypeTests 3 3 0 49ms
โœ… NetworkOfflineDetectionTests 3 3 0 18ms
โœ… NetworkQueueTests 11 11 0 744ms
โœ… NetworkRequestQueueTests 2 2 0 10.13s
โœ… NetworkRetryLogicTests 7 7 0 81ms
โœ… NetworkTimeoutTests 2 2 0 23ms
โœ… NotificationEventTypeContractTests 7 7 0 14ms
โœ… NotificationPayloadContractTests 10 10 0 33ms
โœ… NotificationServiceStateMachineTests 9 9 0 1.37s
โœ… NotificationServiceTests 16 16 0 49ms
โœ… NotificationServiceTokenTests 13 13 0 37ms
โœ… NotificationSyncThrottleTests 5 5 0 11ms
โœ… NotificationTokenDataTests 4 4 0 12ms
โœ… NotificationTokenRegistrationTests 10 10 0 99ms
โœ… NowPlayingCoordinatorBackgroundTests 6 6 0 404ms
โœ… NowPlayingCoordinatorTests 19 19 0 206ms
โœ… OAuthSAMLRedirectRegressionTests 4 4 0 338ms
โœ… OIDCAuthDocumentParsingTests 4 4 0 253ms
โœ… OIDCAuthTypeTests 5 5 0 12ms
โœ… OIDCAuthenticationPropertyTests 8 8 0 679ms
โœ… OIDCCallbackEdgeCaseTests 9 9 0 735ms
โœ… OIDCCallbackHandlingTests 5 5 0 402ms
โœ… OIDCCallbackSchemeTests 3 3 0 15ms
โœ… OIDCIsolationRegressionTests 6 6 0 642ms
โœ… OIDCLoginRoutingTests 3 3 0 267ms
โœ… OIDCMakeRequestTests 3 3 0 245ms
โœ… OIDCNSCodingTests 1 1 0 453ms
โœ… OIDCNetworkLayer401Tests 5 5 0 2.50s
โœ… OIDCReauthOnExpiredTokenTests 5 5 0 1.04s
โœ… OIDCRedirectURIConstructionTests 6 6 0 507ms
โœ… OIDCRegressionTests 9 9 0 2.74s
โœ… OIDCSelectedAuthenticationTests 2 2 0 166ms
โœ… OIDCSignOutRegressionTests 6 6 0 547ms
โœ… OIDCTokenRefreshRegressionTests 6 6 0 485ms
โœ… OIDCUpdateUserAccountTests 5 5 0 747ms
โœ… OIDCViewModelRegressionTests 1 1 0 91ms
โœ… OIDCViewModelSignInTests 2 2 0 32ms
โœ… OPDS1BorrowEntryContractTests 4 4 0 31ms
โœ… OPDS1CatalogGroupedContractTests 3 3 0 17ms
โœ… OPDS1HoldEntriesContractTests 4 4 0 234ms
โœ… OPDS1LoansFeedContractTests 6 6 0 54ms
โœ… OPDS1ParsingTests 34 34 0 223ms
โœ… OPDS1RevokeResponseContractTests 2 2 0 14ms
โœ… OPDS2AuthenticationDocumentTests 18 18 0 342ms
โœ… OPDS2AvailabilityTests 4 4 0 9ms
โœ… OPDS2BookBridgeTests 44 44 0 131ms
โœ… OPDS2BorrowResponseContractTests 3 3 0 8ms
โœ… OPDS2CatalogWiringTests 17 17 0 131ms
โœ… OPDS2CatalogsFeedTests 3 3 0 234ms
โœ… OPDS2ContributorTests 2 2 0 6ms
โœ… OPDS2EmptyFeedContractTests 1 1 0 4ms
โœ… OPDS2FeedContractTests 4 4 0 25ms
โœ… OPDS2FeedParsingTests 11 11 0 601ms
โœ… OPDS2FeedTests 13 13 0 57ms
โœ… OPDS2FullMetadataTests 4 4 0 14ms
โœ… OPDS2FullPublicationTests 13 13 0 212ms
โœ… OPDS2IntegrationTests 18 18 0 162ms
โœ… OPDS2LinkArrayTests 5 5 0 20ms
โœ… OPDS2LinkComputedPropertyTests 20 20 0 67ms
โœ… OPDS2LinkRelTests 1 1 0 2ms
โœ… OPDS2LinkTests 2 2 0 162ms
โœ… OPDS2ParsingTests 38 38 0 159ms
โœ… OPDS2PublicationExtendedTests 53 53 0 313ms
โœ… OPDS2PublicationImageTests 6 6 0 14ms
โœ… OPDS2PublicationNarratorTests 3 3 0 17ms
โœ… OPDS2PublicationTests 2 2 0 197ms
โœ… OPDS2SamlIDPTests 6 6 0 14ms
โœ… OPDS2SearchResultsContractTests 3 3 0 15ms
โœ… OPDS2SubjectTests 2 2 0 4ms
โœ… OPDS2SupportingTypesTests 5 5 0 32ms
โœ… OPDSAcquisitionPathExpandedTests 15 15 0 404ms
โœ… OPDSFeedCacheTests 14 14 0 202ms
โœ… OPDSFeedMigrationTests 11 11 0 53ms
โœ… OPDSFeedParsingTests 2 2 0 155ms
โœ… OPDSFeedServiceStateMachineTests 3 3 0 386ms
โœ… OPDSFeedServiceTests 2 2 0 5ms
โœ… OPDSFormatTests 13 13 0 158ms
โœ… OPDSParserCoreTests 4 4 0 12ms
โœ… OPDSParserTests 4 4 0 11ms
โœ… OPDSParsingTests 57 57 0 7.95s
โœ… OfflineActionTests 29 29 0 71ms
โœ… OfflineQueueServiceExtendedTests 13 13 0 5.27s
โœ… OfflineQueueServiceTests 17 17 0 7.03s
โœ… OpenAccessAdapterTests 6 6 0 95ms
โœ… OverdriveDeferredFulfillmentTests 6 6 0 12ms
โœ… OverdriveDownloadHandlerTests 9 9 0 432ms
โœ… OverdriveFulfillmentTests 5 5 0 94ms
โœ… PDFExtensionsTests 20 20 0 57ms
โœ… PDFReaderTests 12 12 0 40ms
โœ… PP3596RegressionTests 3 3 0 42ms
โŒ Palace 2 1 1 <1ms
โœ… PalaceCheckPropertyTests 8 8 0 137ms
โœ… PalaceErrorCategoryTests 20 20 0 57ms
โœ… PalaceErrorExtendedTests 23 23 0 56ms
โœ… PalaceErrorTests 11 11 0 85ms
โœ… PalacePDFViewTests 12 12 0 90ms
โœ… PalaceTestSetupObservationTests 4 4 0 74ms
โœ… PalaceWiringTestCaseTests 4 4 0 16ms
โœ… ParserFuzzTests 4 4 0 32.50s
โœ… PatronProfileContractTests 4 4 0 13ms
โœ… PerformanceMonitorTests 14 14 0 116ms
โœ… PerformanceReportTests 14 14 0 59ms
โœ… PersistentLoggerTests 9 9 0 1.73s
โœ… PlaybackBootstrapperTests 8 8 0 84ms
โœ… PlaybackFailureRecordTests 5 5 0 15ms
โœ… PlaybackOpenPolicyTests 7 7 0 27ms
โœ… PlaybackRateTests 16 16 0 96ms
โœ… PlaybackTrackingRegressionTests 5 5 0 122ms
โœ… PositionPersistenceLogicTests 6 6 0 15ms
โœ… PositionPersistenceTests 2 2 0 13ms
โœ… PositionSyncServiceTests 13 13 0 178ms
โœ… PositionSyncTests 5 5 0 17ms
โœ… PositionWriterContractTests 6 6 0 84ms
โœ… PostUpdateMigrationTests 5 5 0 36ms
โœ… ProblemDocumentContractTests 4 4 0 25ms
โœ… ProblemDocumentLoanExpiryTests 5 5 0 17ms
โœ… ProblemDocumentTests 12 12 0 28ms
โœ… ProblemReportEmailTests 8 8 0 39ms
โœ… ReachabilityTests 10 10 0 23ms
โœ… Reader2BookmarkContractTests 3 3 0 18ms
โœ… Reader2PositionAdapterContractTests 4 3 0 237ms
โœ… Reader2PositionResumeContractTests 3 3 0 144ms
โœ… ReaderAccessibilityTests 7 7 0 27ms
โœ… ReaderEditingActionsTests 5 5 0 14ms
โœ… ReaderErrorTests 5 5 0 14ms
โœ… ReaderNavBarVoiceOverTests 2 2 0 14ms
โœ… ReaderServiceSyncTests 3 3 0 28ms
โœ… ReaderThemeTests 24 24 0 83ms
โœ… ReadingPositionTests 22 22 0 87ms
โœ… ReadingSessionTrackerTests 13 13 0 191ms
โœ… ReadingStatsServiceTests 12 12 0 65ms
โœ… ReadingStatsStoreTests 9 9 0 595ms
โœ… RedirectHandlingIntegrationTests 4 4 0 10ms
โœ… RedirectPolicyTests 9 9 0 35ms
โœ… RemoteFeatureFlagsGapTests 4 4 0 482ms
โœ… RemoteFeatureFlagsTests 9 9 0 359ms
โœ… ResourcePropertiesLengthTests 3 3 0 9ms
โœ… RetryClassificationTests 17 17 0 84ms
โœ… ReturnFlowTests 1 1 0 2ms
โœ… RightsManagementDetectionTests 5 5 0 9ms
โœ… RightsManagementDispatcherTests 10 10 0 123ms
โœ… SAMLCookieSyncTests 5 5 0 29ms
โœ… SAMLLogoutCallbackDetectionTests 4 4 0 8ms
โœ… SAMLLogoutLinkParsingTests 5 5 0 93ms
โœ… SAMLLogoutURLTests 4 4 0 10ms
โœ… SAMLPlusBiblioBoardExpirationTests 8 8 0 636ms
โœ… SEMigrationsTests 6 6 0 177ms
โœ… SafeDictionaryTests 21 21 0 682ms
โœ… SamplePlayerErrorTests 5 5 0 19ms
โœ… SampleTypeTests 8 8 0 34ms
โœ… SceneDelegateTests 1 1 0 3ms
โœ… ScopedResetTests 9 9 0 130ms
โœ… SearchAccessibilityTests 6 6 0 51ms
โœ… SearchFlowIntegrationTests 8 8 0 255ms
โœ… SettingsViewModelComputedPropertyTests 6 6 0 30ms
โœ… SettingsViewModelEdgeCaseTests 7 7 0 82ms
โœ… SettingsViewModelGapTests 1 1 0 3ms
โœ… SettingsViewModelSyncTests 14 14 0 123ms
โœ… SettingsViewModelTests 33 33 0 2.40s
โœ… SignInModalLifecycleTests 9 9 0 53ms
โœ… SignInModalPredicateTests 3 3 0 10ms
โœ… SignInModalSAMLOIDCTests 6 6 0 11ms
โœ… SignInOAuthErrorPropagationTests 8 8 0 659ms
โœ… SignInToReadFlowIntegrationTests 5 5 0 836ms
โœ… SignInWebSheetIntegrationTests 3 3 0 1.93s
โœ… SignInWebSheetViewModelTests 31 31 0 94ms
โœ… SignOutCacheClearingTests 3 3 0 11ms
โœ… SingletonResetRegistryTests 5 5 0 80ms
โœ… StatsViewModelTests 10 10 0 463ms
โœ… StatusAnnouncementTests 22 22 0 144ms
โœ… StopPositionSaveTests 2 2 0 5ms
โœ… StoreTests 5 5 0 14ms
โœ… StreamingReaderPresentationContractTests 1 1 0 22ms
โœ… StreamingReaderProgressStoreTests 7 7 0 50ms
โœ… StreamingReaderViewControllerScrollRestoreTests 12 12 0 689ms
โœ… StreamingReaderViewModelTests 9 9 0 70ms
โœ… StringExtensionTests 8 8 0 21ms
โœ… StringExtensionsTests 3 3 0 19ms
โœ… StringHTMLEntitiesTests 7 7 0 15ms
โœ… StringNYPLAdditionsTests 4 4 0 27ms
โœ… String_NYPLAdditionsTests 4 4 0 11ms
โœ… SupportSectionDecisionTests 5 5 0 12ms
โœ… SyncConflictResolutionTests 3 3 0 8ms
โœ… SyncDeletionGuardTests 5 5 0 10ms
โœ… SyncDeletionRatioTests 6 6 0 14ms
โœ… SyncPermissionTests 5 5 0 164ms
โœ… TPPAccountAuthStateEnumTests 5 5 0 11ms
โœ… TPPAccountListDataSourceTests 3 3 0 9ms
โœ… TPPAdobeActivationSkipTests 6 6 0 464ms
โœ… TPPAgeCheckCompletionTests 5 5 0 404ms
โœ… TPPAgeCheckIsValidTests 5 5 0 489ms
โœ… TPPAgeCheckStateMachineTests 4 4 0 547ms
โœ… TPPAgeCheckTests 6 6 0 1.50s
โœ… TPPAgeCheckVerifyDecisionTests 5 5 0 320ms
โœ… TPPAlertUtilsTests 45 45 0 960ms
โœ… TPPAnnotationsHermeticTests 15 15 0 124ms
โœ… TPPAnnotationsOverrideTests 4 4 0 226ms
โœ… TPPAnnotationsTests 29 29 0 2.37s
โœ… TPPAnnouncementManagerTests 3 3 0 12ms
โœ… TPPAuthDocumentContractTests 3 3 0 27ms
โœ… TPPBackgroundExecutorTests 3 3 0 18ms
โœ… TPPBadgeImageGapTests 2 2 0 87ms
โœ… TPPBaseReaderViewControllerInitialLocationTests 5 5 0 100ms
โœ… TPPBasicAuthTests 11 11 0 27ms
โœ… TPPBookAccessibilityLabelTests 8 8 0 35ms
โœ… TPPBookAuthorCoverageTests 3 3 0 7ms
โœ… TPPBookAuthorTests 6 6 0 23ms
โœ… TPPBookBearerTokenTests 9 8 0 68ms
โœ… TPPBookButtonsStateTests 7 7 0 87ms
โœ… TPPBookContentMetadataFilesHelperTests 9 9 0 21ms
โœ… TPPBookContentTypeConverterStreamingHTMLTests 2 2 0 4ms
โœ… TPPBookContentTypeConverterTests 4 4 0 8ms
โœ… TPPBookContentTypeExtendedTests 4 4 0 13ms
โœ… TPPBookContentTypeTests 14 14 0 44ms
โœ… TPPBookCoverRegistryTests 14 14 0 546ms
โœ… TPPBookCreationTests 7 7 0 89ms
โœ… TPPBookExtensionsTests 21 21 0 116ms
โœ… TPPBookIsDRMProtectedTests 9 9 0 28ms
โœ… TPPBookLocationCoverageTests 7 7 0 127ms
โœ… TPPBookLocationEdgeCaseTests 27 27 0 101ms
โœ… TPPBookLocationKeyTests 3 3 0 79ms
โœ… TPPBookLocationTests 11 11 0 54ms
โœ… TPPBookModelGapTests 4 4 0 32ms
โœ… TPPBookRegistryAsyncReadinessTests 3 3 0 313ms
โœ… TPPBookRegistryAtomicWriteTests 7 7 0 635ms
โœ… TPPBookRegistryBookRetrievalTests 7 7 0 77ms
โœ… TPPBookRegistryBookmarkTests 7 7 0 50ms
โœ… TPPBookRegistryCorruptedDataTests 5 5 0 37ms
โœ… TPPBookRegistryDataTests 4 4 0 19ms
โœ… TPPBookRegistryDependencyTests 4 4 0 22ms
โœ… TPPBookRegistryFulfillmentIdTests 4 4 0 270ms
โœ… TPPBookRegistryLargeCorpusTests 5 5 0 1m 12s
โœ… TPPBookRegistryLoadReentrancyTests 2 2 0 510ms
โœ… TPPBookRegistryLocationTests 4 4 0 29ms
โœ… TPPBookRegistryMigrationTests 16 16 0 2.69s
โœ… TPPBookRegistryPersistenceTests 10 10 0 1.88s
โœ… TPPBookRegistryProcessingTests 2 2 0 1.59s
โœ… TPPBookRegistryPublisherTests 6 6 0 5.06s
โœ… TPPBookRegistryRecordPersistenceTests 3 3 0 32ms
โœ… TPPBookRegistryRecordTests 10 10 0 30ms
โœ… TPPBookRegistryStateManagementTests 11 11 0 126ms
โœ… TPPBookRegistryThreadSafetyTests 3 3 0 260ms
โœ… TPPBookRegistryUpdateAndRemoveTests 1 1 0 1.39s
โœ… TPPBookRequiresAdobeDRMTests 6 6 0 13ms
โœ… TPPBookSerializationTests 13 13 0 58ms
โœ… TPPBookStateInitializationTests 4 4 0 21ms
โœ… TPPBookStateTests 4 4 0 10ms
โœ… TPPBookTests 93 93 0 582ms
โœ… TPPBookmarkDeletionLogTests 11 11 0 81ms
โœ… TPPBookmarkFactoryInitTests 2 2 0 8ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests 5 5 0 19ms
โœ… TPPBookmarkFactoryTests 15 15 0 76ms
โœ… TPPBookmarkR3ConversionTests 5 5 0 20ms
โœ… TPPBookmarkR3LocationTests 13 13 0 47ms
โœ… TPPBookmarkSpecTests 1 1 0 6ms
โœ… TPPCachingTests 3 3 0 9ms
โœ… TPPCapturedCredentialsTests 5 5 0 463ms
โœ… TPPConfigurationTests 22 22 0 222ms
โœ… TPPContentTypeTests 9 9 0 21ms
โœ… TPPCredentialConcurrencyTests 3 3 0 12ms
โœ… TPPCredentialIsolationE2ETests 5 0 0 162ms
โœ… TPPCredentialPersistenceTests 6 6 0 855ms
โœ… TPPCredentialSnapshotCoherenceTests 3 0 0 26ms
โœ… TPPCredentialSnapshotTests 8 8 0 16ms
โœ… TPPCredentialsCoverageTests 9 9 0 31ms
โœ… TPPCredentialsTests 26 26 0 119ms
โœ… TPPCrossLibrarySignOutTests 6 6 0 685ms
โœ… TPPDRMFailureCredentialPreservationTests 4 4 0 1.77s
โœ… TPPErrorLoggerTests 27 27 0 169ms
โœ… TPPIdleSignOutRegressionTests 13 13 0 1.17s
โœ… TPPJWKConversionTest 1 1 0 35ms
โœ… TPPKeychainManagerTests 5 5 0 63ms
โœ… TPPLastReadPositionPosterTests 13 13 0 362ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests 5 5 0 36ms
โœ… TPPLastReadPositionSynchronizerTests 23 23 0 71ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests 5 5 0 16ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests 9 9 0 19ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests 3 3 0 15ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests 9 9 0 70ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests 10 10 0 36ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests 4 4 0 55ms
โœ… TPPLoginNoActivationTests 3 3 0 284ms
โœ… TPPMainThreadCheckerTests 4 4 0 18ms
โœ… TPPMigrationManagerTests 15 15 0 64ms
โœ… TPPNetworkExecutorAPITests 14 14 0 75ms
โœ… TPPNetworkExecutorStubbedTests 17 17 0 214ms
โœ… TPPNetworkExecutorTests 3 3 0 34ms
โœ… TPPNetworkResponderAuthCoordinatorTests 5 5 0 33ms
โœ… TPPNetworkResponderTests 12 12 0 53ms
โœ… TPPOPDSAcquisitionPathTests 5 5 0 39ms
โœ… TPPOPDSEntryTests 5 5 0 34ms
โœ… TPPOPDSFeedTests 3 3 0 202ms
โœ… TPPOPDSGroupSwiftTests 3 3 0 6ms
โœ… TPPOPDSLinkTests 7 7 0 27ms
โœ… TPPOpenSearchDescriptionExpandedTests 10 10 0 30ms
โœ… TPPOpenSearchDescriptionTests 1 1 0 5ms
โœ… TPPPDFDocumentMetadataTests 15 15 0 89ms
โœ… TPPPDFDocumentTests 8 8 0 22ms
โœ… TPPPDFLocationCoverageTests 7 7 0 28ms
โœ… TPPPDFLocationTests 10 10 0 36ms
โœ… TPPPDFPageBookmarkTests 9 9 0 21ms
โœ… TPPPDFPageTests 5 5 0 13ms
โœ… TPPPDFReaderModeTests 6 6 0 14ms
โœ… TPPPerAccountIsolationTests 8 0 0 161ms
โœ… TPPPreferredAuthSelectionTests 8 8 0 640ms
โœ… TPPProblemDocumentCacheManagerTests 12 12 0 105ms
โœ… TPPProblemDocumentTests 21 21 0 46ms
โœ… TPPReaderAppearanceTests 4 4 0 13ms
โœ… TPPReaderBookmarksBusinessLogicTests 12 12 0 1.02s
โœ… TPPReaderBookmarksReadinessTests 2 2 0 191ms
โœ… TPPReaderFontTests 4 4 0 9ms
โœ… TPPReaderPreferencesLoadTests 3 3 0 15ms
โœ… TPPReaderSettingsTests 28 28 0 113ms
โœ… TPPReaderTOCBusinessLogicTests 15 15 0 4.52s
โœ… TPPReaderTOCFlattenTests 2 2 0 1.03s
โœ… TPPReadiumBookmarkLocationMatchingTests 5 5 0 14ms
โœ… TPPReadiumBookmarkTests 21 21 0 97ms
โœ… TPPReauthenticatorMockTests 2 2 0 4ms
โœ… TPPReauthenticatorTests 4 4 0 9ms
โœ… TPPReturnPromptHelperTests 5 5 0 26ms
โœ… TPPSAMLCookieExpirationTests 7 7 0 21ms
โœ… TPPSAMLFlowTests 10 10 0 63ms
โœ… TPPSAMLReauthFlowTests 2 2 0 172ms
โœ… TPPSAMLRegressionTests 4 4 0 231ms
โœ… TPPSAMLSignInTests 26 26 0 2.30s
โœ… TPPSAMLStateIsolationTests 4 4 0 168ms
โœ… TPPSAMLStateMachineTests 6 6 0 490ms
โœ… TPPSettingsTests 6 6 0 76ms
โœ… TPPSignInAdobeSkipTests 14 14 0 1.26s
โœ… TPPSignInAuthStateTransitionTests 3 3 0 269ms
โœ… TPPSignInBusinessLogicExtendedTests 58 58 0 5.16s
โœ… TPPSignInBusinessLogicOAuthTests 11 11 0 958ms
โœ… TPPSignInBusinessLogicSignOutTests 11 11 0 1.13s
โœ… TPPSignInBusinessLogicStateMachineTests 9 9 0 2.49s
โœ… TPPSignInBusinessLogicTests 18 18 0 6.18s
โœ… TPPSignInBusinessLogicTokenFlowTests 3 3 0 279ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests 2 2 0 176ms
โœ… TPPSignInErrorHandlingTests 2 2 0 181ms
โœ… TPPSignInProfileDocEdgeCaseTests 3 3 0 341ms
โœ… TPPSignedInStateProviderTests 3 3 0 6ms
โœ… TPPUserAccountAuthStateTests 6 6 0 13ms
โœ… TPPUserAccountGapTests 4 4 0 11ms
โœ… TPPUserAccountIsolationLintTests 3 3 0 865ms
โœ… TPPUserAccountTestFactoryTests 7 0 0 67ms
โœ… TPPUserFriendlyErrorTests 11 11 0 38ms
โœ… TPPUserNotificationsTests 10 10 0 50ms
โœ… TPPXMLSwiftTests 16 16 0 108ms
โœ… TPPXMLTests 3 3 0 10ms
โœ… TearDownRequiredLintTests 5 5 0 1.45s
โœ… TestAppContainerFactoryTests 5 5 0 38ms
โœ… TimeEntryTests 3 3 0 6ms
โŒ TokenRefreshAndRetryQueueTests 11 10 1 9.51s
โœ… TokenRefreshIntegrationTests 2 2 0 33ms
โœ… TokenRefreshInterceptorAuthCoordinatorTests 8 8 0 4.31s
โœ… TokenRefreshInterceptorTests 22 22 0 5.79s
โœ… TokenRefreshOnForegroundTests 10 10 0 2.32s
โœ… TokenRefreshTests 25 25 0 150ms
โœ… TokenRequestCredentialGuardTests 13 13 0 1.53s
โœ… TokenRequestTests 11 11 0 53ms
โœ… TokenResponseTests 21 21 0 62ms
โœ… TypographyPresetTests 21 21 0 126ms
โœ… TypographyServiceTests 31 31 0 1.13s
โœ… TypographySettingsViewModelTests 27 27 0 527ms
โœ… UIAlertCACommitGuardTests 8 8 0 248ms
โœ… UIColor_NYPLAdditionsTests 1 1 0 3ms
โœ… URLBackupExclusionTests 3 3 0 25ms
โœ… URLExtensionTests 16 16 0 61ms
โœ… URLExtensionsTests 6 6 0 13ms
โœ… URLRequestExtensionsCoverageTests 3 3 0 12ms
โœ… URLRequestExtensionsTests 11 11 0 47ms
โœ… URLRequestNYPLAdditionsTests 11 11 0 28ms
โœ… URLRequest_NYPLTests 1 1 0 2ms
โœ… URLResponseAuthenticationTests 10 10 0 25ms
โœ… URLResponseNYPLTests 14 14 0 29ms
โœ… URLSessionCredentialStorageTests 3 3 0 7ms
โœ… URLSessionStubbingResetTests 2 2 0 12ms
โœ… URLTypeTests 2 2 0 8ms
โœ… URLValidationTests 5 5 0 77ms
โœ… UnifiedOPDSServiceStateMachineTests 2 2 0 724ms
โœ… UserAccountPublisherAuthStateTests 5 5 0 39ms
โœ… UserAccountPublisherTests 14 14 0 294ms
โœ… UserAccountValidationTests 11 11 0 1.17s
โœ… UserDefaultsIsolationLintTests 2 2 0 626ms
โœ… UserProfileDocumentTests 7 7 0 24ms
โœ… UserRetryTrackerTests 10 10 0 21ms
โœ… XCTestCase_testUserDefaultsTests 3 3 0 24ms
โœ… iPadOnMacRMSDKGuardTests 1 1 0 3ms

๐Ÿ“ˆ Code Coverage

Target Coverage Lines
Palace.app
46.0%
40916 / 88990

๐Ÿ“‹ All Tests

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