aboutsummaryrefslogtreecommitdiff
path: root/packages/demobank-ui/src/components/Transactions/test.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/demobank-ui/src/components/Transactions/test.ts')
-rw-r--r--packages/demobank-ui/src/components/Transactions/test.ts224
1 files changed, 116 insertions, 108 deletions
diff --git a/packages/demobank-ui/src/components/Transactions/test.ts b/packages/demobank-ui/src/components/Transactions/test.ts
index b746f6bb7..21a0eefbb 100644
--- a/packages/demobank-ui/src/components/Transactions/test.ts
+++ b/packages/demobank-ui/src/components/Transactions/test.ts
@@ -26,149 +26,157 @@ import { TRANSACTION_API_EXAMPLE } from "../../endpoints.js";
import { Props } from "./index.js";
import { useComponentState } from "./state.js";
-
describe("Transaction states", () => {
-
it("should query backend and render transactions", async () => {
-
const env = new SwrMockEnvironment();
const props: Props = {
accountLabel: "myAccount",
- pageNumber: 0
- }
+ pageNumber: 0,
+ };
env.addRequestExpectation(TRANSACTION_API_EXAMPLE.LIST_FIRST_PAGE, {
response: {
- "transactions": [
+ transactions: [
{
- "creditorIban": "DE159593",
- "creditorBic": "SANDBOXX",
- "creditorName": "exchange company",
- "debtorIban": "DE118695",
- "debtorBic": "SANDBOXX",
- "debtorName": "Name unknown",
- "amount": "1",
- "currency": "KUDOS",
- "subject": "Taler Withdrawal N588V8XE9TR49HKAXFQ20P0EQ0EYW2AC9NNANV8ZP5P59N6N0410",
- "date": "2022-12-12Z",
- "uid": "8PPFR9EM",
- "direction": "DBIT",
- "pmtInfId": null,
- "msgId": null
+ creditorIban: "DE159593",
+ creditorBic: "SANDBOXX",
+ creditorName: "exchange company",
+ debtorIban: "DE118695",
+ debtorBic: "SANDBOXX",
+ debtorName: "Name unknown",
+ amount: "1",
+ currency: "KUDOS",
+ subject:
+ "Taler Withdrawal N588V8XE9TR49HKAXFQ20P0EQ0EYW2AC9NNANV8ZP5P59N6N0410",
+ date: "2022-12-12Z",
+ uid: "8PPFR9EM",
+ direction: "DBIT",
+ pmtInfId: null,
+ msgId: null,
},
{
- "creditorIban": "DE159593",
- "creditorBic": "SANDBOXX",
- "creditorName": "exchange company",
- "debtorIban": "DE118695",
- "debtorBic": "SANDBOXX",
- "debtorName": "Name unknown",
- "amount": "5.00",
- "currency": "KUDOS",
- "subject": "HNEWWT679TQC5P1BVXJS48FX9NW18FWM6PTK2N80Z8GVT0ACGNK0",
- "date": "2022-12-07Z",
- "uid": "7FZJC3RJ",
- "direction": "DBIT",
- "pmtInfId": null,
- "msgId": null
+ creditorIban: "DE159593",
+ creditorBic: "SANDBOXX",
+ creditorName: "exchange company",
+ debtorIban: "DE118695",
+ debtorBic: "SANDBOXX",
+ debtorName: "Name unknown",
+ amount: "5.00",
+ currency: "KUDOS",
+ subject: "HNEWWT679TQC5P1BVXJS48FX9NW18FWM6PTK2N80Z8GVT0ACGNK0",
+ date: "2022-12-07Z",
+ uid: "7FZJC3RJ",
+ direction: "DBIT",
+ pmtInfId: null,
+ msgId: null,
},
{
- "creditorIban": "DE118695",
- "creditorBic": "SANDBOXX",
- "creditorName": "Name unknown",
- "debtorIban": "DE579516",
- "debtorBic": "SANDBOXX",
- "debtorName": "The Bank",
- "amount": "100",
- "currency": "KUDOS",
- "subject": "Sign-up bonus",
- "date": "2022-12-07Z",
- "uid": "I31A06J8",
- "direction": "CRDT",
- "pmtInfId": null,
- "msgId": null
- }
- ]
- }
- });
-
- const hookBehavior = await tests.hookBehaveLikeThis(useComponentState, props, [
- ({ status, error }) => {
-
- expect(status).equals("loading");
- expect(error).undefined;
- },
- ({ status, error }) => {
-
- expect(status).equals("ready");
- expect(error).undefined;
+ creditorIban: "DE118695",
+ creditorBic: "SANDBOXX",
+ creditorName: "Name unknown",
+ debtorIban: "DE579516",
+ debtorBic: "SANDBOXX",
+ debtorName: "The Bank",
+ amount: "100",
+ currency: "KUDOS",
+ subject: "Sign-up bonus",
+ date: "2022-12-07Z",
+ uid: "I31A06J8",
+ direction: "CRDT",
+ pmtInfId: null,
+ msgId: null,
+ },
+ ],
},
- ], env.buildTestingContext())
-
- expect(hookBehavior).deep.eq({ result: "ok" })
+ });
- expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" })
+ const hookBehavior = await tests.hookBehaveLikeThis(
+ useComponentState,
+ props,
+ [
+ ({ status, error }) => {
+ expect(status).equals("loading");
+ expect(error).undefined;
+ },
+ ({ status, error }) => {
+ expect(status).equals("ready");
+ expect(error).undefined;
+ },
+ ],
+ env.buildTestingContext(),
+ );
+
+ expect(hookBehavior).deep.eq({ result: "ok" });
+
+ expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" });
});
it("should show error message on not found", async () => {
-
const env = new SwrMockEnvironment();
const props: Props = {
accountLabel: "myAccount",
- pageNumber: 0
- }
+ pageNumber: 0,
+ };
env.addRequestExpectation(TRANSACTION_API_EXAMPLE.LIST_NOT_FOUND, {});
- const hookBehavior = await tests.hookBehaveLikeThis(useComponentState, props, [
- ({ status, error }) => {
- expect(status).equals("loading");
- expect(error).undefined;
- },
- ({ status, error }) => {
- expect(status).equals("loading-error");
- expect(error).deep.eq({
- hasError: true,
- operational: false,
- message: "Transactions page 0 was not found."
- });
- },
- ], env.buildTestingContext())
-
- expect(hookBehavior).deep.eq({ result: "ok" })
- expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" })
+ const hookBehavior = await tests.hookBehaveLikeThis(
+ useComponentState,
+ props,
+ [
+ ({ status, error }) => {
+ expect(status).equals("loading");
+ expect(error).undefined;
+ },
+ ({ status, error }) => {
+ expect(status).equals("loading-error");
+ expect(error).deep.eq({
+ hasError: true,
+ operational: false,
+ message: "Transactions page 0 was not found.",
+ });
+ },
+ ],
+ env.buildTestingContext(),
+ );
+
+ expect(hookBehavior).deep.eq({ result: "ok" });
+ expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" });
});
it("should show error message on server error", async () => {
-
const env = new SwrMockEnvironment(false);
const props: Props = {
accountLabel: "myAccount",
- pageNumber: 0
- }
+ pageNumber: 0,
+ };
env.addRequestExpectation(TRANSACTION_API_EXAMPLE.LIST_ERROR, {});
- const hookBehavior = await tests.hookBehaveLikeThis(useComponentState, props, [
- ({ status, error }) => {
- expect(status).equals("loading");
- expect(error).undefined;
- },
- ({ status, error }) => {
- expect(status).equals("loading-error");
- expect(error).deep.equal({
- hasError: true,
- operational: false,
- message: "Transaction page 0 could not be retrieved."
- });
- },
- ], env.buildTestingContext())
-
- expect(hookBehavior).deep.eq({ result: "ok" })
- expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" })
+ const hookBehavior = await tests.hookBehaveLikeThis(
+ useComponentState,
+ props,
+ [
+ ({ status, error }) => {
+ expect(status).equals("loading");
+ expect(error).undefined;
+ },
+ ({ status, error }) => {
+ expect(status).equals("loading-error");
+ expect(error).deep.equal({
+ hasError: true,
+ operational: false,
+ message: "Transaction page 0 could not be retrieved.",
+ });
+ },
+ ],
+ env.buildTestingContext(),
+ );
+
+ expect(hookBehavior).deep.eq({ result: "ok" });
+ expect(env.assertJustExpectedRequestWereMade()).deep.eq({ result: "ok" });
});
});
-