๐Ÿงช Palace iOS Test Report

Generated: 2026-05-27 15:32:03 UTC | Commit: 82de82bf016f | Branch: fix/PP-4454-lcp-pdf-marketplace

โœ… ALL TESTS PASSED

6693 tests completed in 10m 58s

6693
Total Tests
6600
Passed
0
Failed
93
Skipped
10m 58s
Duration
44.9%
Coverage

๐Ÿ“Š Tests by Class

Class Total Passed Failed Duration
โœ… AccessLintComplianceTests 11 11 0 83ms
โœ… AccessibilityAnnouncementCenterTests 20 20 0 1.59s
โœ… AccessibilityLabelTests 9 9 0 28ms
โœ… AccessibilityPreferencesTests 26 26 0 62ms
โœ… AccessibilityServiceTests 11 11 0 109ms
โœ… AccountAuthDocCarryoverTests 5 5 0 804ms
โœ… AccountAwareNetworkTests 10 10 0 249ms
โœ… AccountDetailCredentialStateTests 7 0 0 173ms
โœ… AccountDetailPINVisibilityTests 25 0 0 734ms
โœ… AccountDetailSignOutConfirmationTests 2 0 0 11ms
โœ… AccountDetailViewModelGapTests 1 1 0 119ms
โœ… AccountDetailViewModelTests 19 0 0 128ms
โœ… AccountDetailsNeedsAuthAggregateTests 10 10 0 38ms
โœ… AccountDetailsURLTests 17 17 0 82ms
โœ… AccountModelGapTests 9 9 0 790ms
โœ… AccountModelTests 20 20 0 113ms
โœ… AccountProfileDocumentTests 3 3 0 20ms
โœ… AccountStateMachineTests 7 7 0 28ms
โœ… AccountSwitchCleanupTests 8 8 0 204ms
โœ… AccountSwitchIntegrationTests 8 8 0 222ms
โœ… AccountSwitchLifecycleTests 9 0 0 61ms
โœ… AccountsManagerCacheTests 16 16 0 452ms
โœ… AccountsManagerGapTests 3 3 0 38ms
โœ… AccountsManagerHelpersTests 12 12 0 20ms
โœ… AccountsManagerStateMachineWiringTests 10 10 0 5.72s
โœ… AccountsManagerTests 51 51 0 8.91s
โœ… AdobeActivationTests 6 6 0 15ms
โœ… AdobeCertificateGapTests 7 7 0 48ms
โœ… AdobeDRMCharacterizationTests 21 21 0 64ms
โœ… AdobeDRMErrorGapTests 3 3 0 77ms
โœ… AdobeDRMHandlerTests 12 12 0 95ms
โœ… AdobeDRMServiceGapTests 2 2 0 8ms
โœ… AlertModelCoverageTests 6 6 0 10ms
โœ… AlertModelRetryTests 7 7 0 26ms
โœ… AlertModelTests 2 2 0 5ms
โœ… AlertUtilsTests 20 20 0 349ms
โœ… AnnotationContractTests 3 3 0 12ms
โœ… AnnotationDeviceIDTests 2 2 0 4ms
โœ… AnnotationPostResponseContractTests 1 1 0 3ms
โœ… AnnouncementChainTests 5 5 0 35ms
โœ… AnnouncementTests 3 3 0 6ms
โœ… AnonymousBorrowBaselineFixtureTests 13 13 0 54ms
โœ… AnonymousBorrowCandidateFixtureTests 6 6 0 127ms
โœ… AnonymousBorrowDeltaTests 2 2 0 32ms
โœ… AppContainerAudiobookFactoryTests 3 3 0 9ms
โœ… AppContainerImageLoaderInjectionTests 4 4 0 96ms
โœ… AppContainerTests 4 4 0 8ms
โœ… AppHealthViewModelTests 8 8 0 1.27s
โœ… AppLaunchTrackerExtendedTests 16 16 0 412ms
โœ… AppLaunchTrackerTests 10 10 0 337ms
โœ… AppRouteTests 5 5 0 11ms
โœ… AppTabHostViewBadgeCountTests 10 10 0 55ms
โœ… AppTabRouterCoverageTests 4 4 0 16ms
โœ… AppTabRouterGapTests 3 3 0 113ms
โœ… ArrayExtensionsTests 6 6 0 52ms
โœ… AudioBookmarkGapTests 6 6 0 20ms
โœ… AudioEngineWrapperTests 8 8 0 302ms
โœ… AudioInterruptionLogicTests 6 6 0 18ms
โœ… AudiobookAccessibilityTests 7 7 0 33ms
โœ… AudiobookBackgroundAudioTests 2 2 0 26ms
โœ… AudiobookBookmarkBusinessLogicPositionWriteTests 6 6 0 112ms
โœ… AudiobookBookmarkBusinessLogicTests 21 21 0 3.99s
โœ… AudiobookChapterTOCNormalizationTests 6 6 0 14ms
โœ… AudiobookDataManagerEmptyQueueTests 1 1 0 6ms
โœ… AudiobookDataManagerErrorHandlingTests 5 5 0 10.20s
โœ… AudiobookDataManagerModelsTests 20 20 0 80ms
โœ… AudiobookDataManagerNetworkSyncTests 5 5 0 5.14s
โœ… AudiobookDataManagerSaveTests 4 4 0 23ms
โœ… AudiobookDataManagerStoreRecoveryTests 5 5 0 2.06s
โœ… AudiobookFileLoggerTests 14 14 0 304ms
โœ… AudiobookLoadFailureSAMLReauthTests 10 10 0 909ms
โœ… AudiobookLoaderDispatchTests 7 7 0 199ms
โœ… AudiobookLoaderFinalizeBuildTests 9 9 0 220ms
โœ… AudiobookLoaderOPDSShapeMatrixTests 6 6 0 164ms
โœ… AudiobookLoaderPredicateTests 11 11 0 24ms
โœ… AudiobookLoaderTests 2 2 0 320ms
โœ… AudiobookNetworkValidationTests 3 3 0 5ms
โœ… AudiobookOpenStateRaceTests 3 3 0 428ms
โœ… AudiobookPhoneAlertContentTests 3 3 0 10ms
โœ… AudiobookPlaybackStateTests 3 3 0 49ms
โœ… AudiobookPlaybackTests 26 26 0 544ms
โœ… AudiobookPositionAdapterContractTests 3 3 0 166ms
โœ… AudiobookPositionPolicyValidatorTests 14 14 0 24ms
โœ… AudiobookSAMLReauthTests 6 6 0 30ms
โœ… AudiobookSessionErrorDescriptionTests 4 4 0 9ms
โœ… AudiobookSessionErrorExtTests 4 4 0 13ms
โœ… AudiobookSessionErrorTests 2 2 0 3ms
โœ… AudiobookSessionManagerErrorMappingTests 6 6 0 18ms
โœ… AudiobookSessionManagerShutdownTests 8 8 0 55ms
โœ… AudiobookSessionStateTests 6 6 0 19ms
โœ… AudiobookSessionStateTransitionTests 18 18 0 148ms
โœ… AudiobookSleepTimerIntegrationTests 5 5 0 261ms
โœ… AudiobookStorageLocationTests 3 3 0 21ms
โœ… AudiobookTOCTests 18 18 0 259ms
โœ… AudiobookTimeEntryTests 6 6 0 46ms
โœ… AudiobookTimeTrackerEdgeTests 8 8 0 132ms
โœ… AudiobookTimeTrackerLifecycleTests 5 5 0 1.18s
โœ… AudiobookTimeTrackerTests 9 9 0 120ms
โœ… AudiobookTrackCompletionTests 2 2 0 26ms
โœ… AudiobookTypeRoutingTests 5 5 0 31ms
โœ… AudiobookVendorAdapterTests 5 5 0 449ms
โœ… AudiobookmarkTests 4 4 0 37ms
โœ… AuthDocumentContractTests 2 2 0 6ms
โœ… AuthDocumentVariantsContractTests 5 5 0 81ms
โœ… AuthErrorCategoryTests 12 12 0 32ms
โœ… AuthErrorProblemDocSeamTests 6 6 0 24ms
โœ… AuthFlowSecurityTests 3 0 0 28ms
โœ… AuthReducerTests 21 21 0 304ms
โœ… AuthTypeTests 7 7 0 21ms
โœ… AuthenticationTests 16 16 0 37ms
โœ… BackgroundDownloadHandlerTests 28 28 0 186ms
โœ… BackgroundListenerTests 2 2 0 39ms
โœ… BackupExclusionMigrationTests 3 3 0 44ms
โœ… BadgeDefinitionTests 33 33 0 74ms
โœ… BadgeServiceTests 16 16 0 1.21s
โœ… BadgesViewModelTests 14 14 0 137ms
โœ… BasicAuthEmptyCredentialTests 4 4 0 29ms
โœ… BearerTokenAdapterTests 5 4 0 46ms
โœ… BearerTokenFulfillFlowTests 4 4 0 25ms
โœ… BearerTokenRefreshTests 4 4 0 13ms
โœ… BearerTokenResponseDetectionTests 7 7 0 23ms
โœ… BeginningPositionPolicyTests 8 8 0 14ms
โœ… BookAvailabilityFormatterTests 18 18 0 68ms
โœ… BookButtonMapperHoldReadyTests 10 10 0 45ms
โœ… BookButtonMapperTests 14 14 0 86ms
โœ… BookButtonMapperViewModelTests 18 18 0 36ms
โœ… BookButtonStateTests 8 8 0 34ms
โœ… BookButtonTypeTests 13 13 0 58ms
โœ… BookCellModelActionTests 18 18 0 656ms
โœ… BookCellModelCacheInvalidationTests 8 8 0 127ms
โœ… BookCellModelCachePrefetchSafetyTests 9 9 0 287ms
โœ… BookCellModelCacheTests 22 22 0 414ms
โœ… BookCellModelComputedPropertyTests 19 19 0 238ms
โœ… BookCellModelOfflineTests 9 9 0 337ms
โœ… BookCellModelRegistryBindingTests 4 4 0 294ms
โœ… BookCellModelStateTests 16 16 0 221ms
โœ… BookCellStateComprehensiveTests 14 14 0 24ms
โœ… BookContentResetServiceTests 2 2 0 12ms
โœ… BookDetailMetadataHydrationTests 6 6 0 46ms
โœ… BookDetailViewModelTests 85 85 0 1.49s
โœ… BookFileManagerTests 8 8 0 43ms
โœ… BookListViewAccessibilityTests 9 9 0 37ms
โœ… BookPreviewTests 4 4 0 19ms
โœ… BookRegistryStoreTests 26 26 0 811ms
โœ… BookRegistrySyncReadinessTests 3 2 0 297ms
โœ… BookRegistrySyncTests 23 23 0 157ms
โœ… BookReturnServiceContractTests 5 5 0 611ms
โœ… BookReturnServiceTests 8 8 0 219ms
โœ… BookSignInRedirectHandlerTests 8 8 0 245ms
โœ… BookStateIntegrationTests 8 8 0 76ms
โœ… BookmarkBusinessLogicExtendedTests 6 6 0 451ms
โœ… BookmarkDeletionLogTests 3 3 0 246ms
โœ… BookmarkDeviceIdMatchingTests 3 3 0 317ms
โœ… BookmarkExistenceTests 4 4 0 316ms
โœ… BookmarkManagerTests 24 24 0 278ms
โœ… BookmarkSortingTests 1 1 0 110ms
โœ… BookmarkSyncTests 3 3 0 609ms
โœ… BorrowAndDownloadIntegrationTests 7 7 0 13.10s
โœ… BorrowErrorMessageTests 13 13 0 30ms
โœ… BorrowErrorPresenterTests 6 6 0 536ms
โœ… BorrowOperationContractTests 6 6 0 661ms
โœ… BorrowOperationTests 12 12 0 2.79s
โœ… BorrowOperationTimeoutTests 3 3 0 118ms
โœ… BorrowReducerContractTests 2 2 0 20ms
โœ… BorrowReducerTests 21 21 0 47ms
โœ… BundledRegistrySnapshotTests 5 5 0 625ms
โœ… ButtonStateTests 16 16 0 137ms
โœ… ButtonStyleTypeTests 2 2 0 161ms
โœ… C64ConversionTests 6 6 0 25ms
โœ… CarPlayAuthHelperReadinessTests 3 3 0 307ms
โœ… CarPlayChapterListTests 3 3 0 15ms
โœ… CarPlayIntegrationTests 2 2 0 9ms
โœ… CarPlayLibraryRefreshTests 3 3 0 5ms
โœ… CarPlayNowPlayingTemplateTests 4 4 0 525ms
โœ… CarPlayOpenAppAlertTests 4 4 0 18ms
โœ… CarPlayPlaybackErrorTests 8 8 0 34ms
โœ… CarPlayTests 12 12 0 55ms
โœ… CarPlayTimeTrackingTests 3 3 0 394ms
โœ… CatalogAPIDedupeTests 3 3 0 524ms
โœ… CatalogAPIEntryPointTests 1 1 0 4ms
โœ… CatalogAccessibilityTests 8 8 0 25ms
โœ… CatalogCacheKeyAndIsolationTests 12 12 0 576ms
โœ… CatalogCacheMetadataExactBoundaryTests 4 4 0 14ms
โœ… CatalogCacheMetadataTests 21 21 0 51ms
โœ… CatalogFeedModelTests 4 4 0 9ms
โœ… CatalogFilterGroupModelTests 17 17 0 67ms
โœ… CatalogFilterModelTests 17 17 0 45ms
โœ… CatalogFilterServiceTests 29 29 0 2.99s
โœ… CatalogFilterTests 1 1 0 2ms
โœ… CatalogLaneAssemblyTests 7 7 0 32ms
โœ… CatalogLaneModelStructTests 18 18 0 686ms
โœ… CatalogLaneModelTests 1 1 0 3ms
โœ… CatalogLaneMoreFilterStateTests 8 8 0 25ms
โœ… CatalogLaneMoreViewModelTests 42 42 0 744ms
โœ… CatalogLaneRowViewAccessibilityTests 11 11 0 110ms
โœ… CatalogLaneSortingTests 4 4 0 10.25s
โœ… CatalogLoadIntegrationTests 6 6 0 370ms
โœ… CatalogOPDS2NegotiationTests 12 12 0 423ms
โœ… CatalogPreloaderTests 6 6 0 23ms
โœ… CatalogProblemDocumentTests 6 6 0 15ms
โœ… CatalogRepositoryCoreTests 9 9 0 363ms
โœ… CatalogRepositoryStaleWhileRevalidateTests 12 12 0 385ms
โœ… CatalogRepositoryTests 19 19 0 428ms
โœ… CatalogSearchViewModelRegistryUpdateTests 5 5 0 118ms
โœ… CatalogSearchViewModelTests 67 67 0 7.23s
โœ… CatalogSelectorsTests 2 2 0 5ms
โœ… CatalogSortServiceTests 14 14 0 125ms
โœ… CatalogStateTests 7 7 0 30ms
โœ… CatalogViewModelStateMachineTests 10 10 0 36ms
โœ… ChaosFaultInjectionTests 5 5 0 78ms
โœ… ChapterChangeDetectorTests 5 5 0 135ms
โœ… ChapterTOCNormalizerTests 7 7 0 28ms
โœ… CirculationAnalyticsTests 4 4 0 16ms
โœ… ColdStartResumeIntegrationTests 10 10 0 1.05s
โœ… ColorExtensionTests 5 5 0 9ms
โœ… ConcurrentBookStateTests 3 3 0 26ms
โœ… ConcurrentDownloadStateTests 3 3 0 25ms
โœ… ConcurrentTokenRefreshTests 2 2 0 22ms
โœ… ContinuousPlaybackTrackingTests 3 3 0 652ms
โœ… CookiePersistenceTests 10 10 0 777ms
โœ… CrawlStateTests 16 16 0 36ms
โœ… CrawlableFeedAnalysisTests 17 17 0 40ms
โœ… CrawlerFallbackTests 12 12 0 98ms
โœ… CredentialEdgeCaseTests 6 6 0 23ms
โœ… CredentialPrivacyTests 4 4 0 13ms
โœ… CredentialPromptCoordinatorTests 4 4 0 408ms
โœ… CrossDeviceBookmarkSyncTests 12 12 0 47ms
โœ… CrossDeviceSyncE2ETests 5 5 0 605ms
โœ… CrossDomain401Tests 8 8 0 30ms
โœ… CrossFormatMappingTests 14 14 0 51ms
โœ… DPLAErrorTests 3 3 0 17ms
โœ… DRMAdversarialTests 4 1 0 43ms
โœ… DRMFulfilledPublicationTests 6 6 0 16ms
โœ… DataBase64Tests 3 3 0 8ms
โœ… DataReceptionComparisonTests 2 2 0 47ms
โœ… DateExtensionTests 9 9 0 33ms
โœ… DateFormattingTests 4 4 0 18ms
โœ… Date_NYPLAdditionsTests 7 7 0 2.51s
โœ… DebugSettingsTests 27 27 0 157ms
โœ… DefaultCatalogAPITests 31 31 0 276ms
โœ… DeriveInitialStateTests 4 4 0 22ms
โœ… DeviceLogCollectorGapTests 2 2 0 23.61s
โœ… DeviceLogCollectorTests 9 9 0 2m 0s
โœ… DeviceOrientationTests 7 7 0 20ms
โœ… DeviceSpecificErrorMonitorTests 11 11 0 44ms
โœ… DictionaryExtensionsTests 5 5 0 11ms
โœ… DiskBudgetManagerTests 7 7 0 31ms
โœ… DiskBudgetTests 2 2 0 6ms
โœ… DownloadAlertPresenterTests 8 8 0 266ms
โœ… DownloadAnnouncementServiceTests 12 12 0 674ms
โœ… DownloadAuthRetryHandlerTests 11 11 0 1.24s
โœ… DownloadCancellationHandlerTests 5 5 0 281ms
โœ… DownloadCompletionParserTests 9 9 0 145ms
โœ… DownloadCoordinatorIntegrationTests 10 10 0 58ms
โœ… DownloadCoordinatorTests 11 11 0 36ms
โœ… DownloadDiskSpaceTests 2 2 0 4ms
โœ… DownloadErrorInfoTests 3 3 0 8ms
โœ… DownloadErrorRecoveryPolicyTests 11 11 0 108ms
โœ… DownloadErrorRecoveryTests 3 3 0 15ms
โœ… DownloadFreeSpaceExhaustionTests 11 11 0 94ms
โœ… DownloadInfoTests 5 5 0 18ms
โœ… DownloadIntegrityTests 10 10 0 163ms
โœ… DownloadOnlyOnWiFiTests 10 10 0 32ms
โœ… DownloadPersistenceStoreTests 5 5 0 74ms
โœ… DownloadProgressPublisherCoreTests 19 19 0 641ms
โœ… DownloadProgressPublisherTests 2 2 0 8ms
โœ… DownloadQueueIntegrationTests 3 3 0 1.49s
โœ… DownloadQueueOrchestratorTests 9 9 0 217ms
โœ… DownloadRMSDKHandoffTests 1 1 0 3ms
โœ… DownloadRedirectTests 7 7 0 14ms
โœ… DownloadResumeAfterKillTests 7 7 0 124ms
โœ… DownloadSlotManagementTests 5 5 0 34ms
โœ… DownloadStartCoordinatorContractTests 5 5 0 91ms
โœ… DownloadStartCoordinatorTests 9 9 0 191ms
โœ… DownloadStartDispatcherTests 14 14 0 170ms
โœ… DownloadStateMachineIntegrationTests 15 15 0 81ms
โœ… DownloadStateMachineTests 5 5 0 25ms
โœ… DownloadStateManagerTests 16 16 0 133ms
โœ… DownloadTaskLifecycleServiceTests 9 9 0 202ms
โœ… DownloadThrottlingServiceTests 10 10 0 409ms
โœ… DownloadWatchdogTests 3 3 0 15ms
โœ… EPUBKeyCommandsPP4289Tests 4 4 0 36ms
โœ… EPUBModuleTests 4 4 0 16ms
โœ… EPUBPositionTests 8 8 0 23ms
โœ… EPUBSearchViewModelTests 18 18 0 65ms
โœ… EPUBToolbarToggleTests 11 11 0 38ms
โœ… EmailAddressTests 16 16 0 143ms
โœ… EpubSampleFactoryTests 5 5 0 32ms
โœ… ErrorActivityTrackerTests 12 12 0 120ms
โœ… ErrorDetailTests 12 12 0 76ms
โœ… ErrorDetailViewControllerGapTests 3 3 0 174ms
โœ… ErrorDetailViewControllerTests 14 14 0 86ms
โœ… ErrorLogExporterTests 5 5 0 16.30s
โœ… ExpiredLoanStringsTests 5 5 0 8ms
โœ… FacetEnumTests 3 3 0 10ms
โœ… FacetToolbarAccessibilityTests 5 5 0 10ms
โœ… FacetViewModelLogoDelegateTests 4 4 0 28ms
โœ… FacetViewModelTests 18 18 0 79ms
โœ… FetchManifestWithBearerTokenLCPSafetyTests 1 1 0 11ms
โœ… FetchManifestWithBearerTokenTests 9 9 0 87ms
โœ… FetchOpenAccessManifestLCPSafetyTests 4 4 0 16ms
โœ… FileURLGenerationTests 3 3 0 26ms
โœ… FindawayChapterStatusGuardTests 1 1 0 3ms
โœ… FloatTPPAdditionsTests 5 5 0 10ms
โœ… FocusIndicationTests 7 7 0 31ms
โœ… FontManagerTests 17 17 0 195ms
โœ… ForceResetTests 6 6 0 29ms
โœ… GeneralCacheTests 20 20 0 3.79s
โœ… GroupEnumTests 1 1 0 8ms
โœ… HTMLTextViewTests 70 70 0 22.99s
โœ… HoldNotificationClassificationTests 2 2 0 5ms
โœ… HoldsBadgeCountTests 9 9 0 89ms
โœ… HoldsBookViewModelTests 8 8 0 36ms
โœ… HoldsReducerTests 11 11 0 120ms
โœ… HoldsSyncFailureTests 12 12 0 318ms
โœ… HoldsViewModelTests 23 23 0 1.05s
โœ… ImageCacheTypeTests 1 1 0 5ms
โœ… ImageLoaderTests 11 11 0 82ms
โœ… IntExtensionsTests 4 4 0 14ms
โœ… KeyboardNavigationFKATests 11 11 0 38ms
โœ… KeyboardNavigationHandlerTests 16 16 0 50ms
โœ… KeyboardVoiceOverTests 5 5 0 73ms
โœ… LCPAcquisitionPredicateTests 4 4 0 13ms
โœ… LCPAdapterTests 8 8 0 148ms
โœ… LCPAudiobookURLSchemeTests 4 4 0 8ms
โœ… LCPAudiobooksTests 21 21 0 123ms
โœ… LCPBotanCRLGuardTests 5 5 0 35ms
โœ… LCPCharacterizationTests 31 31 0 136ms
โœ… LCPClientTests 8 8 0 35ms
โœ… LCPFulfillmentHandlerTests 8 8 0 732ms
โœ… LCPLibraryServiceTests 20 20 0 498ms
โœ… LCPLicenseDocumentDetectionTests 5 5 0 10ms
โœ… LCPLicenseFilePathTests 3 3 0 6ms
โœ… LCPOrphanedDownloadRegistryTests 4 4 0 96ms
โœ… LCPPDFAcquisitionPredicateTests 5 5 0 60ms
โœ… LCPPDFDiskExtractTests 5 5 0 57ms
โœ… LCPPDFOpenProgressTests 13 13 0 91ms
โœ… LCPPassphraseReadinessTests 2 2 0 8ms
โœ… LCPSessionIdentifierTests 3 3 0 10ms
โœ… LegacySAMLProblemDocumentPropagationTests 7 7 0 745ms
โœ… LibraryCatalogMergerTests 9 9 0 23ms
โœ… LibraryRegistryCrawlerTests 14 14 0 213ms
โœ… LicensesServiceTests 4 4 0 19ms
โœ… LiveCrawlableParsingTest 4 0 0 29ms
โœ… LocalBookContentServiceTests 7 7 0 58ms
โœ… LocalFileAdapterTests 6 5 0 44ms
โœ… LogTests 14 14 0 359ms
โœ… LoginKeyboardTests 8 8 0 115ms
โœ… MainActorHelpersTests 22 22 0 696ms
โœ… MappedCatalogBridgeTests 3 3 0 41ms
โœ… MappedCatalogModelTests 11 11 0 438ms
โœ… MockBackendExpiredCredentialsTests 3 3 0 64ms
โœ… MockBackendIntegrationTests 4 4 0 64ms
โœ… MockBackendLoanLimitTests 2 2 0 16ms
โœ… MockBackendRouteMatchingTests 4 4 0 11ms
โœ… MockBackendServerDownTests 1 1 0 23ms
โœ… MockIsolationLintTests 3 3 0 24ms
โœ… MultiLibraryTokenIsolationTests 14 14 0 153ms
โœ… MyBooksDownloadCenterAdeptGapTests 3 3 0 13ms
โœ… MyBooksDownloadCenterConcurrencyTests 21 21 0 368ms
โœ… MyBooksDownloadCenterEvictionTests 7 7 0 250ms
โœ… MyBooksDownloadCenterOfflineTests 8 8 0 607ms
โœ… MyBooksDownloadSessionInvalidationTests 3 3 0 18ms
โœ… MyBooksSimplifiedBearerTokenTests 17 17 0 90ms
โœ… MyBooksViewModelBooksPublisherTests 3 3 0 42ms
โœ… MyBooksViewModelConcurrencyTests 4 4 0 38ms
โœ… MyBooksViewModelDownloadStateTests 3 3 0 25ms
โœ… MyBooksViewModelEmptyArrayTests 3 3 0 9ms
โœ… MyBooksViewModelEmptyStateTests 4 4 0 70ms
โœ… MyBooksViewModelExtendedTests 15 15 0 87ms
โœ… MyBooksViewModelFacetIntegrationTests 4 4 0 35ms
โœ… MyBooksViewModelFacetPublisherTests 3 3 0 9ms
โœ… MyBooksViewModelFilterSortInteractionTests 2 2 0 22ms
โœ… MyBooksViewModelFilterTests 9 9 0 75ms
โœ… MyBooksViewModelGuardConditionsTests 2 2 0 16ms
โœ… MyBooksViewModelLargeDatasetTests 2 2 0 494ms
โœ… MyBooksViewModelLoadAccountTests 2 2 0 200ms
โœ… MyBooksViewModelLoginStateTests 4 4 0 350ms
โœ… MyBooksViewModelMultipleAuthorSortingTests 3 3 0 29ms
โœ… MyBooksViewModelNotificationTests 4 4 0 322ms
โœ… MyBooksViewModelOfflineFilteringTests 3 3 0 38ms
โœ… MyBooksViewModelPublisherTests 7 7 0 31ms
โœ… MyBooksViewModelSearchEdgeCaseTests 6 6 0 68ms
โœ… MyBooksViewModelSearchQueryTests 3 3 0 26ms
โœ… MyBooksViewModelSortPersistenceTests 3 3 0 123ms
โœ… MyBooksViewModelSortingIntegrationTests 5 5 0 30ms
โœ… MyBooksViewModelSortingTests 6 6 0 65ms
โœ… MyBooksViewModelStateTransitionTests 3 3 0 382ms
โœ… MyBooksViewModelUIBindingTests 3 3 0 13ms
โœ… NSErrorAdditionsTests 7 7 0 17ms
โœ… NSNotificationTPPTests 3 3 0 8ms
โœ… NavigationCoordinatorTests 17 17 0 47ms
โœ… NavigationFreezePreventionTests 5 5 0 24ms
โœ… NetworkExecutorCredentialGuardTests 8 8 0 66ms
โœ… NetworkExecutorResponseRegressionTests 4 4 0 100ms
โœ… NetworkExecutorTaskTypeTests 3 3 0 45ms
โœ… NetworkOfflineDetectionTests 3 3 0 6ms
โœ… NetworkQueueTests 11 11 0 833ms
โœ… NetworkRequestQueueTests 2 2 0 10.12s
โœ… NetworkRetryLogicTests 7 7 0 36ms
โœ… NetworkTimeoutTests 2 2 0 5ms
โœ… NotificationEventTypeContractTests 7 7 0 20ms
โœ… NotificationPayloadContractTests 10 10 0 62ms
โœ… NotificationServiceStateMachineTests 9 9 0 1.51s
โœ… NotificationServiceTests 16 16 0 44ms
โœ… NotificationServiceTokenTests 13 13 0 97ms
โœ… NotificationSyncThrottleTests 5 5 0 17ms
โœ… NotificationTokenDataTests 4 4 0 7ms
โœ… NotificationTokenRegistrationTests 10 10 0 17ms
โœ… NowPlayingCoordinatorBackgroundTests 6 6 0 780ms
โœ… NowPlayingCoordinatorTests 19 19 0 197ms
โœ… OAuthSAMLRedirectRegressionTests 4 4 0 587ms
โœ… OIDCAuthDocumentParsingTests 4 4 0 2.13s
โœ… OIDCAuthTypeTests 5 5 0 10ms
โœ… OIDCAuthenticationPropertyTests 8 8 0 982ms
โœ… OIDCCallbackEdgeCaseTests 9 9 0 1.17s
โœ… OIDCCallbackHandlingTests 5 5 0 489ms
โœ… OIDCCallbackSchemeTests 3 3 0 9ms
โœ… OIDCIsolationRegressionTests 6 6 0 661ms
โœ… OIDCLoginRoutingTests 3 3 0 667ms
โœ… OIDCMakeRequestTests 3 3 0 260ms
โœ… OIDCNSCodingTests 1 1 0 96ms
โœ… OIDCNetworkLayer401Tests 5 5 0 423ms
โœ… OIDCReauthOnExpiredTokenTests 5 5 0 505ms
โœ… OIDCRedirectURIConstructionTests 6 6 0 625ms
โœ… OIDCRegressionTests 9 9 0 729ms
โœ… OIDCSelectedAuthenticationTests 2 2 0 216ms
โœ… OIDCSignOutRegressionTests 6 6 0 1.33s
โœ… OIDCTokenRefreshRegressionTests 6 6 0 634ms
โœ… OIDCUpdateUserAccountTests 5 5 0 465ms
โœ… OIDCViewModelRegressionTests 1 1 0 84ms
โœ… OIDCViewModelSignInTests 2 2 0 58ms
โœ… OPDS1BorrowEntryContractTests 4 4 0 29ms
โœ… OPDS1CatalogGroupedContractTests 3 3 0 20ms
โœ… OPDS1HoldEntriesContractTests 4 4 0 43ms
โœ… OPDS1LoansFeedContractTests 6 6 0 92ms
โœ… OPDS1ParsingTests 34 34 0 213ms
โœ… OPDS1RevokeResponseContractTests 2 2 0 17ms
โœ… OPDS2AuthenticationDocumentTests 18 18 0 78ms
โœ… OPDS2AvailabilityTests 4 4 0 13ms
โœ… OPDS2BookBridgeTests 44 44 0 802ms
โœ… OPDS2BorrowResponseContractTests 3 3 0 9ms
โœ… OPDS2CatalogWiringTests 17 17 0 121ms
โœ… OPDS2CatalogsFeedTests 3 3 0 221ms
โœ… OPDS2ContributorTests 2 2 0 9ms
โœ… OPDS2EmptyFeedContractTests 1 1 0 22ms
โœ… OPDS2FeedContractTests 4 4 0 35ms
โœ… OPDS2FeedParsingTests 11 11 0 364ms
โœ… OPDS2FeedTests 13 13 0 38ms
โœ… OPDS2FullMetadataTests 4 4 0 65ms
โœ… OPDS2FullPublicationTests 13 13 0 132ms
โœ… OPDS2IntegrationTests 18 18 0 175ms
โœ… OPDS2LinkArrayTests 5 5 0 16ms
โœ… OPDS2LinkComputedPropertyTests 20 20 0 43ms
โœ… OPDS2LinkRelTests 1 1 0 2ms
โœ… OPDS2LinkTests 2 2 0 226ms
โœ… OPDS2ParsingTests 38 38 0 162ms
โœ… OPDS2PublicationExtendedTests 46 46 0 265ms
โœ… OPDS2PublicationImageTests 6 6 0 16ms
โœ… OPDS2PublicationNarratorTests 3 3 0 30ms
โœ… OPDS2PublicationTests 2 2 0 220ms
โœ… OPDS2SamlIDPTests 6 6 0 11ms
โœ… OPDS2SearchResultsContractTests 3 3 0 24ms
โœ… OPDS2SubjectTests 2 2 0 10ms
โœ… OPDS2SupportingTypesTests 5 5 0 34ms
โœ… OPDSAcquisitionPathExpandedTests 15 15 0 679ms
โœ… OPDSFeedCacheTests 14 14 0 37ms
โœ… OPDSFeedMigrationTests 11 11 0 80ms
โœ… OPDSFeedParsingTests 2 2 0 190ms
โœ… OPDSFeedServiceStateMachineTests 3 3 0 784ms
โœ… OPDSFeedServiceTests 2 2 0 6ms
โœ… OPDSFormatTests 13 13 0 46ms
โœ… OPDSParserCoreTests 4 4 0 10ms
โœ… OPDSParserTests 4 4 0 8ms
โœ… OPDSParsingTests 54 54 0 2.21s
โœ… OfflineActionTests 29 29 0 76ms
โœ… OfflineQueueServiceExtendedTests 13 13 0 5.24s
โœ… OfflineQueueServiceTests 17 17 0 7.03s
โœ… OpenAccessAdapterTests 6 6 0 79ms
โœ… OverdriveDeferredFulfillmentTests 6 6 0 19ms
โœ… OverdriveDownloadHandlerTests 9 9 0 288ms
โœ… OverdriveFulfillmentTests 5 5 0 65ms
โœ… PDFExtensionsTests 20 20 0 38ms
โœ… PDFReaderTests 12 12 0 35ms
โœ… PP3596RegressionTests 3 3 0 73ms
โœ… Palace 2 2 0 <1ms
โœ… PalaceCheckPropertyTests 8 8 0 306ms
โœ… PalaceErrorCategoryTests 20 20 0 65ms
โœ… PalaceErrorExtendedTests 23 23 0 129ms
โœ… PalaceErrorTests 11 11 0 71ms
โœ… ParserFuzzTests 4 4 0 35.20s
โœ… PatronProfileContractTests 4 4 0 13ms
โœ… PerformanceMonitorTests 14 14 0 222ms
โœ… PerformanceReportTests 14 14 0 65ms
โœ… PersistentLoggerTests 9 9 0 2.22s
โœ… PlaybackBootstrapperTests 8 8 0 60ms
โœ… PlaybackFailureRecordTests 5 5 0 19ms
โœ… PlaybackRateTests 16 16 0 43ms
โœ… PlaybackTrackingRegressionTests 5 5 0 108ms
โœ… PositionPersistenceLogicTests 6 6 0 10ms
โœ… PositionPersistenceTests 2 2 0 7ms
โœ… PositionSyncServiceTests 13 13 0 191ms
โœ… PositionSyncTests 5 5 0 12ms
โœ… PositionWriterContractTests 6 6 0 95ms
โœ… PostUpdateMigrationTests 5 5 0 48ms
โœ… ProblemDocumentContractTests 4 4 0 10ms
โœ… ProblemDocumentLoanExpiryTests 5 5 0 9ms
โœ… ProblemDocumentTests 12 12 0 43ms
โœ… ProblemReportEmailTests 8 8 0 28ms
โœ… ReachabilityTests 2 2 0 6ms
โœ… Reader2PositionAdapterContractTests 4 3 0 315ms
โœ… ReaderAccessibilityTests 7 7 0 11ms
โœ… ReaderErrorTests 5 5 0 15ms
โœ… ReaderNavBarVoiceOverTests 2 2 0 10ms
โœ… ReaderServiceSyncTests 3 3 0 14ms
โœ… ReaderThemeTests 24 24 0 357ms
โœ… ReadingPositionTests 22 22 0 61ms
โœ… ReadingSessionTrackerTests 13 13 0 145ms
โœ… ReadingStatsServiceTests 12 12 0 209ms
โœ… ReadingStatsStoreTests 9 9 0 102ms
โœ… RedirectHandlingIntegrationTests 4 4 0 89ms
โœ… RedirectPolicyTests 9 9 0 85ms
โœ… RemoteFeatureFlagsGapTests 4 4 0 51ms
โœ… RemoteFeatureFlagsTests 13 13 0 41ms
โœ… RetryClassificationTests 17 17 0 61ms
โœ… ReturnFlowTests 1 1 0 6ms
โœ… RightsManagementDetectionTests 5 5 0 17ms
โœ… RightsManagementDispatcherTests 10 10 0 124ms
โœ… SAMLCookieSyncTests 5 5 0 13ms
โœ… SAMLLogoutCallbackDetectionTests 4 4 0 9ms
โœ… SAMLLogoutLinkParsingTests 5 5 0 107ms
โœ… SAMLLogoutURLTests 4 4 0 19ms
โœ… SAMLPlusBiblioBoardExpirationTests 8 8 0 7.64s
โœ… SEMigrationsTests 6 6 0 138ms
โœ… SafeDictionaryTests 21 21 0 259ms
โœ… SamplePlayerErrorTests 5 5 0 21ms
โœ… SampleTypeTests 8 8 0 41ms
โœ… SceneDelegateTests 1 1 0 3ms
โœ… SearchAccessibilityTests 6 6 0 10ms
โœ… SearchFlowIntegrationTests 8 8 0 78ms
โœ… SettingsViewModelComputedPropertyTests 6 6 0 158ms
โœ… SettingsViewModelEdgeCaseTests 7 7 0 48ms
โœ… SettingsViewModelGapTests 1 1 0 3ms
โœ… SettingsViewModelSyncTests 14 14 0 37ms
โœ… SettingsViewModelTests 33 33 0 360ms
โœ… SignInModalPredicateTests 7 7 0 14ms
โœ… SignInModalSAMLOIDCTests 6 6 0 29ms
โœ… SignInOAuthErrorPropagationTests 8 8 0 853ms
โœ… SignInToReadFlowIntegrationTests 5 5 0 7.46s
โœ… SignInWebSheetIntegrationTests 3 3 0 2.35s
โœ… SignInWebSheetViewModelTests 31 31 0 81ms
โœ… SignOutCacheClearingTests 3 3 0 10ms
โœ… StatsViewModelTests 10 10 0 265ms
โœ… StatusAnnouncementTests 22 22 0 95ms
โœ… StopPositionSaveTests 2 2 0 4ms
โœ… StoreTests 5 5 0 22ms
โœ… StringExtensionTests 8 8 0 17ms
โœ… StringExtensionsTests 3 3 0 566ms
โœ… StringHTMLEntitiesTests 7 7 0 13ms
โœ… StringNYPLAdditionsTests 4 4 0 31ms
โœ… String_NYPLAdditionsTests 4 4 0 17ms
โœ… SyncConflictResolutionTests 3 3 0 9ms
โœ… SyncDeletionGuardTests 5 5 0 9ms
โœ… SyncDeletionRatioTests 6 6 0 20ms
โœ… SyncPermissionTests 5 5 0 329ms
โœ… TPPAccountAuthStateEnumTests 5 5 0 12ms
โœ… TPPAccountListDataSourceTests 3 3 0 7ms
โœ… TPPAdobeActivationSkipTests 6 6 0 635ms
โœ… TPPAgeCheckCompletionTests 5 5 0 428ms
โœ… TPPAgeCheckIsValidTests 5 5 0 22ms
โœ… TPPAgeCheckStateMachineTests 3 3 0 723ms
โœ… TPPAgeCheckTests 6 6 0 1.70s
โœ… TPPAgeCheckVerifyDecisionTests 5 5 0 416ms
โœ… TPPAlertUtilsTests 45 45 0 729ms
โœ… TPPAnnotationsHermeticTests 15 15 0 69ms
โœ… TPPAnnotationsOverrideTests 4 4 0 480ms
โœ… TPPAnnotationsTests 29 29 0 5.46s
โœ… TPPAnnouncementManagerTests 3 3 0 9ms
โœ… TPPAuthDocumentContractTests 3 3 0 54ms
โœ… TPPBackgroundExecutorTests 3 3 0 19ms
โœ… TPPBadgeImageGapTests 2 2 0 21ms
โœ… TPPBaseReaderViewControllerInitialLocationTests 5 5 0 38ms
โœ… TPPBasicAuthTests 11 11 0 23ms
โœ… TPPBookAccessibilityLabelTests 8 8 0 37ms
โœ… TPPBookAuthorCoverageTests 3 3 0 5ms
โœ… TPPBookAuthorTests 6 6 0 12ms
โœ… TPPBookBearerTokenTests 9 8 0 90ms
โœ… TPPBookButtonsStateTests 7 7 0 35ms
โœ… TPPBookContentMetadataFilesHelperTests 9 9 0 18ms
โœ… TPPBookContentTypeConverterTests 4 4 0 9ms
โœ… TPPBookContentTypeExtendedTests 4 4 0 8ms
โœ… TPPBookContentTypeTests 14 14 0 60ms
โœ… TPPBookCoverRegistryTests 14 14 0 621ms
โœ… TPPBookCreationTests 7 7 0 147ms
โœ… TPPBookExtensionsTests 21 21 0 124ms
โœ… TPPBookLocationCoverageTests 7 7 0 24ms
โœ… TPPBookLocationEdgeCaseTests 27 27 0 83ms
โœ… TPPBookLocationKeyTests 3 3 0 10ms
โœ… TPPBookLocationTests 11 11 0 19ms
โœ… TPPBookModelGapTests 4 4 0 37ms
โœ… TPPBookRegistryAsyncReadinessTests 3 3 0 441ms
โœ… TPPBookRegistryAtomicWriteTests 7 7 0 6.03s
โœ… TPPBookRegistryBookRetrievalTests 7 7 0 44ms
โœ… TPPBookRegistryBookmarkTests 7 7 0 81ms
โœ… TPPBookRegistryCorruptedDataTests 5 5 0 70ms
โœ… TPPBookRegistryDataTests 4 4 0 13ms
โœ… TPPBookRegistryDependencyTests 4 4 0 1.82s
โœ… TPPBookRegistryFulfillmentIdTests 4 4 0 21ms
โœ… TPPBookRegistryLargeCorpusTests 5 5 0 2m 3s
โœ… TPPBookRegistryLoadReentrancyTests 2 2 0 5ms
โœ… TPPBookRegistryLocationTests 4 4 0 36ms
โœ… TPPBookRegistryMigrationTests 16 16 0 14.59s
โœ… TPPBookRegistryPersistenceTests 10 10 0 13.54s
โœ… TPPBookRegistryProcessingTests 2 2 0 4ms
โœ… TPPBookRegistryPublisherTests 6 6 0 59ms
โœ… TPPBookRegistryRecordPersistenceTests 3 3 0 26ms
โœ… TPPBookRegistryRecordTests 10 10 0 39ms
โœ… TPPBookRegistryStateManagementTests 11 11 0 47ms
โœ… TPPBookRegistryThreadSafetyTests 3 3 0 295ms
โœ… TPPBookRegistryUpdateAndRemoveTests 1 1 0 40ms
โœ… TPPBookRequiresAdobeDRMTests 6 6 0 32ms
โœ… TPPBookSerializationTests 13 13 0 57ms
โœ… TPPBookStateInitializationTests 4 4 0 9ms
โœ… TPPBookStateTests 4 4 0 12ms
โœ… TPPBookTests 83 83 0 394ms
โœ… TPPBookmarkDeletionLogTests 11 11 0 128ms
โœ… TPPBookmarkFactoryInitTests 2 2 0 9ms
โœ… TPPBookmarkFactoryServerAnnotationEdgeCaseTests 5 5 0 20ms
โœ… TPPBookmarkFactoryTests 15 15 0 112ms
โœ… TPPBookmarkR3ConversionTests 5 5 0 26ms
โœ… TPPBookmarkR3LocationTests 13 13 0 24ms
โœ… TPPBookmarkSpecTests 1 1 0 6ms
โœ… TPPCachingTests 3 3 0 8ms
โœ… TPPCapturedCredentialsTests 5 5 0 420ms
โœ… TPPConfigurationTests 22 22 0 111ms
โœ… TPPContentTypeTests 7 7 0 17ms
โœ… TPPCredentialConcurrencyTests 3 3 0 8ms
โœ… TPPCredentialIsolationE2ETests 5 0 0 192ms
โœ… TPPCredentialPersistenceTests 6 6 0 685ms
โœ… TPPCredentialSnapshotCoherenceTests 3 0 0 184ms
โœ… TPPCredentialSnapshotTests 8 8 0 18ms
โœ… TPPCredentialsCoverageTests 9 9 0 18ms
โœ… TPPCredentialsTests 26 26 0 151ms
โœ… TPPCrossLibrarySignOutTests 6 6 0 716ms
โœ… TPPDRMFailureCredentialPreservationTests 4 4 0 381ms
โœ… TPPErrorLoggerTests 27 27 0 459ms
โœ… TPPIdleSignOutRegressionTests 13 13 0 1.44s
โœ… TPPJWKConversionTest 1 1 0 13ms
โœ… TPPKeychainManagerTests 5 5 0 29ms
โœ… TPPLastReadPositionPosterTests 13 13 0 434ms
โœ… TPPLastReadPositionSynchronizerIntegrationTests 5 5 0 30ms
โœ… TPPLastReadPositionSynchronizerTests 23 23 0 79ms
โœ… TPPLastReadPositionSynchronizer_BehaviorDocumentationTests 5 5 0 15ms
โœ… TPPLastReadPositionSynchronizer_BookLocationTests 9 9 0 21ms
โœ… TPPLastReadPositionSynchronizer_ConcurrencyTests 3 3 0 9ms
โœ… TPPLastReadPositionSynchronizer_ReadiumBookmarkTests 9 9 0 40ms
โœ… TPPLastReadPositionSynchronizer_SyncLogicTests 10 10 0 58ms
โœ… TPPLastReadPositionSynchronizer_WriterDelegationTests 4 4 0 24ms
โœ… TPPLoginNoActivationTests 3 3 0 430ms
โœ… TPPMainThreadCheckerTests 4 4 0 10ms
โœ… TPPMigrationManagerTests 15 15 0 63ms
โœ… TPPNetworkExecutorAPITests 14 14 0 137ms
โœ… TPPNetworkExecutorStubbedTests 17 17 0 290ms
โœ… TPPNetworkExecutorTests 3 3 0 17ms
โœ… TPPNetworkResponderTests 12 12 0 47ms
โœ… TPPOPDSAcquisitionPathTests 2 2 0 19ms
โœ… TPPOPDSEntryTests 5 5 0 50ms
โœ… TPPOPDSFeedTests 3 3 0 203ms
โœ… TPPOPDSGroupSwiftTests 3 3 0 6ms
โœ… TPPOPDSLinkTests 7 7 0 24ms
โœ… TPPOpenSearchDescriptionExpandedTests 10 10 0 30ms
โœ… TPPOpenSearchDescriptionTests 1 1 0 3ms
โœ… TPPPDFDocumentMetadataTests 15 15 0 91ms
โœ… TPPPDFDocumentTests 8 8 0 32ms
โœ… TPPPDFLocationCoverageTests 7 7 0 23ms
โœ… TPPPDFLocationTests 10 10 0 35ms
โœ… TPPPDFPageBookmarkTests 9 9 0 52ms
โœ… TPPPDFPageTests 5 5 0 13ms
โœ… TPPPDFReaderModeTests 6 6 0 10ms
โœ… TPPPerAccountIsolationTests 8 0 0 367ms
โœ… TPPPreferredAuthSelectionTests 8 8 0 669ms
โœ… TPPProblemDocumentCacheManagerTests 12 12 0 101ms
โœ… TPPProblemDocumentTests 21 21 0 104ms
โœ… TPPReaderAppearanceTests 4 4 0 14ms
โœ… TPPReaderBookmarksBusinessLogicTests 12 12 0 1.28s
โœ… TPPReaderBookmarksReadinessTests 2 2 0 237ms
โœ… TPPReaderFontTests 4 4 0 7ms
โœ… TPPReaderPreferencesLoadTests 3 3 0 27ms
โœ… TPPReaderSettingsTests 28 28 0 114ms
โœ… TPPReaderTOCBusinessLogicTests 15 15 0 3.07s
โœ… TPPReaderTOCFlattenTests 2 2 0 1.01s
โœ… TPPReadiumBookmarkLocationMatchingTests 5 5 0 12ms
โœ… TPPReadiumBookmarkTests 21 21 0 54ms
โœ… TPPReauthenticatorMockTests 2 2 0 5ms
โœ… TPPReauthenticatorTests 4 4 0 11ms
โœ… TPPReturnPromptHelperTests 5 5 0 18ms
โœ… TPPSAMLCookieExpirationTests 5 5 0 81ms
โœ… TPPSAMLFlowTests 10 10 0 45ms
โœ… TPPSAMLReauthFlowTests 2 2 0 303ms
โœ… TPPSAMLRegressionTests 4 4 0 334ms
โœ… TPPSAMLSignInTests 26 26 0 2.27s
โœ… TPPSAMLStateIsolationTests 4 4 0 265ms
โœ… TPPSAMLStateMachineTests 6 6 0 441ms
โœ… TPPSettingsTests 6 6 0 40ms
โœ… TPPSignInAdobeSkipTests 14 14 0 1.39s
โœ… TPPSignInAuthStateTransitionTests 3 3 0 271ms
โœ… TPPSignInBusinessLogicExtendedTests 58 58 0 7.26s
โœ… TPPSignInBusinessLogicOAuthTests 11 11 0 893ms
โœ… TPPSignInBusinessLogicSignOutTests 11 11 0 1.16s
โœ… TPPSignInBusinessLogicStateMachineTests 9 9 0 1.65s
โœ… TPPSignInBusinessLogicTests 15 15 0 1.52s
โœ… TPPSignInBusinessLogicTokenFlowTests 3 3 0 337ms
โœ… TPPSignInBusinessLogicValidationCallbackOrderTests 2 2 0 340ms
โœ… TPPSignInErrorHandlingTests 2 2 0 229ms
โœ… TPPSignInProfileDocEdgeCaseTests 3 3 0 383ms
โœ… TPPSignedInStateProviderTests 3 3 0 6ms
โœ… TPPUserAccountAuthStateTests 6 6 0 22ms
โœ… TPPUserAccountGapTests 4 4 0 13ms
โœ… TPPUserFriendlyErrorTests 11 11 0 22ms
โœ… TPPUserNotificationsTests 10 10 0 91ms
โœ… TPPXMLSwiftTests 16 16 0 61ms
โœ… TPPXMLTests 3 3 0 9ms
โœ… TimeEntryTests 3 3 0 8ms
โœ… TokenRefreshAndRetryQueueTests 9 9 0 6.22s
โœ… TokenRefreshIntegrationTests 2 2 0 180ms
โœ… TokenRefreshInterceptorTests 22 22 0 5.66s
โœ… TokenRefreshOnForegroundTests 10 10 0 1.34s
โœ… TokenRefreshTests 25 25 0 127ms
โœ… TokenRequestCredentialGuardTests 13 13 0 113ms
โœ… TokenRequestTests 11 11 0 40ms
โœ… TokenResponseTests 21 21 0 50ms
โœ… TypographyPresetTests 21 21 0 171ms
โœ… TypographyServiceTests 31 31 0 1.14s
โœ… TypographySettingsViewModelTests 27 27 0 536ms
โœ… UIAlertCACommitGuardTests 8 8 0 242ms
โœ… UIColor_NYPLAdditionsTests 1 1 0 4ms
โœ… URLBackupExclusionTests 3 3 0 12ms
โœ… URLExtensionTests 16 16 0 36ms
โœ… URLExtensionsTests 6 6 0 18ms
โœ… URLRequestExtensionsCoverageTests 3 3 0 9ms
โœ… URLRequestExtensionsTests 11 11 0 38ms
โœ… URLRequestNYPLAdditionsTests 11 11 0 85ms
โœ… URLRequest_NYPLTests 1 1 0 2ms
โœ… URLResponseAuthenticationTests 10 10 0 25ms
โœ… URLResponseNYPLTests 14 14 0 28ms
โœ… URLSessionCredentialStorageTests 3 3 0 6ms
โœ… URLTypeTests 2 2 0 18ms
โœ… URLValidationTests 5 5 0 9ms
โœ… UnifiedOPDSServiceStateMachineTests 2 2 0 340ms
โœ… UserAccountPublisherAuthStateTests 5 5 0 27ms
โœ… UserAccountPublisherTests 11 11 0 799ms
โœ… UserAccountValidationTests 11 11 0 1.47s
โœ… UserProfileDocumentTests 7 7 0 56ms
โœ… UserRetryTrackerTests 10 10 0 39ms
โœ… iPadOnMacRMSDKGuardTests 1 1 0 2ms

๐Ÿ“ˆ Code Coverage

Target Coverage Lines
Palace.app
44.9%
37445 / 83374

๐Ÿ“‹ All Tests

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