@coveo/quantic 3.33.0 → 3.33.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +15 -15
- package/force-app/main/default/lwc/quanticAriaLive/__tests__/quanticAriaLive.test.js +106 -0
- package/force-app/main/default/lwc/quanticBreadcrumbManager/__tests__/quanticBreadcrumbManager.test.js +752 -0
- package/force-app/main/default/lwc/quanticBreadcrumbManager/e2e/fixture.ts +76 -0
- package/force-app/main/default/lwc/quanticBreadcrumbManager/e2e/pageObject.ts +282 -0
- package/force-app/main/default/lwc/quanticBreadcrumbManager/e2e/quanticBreadcrumbManager.e2e.ts +167 -0
- package/force-app/main/default/lwc/quanticCarousel/__tests__/quanticCarousel.test.js +262 -0
- package/force-app/main/default/lwc/quanticCaseClassification/__tests__/quanticCaseClassification.test.js +819 -0
- package/force-app/main/default/lwc/quanticCaseClassification/e2e/data.ts +23 -0
- package/force-app/main/default/lwc/quanticCaseClassification/e2e/fixture.ts +51 -0
- package/force-app/main/default/lwc/quanticCaseClassification/e2e/pageObject.ts +152 -0
- package/force-app/main/default/lwc/quanticCaseClassification/e2e/quanticCaseClassification.e2e.ts +269 -0
- package/force-app/main/default/lwc/quanticCategoryFacet/__tests__/quanticCategoryFacet.test.js +1183 -0
- package/force-app/main/default/lwc/quanticCategoryFacet/e2e/data.ts +27 -0
- package/force-app/main/default/lwc/quanticCategoryFacet/e2e/fixture.ts +75 -0
- package/force-app/main/default/lwc/quanticCategoryFacet/e2e/pageObject.ts +55 -0
- package/force-app/main/default/lwc/quanticCategoryFacet/e2e/quanticCategoryFacet.e2e.ts +199 -0
- package/force-app/main/default/lwc/quanticCitation/__tests__/quanticCitation.test.js +371 -0
- package/force-app/main/default/lwc/quanticColoredResultBadge/__tests__/quanticColoredResultBadge.test.js +212 -0
- package/force-app/main/default/lwc/quanticDateFacet/__tests__/quanticDateFacet.test.js +688 -0
- package/force-app/main/default/lwc/quanticDateFacet/e2e/data.ts +24 -0
- package/force-app/main/default/lwc/quanticDateFacet/e2e/fixture.ts +68 -0
- package/force-app/main/default/lwc/quanticDateFacet/e2e/pageObject.ts +27 -0
- package/force-app/main/default/lwc/quanticDateFacet/e2e/quanticDateFacet.e2e.ts +145 -0
- package/force-app/main/default/lwc/quanticDidYouMean/__tests__/quanticDidYouMean.test.js +348 -0
- package/force-app/main/default/lwc/quanticDidYouMean/e2e/data.ts +48 -0
- package/force-app/main/default/lwc/quanticDidYouMean/e2e/fixture.ts +80 -0
- package/force-app/main/default/lwc/quanticDidYouMean/e2e/pageObject.ts +173 -0
- package/force-app/main/default/lwc/quanticDidYouMean/e2e/quanticDidYouMean.e2e.ts +219 -0
- package/force-app/main/default/lwc/quanticDocumentSuggestion/__tests__/quanticDocumentSuggestion.test.js +404 -0
- package/force-app/main/default/lwc/quanticDocumentSuggestion/e2e/fixture.ts +38 -0
- package/force-app/main/default/lwc/quanticDocumentSuggestion/e2e/pageObject.ts +52 -0
- package/force-app/main/default/lwc/quanticDocumentSuggestion/e2e/quanticDocumentSuggestion.e2e.ts +102 -0
- package/force-app/main/default/lwc/quanticFacet/__tests__/quanticFacet.test.js +1105 -0
- package/force-app/main/default/lwc/quanticFacet/e2e/data.ts +21 -0
- package/force-app/main/default/lwc/quanticFacet/e2e/fixture.ts +73 -0
- package/force-app/main/default/lwc/quanticFacet/e2e/pageObject.ts +67 -0
- package/force-app/main/default/lwc/quanticFacet/e2e/quanticFacet.e2e.ts +208 -0
- package/force-app/main/default/lwc/quanticFacetCaption/__tests__/quanticFacetCaption.test.js +28 -0
- package/force-app/main/default/lwc/quanticFacetManager/__tests__/quanticFacetManager.test.js +178 -0
- package/force-app/main/default/lwc/quanticFacetManager/e2e/fixture.ts +64 -0
- package/force-app/main/default/lwc/quanticFacetManager/e2e/pageObject.ts +23 -0
- package/force-app/main/default/lwc/quanticFacetManager/e2e/quanticFacetManager.e2e.ts +82 -0
- package/force-app/main/default/lwc/quanticFeedback/__tests__/quanticFeedback.test.js +392 -0
- package/force-app/main/default/lwc/quanticFeedbackModal/__tests__/quanticFeedbackModal.test.js +448 -0
- package/force-app/main/default/lwc/quanticFeedbackModalQna/__tests__/quanticFeedbackModalQna.test.js +298 -0
- package/force-app/main/default/lwc/quanticFoldedResultList/__tests__/quanticFoldedResultList.test.js +323 -0
- package/force-app/main/default/lwc/quanticFoldedResultList/e2e/fixture.ts +70 -0
- package/force-app/main/default/lwc/quanticFoldedResultList/e2e/pageObject.ts +81 -0
- package/force-app/main/default/lwc/quanticFoldedResultList/e2e/quanticFoldedResultList.e2e.ts +69 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswer/__tests__/quanticGeneratedAnswer.test.js +1158 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswer/e2e/data.ts +56 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswer/e2e/fixture.ts +185 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswer/e2e/pageObject.ts +451 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswer/e2e/quanticGeneratedAnswer.e2e.ts +337 -0
- package/force-app/main/default/lwc/quanticGeneratedAnswerContent/__tests__/quanticGeneratedAnswerContent.test.js +151 -0
- package/force-app/main/default/lwc/quanticHeading/__tests__/quanticHeading.test.js +71 -0
- package/force-app/main/default/lwc/quanticHeadlessLoader/__tests__/quanticHeadlessLoader.test.js +651 -0
- package/force-app/main/default/lwc/quanticInsightInterface/__tests__/quanticInsightInterface.test.js +194 -0
- package/force-app/main/default/lwc/quanticInsightSummary/__tests__/quanticInsightSummary.test.js +230 -0
- package/force-app/main/default/lwc/quanticModal/__tests__/quanticModal.test.js +205 -0
- package/force-app/main/default/lwc/quanticNotifications/__tests__/quanticNotifications.test.js +309 -0
- package/force-app/main/default/lwc/quanticNotifications/e2e/fixture.ts +58 -0
- package/force-app/main/default/lwc/quanticNotifications/e2e/pageObject.ts +55 -0
- package/force-app/main/default/lwc/quanticNotifications/e2e/quanticNotifications.e2e.ts +47 -0
- package/force-app/main/default/lwc/quanticNumericFacet/__tests__/quanticNumericFacet.test.js +953 -0
- package/force-app/main/default/lwc/quanticNumericFacet/e2e/data.ts +28 -0
- package/force-app/main/default/lwc/quanticNumericFacet/e2e/fixture.ts +71 -0
- package/force-app/main/default/lwc/quanticNumericFacet/e2e/pageObject.ts +59 -0
- package/force-app/main/default/lwc/quanticNumericFacet/e2e/quanticNumericFacet.e2e.ts +164 -0
- package/force-app/main/default/lwc/quanticPager/__tests__/quanticPager.test.js +430 -0
- package/force-app/main/default/lwc/quanticPager/e2e/fixture.ts +65 -0
- package/force-app/main/default/lwc/quanticPager/e2e/pageObject.ts +69 -0
- package/force-app/main/default/lwc/quanticPager/e2e/quanticPager.e2e.ts +106 -0
- package/force-app/main/default/lwc/quanticPlaceholder/__tests__/quanticPlaceholder.test.js +47 -0
- package/force-app/main/default/lwc/quanticQuickviewContent/__tests__/data/defaultTestCase.json +13 -0
- package/force-app/main/default/lwc/quanticQuickviewContent/__tests__/data/youtubeTestCase.json +14 -0
- package/force-app/main/default/lwc/quanticQuickviewContent/__tests__/quanticQuickviewContent.test.js +82 -0
- package/force-app/main/default/lwc/quanticRadioButtonsGroup/__tests__/quanticRadioButtonsGroup.test.js +273 -0
- package/force-app/main/default/lwc/quanticRecentQueriesList/__tests__/quanticRecentQueriesList.test.js +448 -0
- package/force-app/main/default/lwc/quanticRecentQueriesList/e2e/fixture.ts +42 -0
- package/force-app/main/default/lwc/quanticRecentQueriesList/e2e/pageObject.ts +55 -0
- package/force-app/main/default/lwc/quanticRecentQueriesList/e2e/quanticRecentQueriesList.e2e.ts +93 -0
- package/force-app/main/default/lwc/quanticRecentResultsList/__tests__/quanticRecentResultsList.test.js +516 -0
- package/force-app/main/default/lwc/quanticRecentResultsList/e2e/fixture.ts +42 -0
- package/force-app/main/default/lwc/quanticRecentResultsList/e2e/pageObject.ts +61 -0
- package/force-app/main/default/lwc/quanticRecentResultsList/e2e/quanticRecentResultsList.e2e.ts +48 -0
- package/force-app/main/default/lwc/quanticRecommendationList/__tests__/quanticRecommendationList.test.js +491 -0
- package/force-app/main/default/lwc/quanticRecommendationList/e2e/fixture.ts +35 -0
- package/force-app/main/default/lwc/quanticRecommendationList/e2e/pageObject.ts +52 -0
- package/force-app/main/default/lwc/quanticRecommendationList/e2e/quanticRecommendationList.e2e.ts +53 -0
- package/force-app/main/default/lwc/quanticRefineModalContent/__tests__/quanticRefineModalContent.test.js +747 -0
- package/force-app/main/default/lwc/quanticRefineToggle/__tests__/quanticRefineToggle.test.js +542 -0
- package/force-app/main/default/lwc/quanticResultAction/__tests__/quanticResultAction.test.js +262 -0
- package/force-app/main/default/lwc/quanticResultActionBar/__tests__/quanticResultActionBar.test.js +141 -0
- package/force-app/main/default/lwc/quanticResultChildren/__tests__/quanticResultChildren.test.js +340 -0
- package/force-app/main/default/lwc/quanticResultCopyToClipboard/__tests__/quanticResultCopyToClipboard.test.js +300 -0
- package/force-app/main/default/lwc/quanticResultCopyToClipboard/e2e/fixture.ts +46 -0
- package/force-app/main/default/lwc/quanticResultCopyToClipboard/e2e/pageObject.ts +49 -0
- package/force-app/main/default/lwc/quanticResultCopyToClipboard/e2e/quanticResultCopyToClipboard.e2e.ts +40 -0
- package/force-app/main/default/lwc/quanticResultDate/__tests__/quanticResultDate.test.js +144 -0
- package/force-app/main/default/lwc/quanticResultField/__tests__/quanticResultField.test.js +120 -0
- package/force-app/main/default/lwc/quanticResultHighlightedTextField/__tests__/quanticResultHighlightedTextField.test.js +209 -0
- package/force-app/main/default/lwc/quanticResultLink/__tests__/quanticResultLink.test.js +261 -0
- package/force-app/main/default/lwc/quanticResultList/__tests__/quanticResultList.test.js +342 -0
- package/force-app/main/default/lwc/quanticResultList/e2e/fixture.ts +66 -0
- package/force-app/main/default/lwc/quanticResultList/e2e/pageObject.ts +81 -0
- package/force-app/main/default/lwc/quanticResultList/e2e/quanticResultList.e2e.ts +69 -0
- package/force-app/main/default/lwc/quanticResultMultiValueText/__tests__/quanticResultMultiValueText.test.js +235 -0
- package/force-app/main/default/lwc/quanticResultNumber/__tests__/quanticResultNumber.test.js +144 -0
- package/force-app/main/default/lwc/quanticResultPrintableUri/__tests__/quanticResultPrintableUri.test.js +324 -0
- package/force-app/main/default/lwc/quanticResultQuickview/__tests__/quanticResultQuickview.test.js +301 -0
- package/force-app/main/default/lwc/quanticResultQuickview/e2e/fixture.ts +81 -0
- package/force-app/main/default/lwc/quanticResultQuickview/e2e/pageObject.ts +38 -0
- package/force-app/main/default/lwc/quanticResultQuickview/e2e/quanticResultQuickView.e2e.ts +66 -0
- package/force-app/main/default/lwc/quanticResultTemplate/__tests__/quanticResultTemplate.test.js +90 -0
- package/force-app/main/default/lwc/quanticResultText/__tests__/quanticResultText.test.js +155 -0
- package/force-app/main/default/lwc/quanticResultsPerPage/__tests__/quanticResultsPerPage.test.js +464 -0
- package/force-app/main/default/lwc/quanticResultsPerPage/e2e/fixture.ts +74 -0
- package/force-app/main/default/lwc/quanticResultsPerPage/e2e/pageObject.ts +85 -0
- package/force-app/main/default/lwc/quanticResultsPerPage/e2e/quanticResultsPerPage.e2e.ts +97 -0
- package/force-app/main/default/lwc/quanticSearchBox/__tests__/quanticSearchBox.test.js +487 -0
- package/force-app/main/default/lwc/quanticSearchBox/e2e/fixture.ts +84 -0
- package/force-app/main/default/lwc/quanticSearchBox/e2e/pageObject.ts +45 -0
- package/force-app/main/default/lwc/quanticSearchBox/e2e/quanticSearchBox.e2e.ts +159 -0
- package/force-app/main/default/lwc/quanticSearchBoxInput/__tests__/quanticSearchBoxInput.test.js +743 -0
- package/force-app/main/default/lwc/quanticSearchBoxSuggestionsList/__tests__/quanticSearchBoxSuggestionsList.test.js +571 -0
- package/force-app/main/default/lwc/quanticSearchBoxSuggestionsList/e2e/fixture.ts +110 -0
- package/force-app/main/default/lwc/quanticSearchBoxSuggestionsList/e2e/pageObject.ts +113 -0
- package/force-app/main/default/lwc/quanticSearchBoxSuggestionsList/e2e/quanticSearchBoxSuggestionsList.e2e.ts +299 -0
- package/force-app/main/default/lwc/quanticSmartSnippet/__tests__/quanticSmartSnippet.test.js +341 -0
- package/force-app/main/default/lwc/quanticSmartSnippet/e2e/data.ts +21 -0
- package/force-app/main/default/lwc/quanticSmartSnippet/e2e/fixture.ts +91 -0
- package/force-app/main/default/lwc/quanticSmartSnippet/e2e/pageObject.ts +196 -0
- package/force-app/main/default/lwc/quanticSmartSnippet/e2e/quanticSmartSnippet.e2e.ts +192 -0
- package/force-app/main/default/lwc/quanticSmartSnippetAnswer/__tests__/quanticSmartSnippetAnswer.test.js +126 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSource/__tests__/quanticSmartSnippetSource.test.js +290 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSuggestions/__tests__/quanticSmartSnippetSuggestions.test.js +329 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSuggestions/e2e/data.ts +31 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSuggestions/e2e/fixture.ts +93 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSuggestions/e2e/pageObject.ts +160 -0
- package/force-app/main/default/lwc/quanticSmartSnippetSuggestions/e2e/quanticSmartSnippetSuggestions.e2e.ts +127 -0
- package/force-app/main/default/lwc/quanticSort/__tests__/quanticSort.test.js +416 -0
- package/force-app/main/default/lwc/quanticSort/e2e/fixture.ts +61 -0
- package/force-app/main/default/lwc/quanticSort/e2e/pageObject.ts +89 -0
- package/force-app/main/default/lwc/quanticSort/e2e/quanticSort.e2e.ts +91 -0
- package/force-app/main/default/lwc/quanticSourceCitations/__tests__/quanticSourceCitations.test.js +136 -0
- package/force-app/main/default/lwc/quanticStandaloneSearchBox/__tests__/quanticStandaloneSearchBox.test.js +387 -0
- package/force-app/main/default/lwc/quanticStandaloneSearchBox/e2e/fixture.ts +53 -0
- package/force-app/main/default/lwc/quanticStandaloneSearchBox/e2e/pageObject.ts +54 -0
- package/force-app/main/default/lwc/quanticStandaloneSearchBox/e2e/quanticStandaloneSearchBox.e2e.ts +72 -0
- package/force-app/main/default/lwc/quanticStatefulButton/__tests__/quanticStatefulButton.test.js +222 -0
- package/force-app/main/default/lwc/quanticSummary/__tests__/quanticSummary.test.js +244 -0
- package/force-app/main/default/lwc/quanticTab/__tests__/quanticTab.test.js +333 -0
- package/force-app/main/default/lwc/quanticTab/e2e/fixture.ts +56 -0
- package/force-app/main/default/lwc/quanticTab/e2e/pageObject.ts +68 -0
- package/force-app/main/default/lwc/quanticTab/e2e/quanticTab.e2e.ts +72 -0
- package/force-app/main/default/lwc/quanticTabBar/__tests__/quanticTabBar.test.js +331 -0
- package/force-app/main/default/lwc/quanticTabBar/e2e/fixture.ts +61 -0
- package/force-app/main/default/lwc/quanticTabBar/e2e/pageObject.ts +80 -0
- package/force-app/main/default/lwc/quanticTabBar/e2e/quanticTabBar.e2e.ts +171 -0
- package/force-app/main/default/lwc/quanticTimeframeFacet/__tests__/quanticTimeframeFacet.test.js +1037 -0
- package/force-app/main/default/lwc/quanticTimeframeFacet/e2e/fixture.ts +58 -0
- package/force-app/main/default/lwc/quanticTimeframeFacet/e2e/pageObject.ts +43 -0
- package/force-app/main/default/lwc/quanticTimeframeFacet/e2e/quanticTimeframeFacet.e2e.ts +160 -0
- package/force-app/main/default/lwc/quanticTooltip/__tests__/quanticTooltip.test.js +107 -0
- package/force-app/main/default/lwc/quanticUserAction/__tests__/quanticUserAction.test.js +427 -0
- package/force-app/main/default/lwc/quanticUserActionsSession/__tests__/quanticUserActionsSession.test.js +269 -0
- package/force-app/main/default/lwc/quanticUserActionsTimeline/__tests__/data/userActionsState.json +89 -0
- package/force-app/main/default/lwc/quanticUserActionsTimeline/__tests__/quanticUserActionsTimeline.test.js +511 -0
- package/force-app/main/default/lwc/quanticUserActionsToggle/__tests__/quanticUserActionsToggle.test.js +229 -0
- package/force-app/main/default/lwc/quanticUserActionsToggle/e2e/data.ts +32 -0
- package/force-app/main/default/lwc/quanticUserActionsToggle/e2e/fixture.ts +32 -0
- package/force-app/main/default/lwc/quanticUserActionsToggle/e2e/pageObject.ts +71 -0
- package/force-app/main/default/lwc/quanticUserActionsToggle/e2e/quanticUserActionsToggle.e2e.ts +39 -0
- package/force-app/main/default/lwc/quanticUtils/__tests__/citationAnchoringUtils.test.js +84 -0
- package/force-app/main/default/lwc/quanticUtils/__tests__/facetDependenciesUtils.test.js +92 -0
- package/force-app/main/default/lwc/quanticUtils/__tests__/markdownUtils.test.js +71 -0
- package/force-app/main/default/lwc/quanticUtils/__tests__/quanticUtils.test.js +223 -0
- package/force-app/main/default/lwc/quanticViewedByCustomerBadge/__tests__/quanticViewedByCustomerBadge.test.js +131 -0
- package/force-app/main/default/staticresources/coveoheadless/case-assist/headless.js +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/case-assist-engine/case-assist-engine.d.ts +3 -3
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/commerce-engine/commerce-engine.d.ts +16 -16
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/common-reducers.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/insight-engine/insight-engine.d.ts +5 -5
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/recommendation-engine/recommendation-engine.d.ts +4 -4
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/search-engine/search-engine.d.ts +4 -4
- package/force-app/main/default/staticresources/coveoheadless/definitions/app/store.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/controllers/commerce/core/facets/headless-core-commerce-facet.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/controllers/core/facets/range-facet/headless-core-range-facet.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/actions-history/ipx-actions-history-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/advanced-search-queries/advanced-search-queries-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/attached-results/attached-results-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/case-assist-configuration/case-assist-configuration-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/case-context/case-context-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/case-field/case-field-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/case-field/case-field-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/case-input/case-input-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/configuration/configuration-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/context/cart/cart-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/context/cart/cart-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/context/context-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/did-you-mean/did-you-mean-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/facets/facet-search-set/commerce-facet-search-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/facets/facet-set/facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/facets/field-suggestions-order/field-suggestions-order-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/facets/numeric-facet/manual-numeric-facet-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/instant-products/instant-products-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/pagination/pagination-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/parameters/parameters-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/product/product-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/product-listing/product-listing-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/product-listing/product-listing-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/query/query-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/query-suggest/query-suggest-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/recent-queries/recent-queries-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/recommendations/recommendations-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/recommendations/recommendations-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/search/search-actions.d.ts +4 -4
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/search/search-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/sort/sort-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/standalone-search-box-set/standalone-search-box-set-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/standalone-search-box-set/standalone-search-box-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/commerce/triggers/triggers-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/configuration/configuration-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/context/context-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/debug/debug-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/debug/version-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/dictionary-field-context/dictionary-field-context-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/did-you-mean/did-you-mean-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/document-suggestion/document-suggestion-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/document-suggestion/document-suggestion-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/excerpt-length/excerpt-length-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facet-options/facet-options-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/automatic-facet-set/automatic-facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/category-facet-set/category-facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-order/facet-order-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-search-set/category/category-facet-search-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-search-set/generic/generic-facet-search-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-search-set/specific/specific-facet-search-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-set/facet-set-controller-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/facet-set/facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/range-facets/date-facet-set/date-facet-controller-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/range-facets/date-facet-set/date-facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/range-facets/numeric-facet-set/numeric-facet-controller-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/facets/range-facets/numeric-facet-set/numeric-facet-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/fields/fields-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/fields/fields-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/folding/folding-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/folding/folding-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/folding/insight-folding-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/generated-answer/generated-answer-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/generated-answer/generated-answer-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/history/history-actions.d.ts +3 -3
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/history/history-slice.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-configuration/insight-configuration-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-interface/insight-interface-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-interface/insight-interface-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-search/insight-search-actions.d.ts +5 -5
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-search/legacy/insight-search-actions.d.ts +4 -4
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-user-actions/insight-user-actions-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/insight-user-actions/insight-user-actions-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/instant-results/instant-results-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/pagination/pagination-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/pipeline/pipeline-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/query/query-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/query-set/query-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/query-suggest/query-suggest-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/query-suggest/query-suggest-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/question-answering/question-answering-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/recent-queries/recent-queries-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/recent-results/recent-results-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/recommendation/recommendation-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/recommendation/recommendation-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/result-preview/result-preview-actions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/result-preview/result-preview-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/search/legacy/search-actions.d.ts +5 -5
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/search/search-actions.d.ts +6 -6
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/search/search-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/search-hub/search-hub-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/sort-criteria/sort-criteria-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/standalone-search-box-set/standalone-search-box-set-actions.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/standalone-search-box-set/standalone-search-box-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/static-filter-set/static-filter-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/tab-set/tab-set-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/features/triggers/triggers-slice.d.ts +1 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/ssr/commerce/factories/build-factory.d.ts +6 -1
- package/force-app/main/default/staticresources/coveoheadless/definitions/ssr/common/access-token-manager.d.ts +19 -0
- package/force-app/main/default/staticresources/coveoheadless/definitions/ssr-next/commerce/types/engine.d.ts +4 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/ssr-next/common/access-token-manager.d.ts +19 -0
- package/force-app/main/default/staticresources/coveoheadless/definitions/ssr-next/search/engine/search-engine.ssr.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/definitions/test/mock-ssr-controller-definitions.d.ts +2 -2
- package/force-app/main/default/staticresources/coveoheadless/headless.js +2 -2
- package/force-app/main/default/staticresources/coveoheadless/insight/headless.js +2 -2
- package/force-app/main/default/staticresources/coveoheadless/recommendation/headless.js +2 -2
- package/package.json +46 -44
package/force-app/main/default/lwc/quanticGeneratedAnswer/__tests__/quanticGeneratedAnswer.test.js
ADDED
|
@@ -0,0 +1,1158 @@
|
|
|
1
|
+
/* eslint-disable no-import-assign */
|
|
2
|
+
// @ts-ignore
|
|
3
|
+
import {createElement} from 'lwc';
|
|
4
|
+
import QuanticGeneratedAnswer from 'c/quanticGeneratedAnswer';
|
|
5
|
+
import * as mockHeadlessLoader from 'c/quanticHeadlessLoader';
|
|
6
|
+
|
|
7
|
+
let mockAnswerHeight = 250;
|
|
8
|
+
let mockedConsoleWarn;
|
|
9
|
+
|
|
10
|
+
const exampleItemOne = document.createElement('div');
|
|
11
|
+
exampleItemOne.innerText = 'Custom error message';
|
|
12
|
+
const exampleAssignedElements = [exampleItemOne];
|
|
13
|
+
const exampleCitations = [
|
|
14
|
+
{
|
|
15
|
+
id: 'citation1',
|
|
16
|
+
title: 'Example Citation 1',
|
|
17
|
+
uri: 'https://example.com/1',
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
id: 'citation2',
|
|
21
|
+
title: 'Example Citation 2',
|
|
22
|
+
uri: 'https://example.com/2',
|
|
23
|
+
},
|
|
24
|
+
];
|
|
25
|
+
jest.mock('c/quanticHeadlessLoader');
|
|
26
|
+
jest.mock('c/quanticUtils', () => ({
|
|
27
|
+
AriaLiveRegion: jest.fn(() => ({
|
|
28
|
+
dispatchMessage: jest.fn(),
|
|
29
|
+
})),
|
|
30
|
+
loadMarkdownDependencies: jest.fn(
|
|
31
|
+
() =>
|
|
32
|
+
new Promise((resolve) => {
|
|
33
|
+
resolve();
|
|
34
|
+
})
|
|
35
|
+
),
|
|
36
|
+
getAbsoluteHeight: jest.fn(() => {
|
|
37
|
+
return mockAnswerHeight;
|
|
38
|
+
}),
|
|
39
|
+
I18nUtils: {
|
|
40
|
+
format: jest.fn(),
|
|
41
|
+
},
|
|
42
|
+
}));
|
|
43
|
+
jest.mock(
|
|
44
|
+
'@salesforce/label/c.quantic_NoGeneratedAnswer',
|
|
45
|
+
() => ({default: 'No generated answer available.'}),
|
|
46
|
+
{
|
|
47
|
+
virtual: true,
|
|
48
|
+
}
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
/** @type {Object} */
|
|
52
|
+
const defaultOptions = {
|
|
53
|
+
fieldsToIncludeInCitations: 'sfid,sfkbid,sfkavid,filetype',
|
|
54
|
+
answerConfigurationId: undefined,
|
|
55
|
+
withToggle: false,
|
|
56
|
+
collapsible: false,
|
|
57
|
+
maxCollapsedHeight: 250,
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
function createTestComponent(options = defaultOptions, assignedElements = []) {
|
|
61
|
+
mockSlotAssignedNodes(assignedElements);
|
|
62
|
+
const element = createElement('c-quantic-generated-answer', {
|
|
63
|
+
is: QuanticGeneratedAnswer,
|
|
64
|
+
});
|
|
65
|
+
for (const [key, value] of Object.entries(options)) {
|
|
66
|
+
element[key] = value;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
document.body.appendChild(element);
|
|
70
|
+
return element;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const selectors = {
|
|
74
|
+
initializationError: 'c-quantic-component-error',
|
|
75
|
+
generatedAnswerCard: '[data-testid="generated-answer__card"]',
|
|
76
|
+
generatedAnswer: '[data-testid="generated-answer__answer"]',
|
|
77
|
+
generatedAnswerBadge: '[data-testid="generated-answer__badge"]',
|
|
78
|
+
generatedAnswerRetryButton: '[data-testid="generated-answer__retry-button"]',
|
|
79
|
+
generatedAnswerActions: '[data-testid="generated-answer__actions"]',
|
|
80
|
+
generatedAnswerToggleButton: 'c-quantic-generated-answer-toggle',
|
|
81
|
+
generatedAnswerContent: 'c-quantic-generated-answer-content',
|
|
82
|
+
generatingMessageWhenAnswerCollapsed:
|
|
83
|
+
'[data-testid="generated-answer__collapse-generating-message"]',
|
|
84
|
+
generatedAnswerCollapseToggle:
|
|
85
|
+
'[data-testid="generated-answer__answer-toggle"]',
|
|
86
|
+
generatedAnswerDisclaimer: '[data-testid="generated-answer__disclaimer"]',
|
|
87
|
+
generatedAnswerNoAnswerCard:
|
|
88
|
+
'[data-testid="generated-answer__no-answer-card"]',
|
|
89
|
+
generatedAnswerNoAnswerMessage:
|
|
90
|
+
'[data-testid="generated-answer__no-answer-message"]',
|
|
91
|
+
generatedAnswerCitations: 'c-quantic-source-citations',
|
|
92
|
+
loadingSpinner: 'lightning-spinner',
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
const initialSearchStatusState = {
|
|
96
|
+
hasError: false,
|
|
97
|
+
};
|
|
98
|
+
let searchStatusState = initialSearchStatusState;
|
|
99
|
+
|
|
100
|
+
const initialGeneratedAnswerState = {isVisible: true, cannotAnswer: false};
|
|
101
|
+
let generatedAnswerState = initialGeneratedAnswerState;
|
|
102
|
+
|
|
103
|
+
const functionsMocks = {
|
|
104
|
+
buildGeneratedAnswer: jest.fn(() => ({
|
|
105
|
+
state: generatedAnswerState,
|
|
106
|
+
subscribe: functionsMocks.generatedAnswerStateSubscriber,
|
|
107
|
+
retry: functionsMocks.retry,
|
|
108
|
+
})),
|
|
109
|
+
buildSearchStatus: jest.fn(() => ({
|
|
110
|
+
state: searchStatusState,
|
|
111
|
+
subscribe: functionsMocks.searchStatusStateSubscriber,
|
|
112
|
+
})),
|
|
113
|
+
generatedAnswerStateSubscriber: jest.fn((cb) => {
|
|
114
|
+
cb();
|
|
115
|
+
return functionsMocks.generatedAnswerStateUnsubscriber;
|
|
116
|
+
}),
|
|
117
|
+
searchStatusStateSubscriber: jest.fn((cb) => {
|
|
118
|
+
cb();
|
|
119
|
+
return functionsMocks.searchStatusStateUnsubscriber;
|
|
120
|
+
}),
|
|
121
|
+
generatedAnswerStateUnsubscriber: jest.fn(),
|
|
122
|
+
searchStatusStateUnsubscriber: jest.fn(),
|
|
123
|
+
retry: jest.fn(),
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* Mocks the return value of the assignedNodes method.
|
|
128
|
+
* @param {Array<Element>} assignedElements
|
|
129
|
+
*/
|
|
130
|
+
function mockSlotAssignedNodes(assignedElements) {
|
|
131
|
+
HTMLSlotElement.prototype.assignedNodes = function () {
|
|
132
|
+
return assignedElements;
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
// Helper function to wait until the microtask queue is empty.
|
|
137
|
+
function flushPromises() {
|
|
138
|
+
// eslint-disable-next-line @lwc/lwc/no-async-operation
|
|
139
|
+
return new Promise((resolve) => setTimeout(resolve, 0));
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
const exampleEngine = {
|
|
143
|
+
id: 'dummy engine',
|
|
144
|
+
};
|
|
145
|
+
let isInitialized = false;
|
|
146
|
+
const defaultAnswerHeight = 250;
|
|
147
|
+
|
|
148
|
+
function prepareHeadlessState() {
|
|
149
|
+
// @ts-ignore
|
|
150
|
+
mockHeadlessLoader.getHeadlessBundle = () => {
|
|
151
|
+
return {
|
|
152
|
+
buildGeneratedAnswer: functionsMocks.buildGeneratedAnswer,
|
|
153
|
+
buildSearchStatus: functionsMocks.buildSearchStatus,
|
|
154
|
+
};
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
function mockSuccessfulHeadlessInitialization() {
|
|
159
|
+
// @ts-ignore
|
|
160
|
+
mockHeadlessLoader.initializeWithHeadless = (element, _, initialize) => {
|
|
161
|
+
if (element instanceof QuanticGeneratedAnswer && !isInitialized) {
|
|
162
|
+
isInitialized = true;
|
|
163
|
+
initialize(exampleEngine);
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
function mockErroneousHeadlessInitialization() {
|
|
169
|
+
// @ts-ignore
|
|
170
|
+
mockHeadlessLoader.initializeWithHeadless = (element) => {
|
|
171
|
+
if (element instanceof QuanticGeneratedAnswer) {
|
|
172
|
+
element.setInitializationError();
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
function cleanup() {
|
|
178
|
+
// The jsdom instance is shared across test cases in a single file so reset the DOM
|
|
179
|
+
while (document.body.firstChild) {
|
|
180
|
+
document.body.removeChild(document.body.firstChild);
|
|
181
|
+
}
|
|
182
|
+
jest.clearAllMocks();
|
|
183
|
+
isInitialized = false;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
describe('c-quantic-generated-answer', () => {
|
|
187
|
+
beforeEach(() => {
|
|
188
|
+
mockedConsoleWarn = jest.spyOn(console, 'warn').mockImplementation();
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
afterEach(() => {
|
|
192
|
+
cleanup();
|
|
193
|
+
});
|
|
194
|
+
|
|
195
|
+
describe('when an initialization error occurs', () => {
|
|
196
|
+
beforeEach(() => {
|
|
197
|
+
mockErroneousHeadlessInitialization();
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
it('should display the initialization error component', async () => {
|
|
201
|
+
const element = createTestComponent();
|
|
202
|
+
await flushPromises();
|
|
203
|
+
|
|
204
|
+
const initializationError = element.shadowRoot.querySelector(
|
|
205
|
+
selectors.initializationError
|
|
206
|
+
);
|
|
207
|
+
|
|
208
|
+
expect(initializationError).not.toBeNull();
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
describe('when an RGA retryable error occurs', () => {
|
|
213
|
+
beforeEach(() => {
|
|
214
|
+
searchStatusState = {...initialSearchStatusState, hasError: false};
|
|
215
|
+
generatedAnswerState = {
|
|
216
|
+
...initialGeneratedAnswerState,
|
|
217
|
+
error: {
|
|
218
|
+
isRetryable: true,
|
|
219
|
+
},
|
|
220
|
+
};
|
|
221
|
+
mockSuccessfulHeadlessInitialization();
|
|
222
|
+
prepareHeadlessState();
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
afterAll(() => {
|
|
226
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
227
|
+
searchStatusState = initialSearchStatusState;
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
it('should display retry prompt', async () => {
|
|
231
|
+
const element = createTestComponent();
|
|
232
|
+
await flushPromises();
|
|
233
|
+
|
|
234
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
235
|
+
selectors.generatedAnswerCard
|
|
236
|
+
);
|
|
237
|
+
const generatedAnswerRetryButton = element.shadowRoot.querySelector(
|
|
238
|
+
selectors.generatedAnswerRetryButton
|
|
239
|
+
);
|
|
240
|
+
|
|
241
|
+
expect(generatedAnswerCard).not.toBeNull();
|
|
242
|
+
expect(generatedAnswerRetryButton).not.toBeNull();
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
describe('when the retry button is clicked', () => {
|
|
246
|
+
it('should call the retry method of the generated answer controller controller', async () => {
|
|
247
|
+
const element = createTestComponent();
|
|
248
|
+
await flushPromises();
|
|
249
|
+
|
|
250
|
+
const generatedAnswerRetryButton = element.shadowRoot.querySelector(
|
|
251
|
+
selectors.generatedAnswerRetryButton
|
|
252
|
+
);
|
|
253
|
+
|
|
254
|
+
expect(generatedAnswerRetryButton).not.toBeNull();
|
|
255
|
+
generatedAnswerRetryButton.click();
|
|
256
|
+
expect(functionsMocks.retry).toHaveBeenCalledTimes(1);
|
|
257
|
+
});
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
|
|
261
|
+
describe('controller initialization', () => {
|
|
262
|
+
beforeEach(() => {
|
|
263
|
+
mockSuccessfulHeadlessInitialization();
|
|
264
|
+
prepareHeadlessState();
|
|
265
|
+
});
|
|
266
|
+
|
|
267
|
+
it('should build the generated answer and search status controllers with the proper parameters', async () => {
|
|
268
|
+
createTestComponent();
|
|
269
|
+
await flushPromises();
|
|
270
|
+
|
|
271
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledTimes(1);
|
|
272
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledWith(
|
|
273
|
+
exampleEngine,
|
|
274
|
+
{
|
|
275
|
+
initialState: {
|
|
276
|
+
isVisible: true,
|
|
277
|
+
responseFormat: {
|
|
278
|
+
contentFormat: ['text/markdown', 'text/plain'],
|
|
279
|
+
},
|
|
280
|
+
},
|
|
281
|
+
fieldsToIncludeInCitations:
|
|
282
|
+
defaultOptions.fieldsToIncludeInCitations.split(','),
|
|
283
|
+
}
|
|
284
|
+
);
|
|
285
|
+
expect(functionsMocks.buildSearchStatus).toHaveBeenCalledTimes(1);
|
|
286
|
+
expect(functionsMocks.buildSearchStatus).toHaveBeenCalledWith(
|
|
287
|
+
exampleEngine
|
|
288
|
+
);
|
|
289
|
+
});
|
|
290
|
+
|
|
291
|
+
it('should subscribe to the headless generated answer and search status state changes', async () => {
|
|
292
|
+
createTestComponent();
|
|
293
|
+
await flushPromises();
|
|
294
|
+
|
|
295
|
+
expect(
|
|
296
|
+
functionsMocks.generatedAnswerStateSubscriber
|
|
297
|
+
).toHaveBeenCalledTimes(1);
|
|
298
|
+
expect(functionsMocks.searchStatusStateSubscriber).toHaveBeenCalledTimes(
|
|
299
|
+
1
|
|
300
|
+
);
|
|
301
|
+
});
|
|
302
|
+
|
|
303
|
+
describe('when the answer configuration id property is passed to the component', () => {
|
|
304
|
+
it('should initialize the controller with the correct answer configuration id value', async () => {
|
|
305
|
+
const exampleAnswerConfigValue = 'exampleAnswerConfig';
|
|
306
|
+
createTestComponent({
|
|
307
|
+
...defaultOptions,
|
|
308
|
+
answerConfigurationId: exampleAnswerConfigValue,
|
|
309
|
+
});
|
|
310
|
+
await flushPromises();
|
|
311
|
+
|
|
312
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledTimes(1);
|
|
313
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledWith(
|
|
314
|
+
exampleEngine,
|
|
315
|
+
expect.objectContaining({
|
|
316
|
+
answerConfigurationId: exampleAnswerConfigValue,
|
|
317
|
+
})
|
|
318
|
+
);
|
|
319
|
+
});
|
|
320
|
+
});
|
|
321
|
+
|
|
322
|
+
describe('when the answer configuration id property is not passed to the component', () => {
|
|
323
|
+
it('should initialize the controller without the answer configuration id value', async () => {
|
|
324
|
+
createTestComponent();
|
|
325
|
+
await flushPromises();
|
|
326
|
+
|
|
327
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledTimes(1);
|
|
328
|
+
expect(functionsMocks.buildGeneratedAnswer).toHaveBeenCalledWith(
|
|
329
|
+
exampleEngine,
|
|
330
|
+
expect.not.objectContaining({
|
|
331
|
+
answerConfigurationId: expect.any(String),
|
|
332
|
+
})
|
|
333
|
+
);
|
|
334
|
+
});
|
|
335
|
+
});
|
|
336
|
+
});
|
|
337
|
+
|
|
338
|
+
describe('the rendering of the generated answer', () => {
|
|
339
|
+
describe('when the answer is streaming', () => {
|
|
340
|
+
const exampleAnswer = 'answer being generated';
|
|
341
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
342
|
+
beforeEach(() => {
|
|
343
|
+
generatedAnswerState = {
|
|
344
|
+
...initialGeneratedAnswerState,
|
|
345
|
+
isStreaming: true,
|
|
346
|
+
answer: exampleAnswer,
|
|
347
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
348
|
+
};
|
|
349
|
+
mockSuccessfulHeadlessInitialization();
|
|
350
|
+
prepareHeadlessState();
|
|
351
|
+
});
|
|
352
|
+
|
|
353
|
+
afterAll(() => {
|
|
354
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
355
|
+
});
|
|
356
|
+
|
|
357
|
+
it('should display the generated answer card', async () => {
|
|
358
|
+
const element = createTestComponent();
|
|
359
|
+
await flushPromises();
|
|
360
|
+
|
|
361
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
362
|
+
selectors.generatedAnswerCard
|
|
363
|
+
);
|
|
364
|
+
const generatedAnswerBadge = element.shadowRoot.querySelector(
|
|
365
|
+
selectors.generatedAnswerBadge
|
|
366
|
+
);
|
|
367
|
+
|
|
368
|
+
expect(generatedAnswerCard).not.toBeNull();
|
|
369
|
+
expect(generatedAnswerBadge).not.toBeNull();
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
describe('when the property withToggle is set to true', () => {
|
|
373
|
+
it('should display the generated answer toggle button', async () => {
|
|
374
|
+
const element = createTestComponent({
|
|
375
|
+
...defaultOptions,
|
|
376
|
+
withToggle: true,
|
|
377
|
+
});
|
|
378
|
+
await flushPromises();
|
|
379
|
+
|
|
380
|
+
const generatedAnswerToggleButton = element.shadowRoot.querySelector(
|
|
381
|
+
selectors.generatedAnswerToggleButton
|
|
382
|
+
);
|
|
383
|
+
|
|
384
|
+
expect(generatedAnswerToggleButton).not.toBeNull();
|
|
385
|
+
});
|
|
386
|
+
});
|
|
387
|
+
|
|
388
|
+
describe('when the property collapsible is set to true', () => {
|
|
389
|
+
describe('when the answer is shorter than the maximum answer height', () => {
|
|
390
|
+
beforeEach(() => {
|
|
391
|
+
mockAnswerHeight = defaultAnswerHeight - 100;
|
|
392
|
+
});
|
|
393
|
+
|
|
394
|
+
it('should not display the generating answer message', async () => {
|
|
395
|
+
const element = createTestComponent({
|
|
396
|
+
...defaultOptions,
|
|
397
|
+
collapsible: true,
|
|
398
|
+
});
|
|
399
|
+
await flushPromises();
|
|
400
|
+
|
|
401
|
+
const generatingMessageWhenAnswerCollapsed =
|
|
402
|
+
element.shadowRoot.querySelector(
|
|
403
|
+
selectors.generatingMessageWhenAnswerCollapsed
|
|
404
|
+
);
|
|
405
|
+
|
|
406
|
+
expect(generatingMessageWhenAnswerCollapsed).toBeNull();
|
|
407
|
+
});
|
|
408
|
+
});
|
|
409
|
+
|
|
410
|
+
describe('when the answer is longer than the maximum answer height', () => {
|
|
411
|
+
beforeEach(() => {
|
|
412
|
+
mockAnswerHeight = defaultAnswerHeight + 100;
|
|
413
|
+
});
|
|
414
|
+
|
|
415
|
+
it('should display the generating answer message', async () => {
|
|
416
|
+
const element = createTestComponent({
|
|
417
|
+
...defaultOptions,
|
|
418
|
+
collapsible: true,
|
|
419
|
+
});
|
|
420
|
+
await flushPromises();
|
|
421
|
+
|
|
422
|
+
const generatingMessageWhenAnswerCollapsed =
|
|
423
|
+
element.shadowRoot.querySelector(
|
|
424
|
+
selectors.generatingMessageWhenAnswerCollapsed
|
|
425
|
+
);
|
|
426
|
+
|
|
427
|
+
expect(generatingMessageWhenAnswerCollapsed).not.toBeNull();
|
|
428
|
+
});
|
|
429
|
+
|
|
430
|
+
it('should not display the generated answer collapse toggle', async () => {
|
|
431
|
+
const element = createTestComponent({
|
|
432
|
+
...defaultOptions,
|
|
433
|
+
collapsible: true,
|
|
434
|
+
});
|
|
435
|
+
await flushPromises();
|
|
436
|
+
|
|
437
|
+
const generatedAnswerCollapseToggle =
|
|
438
|
+
element.shadowRoot.querySelector(
|
|
439
|
+
selectors.generatedAnswerCollapseToggle
|
|
440
|
+
);
|
|
441
|
+
|
|
442
|
+
expect(generatedAnswerCollapseToggle).toBeNull();
|
|
443
|
+
});
|
|
444
|
+
});
|
|
445
|
+
});
|
|
446
|
+
|
|
447
|
+
it('should display the generated answer content', async () => {
|
|
448
|
+
const element = createTestComponent();
|
|
449
|
+
await flushPromises();
|
|
450
|
+
|
|
451
|
+
const generatedAnswerContent = element.shadowRoot.querySelector(
|
|
452
|
+
selectors.generatedAnswerContent
|
|
453
|
+
);
|
|
454
|
+
|
|
455
|
+
expect(generatedAnswerContent).not.toBeNull();
|
|
456
|
+
expect(generatedAnswerContent.isStreaming).toBe(true);
|
|
457
|
+
expect(generatedAnswerContent.answer).toBe(exampleAnswer);
|
|
458
|
+
expect(generatedAnswerContent.answerContentFormat).toBe(
|
|
459
|
+
exampleAnswerContentFormat
|
|
460
|
+
);
|
|
461
|
+
});
|
|
462
|
+
|
|
463
|
+
it('should not display the generated answer actions', async () => {
|
|
464
|
+
const element = createTestComponent();
|
|
465
|
+
await flushPromises();
|
|
466
|
+
|
|
467
|
+
const generatedAnswerActions = element.shadowRoot.querySelector(
|
|
468
|
+
selectors.generatedAnswerActions
|
|
469
|
+
);
|
|
470
|
+
|
|
471
|
+
expect(generatedAnswerActions).toBeNull();
|
|
472
|
+
});
|
|
473
|
+
|
|
474
|
+
it('should not display the generated answer disclaimer', async () => {
|
|
475
|
+
const element = createTestComponent();
|
|
476
|
+
await flushPromises();
|
|
477
|
+
|
|
478
|
+
const generatedAnswerDisclaimer = element.shadowRoot.querySelector(
|
|
479
|
+
selectors.generatedAnswerDisclaimer
|
|
480
|
+
);
|
|
481
|
+
|
|
482
|
+
expect(generatedAnswerDisclaimer).toBeNull();
|
|
483
|
+
});
|
|
484
|
+
});
|
|
485
|
+
|
|
486
|
+
describe('when the answer is ready', () => {
|
|
487
|
+
const exampleAnswer = 'answer generated successfully';
|
|
488
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
489
|
+
beforeEach(() => {
|
|
490
|
+
generatedAnswerState = {
|
|
491
|
+
...initialGeneratedAnswerState,
|
|
492
|
+
isStreaming: false,
|
|
493
|
+
answer: exampleAnswer,
|
|
494
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
495
|
+
citations: exampleCitations,
|
|
496
|
+
};
|
|
497
|
+
mockSuccessfulHeadlessInitialization();
|
|
498
|
+
prepareHeadlessState();
|
|
499
|
+
});
|
|
500
|
+
|
|
501
|
+
afterAll(() => {
|
|
502
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
503
|
+
});
|
|
504
|
+
|
|
505
|
+
it('should display the generated answer card', async () => {
|
|
506
|
+
const element = createTestComponent();
|
|
507
|
+
await flushPromises();
|
|
508
|
+
|
|
509
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
510
|
+
selectors.generatedAnswerCard
|
|
511
|
+
);
|
|
512
|
+
const generatedAnswerBadge = element.shadowRoot.querySelector(
|
|
513
|
+
selectors.generatedAnswerBadge
|
|
514
|
+
);
|
|
515
|
+
|
|
516
|
+
expect(generatedAnswerCard).not.toBeNull();
|
|
517
|
+
expect(generatedAnswerBadge).not.toBeNull();
|
|
518
|
+
});
|
|
519
|
+
|
|
520
|
+
describe('when the property withToggle is set to true', () => {
|
|
521
|
+
it('should display the generated answer toggle button', async () => {
|
|
522
|
+
const element = createTestComponent({
|
|
523
|
+
...defaultOptions,
|
|
524
|
+
withToggle: true,
|
|
525
|
+
});
|
|
526
|
+
await flushPromises();
|
|
527
|
+
|
|
528
|
+
const generatedAnswerToggleButton = element.shadowRoot.querySelector(
|
|
529
|
+
selectors.generatedAnswerToggleButton
|
|
530
|
+
);
|
|
531
|
+
|
|
532
|
+
expect(generatedAnswerToggleButton).not.toBeNull();
|
|
533
|
+
});
|
|
534
|
+
});
|
|
535
|
+
|
|
536
|
+
describe('when the property collapsible is set to true', () => {
|
|
537
|
+
describe('when the answer is shorter than the maximum answer height', () => {
|
|
538
|
+
beforeEach(() => {
|
|
539
|
+
mockAnswerHeight = defaultAnswerHeight - 100;
|
|
540
|
+
});
|
|
541
|
+
|
|
542
|
+
it('should not display the generating answer message', async () => {
|
|
543
|
+
const element = createTestComponent({
|
|
544
|
+
...defaultOptions,
|
|
545
|
+
collapsible: true,
|
|
546
|
+
});
|
|
547
|
+
await flushPromises();
|
|
548
|
+
|
|
549
|
+
const generatingMessageWhenAnswerCollapsed =
|
|
550
|
+
element.shadowRoot.querySelector(
|
|
551
|
+
selectors.generatingMessageWhenAnswerCollapsed
|
|
552
|
+
);
|
|
553
|
+
|
|
554
|
+
expect(generatingMessageWhenAnswerCollapsed).toBeNull();
|
|
555
|
+
});
|
|
556
|
+
|
|
557
|
+
it('should not display the generated answer collapse toggle', async () => {
|
|
558
|
+
const element = createTestComponent({
|
|
559
|
+
...defaultOptions,
|
|
560
|
+
collapsible: true,
|
|
561
|
+
});
|
|
562
|
+
await flushPromises();
|
|
563
|
+
|
|
564
|
+
const generatedAnswerCollapseToggle =
|
|
565
|
+
element.shadowRoot.querySelector(
|
|
566
|
+
selectors.generatedAnswerCollapseToggle
|
|
567
|
+
);
|
|
568
|
+
|
|
569
|
+
expect(generatedAnswerCollapseToggle).toBeNull();
|
|
570
|
+
});
|
|
571
|
+
});
|
|
572
|
+
|
|
573
|
+
describe('when the answer is longer than the maximum answer height', () => {
|
|
574
|
+
beforeEach(() => {
|
|
575
|
+
mockAnswerHeight = defaultAnswerHeight + 100;
|
|
576
|
+
});
|
|
577
|
+
|
|
578
|
+
it('should not display the generating answer message', async () => {
|
|
579
|
+
const element = createTestComponent({
|
|
580
|
+
...defaultOptions,
|
|
581
|
+
collapsible: true,
|
|
582
|
+
});
|
|
583
|
+
await flushPromises();
|
|
584
|
+
|
|
585
|
+
const generatingMessageWhenAnswerCollapsed =
|
|
586
|
+
element.shadowRoot.querySelector(
|
|
587
|
+
selectors.generatingMessageWhenAnswerCollapsed
|
|
588
|
+
);
|
|
589
|
+
|
|
590
|
+
expect(generatingMessageWhenAnswerCollapsed).toBeNull();
|
|
591
|
+
});
|
|
592
|
+
|
|
593
|
+
it('should display the generated answer collapse toggle', async () => {
|
|
594
|
+
const element = createTestComponent({
|
|
595
|
+
...defaultOptions,
|
|
596
|
+
collapsible: true,
|
|
597
|
+
});
|
|
598
|
+
await flushPromises();
|
|
599
|
+
|
|
600
|
+
const generatedAnswerCollapseToggle =
|
|
601
|
+
element.shadowRoot.querySelector(
|
|
602
|
+
selectors.generatedAnswerCollapseToggle
|
|
603
|
+
);
|
|
604
|
+
|
|
605
|
+
expect(generatedAnswerCollapseToggle).not.toBeNull();
|
|
606
|
+
});
|
|
607
|
+
});
|
|
608
|
+
|
|
609
|
+
describe('when the property maxCollapsedHeight is set to a custom value', () => {
|
|
610
|
+
// The valid range is between 150 and 500 pixels.
|
|
611
|
+
describe('when the maxCollapsedHeight value is within the valid range and the answer exceeds it', () => {
|
|
612
|
+
it('should display the generated answer as collapsed and set the maxHeight of the generated answer to the given custom value', async () => {
|
|
613
|
+
const expectedMaxCollapsibleAnswerHeight = 300;
|
|
614
|
+
mockAnswerHeight = 350;
|
|
615
|
+
const element = createTestComponent({
|
|
616
|
+
...defaultOptions,
|
|
617
|
+
collapsible: true,
|
|
618
|
+
maxCollapsedHeight: expectedMaxCollapsibleAnswerHeight,
|
|
619
|
+
});
|
|
620
|
+
await flushPromises();
|
|
621
|
+
|
|
622
|
+
const generatedAnswer = element.shadowRoot.querySelector(
|
|
623
|
+
selectors.generatedAnswer
|
|
624
|
+
);
|
|
625
|
+
expect(generatedAnswer).not.toBeNull();
|
|
626
|
+
|
|
627
|
+
const generatedAnswerCollapseToggle =
|
|
628
|
+
element.shadowRoot.querySelector(
|
|
629
|
+
selectors.generatedAnswerCollapseToggle
|
|
630
|
+
);
|
|
631
|
+
expect(generatedAnswerCollapseToggle).not.toBeNull();
|
|
632
|
+
|
|
633
|
+
const maxHeightValue =
|
|
634
|
+
generatedAnswer.style.getPropertyValue('--maxHeight');
|
|
635
|
+
expect(maxHeightValue).toEqual(
|
|
636
|
+
`${expectedMaxCollapsibleAnswerHeight}px`
|
|
637
|
+
);
|
|
638
|
+
|
|
639
|
+
expect(mockedConsoleWarn).not.toHaveBeenCalled();
|
|
640
|
+
});
|
|
641
|
+
});
|
|
642
|
+
|
|
643
|
+
describe('when the maxCollapsedHeight value is greater than the valid range', () => {
|
|
644
|
+
it('should set the generated answer height with the fallback default value and log a warning in the console', async () => {
|
|
645
|
+
const exampleMaxCollapsedHeightValue = 550;
|
|
646
|
+
const element = createTestComponent({
|
|
647
|
+
...defaultOptions,
|
|
648
|
+
collapsible: true,
|
|
649
|
+
maxCollapsedHeight: exampleMaxCollapsedHeightValue,
|
|
650
|
+
});
|
|
651
|
+
await flushPromises();
|
|
652
|
+
|
|
653
|
+
const generatedAnswer = element.shadowRoot.querySelector(
|
|
654
|
+
selectors.generatedAnswer
|
|
655
|
+
);
|
|
656
|
+
expect(generatedAnswer).not.toBeNull();
|
|
657
|
+
|
|
658
|
+
const generatedAnswerCollapseToggle =
|
|
659
|
+
element.shadowRoot.querySelector(
|
|
660
|
+
selectors.generatedAnswerCollapseToggle
|
|
661
|
+
);
|
|
662
|
+
expect(generatedAnswerCollapseToggle).not.toBeNull();
|
|
663
|
+
|
|
664
|
+
const maxHeightValue =
|
|
665
|
+
generatedAnswer.style.getPropertyValue('--maxHeight');
|
|
666
|
+
expect(maxHeightValue).toEqual(`${defaultAnswerHeight}px`);
|
|
667
|
+
|
|
668
|
+
expect(mockedConsoleWarn).toHaveBeenCalledTimes(1);
|
|
669
|
+
expect(mockedConsoleWarn).toHaveBeenCalledWith(
|
|
670
|
+
`Cannot set max-collapsed-height to (${exampleMaxCollapsedHeightValue}) it accepts a range between 150 and 500. The default value of 250px will be used.`
|
|
671
|
+
);
|
|
672
|
+
});
|
|
673
|
+
});
|
|
674
|
+
|
|
675
|
+
describe('when the maxCollapsedHeight value is smaller than the valid range', () => {
|
|
676
|
+
it('should set the generated answer height with the fallback default value and log a warning in the console', async () => {
|
|
677
|
+
const exampleMaxCollapsedHeightValue = 100;
|
|
678
|
+
const element = createTestComponent({
|
|
679
|
+
...defaultOptions,
|
|
680
|
+
collapsible: true,
|
|
681
|
+
maxCollapsedHeight: exampleMaxCollapsedHeightValue,
|
|
682
|
+
});
|
|
683
|
+
await flushPromises();
|
|
684
|
+
|
|
685
|
+
const generatedAnswer = element.shadowRoot.querySelector(
|
|
686
|
+
selectors.generatedAnswer
|
|
687
|
+
);
|
|
688
|
+
expect(generatedAnswer).not.toBeNull();
|
|
689
|
+
|
|
690
|
+
const generatedAnswerCollapseToggle =
|
|
691
|
+
element.shadowRoot.querySelector(
|
|
692
|
+
selectors.generatedAnswerCollapseToggle
|
|
693
|
+
);
|
|
694
|
+
expect(generatedAnswerCollapseToggle).not.toBeNull();
|
|
695
|
+
|
|
696
|
+
const maxHeightValue =
|
|
697
|
+
generatedAnswer.style.getPropertyValue('--maxHeight');
|
|
698
|
+
|
|
699
|
+
expect(maxHeightValue).toEqual(`${defaultAnswerHeight}px`);
|
|
700
|
+
|
|
701
|
+
expect(mockedConsoleWarn).toHaveBeenCalledTimes(1);
|
|
702
|
+
expect(mockedConsoleWarn).toHaveBeenCalledWith(
|
|
703
|
+
`Cannot set max-collapsed-height to (${exampleMaxCollapsedHeightValue}) it accepts a range between 150 and 500. The default value of 250px will be used.`
|
|
704
|
+
);
|
|
705
|
+
});
|
|
706
|
+
});
|
|
707
|
+
});
|
|
708
|
+
});
|
|
709
|
+
|
|
710
|
+
it('should display the generated answer content', async () => {
|
|
711
|
+
const element = createTestComponent();
|
|
712
|
+
await flushPromises();
|
|
713
|
+
|
|
714
|
+
const generatedAnswerContent = element.shadowRoot.querySelector(
|
|
715
|
+
selectors.generatedAnswerContent
|
|
716
|
+
);
|
|
717
|
+
|
|
718
|
+
expect(generatedAnswerContent).not.toBeNull();
|
|
719
|
+
expect(generatedAnswerContent.isStreaming).toBe(false);
|
|
720
|
+
expect(generatedAnswerContent.answer).toBe(exampleAnswer);
|
|
721
|
+
expect(generatedAnswerContent.answerContentFormat).toBe(
|
|
722
|
+
exampleAnswerContentFormat
|
|
723
|
+
);
|
|
724
|
+
});
|
|
725
|
+
|
|
726
|
+
it('should display the generated answer actions', async () => {
|
|
727
|
+
const element = createTestComponent();
|
|
728
|
+
await flushPromises();
|
|
729
|
+
|
|
730
|
+
const generatedAnswerActions = element.shadowRoot.querySelector(
|
|
731
|
+
selectors.generatedAnswerActions
|
|
732
|
+
);
|
|
733
|
+
|
|
734
|
+
expect(generatedAnswerActions).not.toBeNull();
|
|
735
|
+
});
|
|
736
|
+
|
|
737
|
+
it('should not display the generated answer disclaimer', async () => {
|
|
738
|
+
const element = createTestComponent();
|
|
739
|
+
await flushPromises();
|
|
740
|
+
|
|
741
|
+
const generatedAnswerDisclaimer = element.shadowRoot.querySelector(
|
|
742
|
+
selectors.generatedAnswerDisclaimer
|
|
743
|
+
);
|
|
744
|
+
|
|
745
|
+
expect(generatedAnswerDisclaimer).not.toBeNull();
|
|
746
|
+
});
|
|
747
|
+
|
|
748
|
+
it('should pass the disableCitationAnchoring property to the source citations component', async () => {
|
|
749
|
+
const element = createTestComponent();
|
|
750
|
+
await flushPromises();
|
|
751
|
+
|
|
752
|
+
const generatedAnswerCitations = element.shadowRoot.querySelector(
|
|
753
|
+
selectors.generatedAnswerCitations
|
|
754
|
+
);
|
|
755
|
+
expect(generatedAnswerCitations).not.toBeNull();
|
|
756
|
+
expect(generatedAnswerCitations.disableCitationAnchoring).toBe(false);
|
|
757
|
+
});
|
|
758
|
+
});
|
|
759
|
+
|
|
760
|
+
describe('when the answer cannot be generated after a query is executed', () => {
|
|
761
|
+
const exampleEmptyAnswer = '';
|
|
762
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
763
|
+
beforeEach(() => {
|
|
764
|
+
generatedAnswerState = {
|
|
765
|
+
...initialGeneratedAnswerState,
|
|
766
|
+
isStreaming: false,
|
|
767
|
+
answer: exampleEmptyAnswer,
|
|
768
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
769
|
+
cannotAnswer: true,
|
|
770
|
+
};
|
|
771
|
+
searchStatusState = {
|
|
772
|
+
...initialSearchStatusState,
|
|
773
|
+
hasResults: true,
|
|
774
|
+
};
|
|
775
|
+
mockSuccessfulHeadlessInitialization();
|
|
776
|
+
prepareHeadlessState();
|
|
777
|
+
});
|
|
778
|
+
|
|
779
|
+
afterAll(() => {
|
|
780
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
781
|
+
});
|
|
782
|
+
|
|
783
|
+
describe('when no custom error message slot is provided', () => {
|
|
784
|
+
it('should not display the generated answer card', async () => {
|
|
785
|
+
const element = createTestComponent();
|
|
786
|
+
await flushPromises();
|
|
787
|
+
|
|
788
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
789
|
+
selectors.generatedAnswerCard
|
|
790
|
+
);
|
|
791
|
+
expect(generatedAnswerCard).toBeNull();
|
|
792
|
+
|
|
793
|
+
const generatedAnswerCardNoAnswer = element.shadowRoot.querySelector(
|
|
794
|
+
selectors.generatedAnswerNoAnswerCard
|
|
795
|
+
);
|
|
796
|
+
expect(generatedAnswerCardNoAnswer).toBeNull();
|
|
797
|
+
});
|
|
798
|
+
});
|
|
799
|
+
|
|
800
|
+
describe('when a custom error message slot is provided', () => {
|
|
801
|
+
it('should properly display the no generated answer card', async () => {
|
|
802
|
+
const element = createTestComponent(
|
|
803
|
+
defaultOptions,
|
|
804
|
+
exampleAssignedElements
|
|
805
|
+
);
|
|
806
|
+
await flushPromises();
|
|
807
|
+
|
|
808
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
809
|
+
selectors.generatedAnswerCard
|
|
810
|
+
);
|
|
811
|
+
expect(generatedAnswerCard).toBeNull();
|
|
812
|
+
|
|
813
|
+
const generatedAnswerCardNoAnswer = element.shadowRoot.querySelector(
|
|
814
|
+
selectors.generatedAnswerNoAnswerCard
|
|
815
|
+
);
|
|
816
|
+
expect(generatedAnswerCardNoAnswer).not.toBeNull();
|
|
817
|
+
});
|
|
818
|
+
});
|
|
819
|
+
|
|
820
|
+
describe('when no results are returned', () => {
|
|
821
|
+
beforeEach(() => {
|
|
822
|
+
searchStatusState = {
|
|
823
|
+
...initialSearchStatusState,
|
|
824
|
+
hasResults: false,
|
|
825
|
+
};
|
|
826
|
+
});
|
|
827
|
+
|
|
828
|
+
it('should not display the generated answer or the no generated answer card', async () => {
|
|
829
|
+
const element = createTestComponent(
|
|
830
|
+
defaultOptions,
|
|
831
|
+
exampleAssignedElements
|
|
832
|
+
);
|
|
833
|
+
await flushPromises();
|
|
834
|
+
|
|
835
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
836
|
+
selectors.generatedAnswerCard
|
|
837
|
+
);
|
|
838
|
+
expect(generatedAnswerCard).toBeNull();
|
|
839
|
+
|
|
840
|
+
const generatedAnswerCardNoAnswer = element.shadowRoot.querySelector(
|
|
841
|
+
selectors.generatedAnswerNoAnswerCard
|
|
842
|
+
);
|
|
843
|
+
expect(generatedAnswerCardNoAnswer).toBeNull();
|
|
844
|
+
});
|
|
845
|
+
});
|
|
846
|
+
});
|
|
847
|
+
|
|
848
|
+
describe('automatic answer generation', () => {
|
|
849
|
+
describe('when the answer is loading', () => {
|
|
850
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
851
|
+
beforeEach(() => {
|
|
852
|
+
generatedAnswerState = {
|
|
853
|
+
...initialGeneratedAnswerState,
|
|
854
|
+
isStreaming: false,
|
|
855
|
+
answer: '',
|
|
856
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
857
|
+
answerGenerationMode: 'automatic',
|
|
858
|
+
isLoading: true,
|
|
859
|
+
};
|
|
860
|
+
mockSuccessfulHeadlessInitialization();
|
|
861
|
+
prepareHeadlessState();
|
|
862
|
+
});
|
|
863
|
+
|
|
864
|
+
afterAll(() => {
|
|
865
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
866
|
+
});
|
|
867
|
+
|
|
868
|
+
it('should not display the loading state', async () => {
|
|
869
|
+
const element = createTestComponent();
|
|
870
|
+
await flushPromises();
|
|
871
|
+
|
|
872
|
+
const loadingSpinner = element.shadowRoot.querySelector(
|
|
873
|
+
selectors.loadingSpinner
|
|
874
|
+
);
|
|
875
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
876
|
+
selectors.generatedAnswerCard
|
|
877
|
+
);
|
|
878
|
+
expect(loadingSpinner).toBeNull();
|
|
879
|
+
expect(generatedAnswerCard).toBeNull();
|
|
880
|
+
});
|
|
881
|
+
});
|
|
882
|
+
|
|
883
|
+
describe('when the answer cannot be generated after a query is executed', () => {
|
|
884
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
885
|
+
beforeEach(() => {
|
|
886
|
+
generatedAnswerState = {
|
|
887
|
+
...initialGeneratedAnswerState,
|
|
888
|
+
isStreaming: false,
|
|
889
|
+
isLoading: false,
|
|
890
|
+
answer: '',
|
|
891
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
892
|
+
answerGenerationMode: 'automatic',
|
|
893
|
+
cannotAnswer: true,
|
|
894
|
+
};
|
|
895
|
+
searchStatusState = {
|
|
896
|
+
...initialSearchStatusState,
|
|
897
|
+
hasResults: true,
|
|
898
|
+
};
|
|
899
|
+
mockSuccessfulHeadlessInitialization();
|
|
900
|
+
prepareHeadlessState();
|
|
901
|
+
});
|
|
902
|
+
|
|
903
|
+
afterAll(() => {
|
|
904
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
905
|
+
});
|
|
906
|
+
|
|
907
|
+
describe('when no custom error message slot is provided', () => {
|
|
908
|
+
it('should not display the cannot answer message', async () => {
|
|
909
|
+
const element = createTestComponent();
|
|
910
|
+
await flushPromises();
|
|
911
|
+
|
|
912
|
+
const generatedAnswerCardNoAnswer =
|
|
913
|
+
element.shadowRoot.querySelector(
|
|
914
|
+
selectors.generatedAnswerNoAnswerCard
|
|
915
|
+
);
|
|
916
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
917
|
+
selectors.generatedAnswerCard
|
|
918
|
+
);
|
|
919
|
+
expect(generatedAnswerCard).toBeNull();
|
|
920
|
+
expect(generatedAnswerCardNoAnswer).toBeNull();
|
|
921
|
+
});
|
|
922
|
+
});
|
|
923
|
+
|
|
924
|
+
describe('when a custom error message slot is provided', () => {
|
|
925
|
+
it('should display the cannot answer message', async () => {
|
|
926
|
+
const element = createTestComponent(
|
|
927
|
+
defaultOptions,
|
|
928
|
+
exampleAssignedElements
|
|
929
|
+
);
|
|
930
|
+
await flushPromises();
|
|
931
|
+
|
|
932
|
+
const generatedAnswerCardNoAnswer =
|
|
933
|
+
element.shadowRoot.querySelector(
|
|
934
|
+
selectors.generatedAnswerNoAnswerCard
|
|
935
|
+
);
|
|
936
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
937
|
+
selectors.generatedAnswerCard
|
|
938
|
+
);
|
|
939
|
+
expect(generatedAnswerCard).toBeNull();
|
|
940
|
+
expect(generatedAnswerCardNoAnswer).not.toBeNull();
|
|
941
|
+
});
|
|
942
|
+
});
|
|
943
|
+
|
|
944
|
+
describe('when no results are returned', () => {
|
|
945
|
+
beforeEach(() => {
|
|
946
|
+
searchStatusState = {
|
|
947
|
+
...initialSearchStatusState,
|
|
948
|
+
hasResults: false,
|
|
949
|
+
};
|
|
950
|
+
});
|
|
951
|
+
|
|
952
|
+
it('should not display the generated answer or the no generated answer card', async () => {
|
|
953
|
+
const element = createTestComponent(
|
|
954
|
+
defaultOptions,
|
|
955
|
+
exampleAssignedElements
|
|
956
|
+
);
|
|
957
|
+
await flushPromises();
|
|
958
|
+
|
|
959
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
960
|
+
selectors.generatedAnswerCard
|
|
961
|
+
);
|
|
962
|
+
expect(generatedAnswerCard).toBeNull();
|
|
963
|
+
|
|
964
|
+
const generatedAnswerCardNoAnswer =
|
|
965
|
+
element.shadowRoot.querySelector(
|
|
966
|
+
selectors.generatedAnswerNoAnswerCard
|
|
967
|
+
);
|
|
968
|
+
expect(generatedAnswerCardNoAnswer).toBeNull();
|
|
969
|
+
});
|
|
970
|
+
});
|
|
971
|
+
});
|
|
972
|
+
});
|
|
973
|
+
|
|
974
|
+
describe('manual answer generation', () => {
|
|
975
|
+
describe('when the answer is loading', () => {
|
|
976
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
977
|
+
beforeEach(() => {
|
|
978
|
+
generatedAnswerState = {
|
|
979
|
+
...initialGeneratedAnswerState,
|
|
980
|
+
isStreaming: false,
|
|
981
|
+
answer: '',
|
|
982
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
983
|
+
answerGenerationMode: 'manual',
|
|
984
|
+
isLoading: true,
|
|
985
|
+
};
|
|
986
|
+
mockSuccessfulHeadlessInitialization();
|
|
987
|
+
prepareHeadlessState();
|
|
988
|
+
});
|
|
989
|
+
|
|
990
|
+
afterAll(() => {
|
|
991
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
992
|
+
});
|
|
993
|
+
|
|
994
|
+
it('should display the loading state', async () => {
|
|
995
|
+
const element = createTestComponent();
|
|
996
|
+
await flushPromises();
|
|
997
|
+
|
|
998
|
+
const loadingSpinner = element.shadowRoot.querySelector(
|
|
999
|
+
selectors.loadingSpinner
|
|
1000
|
+
);
|
|
1001
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
1002
|
+
selectors.generatedAnswerCard
|
|
1003
|
+
);
|
|
1004
|
+
expect(loadingSpinner).not.toBeNull();
|
|
1005
|
+
expect(generatedAnswerCard).toBeNull();
|
|
1006
|
+
});
|
|
1007
|
+
|
|
1008
|
+
describe('when cannotAnswer is true in the state', () => {
|
|
1009
|
+
beforeEach(() => {
|
|
1010
|
+
generatedAnswerState = {
|
|
1011
|
+
...initialGeneratedAnswerState,
|
|
1012
|
+
isStreaming: false,
|
|
1013
|
+
answer: '',
|
|
1014
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
1015
|
+
answerGenerationMode: 'manual',
|
|
1016
|
+
isLoading: true,
|
|
1017
|
+
cannotAnswer: true,
|
|
1018
|
+
};
|
|
1019
|
+
searchStatusState = {
|
|
1020
|
+
...initialSearchStatusState,
|
|
1021
|
+
hasResults: true,
|
|
1022
|
+
};
|
|
1023
|
+
mockSuccessfulHeadlessInitialization();
|
|
1024
|
+
prepareHeadlessState();
|
|
1025
|
+
});
|
|
1026
|
+
|
|
1027
|
+
afterAll(() => {
|
|
1028
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
1029
|
+
});
|
|
1030
|
+
|
|
1031
|
+
it('should display the cannot answer message and not display the loading state even when isLoading is true', async () => {
|
|
1032
|
+
const element = createTestComponent();
|
|
1033
|
+
await flushPromises();
|
|
1034
|
+
|
|
1035
|
+
const loadingSpinner = element.shadowRoot.querySelector(
|
|
1036
|
+
selectors.loadingSpinner
|
|
1037
|
+
);
|
|
1038
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
1039
|
+
selectors.generatedAnswerCard
|
|
1040
|
+
);
|
|
1041
|
+
const generatedAnswerCardNoAnswer =
|
|
1042
|
+
element.shadowRoot.querySelector(
|
|
1043
|
+
selectors.generatedAnswerNoAnswerCard
|
|
1044
|
+
);
|
|
1045
|
+
const generatedAnswerCardNoAnswerMessage =
|
|
1046
|
+
element.shadowRoot.querySelector(
|
|
1047
|
+
selectors.generatedAnswerNoAnswerMessage
|
|
1048
|
+
);
|
|
1049
|
+
|
|
1050
|
+
expect(loadingSpinner).toBeNull();
|
|
1051
|
+
expect(generatedAnswerCard).toBeNull();
|
|
1052
|
+
expect(generatedAnswerCardNoAnswer).not.toBeNull();
|
|
1053
|
+
expect(generatedAnswerCardNoAnswerMessage.textContent).toBe(
|
|
1054
|
+
'No generated answer available.'
|
|
1055
|
+
);
|
|
1056
|
+
});
|
|
1057
|
+
});
|
|
1058
|
+
});
|
|
1059
|
+
|
|
1060
|
+
describe('when the answer cannot be generated after a query is executed', () => {
|
|
1061
|
+
const exampleAnswerContentFormat = 'text/markdown';
|
|
1062
|
+
beforeEach(() => {
|
|
1063
|
+
generatedAnswerState = {
|
|
1064
|
+
...initialGeneratedAnswerState,
|
|
1065
|
+
isStreaming: false,
|
|
1066
|
+
isLoading: false,
|
|
1067
|
+
answer: '',
|
|
1068
|
+
answerContentFormat: exampleAnswerContentFormat,
|
|
1069
|
+
answerGenerationMode: 'manual',
|
|
1070
|
+
cannotAnswer: true,
|
|
1071
|
+
};
|
|
1072
|
+
searchStatusState = {
|
|
1073
|
+
...initialSearchStatusState,
|
|
1074
|
+
hasResults: true,
|
|
1075
|
+
};
|
|
1076
|
+
mockSuccessfulHeadlessInitialization();
|
|
1077
|
+
prepareHeadlessState();
|
|
1078
|
+
});
|
|
1079
|
+
|
|
1080
|
+
afterAll(() => {
|
|
1081
|
+
generatedAnswerState = initialGeneratedAnswerState;
|
|
1082
|
+
});
|
|
1083
|
+
|
|
1084
|
+
describe('when no custom error message slot is provided', () => {
|
|
1085
|
+
it('should display the default cannot answer message', async () => {
|
|
1086
|
+
const element = createTestComponent();
|
|
1087
|
+
await flushPromises();
|
|
1088
|
+
|
|
1089
|
+
const generatedAnswerCardNoAnswer =
|
|
1090
|
+
element.shadowRoot.querySelector(
|
|
1091
|
+
selectors.generatedAnswerNoAnswerCard
|
|
1092
|
+
);
|
|
1093
|
+
const generatedAnswerCardNoAnswerMessage =
|
|
1094
|
+
element.shadowRoot.querySelector(
|
|
1095
|
+
selectors.generatedAnswerNoAnswerMessage
|
|
1096
|
+
);
|
|
1097
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
1098
|
+
selectors.generatedAnswerCard
|
|
1099
|
+
);
|
|
1100
|
+
expect(generatedAnswerCard).toBeNull();
|
|
1101
|
+
expect(generatedAnswerCardNoAnswer).not.toBeNull();
|
|
1102
|
+
expect(generatedAnswerCardNoAnswerMessage.textContent).toBe(
|
|
1103
|
+
'No generated answer available.'
|
|
1104
|
+
);
|
|
1105
|
+
});
|
|
1106
|
+
});
|
|
1107
|
+
|
|
1108
|
+
describe('when a custom error message slot is provided', () => {
|
|
1109
|
+
it('should properly display the cannot answer message', async () => {
|
|
1110
|
+
const element = createTestComponent(
|
|
1111
|
+
defaultOptions,
|
|
1112
|
+
exampleAssignedElements
|
|
1113
|
+
);
|
|
1114
|
+
await flushPromises();
|
|
1115
|
+
|
|
1116
|
+
const generatedAnswerCardNoAnswer =
|
|
1117
|
+
element.shadowRoot.querySelector(
|
|
1118
|
+
selectors.generatedAnswerNoAnswerCard
|
|
1119
|
+
);
|
|
1120
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
1121
|
+
selectors.generatedAnswerCard
|
|
1122
|
+
);
|
|
1123
|
+
expect(generatedAnswerCard).toBeNull();
|
|
1124
|
+
expect(generatedAnswerCardNoAnswer).not.toBeNull();
|
|
1125
|
+
});
|
|
1126
|
+
});
|
|
1127
|
+
|
|
1128
|
+
describe('when no results are returned', () => {
|
|
1129
|
+
beforeEach(() => {
|
|
1130
|
+
searchStatusState = {
|
|
1131
|
+
...initialSearchStatusState,
|
|
1132
|
+
hasResults: false,
|
|
1133
|
+
};
|
|
1134
|
+
});
|
|
1135
|
+
|
|
1136
|
+
it('should not display the generated answer or the no generated answer card', async () => {
|
|
1137
|
+
const element = createTestComponent(
|
|
1138
|
+
defaultOptions,
|
|
1139
|
+
exampleAssignedElements
|
|
1140
|
+
);
|
|
1141
|
+
await flushPromises();
|
|
1142
|
+
|
|
1143
|
+
const generatedAnswerCard = element.shadowRoot.querySelector(
|
|
1144
|
+
selectors.generatedAnswerCard
|
|
1145
|
+
);
|
|
1146
|
+
expect(generatedAnswerCard).toBeNull();
|
|
1147
|
+
|
|
1148
|
+
const generatedAnswerCardNoAnswer =
|
|
1149
|
+
element.shadowRoot.querySelector(
|
|
1150
|
+
selectors.generatedAnswerNoAnswerCard
|
|
1151
|
+
);
|
|
1152
|
+
expect(generatedAnswerCardNoAnswer).toBeNull();
|
|
1153
|
+
});
|
|
1154
|
+
});
|
|
1155
|
+
});
|
|
1156
|
+
});
|
|
1157
|
+
});
|
|
1158
|
+
});
|