From 897c9e40b80ddae709ac1339977763e74c6eabff Mon Sep 17 00:00:00 2001 From: Chris Nussbaum Date: Sun, 1 Sep 2024 14:23:50 -0500 Subject: [PATCH] Properly deserialize context when deserializing state in the entity state cache (#1157) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Properly deserialize context when deserializing state in the state cache * Update tests to pass state change events as raw JSON * Fix missed assert --------- Co-authored-by: Tomas Hellström Co-authored-by: Frank Bakker --- .../Internal/EntityStateCacheTest.cs | 52 ++++++++++++------- src/HassModel/NetDeamon.HassModel/Context.cs | 10 ++-- 2 files changed, 39 insertions(+), 23 deletions(-) diff --git a/src/HassModel/NetDaemon.HassModel.Tests/Internal/EntityStateCacheTest.cs b/src/HassModel/NetDaemon.HassModel.Tests/Internal/EntityStateCacheTest.cs index 1fe6d0f5a..2b0fb4f28 100644 --- a/src/HassModel/NetDaemon.HassModel.Tests/Internal/EntityStateCacheTest.cs +++ b/src/HassModel/NetDaemon.HassModel.Tests/Internal/EntityStateCacheTest.cs @@ -3,7 +3,6 @@ using NetDaemon.Client.HomeAssistant.Model; using NetDaemon.Client.Internal.HomeAssistant.Commands; using NetDaemon.HassModel.Tests.TestHelpers; -using Microsoft.Extensions.DependencyInjection; using NetDaemon.Client.Internal.Extensions; using NetDaemon.HassModel.Internal; @@ -43,13 +42,18 @@ public async Task StateChangeEventIsFirstStoredInCacheThanForwarded() cache.GetState(entityId)!.State.Should().Be("InitialState", "The initial value should be available"); // Act 2: now fire a state change event - var changedEventData = new HassStateChangedEventData + var changedEventData = new { - EntityId = entityId, - OldState = new HassState(), - NewState = new HassState + entity_id = entityId, + old_state = new { }, + new_state = new { - State = "newState" + state = "newState", + context = new + { + id = "contextId", + parent_id = "parentId" + } } }; @@ -71,6 +75,8 @@ public async Task StateChangeEventIsFirstStoredInCacheThanForwarded() // Assert eventObserverMock.Verify(m => m.OnNext(It.IsAny())); cache.GetState(entityId)!.State.Should().Be("newState"); + cache.GetState(entityId)!.Context!.Id.Should().Be("contextId"); + cache.GetState(entityId)!.Context!.ParentId.Should().Be("parentId"); } [Fact] @@ -112,14 +118,18 @@ public async Task AllEntityIds_returnsInitialPlusChangedEntities() testSubject.OnNext(new HassEvent { EventType = "state_changed", - DataElement = new HassStateChangedEventData + DataElement = new { - EntityId = "sensor.sensor1", - OldState = new HassState(), - NewState = new HassState + entity_id = "sensor.sensor1", + old_state = new { }, + new_state = new { - State = "newState", - AttributesJson = new {brightness = 200}.ToJsonElement() + state = "newState", + context = new + { + id = "contextId1" + }, + attributes = new {brightness = 200} } }.AsJsonElement() }); @@ -127,14 +137,18 @@ public async Task AllEntityIds_returnsInitialPlusChangedEntities() testSubject.OnNext(new HassEvent { EventType = "state_changed", - DataElement = new HassStateChangedEventData + DataElement = new { - EntityId = "sensor.sensor2", - OldState = new HassState(), - NewState = new HassState + entity_id = "sensor.sensor2", + old_state = new { }, + new_state = new { - State = "newState", - AttributesJson = new {brightness = 300}.ToJsonElement() + state = "newState", + context = new + { + id = "contextId2" + }, + attributes = new {brightness = 300} } }.AsJsonElement() }); @@ -142,6 +156,8 @@ public async Task AllEntityIds_returnsInitialPlusChangedEntities() // Assert cache.AllEntityIds.Should().BeEquivalentTo("sensor.sensor1", "sensor.sensor2"); cache.GetState("sensor.sensor1")!.AttributesJson.GetValueOrDefault().GetProperty("brightness").GetInt32().Should().Be(200); + cache.GetState("sensor.sensor1")!.Context!.Id.Should().Be("contextId1"); cache.GetState("sensor.sensor2")!.AttributesJson.GetValueOrDefault().GetProperty("brightness").GetInt32().Should().Be(300); + cache.GetState("sensor.sensor2")!.Context!.Id.Should().Be("contextId2"); } } diff --git a/src/HassModel/NetDeamon.HassModel/Context.cs b/src/HassModel/NetDeamon.HassModel/Context.cs index d0f3943e3..3b8dfbe69 100644 --- a/src/HassModel/NetDeamon.HassModel/Context.cs +++ b/src/HassModel/NetDeamon.HassModel/Context.cs @@ -8,14 +8,14 @@ public class Context /// /// Id /// - public string Id { get; set; } = ""; - + [JsonPropertyName("id")] public string Id { get; set; } = ""; + /// /// ParentId /// - public string? ParentId { get; set; } + [JsonPropertyName("parent_id")] public string? ParentId { get; set; } /// /// The id of the user who is responsible for the connected item. /// - public string? UserId { get; set; } -} \ No newline at end of file + [JsonPropertyName("user_id")] public string? UserId { get; set; } +}