Skip to content

Commit

Permalink
Merge pull request #1040 from adobe/fixShowContainersTiming
Browse files Browse the repository at this point in the history
Fix show containers timing
  • Loading branch information
jonsnyder authored Oct 18, 2023
2 parents 63d7324 + 2e08077 commit c201849
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 9 deletions.
15 changes: 6 additions & 9 deletions src/components/Personalization/createFetchDataHandler.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,15 +69,12 @@ export default ({
[...pagePropositions, ...currentViewPropositions],
nonRenderedPropositions
));
render()
.then(decisionsMeta => {
showContainers();
handleNotifications(decisionsMeta);
})
.catch(e => {
showContainers();
throw e;
});
render().then(handleNotifications);

// Render could take a long time especially if one of the renders
// is waiting for html to appear on the page. We show the containers
// immediately, and whatever renders quickly will not have flicker.
showContainers();
} else {
({ returnedPropositions, returnedDecisions } = processPropositions(
[],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ governing permissions and limitations under the License.
import createFetchDataHandler from "../../../../../src/components/Personalization/createFetchDataHandler";
import injectCreateProposition from "../../../../../src/components/Personalization/handlers/injectCreateProposition";
import flushPromiseChains from "../../../helpers/flushPromiseChains";
import defer from "../../../../../src/utils/defer";

describe("Personalization::createFetchDataHandler", () => {
let prehidingStyle;
Expand Down Expand Up @@ -149,4 +150,42 @@ describe("Personalization::createFetchDataHandler", () => {
viewName: "myviewname"
});
});

it("should show containers immediately", async () => {
personalizationDetails.isRenderDecisions.and.returnValue(true);
const renderDeferred = defer();
processPropositions = () => {
return {
render: () => renderDeferred.promise,
returnedPropositions: [
{
id: "handle2",
scope: "__view__",
items: ["item1"],
renderAttempted: true
}
],
returnedDecisions: []
};
};
run();
response.getPayloadsByType.and.returnValue([
{
id: "handle2",
scope: "__view__",
items: ["item1"]
}
]);
cacheUpdate.update.and.returnValue([]);
expect(showContainers).not.toHaveBeenCalled();
returnResponse();
expect(showContainers).toHaveBeenCalled();
expect(collect).not.toHaveBeenCalled();
renderDeferred.resolve([{ id: "handle2" }]);
await flushPromiseChains();
expect(collect).toHaveBeenCalledOnceWith({
decisionsMeta: [{ id: "handle2" }],
viewName: undefined
});
});
});

0 comments on commit c201849

Please sign in to comment.