@digital-alchemy/hass 0.3.22 → 0.3.23
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/dist/e2e/utils.js +1 -0
- package/dist/e2e/utils.js.map +1 -1
- package/dist/mock_assistant/extensions/events.extension.js +4 -0
- package/dist/mock_assistant/extensions/events.extension.js.map +1 -1
- package/dist/mock_assistant/extensions/fixtures.extension.d.ts +1 -1
- package/dist/mock_assistant/extensions/fixtures.extension.js +6 -1
- package/dist/mock_assistant/extensions/fixtures.extension.js.map +1 -1
- package/dist/mock_assistant/helpers/fixtures.d.ts +5 -4
- package/dist/mock_assistant/helpers/utils.d.ts +3 -2
- package/dist/mock_assistant/helpers/utils.js +19 -1
- package/dist/mock_assistant/helpers/utils.js.map +1 -1
- package/dist/mock_assistant/main.js +1 -0
- package/dist/mock_assistant/main.js.map +1 -1
- package/dist/testing/workflow.spec.js +46 -91
- package/dist/testing/workflow.spec.js.map +1 -1
- package/package.json +1 -1
package/dist/e2e/utils.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.TOKEN = exports.BASE_URL = void 0;
|
|
4
|
+
/* eslint-disable @cspell/spellchecker */
|
|
4
5
|
exports.BASE_URL = "http://localhost:9123";
|
|
5
6
|
exports.TOKEN = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhYTdjOGQ5MzBiMDM0MDM2OGVjZTdjOTRjMTcyOWQ0OSIsImlhdCI6MTcxNDYwMzkyMywiZXhwIjoyMDI5OTYzOTIzfQ.Tvoh25bukQh5T5WIuvvkL9jVBihcOGG6D5JYdqdwx1U";
|
|
6
7
|
//# sourceMappingURL=utils.js.map
|
package/dist/e2e/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/e2e/utils.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/e2e/utils.ts"],"names":[],"mappings":";;;AAAA,yCAAyC;AAC5B,QAAA,QAAQ,GAAG,uBAAuB,CAAC;AACnC,QAAA,KAAK,GAChB,yLAAyL,CAAC"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Events = void 0;
|
|
4
|
+
const core_1 = require("@digital-alchemy/core");
|
|
5
|
+
const SUPER_SHORT = 1;
|
|
4
6
|
function Events({ mock_assistant, hass }) {
|
|
5
7
|
let id = 1000;
|
|
6
8
|
async function emitEvent(event, data) {
|
|
@@ -18,6 +20,8 @@ function Events({ mock_assistant, hass }) {
|
|
|
18
20
|
const old_state = mock_assistant.fixtures.byId(entity);
|
|
19
21
|
new_state = mock_assistant.fixtures.replace(entity, new_state);
|
|
20
22
|
await emitEvent("state_changed", { new_state, old_state });
|
|
23
|
+
// help ensure all the async flows settle
|
|
24
|
+
await (0, core_1.sleep)(SUPER_SHORT);
|
|
21
25
|
}
|
|
22
26
|
return {
|
|
23
27
|
emitEntityUpdate,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"events.extension.js","sourceRoot":"","sources":["../../../src/mock_assistant/extensions/events.extension.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"events.extension.js","sourceRoot":"","sources":["../../../src/mock_assistant/extensions/events.extension.ts"],"names":[],"mappings":";;;AAAA,gDAA8D;AAI9D,MAAM,WAAW,GAAG,CAAC,CAAC;AAEtB,SAAgB,MAAM,CAAC,EAAE,cAAc,EAAE,IAAI,EAAkB;IAC7D,IAAI,EAAE,GAAG,IAAI,CAAC;IAEd,KAAK,UAAU,SAAS,CAAC,KAAa,EAAE,IAAY;QAClD,EAAE,EAAE,CAAC;QACL,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;YAC1B,KAAK,EAAE;gBACL,IAAI;gBACJ,UAAU,EAAE,KAAK;aACG;YACtB,EAAE,EAAE,EAAE;YACN,IAAI,EAAE,OAAO;SACd,CAAC,CAAC;IACL,CAAC;IAED,KAAK,UAAU,gBAAgB,CAC7B,MAAc,EACd,SAAwC;QAExC,MAAM,SAAS,GAAG,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvD,SAAS,GAAG,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC/D,MAAM,SAAS,CAAC,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;QAC3D,yCAAyC;QACzC,MAAM,IAAA,YAAK,EAAC,WAAW,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO;QACL,gBAAgB;QAChB,SAAS;KACV,CAAC;AACJ,CAAC;AA9BD,wBA8BC"}
|
|
@@ -4,7 +4,7 @@ import { ScannerCacheData } from "../helpers";
|
|
|
4
4
|
type StateOptions = Partial<{
|
|
5
5
|
[entity in PICK_ENTITY]: Partial<ENTITY_STATE<entity>>;
|
|
6
6
|
}>;
|
|
7
|
-
export declare function Fixtures({ hass, lifecycle, config, context, mock_assistant, }: TServiceParams): {
|
|
7
|
+
export declare function Fixtures({ hass, lifecycle, config, internal, context, mock_assistant, }: TServiceParams): {
|
|
8
8
|
byId: (entity: PICK_ENTITY) => ENTITY_STATE<PICK_ENTITY>;
|
|
9
9
|
data: ScannerCacheData;
|
|
10
10
|
replace: <ENTITY extends PICK_ENTITY>(entity: ENTITY, new_state: Partial<ENTITY_STATE<ENTITY>>) => ENTITY_STATE<ENTITY>;
|
|
@@ -4,13 +4,14 @@ exports.Fixtures = void 0;
|
|
|
4
4
|
const core_1 = require("@digital-alchemy/core");
|
|
5
5
|
const fs_1 = require("fs");
|
|
6
6
|
const MEGA_HIGH_PRIORITY = 1000;
|
|
7
|
-
function Fixtures({ hass, lifecycle, config, context, mock_assistant, }) {
|
|
7
|
+
function Fixtures({ hass, lifecycle, config, internal, context, mock_assistant, }) {
|
|
8
8
|
hass.area.list = async () => mock_assistant.fixtures.data?.areas ?? [];
|
|
9
9
|
hass.floor.list = async () => mock_assistant.fixtures.data?.floors ?? [];
|
|
10
10
|
hass.label.list = async () => mock_assistant.fixtures.data?.labels ?? [];
|
|
11
11
|
hass.device.list = async () => mock_assistant.fixtures.data?.devices ?? [];
|
|
12
12
|
hass.fetch.getAllEntities = async () => mock_assistant.fixtures.data?.entities ?? [];
|
|
13
13
|
hass.fetch.listServices = async () => mock_assistant.fixtures.data?.services ?? [];
|
|
14
|
+
hass.fetch.getConfig = async () => mock_assistant.fixtures.data?.config;
|
|
14
15
|
lifecycle.onPreInit(() => {
|
|
15
16
|
const { MOCK_SOCKET } = config.hass;
|
|
16
17
|
const { FIXTURES_FILE } = config.mock_assistant;
|
|
@@ -22,6 +23,10 @@ function Fixtures({ hass, lifecycle, config, context, mock_assistant, }) {
|
|
|
22
23
|
if (!(0, fs_1.existsSync)(FIXTURES_FILE)) {
|
|
23
24
|
throw new core_1.BootstrapException(context, "MISSING_FIXTURES_FILE", `${FIXTURES_FILE} does not exist`);
|
|
24
25
|
}
|
|
26
|
+
if (core_1.is.empty(config.hass.TOKEN)) {
|
|
27
|
+
// prevents throwing errors
|
|
28
|
+
internal.boilerplate.configuration.set("hass", "TOKEN", "--");
|
|
29
|
+
}
|
|
25
30
|
mock_assistant.fixtures.data = JSON.parse((0, fs_1.readFileSync)(FIXTURES_FILE, "utf8"));
|
|
26
31
|
}, MEGA_HIGH_PRIORITY);
|
|
27
32
|
function setState(options) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fixtures.extension.js","sourceRoot":"","sources":["../../../src/mock_assistant/extensions/fixtures.extension.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"fixtures.extension.js","sourceRoot":"","sources":["../../../src/mock_assistant/extensions/fixtures.extension.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { AreaDetails, DeviceDetails, ENTITY_STATE, EntityRegistryItem, FloorDetails, HassServiceDTO as HassServiceDefinition, LabelDefinition, PICK_ENTITY } from "../../helpers";
|
|
1
|
+
import { AreaDetails, DeviceDetails, ENTITY_STATE, EntityRegistryItem, FloorDetails, HassConfig, HassServiceDTO as HassServiceDefinition, LabelDefinition, PICK_ENTITY } from "../../helpers";
|
|
2
2
|
export type ScannerCacheData = {
|
|
3
3
|
areas: AreaDetails[];
|
|
4
|
-
|
|
5
|
-
labels: LabelDefinition[];
|
|
6
|
-
floors: FloorDetails[];
|
|
4
|
+
config: HassConfig;
|
|
7
5
|
devices: DeviceDetails[];
|
|
8
6
|
entities: ENTITY_STATE<PICK_ENTITY>[];
|
|
9
7
|
entity_registry: EntityRegistryItem<PICK_ENTITY>[];
|
|
8
|
+
floors: FloorDetails[];
|
|
9
|
+
labels: LabelDefinition[];
|
|
10
|
+
services: HassServiceDefinition[];
|
|
10
11
|
};
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import { BootstrapOptions, PartialConfiguration, ServiceMap } from "@digital-alchemy/core";
|
|
1
|
+
import { ApplicationDefinition, BootstrapOptions, PartialConfiguration, ServiceFunction, ServiceMap } from "@digital-alchemy/core";
|
|
2
2
|
export declare const SILENT_BOOT: (configuration?: PartialConfiguration, fixtures?: boolean) => BootstrapOptions;
|
|
3
|
-
export declare function CreateTestingApplication(services: ServiceMap):
|
|
3
|
+
export declare function CreateTestingApplication(services: ServiceMap): ApplicationDefinition<ServiceMap, import("@digital-alchemy/core").ModuleConfiguration>;
|
|
4
|
+
export declare const CreateTestRunner: <S extends ServiceMap, C extends import("@digital-alchemy/core").ModuleConfiguration>(UNIT_TESTING_APP: ApplicationDefinition<S, C>) => (setup: ServiceFunction, Test: ServiceFunction) => Promise<void>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CreateTestingApplication = exports.SILENT_BOOT = void 0;
|
|
3
|
+
exports.CreateTestRunner = exports.CreateTestingApplication = exports.SILENT_BOOT = void 0;
|
|
4
4
|
const core_1 = require("@digital-alchemy/core");
|
|
5
5
|
const hass_module_1 = require("../../hass.module");
|
|
6
6
|
const mock_assistant_module_1 = require("../mock-assistant.module");
|
|
@@ -28,4 +28,22 @@ function CreateTestingApplication(services) {
|
|
|
28
28
|
});
|
|
29
29
|
}
|
|
30
30
|
exports.CreateTestingApplication = CreateTestingApplication;
|
|
31
|
+
const CreateTestRunner = (UNIT_TESTING_APP) => {
|
|
32
|
+
// setup runs at construction
|
|
33
|
+
// test runs at ready
|
|
34
|
+
return async function (setup, Test) {
|
|
35
|
+
function test(params) {
|
|
36
|
+
params.lifecycle.onReady(async () => await Test(params));
|
|
37
|
+
}
|
|
38
|
+
return await UNIT_TESTING_APP.bootstrap({
|
|
39
|
+
appendLibrary: mock_assistant_module_1.LIB_MOCK_ASSISTANT,
|
|
40
|
+
appendService: core_1.is.function(setup) ? { setup, test } : { test },
|
|
41
|
+
configuration: {
|
|
42
|
+
boilerplate: { LOG_LEVEL: "error" },
|
|
43
|
+
hass: { MOCK_SOCKET: true },
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
exports.CreateTestRunner = CreateTestRunner;
|
|
31
49
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/mock_assistant/helpers/utils.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/mock_assistant/helpers/utils.ts"],"names":[],"mappings":";;;AAAA,gDAU+B;AAE/B,mDAA6C;AAC7C,oEAA8D;AAEvD,MAAM,WAAW,GAAG,CACzB,gBAAsC,EAAE,EACxC,QAAQ,GAAG,KAAK,EACE,EAAE,CAAC,CAAC;IACtB,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC,0CAAkB,CAAC,CAAC,CAAC,SAAS;IACxD,aAAa;IACb,aAAa;IACb,YAAY,EAAE;QACZ,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;QACf,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;QACf,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;QACf,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;QACd,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;QACf,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;KACf;CACF,CAAC,CAAC;AAfU,QAAA,WAAW,eAerB;AAEH,SAAgB,wBAAwB,CAAC,QAAoB;IAC3D,OAAO,IAAA,wBAAiB,EAAC;QACvB,oBAAoB,EAAE,EAAE;QAExB,SAAS,EAAE,CAAC,sBAAQ,CAAC;QACrB,2BAA2B;QAC3B,IAAI,EAAE,SAAS;QACf,QAAQ;KACT,CAAC,CAAC;AACL,CAAC;AATD,4DASC;AAEM,MAAM,gBAAgB,GAAG,CAI9B,gBAA6C,EAC7C,EAAE;IACF,6BAA6B;IAC7B,qBAAqB;IACrB,OAAO,KAAK,WAAW,KAAsB,EAAE,IAAqB;QAClE,SAAS,IAAI,CAAC,MAAsB;YAClC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAC3D,CAAC;QACD,OAAO,MAAM,gBAAgB,CAAC,SAAS,CAAC;YACtC,aAAa,EAAE,0CAAkB;YACjC,aAAa,EAAE,SAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE;YAC9D,aAAa,EAAE;gBACb,WAAW,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE;gBACnC,IAAI,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;aAC5B;SACF,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC,CAAC;AArBW,QAAA,gBAAgB,oBAqB3B"}
|
|
@@ -21,6 +21,7 @@ const writeFixtures = (0, core_1.CreateApplication)({
|
|
|
21
21
|
lifecycle.onReady(async () => {
|
|
22
22
|
(0, fs_1.writeFileSync)(config.mock_assistant.FIXTURES_FILE, JSON.stringify({
|
|
23
23
|
areas: hass.area.current,
|
|
24
|
+
config: await hass.fetch.getConfig(),
|
|
24
25
|
devices: hass.device.current,
|
|
25
26
|
entities: hass.entity.listEntities().map(i => hass.entity.raw(i)),
|
|
26
27
|
entity_registry: hass.entity.registry.current,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/mock_assistant/main.ts"],"names":[],"mappings":";;;AACA,gDAA0E;AAC1E,2BAAmC;AACnC,+BAA4B;AAC5B,qCAAoC;AAEpC,0BAA8B;AAG9B,MAAM,aAAa,GAAG,IAAA,wBAAiB,EAAC;IACtC,aAAa,EAAE;QACb,aAAa,EAAE;YACb,OAAO,EAAE,IAAA,WAAI,EAAC,IAAA,aAAG,GAAE,EAAE,eAAe,CAAC;YACrC,WAAW,EAAE,EAAE;YACf,IAAI,EAAE,QAAQ;SACf;KACF;IACD,SAAS,EAAE,CAAC,YAAQ,CAAC;IACrB,IAAI,EAAE,gBAAgB;IACtB,QAAQ,EAAE;QACR,KAAK,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAkB;YAC/C,SAAS,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE;gBAC3B,IAAA,kBAAa,EACX,MAAM,CAAC,cAAc,CAAC,aAAa,EACnC,IAAI,CAAC,SAAS,CACZ;oBACE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO;oBACxB,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;oBAC5B,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;oBACjE,eAAe,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO;oBAC7C,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;oBAC1B,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;oBAC1B,QAAQ,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE;iBACtB,EACrB,SAAS,EACT,IAAI,CACL,EACD,MAAM,CACP,CAAC;gBACF,IAAA,cAAI,GAAE,CAAC;YACT,CAAC,CAAC,CAAC;QACL,CAAC;KACF;CACF,CAAC,CAAC;AACH,YAAY,CAAC,KAAK,IAAI,EAAE,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAC"}
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/mock_assistant/main.ts"],"names":[],"mappings":";;;AACA,gDAA0E;AAC1E,2BAAmC;AACnC,+BAA4B;AAC5B,qCAAoC;AAEpC,0BAA8B;AAG9B,MAAM,aAAa,GAAG,IAAA,wBAAiB,EAAC;IACtC,aAAa,EAAE;QACb,aAAa,EAAE;YACb,OAAO,EAAE,IAAA,WAAI,EAAC,IAAA,aAAG,GAAE,EAAE,eAAe,CAAC;YACrC,WAAW,EAAE,EAAE;YACf,IAAI,EAAE,QAAQ;SACf;KACF;IACD,SAAS,EAAE,CAAC,YAAQ,CAAC;IACrB,IAAI,EAAE,gBAAgB;IACtB,QAAQ,EAAE;QACR,KAAK,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAkB;YAC/C,SAAS,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE;gBAC3B,IAAA,kBAAa,EACX,MAAM,CAAC,cAAc,CAAC,aAAa,EACnC,IAAI,CAAC,SAAS,CACZ;oBACE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO;oBACxB,MAAM,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;oBACpC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;oBAC5B,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;oBACjE,eAAe,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO;oBAC7C,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;oBAC1B,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;oBAC1B,QAAQ,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE;iBACtB,EACrB,SAAS,EACT,IAAI,CACL,EACD,MAAM,CACP,CAAC;gBACF,IAAA,cAAI,GAAE,CAAC;YACT,CAAC,CAAC,CAAC;QACL,CAAC;KACF;CACF,CAAC,CAAC;AACH,YAAY,CAAC,KAAK,IAAI,EAAE,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAC"}
|
|
@@ -37,6 +37,7 @@ describe("Workflows", () => {
|
|
|
37
37
|
},
|
|
38
38
|
},
|
|
39
39
|
});
|
|
40
|
+
const runner = (0, mock_assistant_1.CreateTestRunner)(application);
|
|
40
41
|
afterEach(async () => {
|
|
41
42
|
await application.teardown();
|
|
42
43
|
jest.restoreAllMocks();
|
|
@@ -44,87 +45,52 @@ describe("Workflows", () => {
|
|
|
44
45
|
describe("Event and Response", () => {
|
|
45
46
|
it("should be able to trigger a workflow", async () => {
|
|
46
47
|
expect.assertions(2);
|
|
47
|
-
await
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
59
|
-
state: "foo",
|
|
60
|
-
});
|
|
61
|
-
expect(turnOn).toHaveBeenCalledTimes(1);
|
|
62
|
-
expect(turnOff).toHaveBeenCalledTimes(1);
|
|
63
|
-
});
|
|
64
|
-
},
|
|
65
|
-
},
|
|
66
|
-
configuration: {
|
|
67
|
-
boilerplate: { LOG_LEVEL: "error" },
|
|
68
|
-
hass: { MOCK_SOCKET: true, TOKEN: "--" },
|
|
69
|
-
},
|
|
48
|
+
await runner(undefined, async ({ mock_assistant, hass }) => {
|
|
49
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
50
|
+
const turnOff = jest.spyOn(hass.call.switch, "turn_off");
|
|
51
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
52
|
+
state: "test",
|
|
53
|
+
});
|
|
54
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
55
|
+
state: "foo",
|
|
56
|
+
});
|
|
57
|
+
expect(turnOn).toHaveBeenCalledTimes(1);
|
|
58
|
+
expect(turnOff).toHaveBeenCalledTimes(1);
|
|
70
59
|
});
|
|
71
60
|
});
|
|
72
61
|
it("should be able to trigger a from an initial state", async () => {
|
|
73
62
|
expect.assertions(1);
|
|
74
|
-
await
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
mock_assistant.fixtures.setState({
|
|
79
|
-
"sensor.magic": {
|
|
80
|
-
state: "away",
|
|
81
|
-
},
|
|
82
|
-
});
|
|
83
|
-
lifecycle.onReady(async () => {
|
|
84
|
-
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
85
|
-
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
86
|
-
state: "here",
|
|
87
|
-
});
|
|
88
|
-
await (0, core_1.sleep)(1);
|
|
89
|
-
expect(turnOn).toHaveBeenCalledWith({
|
|
90
|
-
entity_id: "switch.living_room_mood_lights",
|
|
91
|
-
});
|
|
92
|
-
});
|
|
63
|
+
await runner(({ mock_assistant }) => {
|
|
64
|
+
mock_assistant.fixtures.setState({
|
|
65
|
+
"sensor.magic": {
|
|
66
|
+
state: "away",
|
|
93
67
|
},
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
68
|
+
});
|
|
69
|
+
}, async ({ hass, mock_assistant }) => {
|
|
70
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
71
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
72
|
+
state: "here",
|
|
73
|
+
});
|
|
74
|
+
await (0, core_1.sleep)(1);
|
|
75
|
+
expect(turnOn).toHaveBeenCalledWith({
|
|
76
|
+
entity_id: "switch.living_room_mood_lights",
|
|
77
|
+
});
|
|
99
78
|
});
|
|
100
79
|
});
|
|
101
80
|
it("should not trigger a from an invalid initial state", async () => {
|
|
102
81
|
expect.assertions(1);
|
|
103
|
-
await
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
Runner({ mock_assistant, lifecycle, hass }) {
|
|
107
|
-
mock_assistant.fixtures.setState({
|
|
108
|
-
"sensor.magic": {
|
|
109
|
-
state: "mars",
|
|
110
|
-
},
|
|
111
|
-
});
|
|
112
|
-
lifecycle.onReady(async () => {
|
|
113
|
-
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
114
|
-
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
115
|
-
state: "here",
|
|
116
|
-
});
|
|
117
|
-
await (0, core_1.sleep)(1);
|
|
118
|
-
expect(turnOn).not.toHaveBeenCalledWith({
|
|
119
|
-
entity_id: "switch.living_room_mood_lights",
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
},
|
|
123
|
-
},
|
|
124
|
-
configuration: {
|
|
125
|
-
boilerplate: { LOG_LEVEL: "error" },
|
|
126
|
-
hass: { MOCK_SOCKET: true, TOKEN: "--" },
|
|
82
|
+
await runner(({ mock_assistant }) => mock_assistant.fixtures.setState({
|
|
83
|
+
"sensor.magic": {
|
|
84
|
+
state: "mars",
|
|
127
85
|
},
|
|
86
|
+
}), async ({ hass, mock_assistant }) => {
|
|
87
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
88
|
+
await mock_assistant.events.emitEntityUpdate("sensor.magic", {
|
|
89
|
+
state: "here",
|
|
90
|
+
});
|
|
91
|
+
expect(turnOn).not.toHaveBeenCalledWith({
|
|
92
|
+
entity_id: "switch.living_room_mood_lights",
|
|
93
|
+
});
|
|
128
94
|
});
|
|
129
95
|
});
|
|
130
96
|
});
|
|
@@ -137,26 +103,15 @@ describe("Workflows", () => {
|
|
|
137
103
|
});
|
|
138
104
|
it("should run at 3PM", async () => {
|
|
139
105
|
expect.assertions(1);
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
expect(turnOn).toHaveBeenCalledWith({
|
|
150
|
-
entity_id: "switch.bedroom_lamp",
|
|
151
|
-
});
|
|
152
|
-
});
|
|
153
|
-
jest.runOnlyPendingTimersAsync();
|
|
154
|
-
},
|
|
155
|
-
},
|
|
156
|
-
configuration: {
|
|
157
|
-
boilerplate: { LOG_LEVEL: "error" },
|
|
158
|
-
hass: { MOCK_SOCKET: true, TOKEN: "--" },
|
|
159
|
-
},
|
|
106
|
+
await runner(() => {
|
|
107
|
+
jest.setSystemTime((0, dayjs_1.default)("2024-01-01 19:59:59").toDate());
|
|
108
|
+
jest.runOnlyPendingTimersAsync();
|
|
109
|
+
}, ({ hass }) => {
|
|
110
|
+
const turnOn = jest.spyOn(hass.call.switch, "turn_on");
|
|
111
|
+
jest.advanceTimersByTime(2 * core_1.SECOND);
|
|
112
|
+
expect(turnOn).toHaveBeenCalledWith({
|
|
113
|
+
entity_id: "switch.bedroom_lamp",
|
|
114
|
+
});
|
|
160
115
|
});
|
|
161
116
|
});
|
|
162
117
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow.spec.js","sourceRoot":"","sources":["../../src/testing/workflow.spec.ts"],"names":[],"mappings":";;;AAAA,gDAM+B;AAC/B,0DAA0B;AAE1B,0BAA8B;AAC9B,
|
|
1
|
+
{"version":3,"file":"workflow.spec.js","sourceRoot":"","sources":["../../src/testing/workflow.spec.ts"],"names":[],"mappings":";;;AAAA,gDAM+B;AAC/B,0DAA0B;AAE1B,0BAA8B;AAC9B,sDAAqD;AAErD,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,WAAW,GAAG,IAAA,wBAAiB,EAAC;QACpC,SAAS,EAAE,CAAC,YAAQ,CAAC;QACrB,2BAA2B;QAC3B,IAAI,EAAE,SAAS;QACf,QAAQ,EAAE;YACR,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAkB;gBACtC,SAAS,CAAC,IAAI,CAAC;oBACb,KAAK,CAAC,IAAI;wBACR,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;4BAC7B,SAAS,EAAE,qBAAqB;yBACjC,CAAC,CAAC;oBACL,CAAC;oBACD,QAAQ,EAAE,qBAAc,CAAC,gBAAgB;iBAC1C,CAAC,CAAC;gBAEH,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAChD,MAAM,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;oBACzB,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC;oBAChE,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;wBAC7B,SAAS,EAAE,oBAAoB;qBAChC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE;oBAC7C,IAAI,SAAS,CAAC,KAAK,KAAK,MAAM,IAAI,SAAS,CAAC,KAAK,KAAK,MAAM,EAAE,CAAC;wBAC7D,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;4BAC7B,SAAS,EAAE,gCAAgC;yBAC5C,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;SACF;KACF,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAA,iCAAgB,EAAC,WAAW,CAAC,CAAC;IAE7C,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;YACpD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,MAAM,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,EAAE;gBACzD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACvD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;gBACzD,MAAM,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE;oBAC3D,KAAK,EAAE,MAAM;iBACd,CAAC,CAAC;gBACH,MAAM,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE;oBAC3D,KAAK,EAAE,KAAK;iBACb,CAAC,CAAC;gBACH,MAAM,CAAC,MAAM,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;gBACxC,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YAC3C,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;YACjE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,MAAM,CACV,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE;gBACrB,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC;oBAC/B,cAAc,EAAE;wBACd,KAAK,EAAE,MAAM;qBACd;iBACF,CAAC,CAAC;YACL,CAAC,EACD,KAAK,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,EAAE;gBACjC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACvD,MAAM,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE;oBAC3D,KAAK,EAAE,MAAM;iBACd,CAAC,CAAC;gBACH,MAAM,IAAA,YAAK,EAAC,CAAC,CAAC,CAAC;gBACf,MAAM,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC;oBAClC,SAAS,EAAE,gCAAgC;iBAC5C,CAAC,CAAC;YACL,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oDAAoD,EAAE,KAAK,IAAI,EAAE;YAClE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,MAAM,CACV,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE,CACrB,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC;gBAC/B,cAAc,EAAE;oBACd,KAAK,EAAE,MAAM;iBACd;aACF,CAAC,EACJ,KAAK,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,EAAE;gBACjC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACvD,MAAM,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE;oBAC3D,KAAK,EAAE,MAAM;iBACd,CAAC,CAAC;gBACH,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAC;oBACtC,SAAS,EAAE,gCAAgC;iBAC5C,CAAC,CAAC;YACL,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,QAAQ,EAAE,GAAG,EAAE;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;YACjC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM,MAAM,CACV,GAAG,EAAE;gBACH,IAAI,CAAC,aAAa,CAAC,IAAA,eAAK,EAAC,qBAAqB,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC1D,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACnC,CAAC,EACD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;gBACX,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACvD,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,aAAM,CAAC,CAAC;gBACrC,MAAM,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC;oBAClC,SAAS,EAAE,qBAAqB;iBACjC,CAAC,CAAC;YACL,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@digital-alchemy/hass",
|
|
3
3
|
"repository": "https://github.com/Digital-Alchemy-TS/hass",
|
|
4
4
|
"homepage": "https://docs.digital-alchemy.app/Hass",
|
|
5
|
-
"version": "0.3.
|
|
5
|
+
"version": "0.3.23",
|
|
6
6
|
"scripts": {
|
|
7
7
|
"build": "rm -rf dist/; tsc",
|
|
8
8
|
"lint": "eslint src",
|