From b83bc2ee89d5826b3ab5fe42ac3af5972360b55c Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期一, 27 四月 2026 19:29:48 +0800
Subject: [PATCH] #
---
src/test/java/com/zy/ai/service/impl/AutoTuneSnapshotServiceImplTest.java | 33 +++++++++++++++++++++++++++++++++
1 files changed, 33 insertions(+), 0 deletions(-)
diff --git a/src/test/java/com/zy/ai/service/impl/AutoTuneSnapshotServiceImplTest.java b/src/test/java/com/zy/ai/service/impl/AutoTuneSnapshotServiceImplTest.java
index 6619623..5aba3a8 100644
--- a/src/test/java/com/zy/ai/service/impl/AutoTuneSnapshotServiceImplTest.java
+++ b/src/test/java/com/zy/ai/service/impl/AutoTuneSnapshotServiceImplTest.java
@@ -2,6 +2,7 @@
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
+import com.zy.ai.domain.autotune.AutoTuneRuleSnapshotItem;
import com.zy.asrs.entity.BasDevp;
import com.zy.asrs.entity.BasStation;
import com.zy.asrs.entity.WrkMast;
@@ -16,6 +17,7 @@
import java.util.Arrays;
import java.util.Collections;
+import java.util.List;
import java.util.Map;
import static org.junit.jupiter.api.Assertions.assertEquals;
@@ -62,6 +64,26 @@
assertNull(result.get("101"));
assertEquals(0, result.get("102"));
assertEquals(3, result.get("103"));
+ }
+
+ @Test
+ void buildRuleSnapshotExposesStepRangeCooldownAndDynamicMaxSource() {
+ List<AutoTuneRuleSnapshotItem> result = service.buildRuleSnapshot();
+
+ AutoTuneRuleSnapshotItem stationOutTaskRule = findRule(result, "station", "outTaskLimit");
+ assertEquals(0, stationOutTaskRule.getMinValue());
+ assertNull(stationOutTaskRule.getMaxValue());
+ assertEquals(1, stationOutTaskRule.getMaxStep());
+ assertEquals(10, stationOutTaskRule.getCooldownMinutes());
+ assertEquals(Boolean.TRUE, stationOutTaskRule.getDynamicMaxValue());
+ assertEquals("currentParameterSnapshot.stationOutBufferCapacities[targetId]",
+ stationOutTaskRule.getDynamicMaxSource());
+
+ AutoTuneRuleSnapshotItem crnMaxOutRule = findRule(result, "crn", "maxOutTask");
+ assertEquals(3, crnMaxOutRule.getMaxStep());
+
+ AutoTuneRuleSnapshotItem crnMaxInRule = findRule(result, "crn", "maxInTask");
+ assertEquals(1, crnMaxInRule.getMaxStep());
}
@Test
@@ -154,4 +176,15 @@
stationObjModel.setStationId(stationId);
return stationObjModel;
}
+
+ private AutoTuneRuleSnapshotItem findRule(List<AutoTuneRuleSnapshotItem> rules,
+ String targetType,
+ String targetKey) {
+ for (AutoTuneRuleSnapshotItem rule : rules) {
+ if (targetType.equals(rule.getTargetType()) && targetKey.equals(rule.getTargetKey())) {
+ return rule;
+ }
+ }
+ throw new AssertionError("rule not found: " + targetType + "/" + targetKey);
+ }
}
--
Gitblit v1.9.1