@thepalaceproject/circulation-admin 0.5.0 → 1.6.0

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/package.json CHANGED
@@ -102,6 +102,7 @@
102
102
  "lint-staged": "^10.4.0",
103
103
  "mini-css-extract-plugin": "1.6.0",
104
104
  "mocha": "^10.2.0",
105
+ "msw": "^1.2.1",
105
106
  "nightwatch": "^1.0.19",
106
107
  "node-sass": "^8.0.0",
107
108
  "prettier": "2.1.2",
@@ -135,5 +136,5 @@
135
136
  "*.{js,jsx,ts,tsx,css,md}": "prettier --write",
136
137
  "*.{js,css,md}": "prettier --write"
137
138
  },
138
- "version": "0.5.0"
139
+ "version": "1.6.0"
139
140
  }
@@ -0,0 +1,108 @@
1
+ import * as React from "react";
2
+ import { screen } from "@testing-library/react";
3
+ import userEvent from "@testing-library/user-event";
4
+ import { rest } from "msw";
5
+ import { setupServer } from "msw/node";
6
+ import CustomLists from "../../../src/components/CustomLists";
7
+ import renderWithContext from "../testUtils/renderWithContext";
8
+ import buildStore from "../../../src/store";
9
+
10
+ describe("CustomLists", () => {
11
+ // Stub scrollTo, since a component in the render tree will try to call it, and it is not
12
+ // provided by JSDOM.
13
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
14
+ Element.prototype.scrollTo = () => {};
15
+
16
+ const server = setupServer(
17
+ rest.get("*/search", (req, res, ctx) => res(ctx.xml("<feed />"))),
18
+ rest.get("*", (req, res, ctx) => res(ctx.json({})))
19
+ );
20
+
21
+ beforeAll(() => {
22
+ server.listen();
23
+ });
24
+
25
+ afterAll(() => {
26
+ server.close();
27
+ });
28
+
29
+ it("adds filters when new filter values are entered", async () => {
30
+ const user = userEvent.setup();
31
+
32
+ const contextProviderProps = {
33
+ csrfToken: "",
34
+ roles: [{ role: "system" }],
35
+ };
36
+
37
+ renderWithContext(
38
+ <CustomLists
39
+ csrfToken=""
40
+ editOrCreate="create"
41
+ library="testlib"
42
+ store={buildStore()}
43
+ />,
44
+ contextProviderProps
45
+ );
46
+
47
+ await user.click(screen.getByRole("textbox", { name: "filter value" }));
48
+ await user.keyboard("horror{enter}");
49
+
50
+ const items = screen.getAllByRole("treeitem");
51
+
52
+ expect(items).toHaveLength(1);
53
+ expect(items[0]).toHaveTextContent(/genre = horror/);
54
+
55
+ await user.click(screen.getByRole("textbox", { name: "filter value" }));
56
+ await user.keyboard("science fiction{enter}");
57
+
58
+ const newItems = screen.getAllByRole("treeitem");
59
+
60
+ expect(newItems).toHaveLength(3);
61
+ expect(newItems[0]).toHaveTextContent(
62
+ /all of these filters must be matched/i
63
+ );
64
+ expect(newItems[1]).toHaveTextContent(/genre = horror/i);
65
+ expect(newItems[2]).toHaveTextContent(/genre = science fiction/i);
66
+ });
67
+
68
+ it("replaces the existing filters when adding a new filter when the clear filters checkbox is checked", async () => {
69
+ const user = userEvent.setup();
70
+
71
+ const contextProviderProps = {
72
+ csrfToken: "",
73
+ roles: [{ role: "system" }],
74
+ };
75
+
76
+ renderWithContext(
77
+ <CustomLists
78
+ csrfToken=""
79
+ editOrCreate="create"
80
+ library="testlib"
81
+ store={buildStore()}
82
+ />,
83
+ contextProviderProps
84
+ );
85
+
86
+ await user.click(screen.getByRole("textbox", { name: "filter value" }));
87
+ await user.keyboard("horror{enter}");
88
+
89
+ let items = screen.getAllByRole("treeitem");
90
+
91
+ expect(items).toHaveLength(1);
92
+ expect(items[0]).toHaveTextContent(/genre = horror/);
93
+
94
+ await user.click(screen.getByRole("textbox", { name: "filter value" }));
95
+ await user.keyboard("science fiction{enter}");
96
+
97
+ items = screen.getAllByRole("treeitem");
98
+ expect(items).toHaveLength(3);
99
+
100
+ await user.click(screen.getByRole("checkbox", { name: /clear filters/i }));
101
+
102
+ await user.click(screen.getByRole("textbox", { name: "filter value" }));
103
+ await user.keyboard("fantasy{enter}");
104
+
105
+ items = screen.getAllByRole("treeitem");
106
+ expect(items).toHaveLength(1);
107
+ });
108
+ });