From 73378e3bba8fcc79533d20ec2641ee5151f4b965 Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Fri, 10 Mar 2023 17:49:17 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=B5=8B=E8=AF=95=E8=AE=A1=E5=88=92=E6=8A=A5?= =?UTF-8?q?=E5=91=8A=E8=BF=9E=E6=8E=A5=E5=88=86=E4=BA=AB=EF=BC=8C=E6=8E=A5?= =?UTF-8?q?=E5=8F=A3=E7=94=A8=E4=BE=8B=E6=9F=A5=E5=87=BA=E7=9A=84=E6=98=AF?= =?UTF-8?q?=E6=9C=80=E6=96=B0=E6=89=A7=E8=A1=8C=E7=BB=93=E6=9E=9C=E7=9A=84?= =?UTF-8?q?=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1022575 --user=宋天阳 【测试跟踪】github#21600,定时执行的测试计划在执行失败后将报告分享至钉钉群,但是访问钉钉群的链接发现,执行结果取的是最新执行的结果,而我们是想看当时执行失败时的接口执行信息 https://www.tapd.cn/55049933/s/1348250 --- .../ShareTestPlanApiReportController.java | 6 + test-track/frontend/src/api/share.js | 24 +- .../detail/component/ApiCaseFailureResult.vue | 283 ++++++++++-------- 3 files changed, 185 insertions(+), 128 deletions(-) diff --git a/api-test/backend/src/main/java/io/metersphere/controller/plan/ShareTestPlanApiReportController.java b/api-test/backend/src/main/java/io/metersphere/controller/plan/ShareTestPlanApiReportController.java index c09e441ab5..d1feacbfb8 100644 --- a/api-test/backend/src/main/java/io/metersphere/controller/plan/ShareTestPlanApiReportController.java +++ b/api-test/backend/src/main/java/io/metersphere/controller/plan/ShareTestPlanApiReportController.java @@ -23,4 +23,10 @@ public class ShareTestPlanApiReportController { shareInfoService.validate(shareId); return apiDefinitionService.getDbResult(testId); } + + @GetMapping("/api/definition/report/by/id/{reportId}") + public ApiReportResult getApiReport(@PathVariable String reportId) { + return apiDefinitionService.getReportById(reportId); + } + } diff --git a/test-track/frontend/src/api/share.js b/test-track/frontend/src/api/share.js index f98fd12190..c47d3c6f09 100644 --- a/test-track/frontend/src/api/share.js +++ b/test-track/frontend/src/api/share.js @@ -1,4 +1,8 @@ -import {get, post, generateShareUrl} from "metersphere-frontend/src/plugins/request" +import { + generateShareUrl, + get, + post, +} from "metersphere-frontend/src/plugins/request"; export function generateApiDocumentShareInfo(param) { return post("/share/generate/api/document", param); @@ -18,20 +22,26 @@ export function getShareContent(shareId, stepId) { } export function getShareApiReport(shareId, testId) { - return get('/share/api/definition/report/getReport/' + shareId + '/' + testId); + return get( + "/share/api/definition/report/getReport/" + shareId + "/" + testId + ); +} + +export function getShareApiReportByReportId(reportId) { + return get("/share/api/definition/report/by/id/" + reportId); } export function getShareInfo(id) { - return get('/share/info/get/' + id); + return get("/share/info/get/" + id); } export function getShareId() { //let herfUrl = 'http://localhost:8080/sharePlanReport?shareId=bf9496ac-8577-46b4-adf9-9c7e93dd06a8'; let herfUrl = window.location.href; - if (herfUrl.indexOf('shareId=') > -1) { - let shareId = ''; + if (herfUrl.indexOf("shareId=") > -1) { + let shareId = ""; new URL(herfUrl).searchParams.forEach((value, key) => { - if (key === 'shareId') { + if (key === "shareId") { shareId = value; } }); @@ -52,6 +62,6 @@ export function getShareId() { } export function getShareRedirectUrl(data) { - let name = '/share-plan-report'; + let name = "/share-plan-report"; return generateShareUrl(name, data.shareUrl); } diff --git a/test-track/frontend/src/business/plan/view/comonents/report/detail/component/ApiCaseFailureResult.vue b/test-track/frontend/src/business/plan/view/comonents/report/detail/component/ApiCaseFailureResult.vue index e92b211e4e..5e0b98ca17 100644 --- a/test-track/frontend/src/business/plan/view/comonents/report/detail/component/ApiCaseFailureResult.vue +++ b/test-track/frontend/src/business/plan/view/comonents/report/detail/component/ApiCaseFailureResult.vue @@ -1,47 +1,53 @@ @@ -85,14 +96,17 @@ import { getSharePlanApiAllCase, getSharePlanApiErrorReportCase, getSharePlanApiFailureCase, - getSharePlanApiUnExecuteCase + getSharePlanApiUnExecuteCase, } from "@/api/remote/plan/test-plan"; import MsTable from "metersphere-frontend/src/components/table/MsTable"; import MsTableColumn from "metersphere-frontend/src/components/table/MsTableColumn"; import MsAsideContainer from "metersphere-frontend/src/components/MsAsideContainer"; import MsMainContainer from "metersphere-frontend/src/components/MsMainContainer"; -import {getShareApiReport} from "@/api/share"; -import {apiDefinitionReportGet, apiDefinitionReportGetDb} from "@/api/remote/api/api-definition"; +import { getShareApiReport, getShareApiReportByReportId } from "@/api/share"; +import { + apiDefinitionReportGet, + apiDefinitionReportGetDb, +} from "@/api/remote/api/api-definition"; import MicroApp from "metersphere-frontend/src/components/MicroApp"; import MsTestPlanApiStatus from "@/business/plan/view/comonents/api/TestPlanApiStatus"; @@ -103,8 +117,13 @@ export default { MsMainContainer, MsAsideContainer, MicroApp, - MsTableColumn, MsTable, StatusTableItem, MethodTableItem, TypeTableItem, PriorityTableItem, - MsRequestResultTail + MsTableColumn, + MsTable, + StatusTableItem, + MethodTableItem, + TypeTableItem, + PriorityTableItem, + MsRequestResultTail, }, props: { planId: String, @@ -115,7 +134,7 @@ export default { isAll: Boolean, isErrorReport: Boolean, isUnExecute: Boolean, - isDb: Boolean + isDb: Boolean, }, data() { return { @@ -123,17 +142,17 @@ export default { responseLoading: false, loading: false, response: {}, - showResponse: false - } + showResponse: false, + }; }, watch: { apiCases() { if (this.apiCases) { - this.$emit('setSize', this.apiCases.length); + this.$emit("setSize", this.apiCases.length); } else { this.apiCases = []; } - } + }, }, mounted() { this.getScenarioApiCase(); @@ -142,76 +161,112 @@ export default { getScenarioApiCase() { if (this.isTemplate || this.isDb) { if (this.isErrorReport) { - this.apiCases = this.report.errorReportCases ? this.report.errorReportCases : []; + this.apiCases = this.report.errorReportCases + ? this.report.errorReportCases + : []; } else if (this.isUnExecute) { - this.apiCases = this.report.unExecuteCases ? this.report.unExecuteCases : []; + this.apiCases = this.report.unExecuteCases + ? this.report.unExecuteCases + : []; } else if (this.isAll) { - this.apiCases = this.report.apiAllCases ? this.report.apiAllCases : []; + this.apiCases = this.report.apiAllCases + ? this.report.apiAllCases + : []; } else { - this.apiCases = this.report.apiFailureCases ? this.report.apiFailureCases : []; + this.apiCases = this.report.apiFailureCases + ? this.report.apiFailureCases + : []; } } else if (this.isShare) { if (this.isErrorReport) { this.loading = true; - getSharePlanApiErrorReportCase(this.shareId, this.planId) - .then((r) => { + getSharePlanApiErrorReportCase(this.shareId, this.planId).then( + (r) => { this.loading = false; this.apiCases = r.data; - }); + } + ); } else if (this.isUnExecute) { this.loading = true; - getSharePlanApiUnExecuteCase(this.shareId, this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getSharePlanApiUnExecuteCase(this.shareId, this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } else if (this.isAll) { this.loading = true; - getSharePlanApiAllCase(this.shareId, this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getSharePlanApiAllCase(this.shareId, this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } else { this.loading = true; - getSharePlanApiFailureCase(this.shareId, this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getSharePlanApiFailureCase(this.shareId, this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } } else { if (this.isErrorReport) { this.loading = true; - getPlanApiErrorReportCase(this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getPlanApiErrorReportCase(this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } else if (this.isUnExecute) { this.loading = true; - getPlanApiUnExecuteCase(this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getPlanApiUnExecuteCase(this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } else if (this.isAll) { this.loading = true; - getPlanApiAllCase(this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getPlanApiAllCase(this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } else { this.loading = true; - getPlanApiFailureCase(this.planId) - .then((r) => { - this.loading = false; - this.apiCases = r.data; - }); + getPlanApiFailureCase(this.planId).then((r) => { + this.loading = false; + this.apiCases = r.data; + }); } } }, + selectReportContentByReportId(reportId) { + this.responseLoading = true; + apiDefinitionReportGet(reportId).then((response) => { + this.responseLoading = false; + if (response.data) { + let data = response.data; + if (data) { + this.showResponse = true; + try { + this.response = JSON.parse(data.content); + } catch (e) { + this.response = {}; + } + } + } + }); + }, + selectShareReportContentByReportId(reportId) { + this.responseLoading = true; + getShareApiReportByReportId(reportId).then((response) => { + this.responseLoading = false; + if (response.data) { + let data = response.data; + if (data) { + this.showResponse = true; + try { + this.response = JSON.parse(data.content); + } catch (e) { + this.response = {}; + } + } + } + }); + }, rowClick(row) { this.showResponse = false; this.$nextTick(() => { @@ -221,9 +276,11 @@ export default { this.response = JSON.parse(row.response); } } else if (this.isShare) { - this.responseLoading = true; - getShareApiReport(this.shareId, row.id) - .then((r) => { + if (row.reportId) { + this.selectShareReportContentByReportId(row.reportId); + } else { + this.responseLoading = true; + getShareApiReport(this.shareId, row.id).then((r) => { this.responseLoading = false; let data = r.data; if (data && data.content) { @@ -231,49 +288,33 @@ export default { this.response = JSON.parse(data.content); } }); + } } else { if (row.reportId) { - this.responseLoading = true; - apiDefinitionReportGet(row.reportId) - .then(response => { - this.responseLoading = false; - if (response.data) { - let data = response.data; - if (data) { - this.showResponse = true; - try { - this.response = JSON.parse(data.content); - } catch (e) { - this.response = {}; - } - } - } - }); + this.selectReportContentByReportId(row.reportId); } else { this.responseLoading = true; - apiDefinitionReportGetDb(row.id) - .then((r) => { - this.responseLoading = false; - let data = r.data; - if (data && data.content) { - this.showResponse = true; - try { - this.response = JSON.parse(data.content); - } catch (e) { - this.response = {}; - } + apiDefinitionReportGetDb(row.id).then((r) => { + this.responseLoading = false; + let data = r.data; + if (data && data.content) { + this.showResponse = true; + try { + this.response = JSON.parse(data.content); + } catch (e) { + this.response = {}; } - }); + } + }); } } }); - } - } -} + }, + }, +};