From 3b30d0718036cfdf174fbaf850e1c435d5026321 Mon Sep 17 00:00:00 2001 From: Lars Gyrup Brink Nielsen Date: Mon, 26 Dec 2022 04:53:15 +0100 Subject: [PATCH] test: cover `RouterHistoryStore` with more test cases --- .../router-history.store.spec.ts | 54 +++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/packages/router-component-store/src/lib/router-history-store/router-history.store.spec.ts b/packages/router-component-store/src/lib/router-history-store/router-history.store.spec.ts index c1e281c..3da2c76 100644 --- a/packages/router-component-store/src/lib/router-history-store/router-history.store.spec.ts +++ b/packages/router-component-store/src/lib/router-history-store/router-history.store.spec.ts @@ -97,7 +97,34 @@ describe(RouterHistoryStore.name, () => { }; } + it('the URLs behave like the History API when navigating using links', async () => { + expect.assertions(2); + + const { click, routerHistory } = await setup(); + let currentUrl: string | undefined; + routerHistory.currentUrl$.subscribe((url) => { + currentUrl = url; + }); + let previousUrl: string | null | undefined; + routerHistory.previousUrl$.subscribe((url) => { + previousUrl = url; + }); + + // At Home + await click('#about-link'); + // At About + await click('#company-link'); + // At Company + await click('#products-link'); + // At Products + + expect(currentUrl).toBe('/products'); + expect(previousUrl).toBe('/company'); + }); + it('the URLs behave like the History API when navigating back', async () => { + expect.assertions(2); + const { click, routerHistory } = await setup(); let currentUrl: string | undefined; routerHistory.currentUrl$.subscribe((url) => { @@ -119,4 +146,31 @@ describe(RouterHistoryStore.name, () => { expect(currentUrl).toBe('/about'); expect(previousUrl).toBe('/home'); }); + + it('the URLs behave like the History API when navigating back then using links', async () => { + expect.assertions(2); + + const { click, routerHistory } = await setup(); + let currentUrl: string | undefined; + routerHistory.currentUrl$.subscribe((url) => { + currentUrl = url; + }); + let previousUrl: string | null | undefined; + routerHistory.previousUrl$.subscribe((url) => { + previousUrl = url; + }); + + // At Home + await click('#about-link'); + // At About + await click('#company-link'); + // At Company + await click('#back-link'); + // At About + await click('#products-link'); + // At Products + + expect(currentUrl).toBe('/products'); + expect(previousUrl).toBe('/about'); + }); });