hermes-io 2.3.42 → 2.3.43

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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hermes-io",
3
- "version": "2.3.42",
3
+ "version": "2.3.43",
4
4
  "description": "A lightweight React library that allows communication between Reactjs components by using the observer pattern and the hook api",
5
5
  "main": "./lib/index.js",
6
6
  "module": "./lib/index.js",
@@ -1,41 +0,0 @@
1
- import { vi } from 'vitest';
2
- import { Context } from "../src/context/context";
3
-
4
- describe("Context", () => {
5
- let context;
6
-
7
- beforeEach(() => {
8
- context = new Context("Test Description");
9
- });
10
-
11
- afterEach(() => {
12
- context = null;
13
- });
14
-
15
- test("update method updates context properties", () => {
16
- const value = "test value";
17
- const listener = vi.fn();
18
- context.update({ value, listener });
19
-
20
- expect(context.date).toBeInstanceOf(Date);
21
- expect(context.value).toBe(value);
22
- expect(context.listener).toBe(listener);
23
- expect(context.stackTrace).toEqual(expect.any(String));
24
- });
25
-
26
- test("takeSnapshot method returns a snapshot object", () => {
27
- const snapshot = context.takeSnapshot();
28
-
29
- expect(snapshot._internalId).toEqual(expect.any(String));
30
- expect(snapshot.value).toBe(context.value);
31
- expect(snapshot.date).toBe(context.date);
32
- expect(snapshot.listener).toBe(context.listener);
33
- expect(snapshot.stackTrace).toBe(context.stackTrace);
34
- });
35
-
36
- test("getStackTrace method returns stack trace", () => {
37
- const stackTrace = context.getStackTrace();
38
-
39
- expect(stackTrace).toEqual(expect.any(String));
40
- });
41
- });
@@ -1,34 +0,0 @@
1
- import { Observer } from "../src/observer/observer";
2
-
3
- describe("Observer", () => {
4
- let observer;
5
- let callback1;
6
- let callback2;
7
-
8
- beforeEach(() => {
9
- observer = new Observer();
10
- callback1 = vi.fn();
11
- callback2 = vi.fn();
12
- });
13
-
14
- afterEach(() => {
15
- observer = null;
16
- callback1 = null;
17
- callback2 = null;
18
- });
19
-
20
- it("subscribe and notify", () => {
21
- observer.subscribe(callback1);
22
- observer.subscribe(callback2);
23
- const args = { data: "test" };
24
- observer.notify(args);
25
- expect(callback1).toHaveBeenCalledWith(args, expect.any(Function));
26
- expect(callback2).toHaveBeenCalledWith(args, expect.any(Function));
27
- });
28
-
29
- it("unsubscribe", async () => {
30
- observer.subscribe(callback1);
31
- observer.unsubscribe(callback1);
32
- expect(callback1).not.toHaveBeenCalled();
33
- });
34
- });
@@ -1,63 +0,0 @@
1
- import { renderHook, act } from "@testing-library/react-hooks/dom";
2
- import { Context, listenersMap } from "../src/context/context";
3
- import { Observer, useObserver } from "../src/observer/observer";
4
- import { test } from "vitest";
5
-
6
- // Mock the observer object and its methods
7
- const mockObserver = {
8
- subscribe: vi.fn(),
9
- unsubscribe: vi.fn(),
10
- };
11
-
12
- describe("useObserver", () => {
13
- let context;
14
- beforeEach(() => {
15
- context = new Context("Test");
16
- });
17
-
18
- afterEach(() => {
19
- listenersMap.clear();
20
- vi.clearAllMocks();
21
- context = null;
22
- });
23
-
24
- test("should subscribe and unsubscribe to observer ", async () => {
25
- const observer = new Observer();
26
- const listener = vi.fn();
27
- const contexts = [context];
28
- const { unmount } = await renderHook(() => {
29
- const hook = useObserver({ observer, listener, contexts });
30
- expect(observer.subscriptors.length).toBe(1);
31
- return hook;
32
- });
33
- await act(() => unmount());
34
- expect(observer.subscriptors.length).toBe(0);
35
- });
36
-
37
- it("should add and remove listener from listenersMap", async () => {
38
- const observer = new Observer();
39
- const listener = vi.fn();
40
- const { unmount } = await renderHook(() => {
41
- const hook = useObserver({ observer, listener, contexts: [context] });
42
- expect(listenersMap.size).toBe(1);
43
- return hook;
44
- });
45
- await act(() => unmount());
46
- expect(listenersMap.size).toBe(0);
47
- });
48
-
49
- it("should call listener on notification", async () => {
50
- const observer = mockObserver;
51
- const listener = vi.fn();
52
- renderHook(() => {
53
- useObserver({ observer, listener, contexts: [context] });
54
- observer.notify({
55
- context,
56
- value: {
57
- test: true,
58
- },
59
- });
60
- expect(listener).toHaveBeenCalledTimes(1);
61
- });
62
- });
63
- });
@@ -1,20 +0,0 @@
1
- import { test, expect } from "vitest";
2
- import { render, screen } from "@testing-library/react";
3
- import { withNotify } from "../src/components/withNotify/withNotify";
4
- import { Context } from "../src/context/context";
5
- import { Observer } from "../src/observer/observer";
6
-
7
- const TestContext = new Context("Test");
8
- const TestObserver = new Observer();
9
-
10
- const Wrapper = withNotify((props) => <h1>{Object.keys(props)}</h1>, {
11
- context: TestContext,
12
- observer: TestObserver,
13
- });
14
-
15
- test("Should add ", () => {
16
- render(<Wrapper />);
17
- const node = screen.getByText(/notify/gi);
18
- expect(node).toBeInTheDocument();
19
- })
20
-
@@ -1,36 +0,0 @@
1
- import { test, expect } from "vitest";
2
- import { render, screen, waitFor } from "@testing-library/react";
3
- import { withReactive } from "../src/components/withReactive/withReactive";
4
- import { Context } from "../src/context/context";
5
- import { Observer } from "../src/observer/observer";
6
-
7
- const TestContext = new Context("Test");
8
- const TestObserver = new Observer();
9
-
10
- const Wrapper = withReactive({
11
- context: TestContext,
12
- observer: TestObserver,
13
- values: {
14
- title: "test",
15
- },
16
- });
17
-
18
- test("Should Renders the component correctly", () => {
19
- render(<Wrapper id="test" render={({ title }) => <h1>{title}</h1>} />);
20
- const node = screen.getByText(/test/gi);
21
- expect(node).toBeInTheDocument();
22
- });
23
-
24
- test("Should re-render on notification", async () => {
25
- await render(<Wrapper id="test2" render={({ title }) => <h1>{title}</h1>} />);
26
- TestObserver.notify({
27
- context: TestContext,
28
- value: {
29
- type: "test2",
30
- value: { title: "new title" },
31
- },
32
- });
33
- await waitFor(() =>
34
- expect(screen.getByText(/new title/gi)).toBeInTheDocument()
35
- );
36
- });