@digital-alchemy/hass 24.9.2 → 24.9.4
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/README.md +4 -1
- package/dist/dynamic.d.ts +1 -1
- package/dist/dynamic.js +7 -2
- package/dist/dynamic.js.map +1 -1
- package/dist/extensions/area.extension.d.ts +2 -12
- package/dist/extensions/area.extension.js +20 -26
- package/dist/extensions/area.extension.js.map +1 -1
- package/dist/extensions/backup.extension.d.ts +2 -7
- package/dist/extensions/backup.extension.js +5 -8
- package/dist/extensions/backup.extension.js.map +1 -1
- package/dist/extensions/call-proxy.extension.d.ts +1 -1
- package/dist/extensions/call-proxy.extension.js +11 -29
- package/dist/extensions/call-proxy.extension.js.map +1 -1
- package/dist/extensions/config.extension.d.ts +2 -6
- package/dist/extensions/config.extension.js +21 -25
- package/dist/extensions/config.extension.js.map +1 -1
- package/dist/extensions/conversation.extension.d.ts +2 -6
- package/dist/extensions/conversation.extension.js +5 -8
- package/dist/extensions/conversation.extension.js.map +1 -1
- package/dist/extensions/device.extension.d.ts +2 -5
- package/dist/extensions/device.extension.js +16 -22
- package/dist/extensions/device.extension.js.map +1 -1
- package/dist/extensions/entity.extension.d.ts +2 -61
- package/dist/extensions/entity.extension.js +42 -83
- package/dist/extensions/entity.extension.js.map +1 -1
- package/dist/extensions/events.extension.d.ts +3 -11
- package/dist/extensions/events.extension.js +8 -11
- package/dist/extensions/events.extension.js.map +1 -1
- package/dist/extensions/fetch-api.extension.d.ts +12 -4
- package/dist/extensions/fetch-api.extension.js +23 -35
- package/dist/extensions/fetch-api.extension.js.map +1 -1
- package/dist/extensions/floor.extension.d.ts +2 -9
- package/dist/extensions/floor.extension.js +17 -23
- package/dist/extensions/floor.extension.js.map +1 -1
- package/dist/extensions/id-by.extension.js +15 -20
- package/dist/extensions/id-by.extension.js.map +1 -1
- package/dist/extensions/index.d.ts +1 -0
- package/dist/extensions/index.js +16 -18
- package/dist/extensions/index.js.map +1 -1
- package/dist/extensions/internal.extension.d.ts +18 -0
- package/dist/extensions/internal.extension.js +102 -0
- package/dist/extensions/internal.extension.js.map +1 -0
- package/dist/extensions/label.extension.d.ts +2 -9
- package/dist/extensions/label.extension.js +17 -23
- package/dist/extensions/label.extension.js.map +1 -1
- package/dist/extensions/reference.extension.d.ts +2 -12
- package/dist/extensions/reference.extension.js +19 -25
- package/dist/extensions/reference.extension.js.map +1 -1
- package/dist/extensions/registry.extension.d.ts +2 -7
- package/dist/extensions/registry.extension.js +1 -4
- package/dist/extensions/registry.extension.js.map +1 -1
- package/dist/extensions/websocket-api.extension.d.ts +3 -78
- package/dist/extensions/websocket-api.extension.js +82 -165
- package/dist/extensions/websocket-api.extension.js.map +1 -1
- package/dist/extensions/zone.extension.d.ts +2 -7
- package/dist/extensions/zone.extension.js +15 -21
- package/dist/extensions/zone.extension.js.map +1 -1
- package/dist/hass.module.d.ts +47 -36
- package/dist/hass.module.js +70 -70
- package/dist/hass.module.js.map +1 -1
- package/dist/helpers/backup.helper.js +1 -2
- package/dist/helpers/constants.helper.js +15 -18
- package/dist/helpers/constants.helper.js.map +1 -1
- package/dist/helpers/device.helper.js +2 -5
- package/dist/helpers/device.helper.js.map +1 -1
- package/dist/helpers/entity-state.helper.d.ts +3 -8
- package/dist/helpers/entity-state.helper.js +1 -8
- package/dist/helpers/entity-state.helper.js.map +1 -1
- package/dist/helpers/features.helper.js +79 -85
- package/dist/helpers/features.helper.js.map +1 -1
- package/dist/helpers/fetch/calendar.js +1 -2
- package/dist/helpers/fetch/configuration.js +2 -5
- package/dist/helpers/fetch/configuration.js.map +1 -1
- package/dist/helpers/fetch/index.js +5 -8
- package/dist/helpers/fetch/index.js.map +1 -1
- package/dist/helpers/fetch/server-log.js +1 -2
- package/dist/helpers/fetch/server-log.js.map +1 -1
- package/dist/helpers/fetch/service-list.js +1 -2
- package/dist/helpers/fetch/weather-forecasts.js +1 -2
- package/dist/helpers/fetch/weather-forecasts.js.map +1 -1
- package/dist/helpers/fetch.helper.d.ts +162 -0
- package/dist/helpers/fetch.helper.js +161 -0
- package/dist/helpers/fetch.helper.js.map +1 -0
- package/dist/helpers/id-by.helper.js +1 -2
- package/dist/helpers/index.d.ts +2 -1
- package/dist/helpers/index.js +13 -15
- package/dist/helpers/index.js.map +1 -1
- package/dist/helpers/interfaces.helper.d.ts +228 -0
- package/dist/helpers/interfaces.helper.js +10 -0
- package/dist/helpers/interfaces.helper.js.map +1 -0
- package/dist/helpers/manifest.helper.d.ts +0 -1
- package/dist/helpers/manifest.helper.js +0 -1
- package/dist/helpers/notify.helper.d.ts +11 -3
- package/dist/helpers/notify.helper.js +1 -2
- package/dist/helpers/registry.js +7 -10
- package/dist/helpers/registry.js.map +1 -1
- package/dist/helpers/utility.helper.d.ts +6 -1
- package/dist/helpers/utility.helper.js +9 -13
- package/dist/helpers/utility.helper.js.map +1 -1
- package/dist/helpers/websocket.helper.d.ts +1 -2
- package/dist/helpers/websocket.helper.js +1 -2
- package/dist/index.js +5 -8
- package/dist/index.js.map +1 -1
- package/dist/mock_assistant/extensions/area.extension.d.ts +8 -0
- package/dist/mock_assistant/extensions/area.extension.js +51 -0
- package/dist/mock_assistant/extensions/area.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/config.extension.d.ts +14 -0
- package/dist/mock_assistant/extensions/config.extension.js +29 -0
- package/dist/mock_assistant/extensions/config.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/device.extension.d.ts +8 -0
- package/dist/mock_assistant/extensions/device.extension.js +33 -0
- package/dist/mock_assistant/extensions/device.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/entity-registry.extension.d.ts +13 -0
- package/dist/mock_assistant/extensions/entity-registry.extension.js +28 -0
- package/dist/mock_assistant/extensions/entity-registry.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/entity.extension.d.ts +30 -0
- package/dist/mock_assistant/extensions/entity.extension.js +77 -0
- package/dist/mock_assistant/extensions/entity.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/events.extension.d.ts +1 -1
- package/dist/mock_assistant/extensions/events.extension.js +3 -6
- package/dist/mock_assistant/extensions/events.extension.js.map +1 -1
- package/dist/mock_assistant/extensions/fetch.extension.d.ts +1 -0
- package/dist/mock_assistant/extensions/fetch.extension.js +4 -0
- package/dist/mock_assistant/extensions/fetch.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/fixtures.extension.d.ts +1 -1
- package/dist/mock_assistant/extensions/fixtures.extension.js +29 -33
- package/dist/mock_assistant/extensions/fixtures.extension.js.map +1 -1
- package/dist/mock_assistant/extensions/floor.extension.d.ts +8 -0
- package/dist/mock_assistant/extensions/floor.extension.js +51 -0
- package/dist/mock_assistant/extensions/floor.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/index.d.ts +10 -0
- package/dist/mock_assistant/extensions/index.js +12 -5
- package/dist/mock_assistant/extensions/index.js.map +1 -1
- package/dist/mock_assistant/extensions/label.extension.d.ts +8 -0
- package/dist/mock_assistant/extensions/label.extension.js +51 -0
- package/dist/mock_assistant/extensions/label.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/services.extension.d.ts +12 -0
- package/dist/mock_assistant/extensions/services.extension.js +20 -0
- package/dist/mock_assistant/extensions/services.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/websocket-api.extension.d.ts +15 -0
- package/dist/mock_assistant/extensions/websocket-api.extension.js +68 -0
- package/dist/mock_assistant/extensions/websocket-api.extension.js.map +1 -0
- package/dist/mock_assistant/extensions/zone.extension.d.ts +8 -0
- package/dist/mock_assistant/extensions/zone.extension.js +51 -0
- package/dist/mock_assistant/extensions/zone.extension.js.map +1 -0
- package/dist/mock_assistant/helpers/fixtures.js +1 -2
- package/dist/mock_assistant/helpers/index.d.ts +0 -1
- package/dist/mock_assistant/helpers/index.js +1 -5
- package/dist/mock_assistant/helpers/index.js.map +1 -1
- package/dist/mock_assistant/index.js +3 -6
- package/dist/mock_assistant/index.js.map +1 -1
- package/dist/mock_assistant/main.js +11 -15
- package/dist/mock_assistant/main.js.map +1 -1
- package/dist/mock_assistant/mock-assistant.module.d.ts +156 -3
- package/dist/mock_assistant/mock-assistant.module.js +56 -11
- package/dist/mock_assistant/mock-assistant.module.js.map +1 -1
- package/dist/quickboot.module.js +5 -8
- package/dist/quickboot.module.js.map +1 -1
- package/dist/testing/area.spec.js +106 -194
- package/dist/testing/area.spec.js.map +1 -1
- package/dist/testing/backup.spec.js +97 -139
- package/dist/testing/backup.spec.js.map +1 -1
- package/dist/testing/config.spec.js +79 -153
- package/dist/testing/config.spec.js.map +1 -1
- package/dist/testing/device.spec.js +35 -69
- package/dist/testing/device.spec.js.map +1 -1
- package/dist/testing/entity.spec.js +94 -149
- package/dist/testing/entity.spec.js.map +1 -1
- package/dist/testing/events.spec.js +33 -57
- package/dist/testing/events.spec.js.map +1 -1
- package/dist/testing/fetch-api.spec.js +242 -427
- package/dist/testing/fetch-api.spec.js.map +1 -1
- package/dist/testing/fixtures.spec.d.ts +1 -0
- package/dist/testing/fixtures.spec.js +150 -0
- package/dist/testing/fixtures.spec.js.map +1 -0
- package/dist/testing/floor.spec.js +106 -194
- package/dist/testing/floor.spec.js.map +1 -1
- package/dist/testing/id-by.spec.js +68 -107
- package/dist/testing/id-by.spec.js.map +1 -1
- package/dist/testing/label.spec.js +106 -194
- package/dist/testing/label.spec.js.map +1 -1
- package/dist/testing/ref-by.spec.js +155 -219
- package/dist/testing/ref-by.spec.js.map +1 -1
- package/dist/testing/websocket.spec.d.ts +1 -8
- package/dist/testing/websocket.spec.js +35 -50
- package/dist/testing/websocket.spec.js.map +1 -1
- package/dist/testing/workflow.spec.js +82 -81
- package/dist/testing/workflow.spec.js.map +1 -1
- package/dist/testing/zone.spec.js +61 -113
- package/dist/testing/zone.spec.js.map +1 -1
- package/package.json +57 -41
- package/dist/helpers/metrics.helper.d.ts +0 -29
- package/dist/helpers/metrics.helper.js +0 -62
- package/dist/helpers/metrics.helper.js.map +0 -1
- package/dist/mock_assistant/helpers/utils.d.ts +0 -4
- package/dist/mock_assistant/helpers/utils.js +0 -57
- package/dist/mock_assistant/helpers/utils.js.map +0 -1
|
@@ -1,70 +1,55 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const mock_assistant_1 = require("../mock_assistant");
|
|
1
|
+
import { hassTestRunner } from "../mock_assistant";
|
|
4
2
|
describe("Websocket", () => {
|
|
5
|
-
let application;
|
|
6
3
|
afterEach(async () => {
|
|
7
|
-
|
|
8
|
-
await application.teardown();
|
|
9
|
-
application = undefined;
|
|
10
|
-
}
|
|
4
|
+
await hassTestRunner.teardown();
|
|
11
5
|
jest.restoreAllMocks();
|
|
12
6
|
});
|
|
13
7
|
describe("API Interactions", () => {
|
|
14
8
|
it("should emit events onConnect", async () => {
|
|
15
9
|
expect.assertions(1);
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
});
|
|
23
|
-
},
|
|
10
|
+
await hassTestRunner.run(({ lifecycle, hass }) => {
|
|
11
|
+
let hit = false;
|
|
12
|
+
hass.socket.onConnect(() => (hit = true));
|
|
13
|
+
lifecycle.onReady(() => {
|
|
14
|
+
expect(hit).toBe(true);
|
|
15
|
+
});
|
|
24
16
|
});
|
|
25
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({ hass: { MOCK_SOCKET: true } }, true));
|
|
26
17
|
});
|
|
27
18
|
it("should emit a socket message with subscribeEvents", async () => {
|
|
28
19
|
expect.assertions(1);
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
exec: () => { },
|
|
39
|
-
});
|
|
40
|
-
expect(spy).toHaveBeenCalledWith(expect.objectContaining({
|
|
41
|
-
event_type: "test",
|
|
42
|
-
type: "subscribe_events",
|
|
43
|
-
}));
|
|
20
|
+
await hassTestRunner.run(({ lifecycle, hass, context }) => {
|
|
21
|
+
const spy = jest
|
|
22
|
+
.spyOn(hass.socket, "sendMessage")
|
|
23
|
+
.mockImplementation(async () => undefined);
|
|
24
|
+
lifecycle.onReady(async () => {
|
|
25
|
+
await hass.socket.subscribe({
|
|
26
|
+
context,
|
|
27
|
+
event_type: "test",
|
|
28
|
+
exec: () => { },
|
|
44
29
|
});
|
|
45
|
-
|
|
30
|
+
expect(spy).toHaveBeenCalledWith(expect.objectContaining({
|
|
31
|
+
event_type: "test",
|
|
32
|
+
type: "subscribe_events",
|
|
33
|
+
}));
|
|
34
|
+
});
|
|
46
35
|
});
|
|
47
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({ hass: { MOCK_SOCKET: true } }, true));
|
|
48
36
|
});
|
|
49
37
|
it("should emit a socket message with fireEvent", async () => {
|
|
50
38
|
expect.assertions(1);
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
});
|
|
65
|
-
},
|
|
39
|
+
await hassTestRunner.run(({ lifecycle, hass }) => {
|
|
40
|
+
const spy = jest
|
|
41
|
+
.spyOn(hass.socket, "sendMessage")
|
|
42
|
+
.mockImplementation(async () => undefined);
|
|
43
|
+
lifecycle.onReady(async () => {
|
|
44
|
+
const data = { example: "data" };
|
|
45
|
+
await hass.socket.fireEvent("test_event", data);
|
|
46
|
+
expect(spy).toHaveBeenCalledWith(expect.objectContaining({
|
|
47
|
+
event_data: data,
|
|
48
|
+
event_type: "test_event",
|
|
49
|
+
type: "fire_event",
|
|
50
|
+
}));
|
|
51
|
+
});
|
|
66
52
|
});
|
|
67
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({ hass: { MOCK_SOCKET: true } }, true));
|
|
68
53
|
});
|
|
69
54
|
});
|
|
70
55
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"websocket.spec.js","sourceRoot":"","sources":["../../src/testing/websocket.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"websocket.spec.js","sourceRoot":"","sources":["../../src/testing/websocket.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,95 +1,91 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const core_1 = require("@digital-alchemy/core");
|
|
5
|
-
const dayjs_1 = tslib_1.__importDefault(require("dayjs"));
|
|
6
|
-
const __1 = require("..");
|
|
7
|
-
const mock_assistant_1 = require("../mock_assistant");
|
|
1
|
+
import { CronExpression, SECOND, sleep } from "@digital-alchemy/core";
|
|
2
|
+
import dayjs from "dayjs";
|
|
3
|
+
import { hassTestRunner } from "../mock_assistant";
|
|
8
4
|
describe("Workflows", () => {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
scheduler.cron({
|
|
16
|
-
async exec() {
|
|
17
|
-
await hass.call.switch.turn_on({
|
|
18
|
-
entity_id: "switch.bedroom_lamp",
|
|
19
|
-
});
|
|
20
|
-
},
|
|
21
|
-
schedule: core_1.CronExpression.EVERY_DAY_AT_8PM,
|
|
22
|
-
});
|
|
23
|
-
const entity = hass.refBy.id("sensor.magic");
|
|
24
|
-
entity.onUpdate(async () => {
|
|
25
|
-
const action = entity.state === "test" ? "turn_on" : "turn_off";
|
|
26
|
-
await hass.call.switch[action]({
|
|
27
|
-
entity_id: "switch.porch_light",
|
|
5
|
+
beforeAll(() => {
|
|
6
|
+
hassTestRunner.appendService(({ hass, scheduler }) => {
|
|
7
|
+
scheduler.cron({
|
|
8
|
+
async exec() {
|
|
9
|
+
await hass.call.switch.turn_on({
|
|
10
|
+
entity_id: "switch.bedroom_lamp",
|
|
28
11
|
});
|
|
12
|
+
},
|
|
13
|
+
schedule: CronExpression.EVERY_DAY_AT_8PM,
|
|
14
|
+
});
|
|
15
|
+
const entity = hass.refBy.id("sensor.magic");
|
|
16
|
+
entity.onUpdate(async () => {
|
|
17
|
+
const action = entity.state === "test" ? "turn_on" : "turn_off";
|
|
18
|
+
await hass.call.switch[action]({
|
|
19
|
+
entity_id: "switch.porch_light",
|
|
29
20
|
});
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
21
|
+
});
|
|
22
|
+
entity.onUpdate(async (new_state, old_state) => {
|
|
23
|
+
if (old_state.state === "away" && new_state.state === "here") {
|
|
24
|
+
await hass.call.switch.turn_on({
|
|
25
|
+
entity_id: "switch.living_room_mood_lights",
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
});
|
|
39
30
|
});
|
|
40
|
-
const runner = (0, mock_assistant_1.CreateTestRunner)(application);
|
|
41
31
|
afterEach(async () => {
|
|
42
|
-
await
|
|
32
|
+
await hassTestRunner.teardown();
|
|
43
33
|
jest.restoreAllMocks();
|
|
44
34
|
});
|
|
45
35
|
describe("Event and Response", () => {
|
|
46
36
|
it("should be able to trigger a workflow", async () => {
|
|
47
37
|
expect.assertions(2);
|
|
48
|
-
await
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
38
|
+
await hassTestRunner.run(({ mock_assistant, hass, lifecycle }) => {
|
|
39
|
+
lifecycle.onReady(async () => {
|
|
40
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
41
|
+
const turnOff = jest.spyOn(hass.call.switch, "turn_off");
|
|
42
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
43
|
+
state: "test",
|
|
44
|
+
});
|
|
45
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
46
|
+
state: "foo",
|
|
47
|
+
});
|
|
48
|
+
expect(turnOn).toHaveBeenCalledTimes(1);
|
|
49
|
+
expect(turnOff).toHaveBeenCalledTimes(1);
|
|
56
50
|
});
|
|
57
|
-
expect(turnOn).toHaveBeenCalledTimes(1);
|
|
58
|
-
expect(turnOff).toHaveBeenCalledTimes(1);
|
|
59
51
|
});
|
|
60
52
|
});
|
|
61
53
|
it("should be able to trigger a from an initial state", async () => {
|
|
62
54
|
expect.assertions(1);
|
|
63
|
-
await
|
|
55
|
+
await hassTestRunner.run(({ mock_assistant, hass, lifecycle }) => {
|
|
64
56
|
mock_assistant.fixtures.setState({
|
|
65
57
|
"sensor.magic": {
|
|
66
58
|
state: "away",
|
|
67
59
|
},
|
|
68
60
|
});
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
61
|
+
lifecycle.onReady(async () => {
|
|
62
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
63
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
64
|
+
state: "here",
|
|
65
|
+
});
|
|
66
|
+
await sleep(1);
|
|
67
|
+
expect(turnOn).toHaveBeenCalledWith({
|
|
68
|
+
entity_id: "switch.living_room_mood_lights",
|
|
69
|
+
});
|
|
77
70
|
});
|
|
78
71
|
});
|
|
79
72
|
});
|
|
80
73
|
it("should not trigger a from an invalid initial state", async () => {
|
|
81
74
|
expect.assertions(1);
|
|
82
|
-
await
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
88
|
-
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
89
|
-
state: "here",
|
|
75
|
+
await hassTestRunner.run(({ mock_assistant, hass, lifecycle }) => {
|
|
76
|
+
mock_assistant.fixtures.setState({
|
|
77
|
+
"sensor.magic": {
|
|
78
|
+
state: "mars",
|
|
79
|
+
},
|
|
90
80
|
});
|
|
91
|
-
|
|
92
|
-
|
|
81
|
+
lifecycle.onReady(async () => {
|
|
82
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
83
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
84
|
+
state: "here",
|
|
85
|
+
});
|
|
86
|
+
expect(turnOn).not.toHaveBeenCalledWith({
|
|
87
|
+
entity_id: "switch.living_room_mood_lights",
|
|
88
|
+
});
|
|
93
89
|
});
|
|
94
90
|
});
|
|
95
91
|
});
|
|
@@ -103,14 +99,15 @@ describe("Workflows", () => {
|
|
|
103
99
|
});
|
|
104
100
|
it("should run at 3PM", async () => {
|
|
105
101
|
expect.assertions(1);
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
102
|
+
jest.setSystemTime(dayjs("2024-01-01 19:59:59").toDate());
|
|
103
|
+
jest.runOnlyPendingTimersAsync();
|
|
104
|
+
await hassTestRunner.run(({ hass, lifecycle }) => {
|
|
105
|
+
lifecycle.onReady(() => {
|
|
106
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
107
|
+
jest.advanceTimersByTime(2 * SECOND);
|
|
108
|
+
expect(turnOn).toHaveBeenCalledWith({
|
|
109
|
+
entity_id: "switch.bedroom_lamp",
|
|
110
|
+
});
|
|
114
111
|
});
|
|
115
112
|
});
|
|
116
113
|
});
|
|
@@ -153,7 +150,7 @@ describe("Workflows", () => {
|
|
|
153
150
|
];
|
|
154
151
|
it("does not allow set", async () => {
|
|
155
152
|
expect.assertions(1);
|
|
156
|
-
await
|
|
153
|
+
await hassTestRunner.run(({ hass }) => {
|
|
157
154
|
try {
|
|
158
155
|
// @ts-expect-error testing
|
|
159
156
|
hass.call.button = {};
|
|
@@ -165,16 +162,20 @@ describe("Workflows", () => {
|
|
|
165
162
|
});
|
|
166
163
|
it("provides keys via ownKeys", async () => {
|
|
167
164
|
expect.assertions(1);
|
|
168
|
-
await
|
|
169
|
-
|
|
170
|
-
|
|
165
|
+
await hassTestRunner.run(({ hass, lifecycle }) => {
|
|
166
|
+
lifecycle.onReady(() => {
|
|
167
|
+
const keys = Object.keys(hass.call);
|
|
168
|
+
expect(keys).toEqual(EXPECTED_KEYS);
|
|
169
|
+
});
|
|
171
170
|
});
|
|
172
171
|
});
|
|
173
172
|
it("does has correctly", async () => {
|
|
174
173
|
expect.assertions(34);
|
|
175
|
-
await
|
|
176
|
-
|
|
177
|
-
|
|
174
|
+
await hassTestRunner.run(({ hass, lifecycle }) => {
|
|
175
|
+
lifecycle.onReady(() => {
|
|
176
|
+
EXPECTED_KEYS.forEach(i => expect(i in hass.call).toBe(true));
|
|
177
|
+
expect("unknown_property" in hass.call).toBe(false);
|
|
178
|
+
});
|
|
178
179
|
});
|
|
179
180
|
});
|
|
180
181
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow.spec.js","sourceRoot":"","sources":["../../src/testing/workflow.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"workflow.spec.js","sourceRoot":"","sources":["../../src/testing/workflow.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const helpers_1 = require("../helpers");
|
|
5
|
-
const mock_assistant_1 = require("../mock_assistant");
|
|
1
|
+
import { sleep } from "@digital-alchemy/core";
|
|
2
|
+
import { ZONE_REGISTRY_UPDATED } from "../helpers";
|
|
3
|
+
import { hassTestRunner } from "../mock_assistant";
|
|
6
4
|
describe("Zone", () => {
|
|
7
|
-
|
|
5
|
+
afterEach(async () => {
|
|
6
|
+
await hassTestRunner.teardown();
|
|
7
|
+
jest.restoreAllMocks();
|
|
8
|
+
});
|
|
8
9
|
const EXAMPLE_ZONE = {
|
|
9
10
|
icon: "",
|
|
10
11
|
latitude: 0,
|
|
@@ -12,140 +13,87 @@ describe("Zone", () => {
|
|
|
12
13
|
name: "Test",
|
|
13
14
|
passive: true,
|
|
14
15
|
};
|
|
15
|
-
afterEach(async () => {
|
|
16
|
-
if (application) {
|
|
17
|
-
await application.teardown();
|
|
18
|
-
application = undefined;
|
|
19
|
-
}
|
|
20
|
-
jest.restoreAllMocks();
|
|
21
|
-
});
|
|
22
16
|
describe("Lifecycle", () => {
|
|
23
17
|
it("should force values to be available before ready", async () => {
|
|
24
18
|
expect.assertions(1);
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
});
|
|
34
|
-
},
|
|
19
|
+
await hassTestRunner.run(({ lifecycle, hass }) => {
|
|
20
|
+
const spy = jest
|
|
21
|
+
.spyOn(hass.socket, "sendMessage")
|
|
22
|
+
.mockImplementation(async () => [EXAMPLE_ZONE]);
|
|
23
|
+
lifecycle.onReady(async () => {
|
|
24
|
+
await hass.zone.list();
|
|
25
|
+
expect(spy).toHaveBeenCalledWith(expect.objectContaining({ type: "zone/list" }));
|
|
26
|
+
});
|
|
35
27
|
});
|
|
36
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({
|
|
37
|
-
hass: {
|
|
38
|
-
AUTO_CONNECT_SOCKET: false,
|
|
39
|
-
AUTO_SCAN_CALL_PROXY: false,
|
|
40
|
-
},
|
|
41
|
-
}));
|
|
42
28
|
});
|
|
43
29
|
});
|
|
44
30
|
describe("API", () => {
|
|
45
31
|
describe("Formatting", () => {
|
|
46
32
|
it("should call list properly", async () => {
|
|
47
33
|
expect.assertions(1);
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
await hass.zone.list();
|
|
55
|
-
expect(spy).toHaveBeenCalledWith(expect.objectContaining({ type: "zone/list" }));
|
|
56
|
-
});
|
|
57
|
-
},
|
|
34
|
+
await hassTestRunner.run(({ lifecycle, hass }) => {
|
|
35
|
+
const spy = jest.spyOn(hass.socket, "sendMessage").mockImplementation(async () => []);
|
|
36
|
+
lifecycle.onReady(async () => {
|
|
37
|
+
await hass.zone.list();
|
|
38
|
+
expect(spy).toHaveBeenCalledWith(expect.objectContaining({ type: "zone/list" }));
|
|
39
|
+
});
|
|
58
40
|
});
|
|
59
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({
|
|
60
|
-
hass: {
|
|
61
|
-
AUTO_CONNECT_SOCKET: false,
|
|
62
|
-
AUTO_SCAN_CALL_PROXY: false,
|
|
63
|
-
},
|
|
64
|
-
}));
|
|
65
41
|
});
|
|
66
42
|
it("should call create properly", async () => {
|
|
67
43
|
expect.assertions(1);
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
...EXAMPLE_ZONE,
|
|
79
|
-
});
|
|
44
|
+
await hassTestRunner.run(({ lifecycle, hass, event }) => {
|
|
45
|
+
const spy = jest
|
|
46
|
+
.spyOn(hass.socket, "sendMessage")
|
|
47
|
+
.mockImplementation(async () => undefined);
|
|
48
|
+
lifecycle.onReady(async () => {
|
|
49
|
+
setImmediate(() => event.emit(ZONE_REGISTRY_UPDATED));
|
|
50
|
+
await hass.zone.create(EXAMPLE_ZONE);
|
|
51
|
+
expect(spy).toHaveBeenCalledWith({
|
|
52
|
+
type: "zone/create",
|
|
53
|
+
...EXAMPLE_ZONE,
|
|
80
54
|
});
|
|
81
|
-
}
|
|
55
|
+
});
|
|
82
56
|
});
|
|
83
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({
|
|
84
|
-
hass: {
|
|
85
|
-
AUTO_CONNECT_SOCKET: false,
|
|
86
|
-
AUTO_SCAN_CALL_PROXY: false,
|
|
87
|
-
},
|
|
88
|
-
}));
|
|
89
57
|
});
|
|
90
58
|
});
|
|
91
59
|
describe("Order of operations", () => {
|
|
92
60
|
it("should debounce updates properly", async () => {
|
|
93
61
|
expect.assertions(1);
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
108
|
-
await (0, core_1.sleep)(75);
|
|
109
|
-
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
110
|
-
});
|
|
111
|
-
await (0, core_1.sleep)(200);
|
|
112
|
-
expect(counter).toBe(2);
|
|
62
|
+
await hassTestRunner.run(({ lifecycle, hass }) => {
|
|
63
|
+
jest.spyOn(hass.socket, "sendMessage").mockImplementation(async () => undefined);
|
|
64
|
+
let counter = 0;
|
|
65
|
+
hass.events.onZoneRegistryUpdate(() => counter++);
|
|
66
|
+
lifecycle.onReady(async () => {
|
|
67
|
+
setImmediate(async () => {
|
|
68
|
+
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
69
|
+
await sleep(5);
|
|
70
|
+
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
71
|
+
await sleep(5);
|
|
72
|
+
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
73
|
+
await sleep(75);
|
|
74
|
+
hass.socket.socketEvents.emit("zone_registry_updated");
|
|
113
75
|
});
|
|
114
|
-
|
|
76
|
+
await sleep(200);
|
|
77
|
+
expect(counter).toBe(2);
|
|
78
|
+
});
|
|
115
79
|
});
|
|
116
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({
|
|
117
|
-
hass: {
|
|
118
|
-
AUTO_CONNECT_SOCKET: false,
|
|
119
|
-
AUTO_SCAN_CALL_PROXY: false,
|
|
120
|
-
},
|
|
121
|
-
}));
|
|
122
80
|
});
|
|
123
81
|
it("should wait for an update before returning when creating", async () => {
|
|
124
82
|
expect.assertions(1);
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
order += "b";
|
|
139
|
-
expect(order).toEqual("ab");
|
|
140
|
-
});
|
|
141
|
-
},
|
|
83
|
+
await hassTestRunner.run(({ lifecycle, hass, event }) => {
|
|
84
|
+
jest.spyOn(hass.socket, "sendMessage").mockImplementation(async () => undefined);
|
|
85
|
+
lifecycle.onReady(async () => {
|
|
86
|
+
const response = hass.zone.create(EXAMPLE_ZONE);
|
|
87
|
+
let order = "";
|
|
88
|
+
setTimeout(() => {
|
|
89
|
+
order += "a";
|
|
90
|
+
event.emit(ZONE_REGISTRY_UPDATED);
|
|
91
|
+
}, 5);
|
|
92
|
+
await response;
|
|
93
|
+
order += "b";
|
|
94
|
+
expect(order).toEqual("ab");
|
|
95
|
+
});
|
|
142
96
|
});
|
|
143
|
-
await application.bootstrap((0, mock_assistant_1.SILENT_BOOT)({
|
|
144
|
-
hass: {
|
|
145
|
-
AUTO_CONNECT_SOCKET: false,
|
|
146
|
-
AUTO_SCAN_CALL_PROXY: false,
|
|
147
|
-
},
|
|
148
|
-
}));
|
|
149
97
|
});
|
|
150
98
|
});
|
|
151
99
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"zone.spec.js","sourceRoot":"","sources":["../../src/testing/zone.spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"zone.spec.js","sourceRoot":"","sources":["../../src/testing/zone.spec.ts"],"names":[],"mappings":"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"}
|