1
0
mirror of https://github.com/home-assistant/frontend.git synced 2026-04-02 00:27:49 +01:00
Files
frontend/test/panels/lovelace/common/validate-condition.test.ts
Paul Bottein 74f7139a09 Add view columns visibility condition (#51288)
* Add view columns visibility condition

* Use max column, not column count

* Rename

* Remove editor
2026-04-01 10:11:53 +02:00

112 lines
3.8 KiB
TypeScript

import { describe, it, expect } from "vitest";
import {
checkConditionsMet,
validateConditionalConfig,
} from "../../../../src/panels/lovelace/common/validate-condition";
import type { HomeAssistant } from "../../../../src/types";
const createMockHass = (states: Record<string, { state: string }> = {}) =>
({
states,
user: { id: "user1" },
}) as unknown as HomeAssistant;
describe("validateConditionalConfig", () => {
describe("state condition validation", () => {
it("should return true for valid state condition", () => {
const conditions = [
{ condition: "state", entity: "sensor.test", state: "on" },
] as any;
expect(validateConditionalConfig(conditions)).toBe(true);
});
it("should return false for state condition without state or state_not", () => {
const conditions = [{ condition: "state", entity: "sensor.test" }] as any;
expect(validateConditionalConfig(conditions)).toBe(false);
});
});
describe("numeric_state condition validation", () => {
it("should return true for valid numeric_state condition", () => {
const conditions = [
{ condition: "numeric_state", entity: "sensor.test", above: 0 },
] as any;
expect(validateConditionalConfig(conditions)).toBe(true);
});
});
});
describe("checkConditionsMet", () => {
describe("state condition evaluation", () => {
it("should return true when state matches", () => {
const hass = createMockHass({
"sensor.test": { state: "on" },
});
const conditions = [
{ condition: "state", entity: "sensor.test", state: "on" },
] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(true);
});
it("should return false when state does not match", () => {
const hass = createMockHass({
"sensor.test": { state: "off" },
});
const conditions = [
{ condition: "state", entity: "sensor.test", state: "on" },
] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(false);
});
it("should return false for condition without state or state_not", () => {
const hass = createMockHass({
"sensor.test": { state: "on" },
});
const conditions = [{ condition: "state", entity: "sensor.test" }] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(false);
});
it("should not crash with invalid condition type", () => {
const hass = createMockHass({
"sensor.test": { state: "5" },
});
const conditions = [
{ condition: "numeric", entity: "sensor.test", above: 0 },
] as any;
// Should not throw - this was the bug
expect(() => checkConditionsMet(conditions, hass, {})).not.toThrow();
expect(checkConditionsMet(conditions, hass, {})).toBe(false);
});
});
describe("numeric_state condition evaluation", () => {
it("should return true when value is above threshold", () => {
const hass = createMockHass({
"sensor.test": { state: "5" },
});
const conditions = [
{ condition: "numeric_state", entity: "sensor.test", above: 0 },
] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(true);
});
});
describe("legacy conditions", () => {
it("should handle legacy state condition", () => {
const hass = createMockHass({
"sensor.test": { state: "on" },
});
const conditions = [{ entity: "sensor.test", state: "on" }] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(true);
});
it("should return false for legacy condition without state", () => {
const hass = createMockHass({
"sensor.test": { state: "on" },
});
const conditions = [{ entity: "sensor.test" }] as any;
expect(checkConditionsMet(conditions, hass, {})).toBe(false);
});
});
});