fix(测试跟踪): 修复测试计划导出html时场景步骤由成功变成失败的问题

--bug=1024448 --user=宋天阳 github #22067 测试计划 的执行报告,
在线看单步结果是成功的,但是导出就变成了失败 https://www.tapd.cn/55049933/s/1350130
This commit is contained in:
song-tianyang 2023-03-14 20:38:10 +08:00 committed by 建国
parent a252e4735b
commit 383144ff65
1 changed files with 201 additions and 83 deletions

View File

@ -3,14 +3,27 @@
<div class="request-result"> <div class="request-result">
<div @click="active"> <div @click="active">
<el-row :gutter="18" type="flex" align="middle" class="info"> <el-row :gutter="18" type="flex" align="middle" class="info">
<el-col class="ms-req-name-col" :span="18" v-if="indexNumber!=undefined"> <el-col
class="ms-req-name-col"
:span="18"
v-if="indexNumber != undefined"
>
<el-tooltip :content="getName(request.name)" placement="top"> <el-tooltip :content="getName(request.name)" placement="top">
<div class="method ms-req-name"> <div class="method ms-req-name">
<div class="el-step__icon is-text ms-api-col-create"> <div class="el-step__icon is-text ms-api-col-create">
<div class="el-step__icon-inner"> {{ indexNumber }}</div> <div class="el-step__icon-inner">{{ indexNumber }}</div>
</div> </div>
<i class="icon el-icon-arrow-right" :class="{'is-active': showActive}" @click="active" @click.stop/> <i
<el-link class="report-label-req" @click="isLink" v-if="redirect && resourceId"> class="icon el-icon-arrow-right"
:class="{ 'is-active': showActive }"
@click="active"
@click.stop
/>
<el-link
class="report-label-req"
@click="isLink"
v-if="redirect && resourceId"
>
{{ request.name }} {{ request.name }}
</el-link> </el-link>
<span v-else>{{ getName(request.name) }}</span> <span v-else>{{ getName(request.name) }}</span>
@ -19,28 +32,52 @@
</el-col> </el-col>
<el-col :span="3"> <el-col :span="3">
<div v-if="totalStatus"> <div v-if="totalStatus">
<el-tooltip effect="dark" v-if="baseErrorCode && baseErrorCode!==''" :content="baseErrorCode" <el-tooltip
style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap;" placement="bottom" effect="dark"
:open-delay="800"> v-if="baseErrorCode && baseErrorCode !== ''"
<div v-if="totalStatus === 'Success'|| totalStatus === 'success'" style="color: #5daf34"> :content="baseErrorCode"
style="
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
"
placement="bottom"
:open-delay="800"
>
<div
v-if="totalStatus === 'Success' || totalStatus === 'success'"
style="color: #5daf34"
>
{{ baseErrorCode }} {{ baseErrorCode }}
</div> </div>
<div v-else-if="totalStatus === 'errorReportResult'" style="color: #F6972A"> <div
v-else-if="totalStatus === 'errorReportResult'"
style="color: #f6972a"
>
{{ baseErrorCode }} {{ baseErrorCode }}
</div> </div>
<div v-else style="color: #FE6F71"> <div v-else style="color: #fe6f71">
{{ baseErrorCode }} {{ baseErrorCode }}
</div> </div>
</el-tooltip> </el-tooltip>
</div> </div>
<div v-else> <div v-else>
<el-tooltip effect="dark" v-if="baseErrorCode && baseErrorCode!==''" :content="baseErrorCode" <el-tooltip
style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap;" placement="bottom" effect="dark"
:open-delay="800"> v-if="baseErrorCode && baseErrorCode !== ''"
<div v-if="request.success" style="color: #F6972A"> :content="baseErrorCode"
style="
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
"
placement="bottom"
:open-delay="800"
>
<div v-if="request.success" style="color: #f6972a">
{{ baseErrorCode }} {{ baseErrorCode }}
</div> </div>
<div v-else style="color: #FE6F71"> <div v-else style="color: #fe6f71">
{{ baseErrorCode }} {{ baseErrorCode }}
</div> </div>
</el-tooltip> </el-tooltip>
@ -48,31 +85,58 @@
</el-col> </el-col>
<el-col :span="6"> <el-col :span="6">
<div v-if="totalStatus"> <div v-if="totalStatus">
<el-tooltip effect="dark" :content="request.responseResult.responseCode" <el-tooltip
style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap;" placement="bottom" effect="dark"
:open-delay="800"> :content="request.responseResult.responseCode"
<div v-if="totalStatus === 'Success'|| totalStatus === 'success'" style="color: #5daf34"> style="
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
"
placement="bottom"
:open-delay="800"
>
<div
v-if="totalStatus === 'Success' || totalStatus === 'success'"
style="color: #5daf34"
>
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
<div v-else-if="totalStatus === 'errorReportResult'" style="color: #F6972A"> <div
v-else-if="totalStatus === 'errorReportResult'"
style="color: #f6972a"
>
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
<div style="color: #FE6F71" v-else> <div style="color: #fe6f71" v-else>
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
</el-tooltip> </el-tooltip>
</div> </div>
<div v-else> <div v-else>
<el-tooltip effect="dark" :content="request.responseResult.responseCode" <el-tooltip
style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap;" placement="bottom" effect="dark"
:open-delay="800"> :content="request.responseResult.responseCode"
<div style="color: #F6972A" v-if="baseErrorCode && baseErrorCode!=='' && request.success"> style="
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
"
placement="bottom"
:open-delay="800"
>
<div
style="color: #f6972a"
v-if="
baseErrorCode && baseErrorCode !== '' && request.success
"
>
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
<div style="color: #5daf34" v-else-if="request.success"> <div style="color: #5daf34" v-else-if="request.success">
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
<div style="color: #FE6F71" v-else> <div style="color: #fe6f71" v-else>
{{ request.responseResult.responseCode }} {{ request.responseResult.responseCode }}
</div> </div>
</el-tooltip> </el-tooltip>
@ -80,13 +144,19 @@
</el-col> </el-col>
<el-col :span="3"> <el-col :span="3">
<div v-if="totalStatus"> <div v-if="totalStatus">
<div v-if="totalStatus === 'Success'|| totalStatus === 'success'" style="color: #5daf34"> <div
v-if="totalStatus === 'Success' || totalStatus === 'success'"
style="color: #5daf34"
>
{{ request.responseResult.responseTime }} {{ request.responseResult.responseTime }}
</div> </div>
<div v-else-if="totalStatus === 'errorReportResult'" style="color: #F6972A"> <div
v-else-if="totalStatus === 'errorReportResult'"
style="color: #f6972a"
>
{{ request.responseResult.responseTime }} {{ request.responseResult.responseTime }}
</div> </div>
<div style="color: #FE6F71" v-else> <div style="color: #fe6f71" v-else>
{{ request.responseResult.responseTime }} {{ request.responseResult.responseTime }}
</div> </div>
</div> </div>
@ -94,45 +164,77 @@
<span v-if="request.success"> <span v-if="request.success">
{{ request.responseResult.responseTime }} ms {{ request.responseResult.responseTime }} ms
</span> </span>
<span style="color: #FE6F71" v-else> <span style="color: #fe6f71" v-else>
{{ request.responseResult.responseTime }} ms {{ request.responseResult.responseTime }} ms
</span> </span>
</div> </div>
</el-col> </el-col>
<el-col :span="2"> <el-col :span="2">
<div v-if="totalStatus"> <div v-if="totalStatus">
<el-tag size="mini" v-if="totalStatus === 'unexecute'">{{ <el-tag size="mini" v-if="totalStatus === 'unexecute'"
$t('api_test.home_page.detail_card.unexecute') >{{ $t("api_test.home_page.detail_card.unexecute") }}
}}
</el-tag> </el-tag>
<el-tag v-else-if="totalStatus === 'errorReportResult' " class="ms-test-error_code" <el-tag
size="mini"> v-else-if="
{{ $t('error_report_library.option.name') }} totalStatus === 'errorReportResult' ||
totalStatus === 'FAKE_ERROR'
"
class="ms-test-error_code"
size="mini"
>
{{ $t("error_report_library.option.name") }}
</el-tag> </el-tag>
<el-tag size="mini" type="success" v-else-if="totalStatus === 'Success' || totalStatus === 'success'"> <el-tag
{{ $t('api_report.success') }} size="mini"
type="success"
v-else-if="
totalStatus === 'Success' ||
totalStatus === 'SUCCESS' ||
totalStatus === 'success'
"
>
{{ $t("api_report.success") }}
</el-tag> </el-tag>
<el-tag size="mini" type="danger" v-else> {{ $t('api_report.fail') }}</el-tag> <el-tag size="mini" type="danger" v-else>
{{ $t("api_report.fail") }}</el-tag
>
</div> </div>
<div v-else> <div v-else>
<el-tag v-if="request.testing" class="ms-test-running" size="mini"> <el-tag
<i class="el-icon-loading" style="font-size: 16px"/> v-if="request.testing"
{{ $t('commons.testing') }} class="ms-test-running"
size="mini"
>
<i class="el-icon-loading" style="font-size: 16px" />
{{ $t("commons.testing") }}
</el-tag> </el-tag>
<el-tag size="mini" v-else-if="request.unexecute">{{ <el-tag size="mini" v-else-if="request.unexecute"
$t('api_test.home_page.detail_card.unexecute') >{{ $t("api_test.home_page.detail_card.unexecute") }}
}}
</el-tag> </el-tag>
<el-tag size="mini" v-else-if="!request.success && request.status && request.status==='unexecute'">{{ <el-tag
$t('api_test.home_page.detail_card.unexecute') size="mini"
}} v-else-if="
!request.success &&
request.status &&
request.status === 'unexecute'
"
>{{ $t("api_test.home_page.detail_card.unexecute") }}
</el-tag> </el-tag>
<el-tag v-else-if="baseErrorCode && baseErrorCode!== '' && request.success" class="ms-test-error_code" <el-tag
size="mini"> v-else-if="
{{ $t('error_report_library.option.name') }} baseErrorCode && baseErrorCode !== '' && request.success
"
class="ms-test-error_code"
size="mini"
>
{{ $t("error_report_library.option.name") }}
</el-tag> </el-tag>
<el-tag size="mini" type="success" v-else-if="request.success"> {{ $t('api_report.success') }}</el-tag> <el-tag size="mini" type="success" v-else-if="request.success">
<el-tag size="mini" type="danger" v-else> {{ $t('api_report.fail') }}</el-tag> {{ $t("api_report.success") }}</el-tag
>
<el-tag size="mini" type="danger" v-else>
{{ $t("api_report.fail") }}</el-tag
>
</div> </div>
</el-col> </el-col>
</el-row> </el-row>
@ -146,7 +248,8 @@
:request-type="requestType" :request-type="requestType"
:request="requestInfo" :request="requestInfo"
:console="console" :console="console"
v-if="showActive"/> v-if="showActive"
/>
</div> </div>
</el-collapse-transition> </el-collapse-transition>
</div> </div>
@ -159,7 +262,7 @@ import MsRequestResultTail from "./RequestResultTail";
export default { export default {
name: "MsRequestResult", name: "MsRequestResult",
components: { components: {
MsRequestResultTail MsRequestResultTail,
}, },
props: { props: {
request: Object, request: Object,
@ -172,11 +275,11 @@ export default {
redirect: Boolean, redirect: Boolean,
errorCode: { errorCode: {
type: String, type: String,
default: "" default: "",
}, },
isActive: { isActive: {
type: Boolean, type: Boolean,
default: false default: false,
}, },
isShare: Boolean, isShare: Boolean,
shareId: String, shareId: String,
@ -192,7 +295,7 @@ export default {
type: String, type: String,
default() { default() {
return "#B8741A"; return "#B8741A";
} },
}, },
requestInfo: { requestInfo: {
loading: true, loading: true,
@ -205,10 +308,10 @@ export default {
type: String, type: String,
default() { default() {
return "#F9F1EA"; return "#F9F1EA";
} },
}, },
showActive: false, showActive: false,
} };
}, },
watch: { watch: {
isActive() { isActive() {
@ -223,23 +326,28 @@ export default {
handler(n) { handler(n) {
if (this.request.errorCode) { if (this.request.errorCode) {
this.baseErrorCode = this.request.errorCode; this.baseErrorCode = this.request.errorCode;
} else if (this.request.attachInfoMap && this.request.attachInfoMap.errorReportResult) { } else if (
this.request.attachInfoMap &&
this.request.attachInfoMap.errorReportResult
) {
if (this.request.attachInfoMap.errorReportResult !== "") { if (this.request.attachInfoMap.errorReportResult !== "") {
this.baseErrorCode = this.request.attachInfoMap.errorReportResult; this.baseErrorCode = this.request.attachInfoMap.errorReportResult;
} }
} }
}, },
} },
}, },
methods: { methods: {
isLink() { isLink() {
let uri = "/#/api/definition?caseId=" + this.resourceId; let uri = "/#/api/definition?caseId=" + this.resourceId;
this.clickResource(uri) this.clickResource(uri);
}, },
clickResource(uri) { clickResource(uri) {
this.$get('/user/update/currentByResourceId/' + this.resourceId).then(() => { this.$get("/user/update/currentByResourceId/" + this.resourceId).then(
this.toPage(uri); () => {
}); this.toPage(uri);
}
);
}, },
toPage(uri) { toPage(uri) {
let id = "new_a"; let id = "new_a";
@ -254,23 +362,33 @@ export default {
element.parentNode.removeChild(element); element.parentNode.removeChild(element);
}, },
loadRequestInfoExpand() { loadRequestInfoExpand() {
if (!this.request.responseResult || this.request.responseResult.body === null || this.request.responseResult.body === undefined) { if (
!this.request.responseResult ||
this.request.responseResult.body === null ||
this.request.responseResult.body === undefined
) {
if (this.isShare) { if (this.isShare) {
this.$get("/share/" + this.shareId + "/scenario/report/selectReportContent/" + this.stepId).then(response => { this.$get(
"/share/" +
this.shareId +
"/scenario/report/selectReportContent/" +
this.stepId
).then((response) => {
this.requestInfo = response.data; this.requestInfo = response.data;
this.$nextTick(() => { this.$nextTick(() => {
this.requestInfo.loading = false; this.requestInfo.loading = false;
}); });
}); });
} else { } else {
this.$get("/ui/scenario/report/selectReportContent/" + this.stepId).then(response => { this.$get(
"/ui/scenario/report/selectReportContent/" + this.stepId
).then((response) => {
this.requestInfo = response.data; this.requestInfo = response.data;
this.$nextTick(() => { this.$nextTick(() => {
this.requestInfo.loading = false; this.requestInfo.loading = false;
}); });
}); });
} }
} else { } else {
this.requestInfo = this.request; this.requestInfo = this.request;
} }
@ -307,9 +425,9 @@ export default {
return ""; return "";
} }
return name; return name;
} },
}, },
} };
</script> </script>
<style scoped> <style scoped>
@ -324,7 +442,7 @@ export default {
} }
.request-result .method { .request-result .method {
color: #1E90FF; color: #1e90ff;
font-size: 14px; font-size: 14px;
font-weight: 500; font-weight: 500;
line-height: 35px; line-height: 35px;
@ -356,11 +474,11 @@ export default {
} }
.sub-result .info { .sub-result .info {
background-color: #FFF; background-color: #fff;
} }
.sub-result .method { .sub-result .method {
border-left: 5px solid #1E90FF; border-left: 5px solid #1e90ff;
padding-left: 20px; padding-left: 20px;
} }
@ -369,7 +487,7 @@ export default {
} }
.sub-result:last-child { .sub-result:last-child {
border-bottom: 1px solid #EBEEF5; border-bottom: 1px solid #ebeef5;
} }
.ms-test-running { .ms-test-running {
@ -377,21 +495,21 @@ export default {
} }
.ms-test-error_code { .ms-test-error_code {
color: #F6972A; color: #f6972a;
background-color: #FDF5EA; background-color: #fdf5ea;
border-color: #FDF5EA; border-color: #fdf5ea;
} }
.ms-api-col { .ms-api-col {
background-color: #EFF0F0; background-color: #eff0f0;
border-color: #EFF0F0; border-color: #eff0f0;
margin-right: 10px; margin-right: 10px;
font-size: 12px; font-size: 12px;
color: #64666A; color: #64666a;
} }
.ms-api-col-create { .ms-api-col-create {
background-color: #EBF2F2; background-color: #ebf2f2;
border-color: #008080; border-color: #008080;
margin-right: 10px; margin-right: 10px;
font-size: 12px; font-size: 12px;