From da20a62ae92500b9d2670151dc2e805ed3df07a6 Mon Sep 17 00:00:00 2001 From: Norton Andreev Date: Thu, 22 Feb 2024 16:03:01 +0200 Subject: [PATCH] web-wallet: Add Create Wallet flow tests Resolves #1443 --- web-wallet/CHANGELOG.md | 3 +- .../(welcome)/setup/create/+page.svelte | 6 +- .../setup/create/MnemonicValidate.svelte | 2 +- .../__tests__/__snapshots__/page.spec.js.snap | 3196 ++++++++++++++++- .../setup/create/__tests__/page.spec.js | 410 ++- .../setup/restore/__tests__/page.spec.js | 8 +- 6 files changed, 3610 insertions(+), 15 deletions(-) diff --git a/web-wallet/CHANGELOG.md b/web-wallet/CHANGELOG.md index c35e73c6e9..d954a0cb78 100644 --- a/web-wallet/CHANGELOG.md +++ b/web-wallet/CHANGELOG.md @@ -8,7 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] ### Added - +- Add Create Wallet flow tests [#1443] - Add visible version, commit hash and build date [#1441] - Add Address validation (Transfer flow) [#1377] @@ -114,6 +114,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 [#1445]: https://github.com/dusk-network/rusk/issues/1445 [#1441]: https://github.com/dusk-network/rusk/issues/1441 [#1460]: https://github.com/dusk-network/rusk/issues/1460 +[#1443]: https://github.com/dusk-network/rusk/issues/1443 [Unreleased]: https://github.com/dusk-network/rusk/tree/master/web-wallet diff --git a/web-wallet/src/routes/(welcome)/setup/create/+page.svelte b/web-wallet/src/routes/(welcome)/setup/create/+page.svelte index 82f89367a9..84abb6ca41 100644 --- a/web-wallet/src/routes/(welcome)/setup/create/+page.svelte +++ b/web-wallet/src/routes/(welcome)/setup/create/+page.svelte @@ -89,7 +89,7 @@ Backup
Mnemonic Phrase - +

Ensure you have backed up the Mnemonic phrase.

diff --git a/web-wallet/src/routes/(welcome)/setup/create/__tests__/__snapshots__/page.spec.js.snap b/web-wallet/src/routes/(welcome)/setup/create/__tests__/__snapshots__/page.spec.js.snap index c3f478b861..21b802eca8 100644 --- a/web-wallet/src/routes/(welcome)/setup/create/__tests__/__snapshots__/page.spec.js.snap +++ b/web-wallet/src/routes/(welcome)/setup/create/__tests__/__snapshots__/page.spec.js.snap @@ -1,6 +1,3200 @@ // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html -exports[`Create > should render the Terms of Service step of the Create flow 1`] = ` +exports[`Create > correctly renders the Mnemonic Preview page 1`] = ` +
+
+ + + +

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ + + + + + +

+ Keep this SAFE +

+ +
+ +
+

+ Please make sure to write your phrase down and save it in a secure location. +

+ +
    +
  1. + cart +
  2. +
  3. + dad +
  4. +
  5. + sail +
  6. +
  7. + wreck +
  8. +
  9. + robot +
  10. +
  11. + grit +
  12. +
  13. + combine +
  14. +
  15. + noble +
  16. +
  17. + rap +
  18. +
  19. + farm +
  20. +
  21. + slide +
  22. +
  23. + sad +
  24. +
+ +
+
+ + + + +
+ + + + + + +
+ + + + + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > correctly renders the Mnemonic Verification page 1`] = ` +
+
+ + + + + + +

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ Verification +

+ +
+ +
+

+ Ensure you have backed up the Mnemonic phrase. +

+ +
+
+ + + +
+ +
    +
  1. + _____ +
  2. +
  3. + _____ +
  4. +
  5. + _____ +
  6. +
  7. + _____ +
  8. +
  9. + _____ +
  10. +
  11. + _____ +
  12. +
  13. + _____ +
  14. +
  15. + _____ +
  16. +
  17. + _____ +
  18. +
  19. + _____ +
  20. +
  21. + _____ +
  22. +
  23. + _____ +
  24. +
+ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + +
+
+ + + + +
+ + + + + + +
+ + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > doesn't let the user proceed if they have entered mismatching Mnemonic 1`] = ` +
+
+ + + + + + +

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ Verification +

+ +
+ +
+

+ Ensure you have backed up the Mnemonic phrase. +

+ +
+
+ + + +
+ +
    +
  1. + grit +
  2. +
  3. + wreck +
  4. +
  5. + cart +
  6. +
  7. + dad +
  8. +
  9. + rap +
  10. +
  11. + sail +
  12. +
  13. + robot +
  14. +
  15. + combine +
  16. +
  17. + noble +
  18. +
  19. + slide +
  20. +
  21. + sad +
  22. +
  23. + farm +
  24. +
+ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + +
+ + + + + + +

+ Mnemonic does not match. +

+
+
+
+ + + + +
+ + + + + + +
+ + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > ensures that the Undo button on the Mnemonic Validate step works as expected 1`] = ` +
+
+ + + + + + +

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ Verification +

+ +
+ +
+

+ Ensure you have backed up the Mnemonic phrase. +

+ +
+
+ + + +
+ +
    +
  1. + cart +
  2. +
  3. + dad +
  4. +
  5. + sail +
  6. +
  7. + wreck +
  8. +
  9. + robot +
  10. +
  11. + grit +
  12. +
  13. + combine +
  14. +
  15. + noble +
  16. +
  17. + rap +
  18. +
  19. + farm +
  20. +
  21. + slide +
  22. +
  23. + _____ +
  24. +
+ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + +
+
+ + + + +
+ + + + + + +
+ + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > ensures the All Done step renders as expected 1`] = ` +
+
+ + + + + + + + + + + + + + + +

+ Welcome to +
+ + + Dusk + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ You are all set! +

+ +
+ + All Set +
+ + + + +
+ + + +
+ + + +
+ + + +
+`; + +exports[`Create > ensures the Password step renders as expected 1`] = ` +
+
+ + + + + + + + + +

+ + Password + +
+ + Setup +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ + + + + + +

+ Password +

+ +
+ +
+ +
+ + + +
+ + + + + + +

+ Setting a password for your web wallet is optional. Doing so allows you + the convenience of opening your wallet file using a password, but it + weakens the overall security. Not using a password requires you to input + the full mnemonic to open your wallet. +

+
+ + +
+ + + + + + +
+ + + + + + + + + +
+ + + +
+`; + +exports[`Create > ensures the Password step renders as expected 2`] = ` +
+
+ + + + + + + + + +

+ + Password + +
+ + Setup +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ + + + + + +

+ Password +

+ +
+ +
+ +
+

+ Please store your password safely. +

+ + + + + +
+ + + + + + Password must be at least 8 characters + +
+
+
+ + + +
+ + + + + + +

+ Setting a password for your web wallet is optional. Doing so allows you + the convenience of opening your wallet file using a password, but it + weakens the overall security. Not using a password requires you to input + the full mnemonic to open your wallet. +

+
+ + +
+ + + + + + +
+ + + + + + + + + +
+ + + +
+`; + +exports[`Create > ensures the Swap To Native Dusk step renders as expected 1`] = ` +
+
+ + + + + + + + + + + + +

+ Swap ERC20 +
+ + to + + Native Dusk + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +

+ The ERC20 token swap functionality is currently disabled + and will be provided after the launch of the Dusk mainnet. +

+ + + + + +
+ + + + + + +
+ + + + + + +
+ + + +
+`; + +exports[`Create > lets the user proceed if they have entered a matching Mnemonic 1`] = ` +
+
+ + + + + + +

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ Verification +

+ +
+ +
+

+ Ensure you have backed up the Mnemonic phrase. +

+ +
+
+ + + +
+ +
    +
  1. + cart +
  2. +
  3. + dad +
  4. +
  5. + sail +
  6. +
  7. + wreck +
  8. +
  9. + robot +
  10. +
  11. + grit +
  12. +
  13. + combine +
  14. +
  15. + noble +
  16. +
  17. + rap +
  18. +
  19. + farm +
  20. +
  21. + slide +
  22. +
  23. + sad +
  24. +
+ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + +
+
+ + + + +
+ + + + + + +
+ + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > should render the \`Securely store your seed phrase!\` agreement step after the ToS 1`] = ` +
+
+

+ Backup +
+ + + Mnemonic Phrase + +

+ +
+
+
+
+ +
+
+
+
+
+
+
+
+
+ + +
+
+ +

+ Securely store your seed phrase! +

+ +
+ +
+
+ + + + +
+ + +
+ + + + +
+ +
+
+ + + +
+ + + + + + +

+ To proceed, please check all the relevant boxes. + Dusk will not save and cannot retrieve your passphrase. +

+
+ + +
+ + + + + + + + + Back + + + + + + + + + + +
+ + + + + + + + + + + + + + + + + + +
+ + + +
+`; + +exports[`Create > should render the Existing Wallet notice step of the Create flow if there is a userId saved in localStorage 1`] = ` +
+
+
+
+
+ + + + + + +

+ Existing Wallet Detected +

+ +
+ +
+

+ Logging in to a new wallet will overwrite the current local wallet cache, + meaning that when you log in again with the previous mnemonic/account + you will need to wait for the wallet to sync. +

+ +
+ + + Back + + + + + + + + +
+
+
+ + +
+ +
+ + +
+`; + +exports[`Create > should render the Terms of Service step of the Create flow if there is no userId saved in localStorage 1`] = `
{ - afterEach(cleanup); +/** + * @param {HTMLElement} input + * @param {*} value + * @returns {Promise} + */ +const fireInput = (input, value) => fireEvent.input(input, { target: { value } }); + +/** @param {HTMLElement} element */ +function asInput (element) { + // eslint-disable-next-line no-extra-parens + return /** @type {HTMLInputElement} */ (element); +} + +describe("Create", async () => { + const walletGetPsksSpy = vi.spyOn(Wallet.prototype, "getPsks").mockResolvedValue(addresses); + const mnemonic = "cart dad sail wreck robot grit combine noble rap farm slide sad"; + const mnemonicShuffled = ["grit", "wreck", "cart", "dad", "rap", + "sail", "robot", "combine", "noble", "slide", "sad", "farm"]; + const pwd = "passwordpassword"; + const seed = getSeedFromMnemonic(mnemonic); + const userId = (await new Wallet(seed).getPsks())[0]; + const generateMnemonicSpy = vi.spyOn(bip39, "generateMnemonic").mockReturnValue(mnemonic); + const shuffleArraySpy = vi.spyOn(shuffleArray, "shuffleArray").mockReturnValue(mnemonicShuffled); + const getWalletSpy = vi.spyOn(walletService, "getWallet"); + const gotoSpy = vi.spyOn(appNavigation, "goto"); + const settingsResetSpy = vi.spyOn(settingsStore, "reset"); + const clearAndInitSpy = vi.spyOn(walletStore, "clearLocalDataAndInit"); + + afterEach(async () => { + cleanup(); + settingsStore.reset(); + walletGetPsksSpy.mockClear(); + generateMnemonicSpy.mockClear(); + shuffleArraySpy.mockClear(); + clearAndInitSpy.mockClear(); + getWalletSpy.mockClear(); + gotoSpy.mockClear(); + settingsResetSpy.mockClear(); + }); + + afterAll(() => { + walletGetPsksSpy.mockRestore(); + generateMnemonicSpy.mockRestore(); + shuffleArraySpy.mockRestore(); + clearAndInitSpy.mockRestore(); + getWalletSpy.mockRestore(); + gotoSpy.mockRestore(); + settingsResetSpy.mockRestore(); + }); + + it("should render the Existing Wallet notice step of the Create flow if there is a userId saved in localStorage", () => { + settingsStore.update(setKey("userId", userId)); - it("should render the Terms of Service step of the Create flow", () => { const { container } = render(Create); expect(container.firstChild).toMatchSnapshot(); }); + + it("should render the Terms of Service step of the Create flow if there is no userId saved in localStorage", () => { + const { container } = render(Create); + + expect(container.firstChild).toMatchSnapshot(); + }); + + it("should render the `Securely store your seed phrase!` agreement step after the ToS", async () => { + const { container, getByRole } = render(Create); + + const mathRandomSpy = vi.spyOn(Math, "random").mockReturnValue(42); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + expect(container.firstChild).toMatchSnapshot(); + + mathRandomSpy.mockRestore(); + }); + + it("should not allow the user proceed unless both agreement checks are selected on the `Securely store your seed phrase!` step", async () => { + const { getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + const firstCheckbox = getAllByRole("checkbox")[0]; + const secondCheckbox = getAllByRole("checkbox")[1]; + const nextButton = getByRole("button", { name: "Next" }); + + // Select the first checkbox + await fireEvent.click(firstCheckbox); + + // Ensure Next is disabled + expect(nextButton).toBeDisabled(); + + // Unselect the first checkbox + await fireEvent.click(firstCheckbox); + + // Select the second checkbox + await fireEvent.click(secondCheckbox); + + // Ensure Next is disabled + expect(getByRole("button", { name: "Next" })).toBeDisabled(); + + // Select first checkbox too + await fireEvent.click(firstCheckbox); + + // Ensure Next is enabled + expect(nextButton).toBeEnabled(); + }); + + it("correctly renders the Mnemonic Preview page", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + expect(container.firstChild).toMatchSnapshot(); + }); + + it("correctly renders the Mnemonic Verification page", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + expect(container.firstChild).toMatchSnapshot(); + }); + + it("doesn't let the user proceed if they have entered mismatching Mnemonic", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const wordButtonsWrapper = + container.getElementsByClassName("dusk-mnemonic__validate-actions-wrapper")[0]; + + const wordButtons = Array.from(wordButtonsWrapper.children); + + wordButtons.forEach(async button => { + await fireEvent.click(button); + }); + + await tick(); + + expect(container.firstChild).toMatchSnapshot(); + + expect(getByRole("button", { name: "Next" })).toBeDisabled(); + }); + + it("lets the user proceed if they have entered a matching Mnemonic", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + expect(container.firstChild).toMatchSnapshot(); + + expect(getByRole("button", { name: "Next" })).toBeEnabled(); + }); + + it("ensures that the Undo button on the Mnemonic Validate step works as expected", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Undo" })); + + expect(container.firstChild).toMatchSnapshot(); + + expect(getByRole("button", { name: "Next" })).toBeDisabled(); + }); + + it("ensures the Password step renders as expected", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Password disabled + expect(container.firstChild).toMatchSnapshot(); + + await fireEvent.click(getByRole("switch")); + + // Password enabled + expect(container.firstChild).toMatchSnapshot(); + }); + + it("ensures the Swap To Native Dusk step renders as expected", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + expect(container.firstChild).toMatchSnapshot(); + }); + + it("ensures the All Done step renders as expected", async () => { + const { container, getByRole, getAllByRole } = render(Create); + + await fireEvent.click(getByRole("button", { name: "Accept" })); + + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + await fireEvent.click(getByRole("button", { name: "Next" })); + + expect(container.firstChild).toMatchSnapshot(); + }); + + it("should initialize the wallet without setting a password", async () => { + const { getByRole, getAllByRole } = render(Create); + + // ToS step + await fireEvent.click(getByRole("button", { name: "Accept" })); + + // Mnemonic Agreement step + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Mnemonic Generate step + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Mnemonic Validate step + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Set Password step + await fireEvent.click(getByRole("button", { name: "Next" })); + expect(loginInfoStorage.get()).toBeNull(); + + // Swap ERC20 to Native Dusk step + await fireEvent.click(getByRole("button", { name: "Next" })); + + // All Done step + await fireEvent.click(getByRole("button", { name: "Next" })); + + await vi.waitUntil(() => gotoSpy.mock.calls.length > 0); + + expect(settingsResetSpy).toHaveBeenCalledTimes(1); + expect(getWalletSpy).toHaveBeenCalledTimes(1); + expect(getWalletSpy).toHaveBeenCalledWith(seed); + expect(clearAndInitSpy).toHaveBeenCalledTimes(1); + expect(clearAndInitSpy).toHaveBeenCalledWith(expect.any(Wallet)); + expect(gotoSpy).toHaveBeenCalledTimes(1); + expect(gotoSpy).toHaveBeenCalledWith("/dashboard"); + }); + + it("should initialize the wallet encrypted mnemonic saved in localStorage", async () => { + const { getByPlaceholderText, getByRole, getAllByRole } = render(Create); + + // ToS step + await fireEvent.click(getByRole("button", { name: "Accept" })); + + // Mnemonic Agreement step + await fireEvent.click(getAllByRole("checkbox")[0]); + await fireEvent.click(getAllByRole("checkbox")[1]); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Mnemonic Generate step + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Mnemonic Validate step + const mnemonicSplit = mnemonic.split(" "); + + mnemonicSplit.forEach(async word => { + await fireEvent.click(getByRole("button", { name: word })); + }); + + await tick(); + + await fireEvent.click(getByRole("button", { name: "Next" })); + + // Set Password step + expect(loginInfoStorage.get()).toBeNull(); + + await fireEvent.click(getByRole("switch")); + + await fireInput(asInput(getByPlaceholderText("Set Password")), pwd); + await fireInput(asInput(getByPlaceholderText("Confirm Password")), pwd); + + expect(loginInfoStorage.get()).toBeNull(); + await fireEvent.click(getByRole("button", { name: "Next" })); + await vi.waitFor(() => { + expect(loginInfoStorage.get()).not.toBeNull(); + }); + + // Swap ERC20 to Native Dusk step + await fireEvent.click(getByRole("button", { name: "Next" })); + + // All Done step + await fireEvent.click(getByRole("button", { name: "Next" })); + + await vi.waitUntil(() => gotoSpy.mock.calls.length > 0); + + expect(settingsResetSpy).toHaveBeenCalledTimes(1); + expect(getWalletSpy).toHaveBeenCalledTimes(1); + expect(getWalletSpy).toHaveBeenCalledWith(seed); + expect(clearAndInitSpy).toHaveBeenCalledTimes(1); + expect(clearAndInitSpy).toHaveBeenCalledWith(expect.any(Wallet)); + expect(gotoSpy).toHaveBeenCalledTimes(1); + expect(gotoSpy).toHaveBeenCalledWith("/dashboard"); + }); }); diff --git a/web-wallet/src/routes/(welcome)/setup/restore/__tests__/page.spec.js b/web-wallet/src/routes/(welcome)/setup/restore/__tests__/page.spec.js index 9f80c81d2d..9085d7d47a 100644 --- a/web-wallet/src/routes/(welcome)/setup/restore/__tests__/page.spec.js +++ b/web-wallet/src/routes/(welcome)/setup/restore/__tests__/page.spec.js @@ -70,15 +70,15 @@ describe("Restore", async () => { walletGetPsksSpy.mockRestore(); }); - it("should render the Terms of Service step of the Restore flow if there is no userId saved in localStorage", () => { + it("should render the Existing Wallet notice step of the Restore flow if there is a userId saved in localStorage", () => { + settingsStore.update(setKey("userId", userId)); + const { container } = render(Restore); expect(container.firstChild).toMatchSnapshot(); }); - it("should render the Existing Wallet notice step of the Restore flow if there is a userId saved in localStorage", () => { - settingsStore.update(setKey("userId", userId)); - + it("should render the Terms of Service step of the Restore flow if there is no userId saved in localStorage", () => { const { container } = render(Restore); expect(container.firstChild).toMatchSnapshot();