diff --git a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/controller/AlertRobotsController.java b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/controller/AlertRobotsController.java index 727af057..60a184fa 100644 --- a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/controller/AlertRobotsController.java +++ b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/controller/AlertRobotsController.java @@ -17,6 +17,7 @@ */ package org.cloud.sonic.controller.controller; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Parameter; @@ -93,7 +94,7 @@ public RespModel delete( @Parameter(name = "projectId", description = "项目id") int projectId, @RequestParam(name = "id") int id ) { - if (alertRobotsService.removeByMap(Map.of("id", id, "projectId", projectId))) { + if (alertRobotsService.remove(Wrappers.lambdaQuery(AlertRobots.class).eq(AlertRobots::getId, id).eq(AlertRobots::getProjectId, projectId))) { return new RespModel<>(RespEnum.DELETE_OK); } else { return new RespModel<>(RespEnum.DELETE_FAIL); diff --git a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/mapper/AlertRobotsMapper.java b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/mapper/AlertRobotsMapper.java index 0d6b3b79..16a82d77 100644 --- a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/mapper/AlertRobotsMapper.java +++ b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/mapper/AlertRobotsMapper.java @@ -73,12 +73,4 @@ default List computeAgentRobots(int agentId) { return listAgentRobotsFromIds(ids); } - @Select(""" - select * from alert_robots r where scene = 'summary' - and ( - r.project_id = ${projectId} or - (r.project_id is null and 1 = (select global_robot from projects where id = ${projectId}) - ) - """) - List computeSummaryRobots(@Param("projectId") int projectId); } diff --git a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/services/impl/AlertRobotsServiceImpl.java b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/services/impl/AlertRobotsServiceImpl.java index 36523cf8..a6e64b4e 100644 --- a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/services/impl/AlertRobotsServiceImpl.java +++ b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/services/impl/AlertRobotsServiceImpl.java @@ -27,16 +27,19 @@ import org.cloud.sonic.controller.services.impl.base.SonicServiceImpl; import org.cloud.sonic.controller.tools.robot.Message; import org.cloud.sonic.controller.tools.robot.RobotFactory; +import org.cloud.sonic.controller.tools.robot.RobotMessenger; import org.cloud.sonic.controller.tools.robot.message.DeviceMessage; import org.cloud.sonic.controller.tools.robot.message.ProjectSummaryMessage; import org.cloud.sonic.controller.tools.robot.message.TestSuiteMessage; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; -import org.springframework.expression.spel.standard.SpelExpressionParser; +import org.springframework.expression.Expression; +import org.springframework.expression.spel.standard.SpelExpression; import org.springframework.stereotype.Service; import org.springframework.web.client.RestTemplate; import java.math.BigDecimal; +import java.math.BigInteger; import java.math.RoundingMode; import java.util.Date; import java.util.List; @@ -85,7 +88,7 @@ public void sendResultFinishReport(int suitId, String suiteName, int pass, int w @Override public void sendProjectReportMessage(int projectId, String projectName, Date startDate, Date endDate, boolean isWeekly, int pass, int warn, int fail) { - var robots = baseMapper.computeSummaryRobots(projectId); + var robots = findRobots(projectId, SCENE_SUMMARY).list(); if (robots.isEmpty()) return; var total = pass + warn + fail; var rate = total > 0 ? BigDecimal.valueOf(((float) pass / total) * 100).setScale(2, RoundingMode.HALF_UP).doubleValue() : 0; @@ -98,7 +101,7 @@ public void sendProjectReportMessage(int projectId, String projectName, Date sta public void sendErrorDevice(int agentId, int errorType, int tem, String udId) { var robots = baseMapper.computeAgentRobots(agentId); if (robots.isEmpty()) return; - var msg = new DeviceMessage(errorType, tem, udId); + var msg = new DeviceMessage(errorType, new BigDecimal(BigInteger.valueOf(tem), 1), udId); send(robots, msg); } @@ -118,11 +121,18 @@ private void send(List robots, Message message) { @Override public String getDefaultNoticeTemplate(int type, String scene) { var messenger = robotFactory.getRobotMessenger(type); - return switch (scene) { - case SCENE_AGENT -> messenger.getDefaultDeviceMessageTemplate().getExpressionString(); - case SCENE_SUMMARY -> messenger.getDefaultProjectSummaryTemplate().getExpressionString(); - case SCENE_TESTSUITE -> messenger.getDefaultTestSuiteTemplate().getExpressionString(); - default -> ""; + var template = switch (scene) { + case SCENE_AGENT -> messenger.getDefaultDeviceMessageTemplate(); + case SCENE_SUMMARY -> messenger.getDefaultProjectSummaryTemplate(); + case SCENE_TESTSUITE -> messenger.getDefaultTestSuiteTemplate(); + default -> null; }; + if (null == template) { + return ""; + } else if (template instanceof SpelExpression) { + return RobotMessenger.templateParserContext.getExpressionPrefix() + template.getExpressionString() + RobotMessenger.templateParserContext.getExpressionSuffix(); + } else { + return template.getExpressionString(); + } } } diff --git a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/message/DeviceMessage.java b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/message/DeviceMessage.java index 3548db9c..29c9dc16 100644 --- a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/message/DeviceMessage.java +++ b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/message/DeviceMessage.java @@ -20,9 +20,11 @@ import lombok.AllArgsConstructor; import org.cloud.sonic.controller.tools.robot.Message; +import java.math.BigDecimal; + @AllArgsConstructor public class DeviceMessage extends Message { public int errorType; - public int tem; + public BigDecimal tem; public String udId; } diff --git a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/vendor/WebhookImpl.java b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/vendor/WebhookImpl.java index 0b7d9c53..2419d873 100644 --- a/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/vendor/WebhookImpl.java +++ b/sonic-server-controller/src/main/java/org/cloud/sonic/controller/tools/robot/vendor/WebhookImpl.java @@ -5,9 +5,11 @@ import org.cloud.sonic.controller.tools.robot.RobotMessenger; import org.springframework.expression.Expression; import org.springframework.http.ResponseEntity; +import org.springframework.stereotype.Service; import org.springframework.web.client.RestTemplate; @Slf4j +@Service("WebhookImpl") public class WebhookImpl implements RobotMessenger { @Override public void sendMessage(RestTemplate restTemplate, String token, String secret, Expression messageTemplate, Message message) { diff --git a/sonic-server-controller/src/test/java/org/cloud/sonic/controller/tools/RobotMsgToolTest.java b/sonic-server-controller/src/test/java/org/cloud/sonic/controller/tools/RobotMsgToolTest.java index c94b911c..d6185ac9 100644 --- a/sonic-server-controller/src/test/java/org/cloud/sonic/controller/tools/RobotMsgToolTest.java +++ b/sonic-server-controller/src/test/java/org/cloud/sonic/controller/tools/RobotMsgToolTest.java @@ -30,6 +30,7 @@ import org.springframework.test.context.junit4.SpringRunner; import org.springframework.web.client.RestTemplate; +import java.math.BigDecimal; import java.util.Date; @SpringBootTest(classes = ControllerApplication.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT) @@ -37,7 +38,7 @@ public class RobotMsgToolTest { private void testMessage(RobotMessenger bot, String token, String secret) { - for (var msg : new Message[]{new DeviceMessage(0, 0, "test"), new ProjectSummaryMessage(0, "test", new Date(System.currentTimeMillis() - 7 * 24 * 3600 * 1000), new Date(), 1, 3, 4, 1.4, 3, "https://sonic/?#=+", true), new ProjectSummaryMessage(0, "test", new Date(System.currentTimeMillis() - 24 * 3600 * 1000), new Date(), 1, 3, 4, 1.4, 3, "https://sonic/?#=+", false), new TestSuiteMessage("asf", 0, 1, 4, 5, 3, "https://sonic/?#=+"),}) { + for (var msg : new Message[]{new DeviceMessage(0, new BigDecimal(0), "test"), new ProjectSummaryMessage(0, "test", new Date(System.currentTimeMillis() - 7 * 24 * 3600 * 1000), new Date(), 1, 3, 4, 1.4, 3, "https://sonic/?#=+", true), new ProjectSummaryMessage(0, "test", new Date(System.currentTimeMillis() - 24 * 3600 * 1000), new Date(), 1, 3, 4, 1.4, 3, "https://sonic/?#=+", false), new TestSuiteMessage("asf", 0, 1, 4, 5, 3, "https://sonic/?#=+"),}) { bot.sendMessage(new RestTemplate(), token, secret, "", msg); } }