refactor(接口定义): 重构接口用例代码,去除一些无用的组件
This commit is contained in:
parent
65cd94a439
commit
2d79a4dcae
|
@ -11,8 +11,6 @@ import io.metersphere.api.dto.definition.request.ElementUtil;
|
|||
import io.metersphere.api.dto.definition.request.ParameterConfig;
|
||||
import io.metersphere.api.dto.definition.request.auth.MsAuthManager;
|
||||
import io.metersphere.api.dto.definition.request.dns.MsDNSCacheManager;
|
||||
import io.metersphere.api.dto.definition.request.processors.post.MsJSR223PostProcessor;
|
||||
import io.metersphere.api.dto.definition.request.processors.pre.MsJSR223PreProcessor;
|
||||
import io.metersphere.api.dto.scenario.Body;
|
||||
import io.metersphere.api.dto.scenario.HttpConfig;
|
||||
import io.metersphere.api.dto.scenario.HttpConfigCondition;
|
||||
|
@ -284,6 +282,7 @@ public class MsHTTPSamplerProxy extends MsTestElement {
|
|||
}
|
||||
|
||||
}
|
||||
|
||||
private void initConnectAndResponseTimeout(ParameterConfig config) {
|
||||
if (config.isEffective(this.getProjectId())) {
|
||||
String useEvnId = config.getConfig().get(this.getProjectId()).getApiEnvironmentid();
|
||||
|
@ -604,7 +603,7 @@ public class MsHTTPSamplerProxy extends MsTestElement {
|
|||
stringBuffer.append(path);
|
||||
stringBuffer.append("/");
|
||||
Map<String, String> keyValueMap = new HashMap<>();
|
||||
this.getRest().stream().filter(KeyValue::isEnable).filter(KeyValue::isValid).forEach(keyValue ->
|
||||
this.getRest().stream().filter(KeyValue::isEnable).filter(KeyValue::isValid).filter(KeyValue::valueIsNotEmpty).forEach(keyValue ->
|
||||
keyValueMap.put(keyValue.getName(), keyValue.getValue() != null && keyValue.getValue().startsWith("@") ?
|
||||
ScriptEngineUtils.buildFunctionCallString(keyValue.getValue()) : keyValue.getValue())
|
||||
);
|
||||
|
@ -613,7 +612,7 @@ public class MsHTTPSamplerProxy extends MsTestElement {
|
|||
Matcher m = p.matcher(path);
|
||||
while (m.find()) {
|
||||
String group = m.group(2);
|
||||
if (!isVariable(path, group)) {
|
||||
if (!isVariable(path, group) && keyValueMap.containsKey(group)) {
|
||||
path = path.replace("{" + group + "}", keyValueMap.get(group));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -58,6 +58,10 @@ public class KeyValue {
|
|||
this(name, value, description, "", required);
|
||||
}
|
||||
|
||||
public boolean valueIsNotEmpty() {
|
||||
return StringUtils.isNotEmpty(this.getValue());
|
||||
}
|
||||
|
||||
public boolean isValid() {
|
||||
return (StringUtils.isNotBlank(name) || "JSON-SCHEMA".equals(type)) && !StringUtils.equalsIgnoreCase(type, "file");
|
||||
}
|
||||
|
|
|
@ -2,13 +2,12 @@
|
|||
<el-header style="width: 100% ;padding: 0px">
|
||||
<el-card>
|
||||
<el-row>
|
||||
<el-col :span="api.protocol==='HTTP'? 3:5">
|
||||
<el-checkbox v-model="isSelectAll" class="select-all"/>
|
||||
<el-col :span="api.protocol==='HTTP'? 7:9">
|
||||
<el-tooltip :content="api.name">
|
||||
<span class="ms-col-name"> {{api.name}}</span>
|
||||
</el-tooltip>
|
||||
</el-col>
|
||||
<el-col :span="api.protocol==='HTTP'? 1:3">
|
||||
<el-col :span="api.protocol==='HTTP'? 6:8">
|
||||
<el-tag size="mini" :style="{'background-color': getColor(true, api.method), border: getColor(true, api.method)}" class="api-el-tag">
|
||||
{{ api.method}}
|
||||
</el-tag>
|
||||
|
@ -16,34 +15,6 @@
|
|||
<el-col :span="api.protocol==='HTTP'? 4:0">
|
||||
<div class="variable-combine" style="margin-left: 10px">{{api.path ===null ? " " : api.path}}</div>
|
||||
</el-col>
|
||||
<el-col :span="2" v-if="!isCaseEdit">
|
||||
<div>{{$t('test_track.plan_view.case_count')}}:{{apiCaseList.length}}</div>
|
||||
</el-col>
|
||||
<el-col :span="3">
|
||||
<div>
|
||||
<el-select size="small" :placeholder="$t('api_test.definition.request.grade_order_asc')" v-model="condition.order"
|
||||
:disabled="isCaseEdit"
|
||||
class="ms-api-header-select" @change="search" clearable>
|
||||
<el-option v-for="grd in priorities" :key="grd.id" :label="$t(grd.label)" :value="grd.id"/>
|
||||
</el-select>
|
||||
</div>
|
||||
</el-col>
|
||||
|
||||
<el-col :span="4">
|
||||
<div class="ms-api-header-select" style="margin-right: 20px">
|
||||
<el-row>
|
||||
<el-col :span="12">
|
||||
<el-input size="small" :placeholder="$t('api_test.definition.request.select_case')"
|
||||
:disabled="isCaseEdit"
|
||||
v-model="condition.name" @blur="search" @keyup.enter.native="search"/>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-link type="primary" style="margin-left: 5px" @click="open">{{$t('commons.adv_search.title')}}</el-link>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</el-col>
|
||||
|
||||
<el-col :span="5">
|
||||
<div>
|
||||
<ms-environment-select
|
||||
|
@ -53,16 +24,8 @@
|
|||
@setEnvironment="setEnvironment" ref="environmentSelect"/>
|
||||
</div>
|
||||
</el-col>
|
||||
<!-- <el-col :span="1" v-if="!(isReadOnly || isCaseEdit) && !(this.$store.state.currentApiCase && this.$store.state.currentApiCase.case)">-->
|
||||
<!-- <el-button size="small" type="primary" @click="addCase" v-permission="['PROJECT_API_DEFINITION:READ+CREATE_CASE']">+{{ $t('api_test.definition.request.case') }}-->
|
||||
<!-- </el-button>-->
|
||||
<!-- </el-col>-->
|
||||
</el-row>
|
||||
</el-card>
|
||||
|
||||
<!--高级搜索-->
|
||||
<ms-table-adv-search-bar :condition.sync="condition" :showLink="false" ref="searchBar" @search="search"/>
|
||||
|
||||
</el-header>
|
||||
</template>
|
||||
|
||||
|
@ -72,22 +35,18 @@
|
|||
import MsTag from "../../../../common/components/MsTag";
|
||||
import MsEnvironmentSelect from "./MsEnvironmentSelect";
|
||||
import {API_METHOD_COLOUR} from "../../model/JsonData";
|
||||
import MsTableAdvSearchBar from "@/business/components/common/components/search/MsTableAdvSearchBar";
|
||||
|
||||
export default {
|
||||
name: "ApiCaseHeader",
|
||||
components: {MsEnvironmentSelect, MsTag, ApiEnvironmentConfig, MsTableAdvSearchBar},
|
||||
components: {MsEnvironmentSelect, MsTag, ApiEnvironmentConfig},
|
||||
data() {
|
||||
return {
|
||||
methodColorMap: new Map(API_METHOD_COLOUR),
|
||||
isSelectAll: false
|
||||
}
|
||||
},
|
||||
props: {
|
||||
api: Object,
|
||||
projectId: String,
|
||||
priorities: Array,
|
||||
apiCaseList: Array,
|
||||
isReadOnly: Boolean,
|
||||
useEnvironment: String,
|
||||
isCaseEdit: Boolean,
|
||||
|
@ -100,11 +59,6 @@
|
|||
},
|
||||
created() {
|
||||
},
|
||||
watch: {
|
||||
isSelectAll() {
|
||||
this.$emit('selectAll', this.isSelectAll);
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
refreshEnvironment(){
|
||||
this.$refs.environmentSelect.refreshEnvironment();
|
||||
|
@ -114,16 +68,6 @@
|
|||
this.$emit('setEnvironment', data.id);
|
||||
}
|
||||
},
|
||||
search() {
|
||||
if (this.priorities && this.condition.order) {
|
||||
for (let index in this.priorities) {
|
||||
if (this.priorities[index].id === this.condition.order) {
|
||||
this.condition.orders = [this.priorities[index]];
|
||||
}
|
||||
}
|
||||
}
|
||||
this.$emit('getApiTest');
|
||||
},
|
||||
open() {
|
||||
this.$refs.searchBar.open();
|
||||
},
|
||||
|
|
|
@ -2,24 +2,6 @@
|
|||
<el-card style="margin-top: 5px" @click.native="selectTestCase(apiCase,$event)" v-loading="saveLoading">
|
||||
<div @click="active(apiCase)" v-if="type!=='detail'">
|
||||
<el-row>
|
||||
<el-col :span="3">
|
||||
<el-row>
|
||||
<el-col :span="2" style="margin-top: 5px">
|
||||
<el-checkbox class="item-select" v-model="apiCase.selected"/>
|
||||
</el-col>
|
||||
<el-col :span="2" style="margin-top: 2px">
|
||||
<show-more-btn :is-show="apiCase.selected" :buttons="buttons" :size="selectSize"/>
|
||||
</el-col>
|
||||
<el-col :span="20">
|
||||
<div class="el-step__icon is-text ms-api-col">
|
||||
<div class="el-step__icon-inner">{{ index + 1 }}</div>
|
||||
</div>
|
||||
<el-select size="mini" v-model="apiCase.priority" class="ms-api-select" @change="changePriority(apiCase)">
|
||||
<el-option v-for="grd in priorities" :key="grd.id" :label="grd.name" :value="grd.id"/>
|
||||
</el-select>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-col>
|
||||
<el-col :span="api.protocol==='HTTP'?4:8" v-loading="loading && !(apiCase.active||type==='detail')">
|
||||
<span @click.stop>
|
||||
<i class="icon el-icon-arrow-right" :class="{'is-active': apiCase.active}" @click="active(apiCase)"/>
|
||||
|
@ -43,6 +25,11 @@
|
|||
</span>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :span="2">
|
||||
<el-select size="mini" v-model="apiCase.priority" class="ms-api-select" @change="changePriority(apiCase)" :disabled="loaded">
|
||||
<el-option v-for="grd in priorities" :key="grd.id" :label="grd.name" :value="grd.id"/>
|
||||
</el-select>
|
||||
</el-col>
|
||||
<el-col :span="api.protocol==='HTTP'?4:0">
|
||||
<span v-if="api.protocol==='HTTP'">
|
||||
<el-tag size="mini" :style="{'background-color': getColor(true, apiCase.request.method), border: getColor(true, apiCase.request.method)}"
|
||||
|
@ -54,10 +41,10 @@
|
|||
</el-tooltip>
|
||||
</span>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-col :span="5">
|
||||
<el-row>
|
||||
<el-col :span="8">
|
||||
<el-select size="small" v-model="apiCase.caseStatus" style="margin-right: 5px" @change="saveTestCase(apiCase,true)">
|
||||
<el-select size="small" v-model="apiCase.caseStatus" style="margin-right: 5px" @change="saveTestCase(apiCase,true)" :disabled="loaded">
|
||||
<el-option v-for="item in options" :key="item.id" :label="$t(item.label)" :value="item.id"/>
|
||||
</el-select>
|
||||
</el-col>
|
||||
|
@ -65,7 +52,7 @@
|
|||
<div class="tag-item" @click.stop>
|
||||
<el-select v-model="apiCase.follows" multiple clearable
|
||||
:placeholder="$t('api_test.automation.follow_people')" filterable size="small"
|
||||
@change="saveTestCase(apiCase,true)" style="width: 100%">
|
||||
@change="saveTestCase(apiCase,true)" style="width: 100%" :disabled="loaded">
|
||||
<el-option
|
||||
v-for="item in maintainerOptions"
|
||||
:key="item.id"
|
||||
|
@ -78,7 +65,7 @@
|
|||
</el-row>
|
||||
<el-row style="margin-top: 5px">
|
||||
<div class="tag-item" @click.stop>
|
||||
<ms-input-tag :currentScenario="apiCase" ref="tag" @keyup.enter.native="saveTestCase(apiCase,true)"/>
|
||||
<ms-input-tag :currentScenario="apiCase" ref="tag" @keyup.enter.native="saveTestCase(apiCase,true)" :disabled="loaded"/>
|
||||
</div>
|
||||
</el-row>
|
||||
</el-col>
|
||||
|
@ -86,7 +73,7 @@
|
|||
<el-col :span="3">
|
||||
<span @click.stop>
|
||||
<ms-tip-button @click="singleRun(apiCase)" :tip="$t('api_test.run')" icon="el-icon-video-play" v-permission="['PROJECT_API_DEFINITION:READ+RUN']"
|
||||
class="run-button" size="mini" :disabled="!apiCase.id" circle v-if="!loading"/>
|
||||
class="run-button" size="mini" :disabled="!apiCase.id || loaded" circle v-if="!loading"/>
|
||||
<el-tooltip :content="$t('report.stop_btn')" placement="top" :enterable="false" v-else>
|
||||
<el-button :disabled="!apiCase.id" @click.once="stop(apiCase)" size="mini" style="color:white;padding: 0;width: 28px;height: 28px;" class="stop-btn" circle>
|
||||
<div style="transform: scale(0.72)">
|
||||
|
@ -95,14 +82,14 @@
|
|||
</el-button>
|
||||
</el-tooltip>
|
||||
<ms-tip-button @click="copyCase(apiCase)" :tip="$t('commons.copy')" icon="el-icon-document-copy" v-permission="['PROJECT_API_DEFINITION:READ+COPY_CASE']"
|
||||
size="mini" :disabled="!apiCase.id || isCaseEdit" circle/>
|
||||
size="mini" :disabled="!apiCase.id || isCaseEdit || loaded" circle/>
|
||||
<ms-tip-button @click="deleteCase(index,apiCase)" :tip="$t('commons.delete')" icon="el-icon-delete" v-permission="['PROJECT_API_SCENARIO:READ+DELETE_CASE']"
|
||||
size="mini" :disabled="!apiCase.id || isCaseEdit" circle/>
|
||||
<ms-api-extend-btns :is-case-edit="isCaseEdit" :environment="environment" :row="apiCase"/>
|
||||
</span>
|
||||
</el-col>
|
||||
|
||||
<el-col :span="2">
|
||||
<el-col :span="4">
|
||||
<el-link @click.stop type="danger" v-if="apiCase.execResult && apiCase.execResult==='error'" @click="showExecResult(apiCase)">
|
||||
{{ getResult(apiCase.execResult) }}
|
||||
</el-link>
|
||||
|
@ -128,16 +115,16 @@
|
|||
<div v-if="apiCase.active||type==='detail'" v-loading="loading">
|
||||
<el-divider></el-divider>
|
||||
<p class="tip">{{ $t('api_test.definition.request.req_param') }} </p>
|
||||
<ms-api-request-form :isShowEnable="true" :showScript="true" :is-read-only="isReadOnly" :headers="apiCase.request.headers " :request="apiCase.request" v-if="api.protocol==='HTTP'"/>
|
||||
<ms-api-request-form :isShowEnable="true" :showScript="true" :headers="apiCase.request.headers " :request="apiCase.request" v-if="api.protocol==='HTTP'"/>
|
||||
<tcp-format-parameters :showScript="true" :request="apiCase.request" v-if="api.method==='TCP' && apiCase.request.esbDataStruct == null"/>
|
||||
<esb-definition v-xpack :request="apiCase.request" :showScript="true" v-if="showXpackCompnent&&api.method==='ESB'" ref="esbDefinition"/>
|
||||
<esb-definition v-xpack :request="apiCase.request" :showScript="true" v-if="isXpack&&api.method==='ESB'" ref="esbDefinition"/>
|
||||
<ms-sql-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='SQL'"/>
|
||||
<ms-dubbo-basis-parameters :showScript="true" :request="apiCase.request" v-if="api.protocol==='DUBBO'"/>
|
||||
|
||||
<!-- HTTP 请求返回数据 -->
|
||||
<p class="tip">{{ $t('api_test.definition.request.res_param') }}</p>
|
||||
<div v-if="showXpackCompnent&&api.method==='ESB'">
|
||||
<esb-definition-response v-xpack v-if="showXpackCompnent" :currentProtocol="apiCase.request.protocol" :request="apiCase.request" :is-api-component="false" :show-options-button="false" :show-header="true" :api-item="apiCase"/>
|
||||
<div v-if="isXpack&&api.method==='ESB'">
|
||||
<esb-definition-response v-xpack v-if="isXpack" :currentProtocol="apiCase.request.protocol" :request="apiCase.request" :is-api-component="false" :show-options-button="false" :show-header="true" :api-item="apiCase"/>
|
||||
</div>
|
||||
<div v-else>
|
||||
<api-response-component :currentProtocol="apiCase.request.protocol" :api-item="apiCase" :result="runResult"/>
|
||||
|
@ -225,8 +212,7 @@ export default {
|
|||
['error', this.$t('test_track.plan_view.execute_result') + ':' + this.$t('api_test.home_page.detail_card.execution_failed')],
|
||||
['default', this.$t('test_track.plan_view.execute_result') + ':' + this.$t('api_test.home_page.detail_card.unexecute')]
|
||||
]),
|
||||
showXpackCompnent: false,
|
||||
isReadOnly: false,
|
||||
isXpack: false,
|
||||
selectedEvent: Object,
|
||||
priorities: PRIORITY,
|
||||
runData: [],
|
||||
|
@ -236,17 +222,17 @@ export default {
|
|||
condition: {},
|
||||
responseData: {type: 'HTTP', responseResult: {}, subRequestResults: []},
|
||||
isShowInput: false,
|
||||
buttons: [
|
||||
{name: this.$t('api_test.automation.batch_execute'), handleClick: this.handleRunBatch},
|
||||
{name: this.$t('test_track.case.batch_edit_case'), handleClick: this.handleEditBatch}
|
||||
],
|
||||
methodColorMap: new Map(API_METHOD_COLOUR),
|
||||
saveLoading: false,
|
||||
beforeRequest: {},
|
||||
}
|
||||
},
|
||||
props: {
|
||||
runResult: {},
|
||||
selectSize: Number,
|
||||
loaded: {
|
||||
type: Boolean,
|
||||
default: false,
|
||||
},
|
||||
apiCase: {
|
||||
type: Object,
|
||||
default() {
|
||||
|
@ -266,6 +252,7 @@ export default {
|
|||
return {}
|
||||
}
|
||||
},
|
||||
currentApi: {},
|
||||
type: String,
|
||||
isCaseEdit: Boolean,
|
||||
loading: {
|
||||
|
@ -278,35 +265,27 @@ export default {
|
|||
},
|
||||
created() {
|
||||
if (requireComponent != null && JSON.stringify(esbDefinition) != '{}' && JSON.stringify(esbDefinitionResponse) != '{}') {
|
||||
this.showXpackCompnent = true;
|
||||
this.isXpack = true;
|
||||
}
|
||||
if (this.apiCase && this.apiCase.id) {
|
||||
this.$get('/api/testcase/follow/' + this.apiCase.id, response => {
|
||||
this.apiCase.follows = response.data;
|
||||
});
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
'apiCase.selected'() {
|
||||
this.$emit('apiCaseSelected');
|
||||
if (this.currentApi && this.currentApi.request) {
|
||||
this.beforeRequest = JSON.parse(JSON.stringify(this.currentApi.request));
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
hasPermission,
|
||||
openHis(row) {
|
||||
this.$refs.changeHistory.open(row.id,["接口定义用例" , "接口定義用例" , "Api definition case"]);
|
||||
},
|
||||
handleRunBatch() {
|
||||
this.$emit('batchRun');
|
||||
this.$refs.changeHistory.open(row.id, ["接口定义用例", "接口定義用例", "Api definition case"]);
|
||||
},
|
||||
getColor(enable, method) {
|
||||
if (enable) {
|
||||
return this.methodColorMap.get(method);
|
||||
}
|
||||
},
|
||||
handleEditBatch() {
|
||||
this.$emit('batchEditCase');
|
||||
},
|
||||
deleteCase(index, row) {
|
||||
this.$alert(this.$t('api_test.definition.request.delete_case_confirm') + ' ' + row.name + " ?", '', {
|
||||
confirmButtonText: this.$t('commons.confirm'),
|
||||
|
@ -348,14 +327,14 @@ export default {
|
|||
}
|
||||
if ($event.currentTarget.className.indexOf('is-selected') > 0) {
|
||||
$event.currentTarget.className = "el-card is-always-shadow";
|
||||
this.$emit('selectTestCase', null);
|
||||
this.currentApi.request = this.beforeRequest;
|
||||
} else {
|
||||
if (this.selectedEvent.currentTarget != undefined) {
|
||||
this.selectedEvent.currentTarget.className = "el-card is-always-shadow";
|
||||
}
|
||||
this.selectedEvent.currentTarget = $event.currentTarget;
|
||||
$event.currentTarget.className = "el-card is-always-shadow is-selected";
|
||||
this.$emit('selectTestCase', item);
|
||||
this.currentApi.request = item.request;
|
||||
}
|
||||
},
|
||||
changePriority(row) {
|
||||
|
|
|
@ -4,43 +4,37 @@
|
|||
<template v-slot:header>
|
||||
<api-case-header
|
||||
:api="api"
|
||||
@getApiTest="getApiTest"
|
||||
@setEnvironment="setEnvironment"
|
||||
@addCase="addCase"
|
||||
@selectAll="selectAll"
|
||||
:condition="condition"
|
||||
:priorities="priorities"
|
||||
:apiCaseList="apiCaseList"
|
||||
:is-read-only="isReadOnly"
|
||||
:project-id="projectId"
|
||||
:useEnvironment="environment"
|
||||
:is-case-edit="isCaseEdit"
|
||||
ref="header"
|
||||
/>
|
||||
ref="header"/>
|
||||
</template>
|
||||
|
||||
<el-container v-if="!result.loading">
|
||||
<el-main>
|
||||
<div v-for="(item,index) in apiCaseList" :key="item.id ? item.id : item.uuid">
|
||||
<api-case-item :loading="singleLoading && singleRunId === item.id || batchLoadingIds.indexOf(item.id) > -1"
|
||||
@refresh="refresh"
|
||||
@singleRun="singleRun"
|
||||
@stop="stop"
|
||||
@refreshModule="refreshModule"
|
||||
@copyCase="copyCase"
|
||||
@showExecResult="showExecResult"
|
||||
@batchEditCase="batchEditCase"
|
||||
@batchRun="batchRun"
|
||||
@apiCaseSelected="apiCaseSelected"
|
||||
@showHistory="showHistory"
|
||||
@reLoadCase="reLoadCase"
|
||||
:environment="environment"
|
||||
:select-size="selectSize"
|
||||
:is-case-edit="isCaseEdit"
|
||||
:api="api"
|
||||
:runResult="runResult"
|
||||
:maintainerOptions="maintainerOptions"
|
||||
:api-case="item" :index="index" ref="apiCaseItem"/>
|
||||
<api-case-item
|
||||
:loading="singleLoading && singleRunId === item.id || batchLoadingIds.indexOf(item.id) > -1"
|
||||
@refresh="refresh"
|
||||
@singleRun="singleRun"
|
||||
@stop="stop"
|
||||
@refreshModule="refreshModule"
|
||||
@copyCase="copyCase"
|
||||
@showExecResult="showExecResult"
|
||||
@showHistory="showHistory"
|
||||
@reLoadCase="reLoadCase"
|
||||
:environment="environment"
|
||||
:is-case-edit="isCaseEdit"
|
||||
:api="api"
|
||||
:currentApi="currentApi"
|
||||
:loaded="loaded"
|
||||
:runResult="runResult"
|
||||
:maintainerOptions="maintainerOptions"
|
||||
:api-case="item" :index="index" ref="apiCaseItem"/>
|
||||
</div>
|
||||
</el-main>
|
||||
</el-container>
|
||||
|
@ -49,11 +43,7 @@
|
|||
<!-- 执行组件 -->
|
||||
<ms-run :debug="false" :reportId="reportId" :run-data="runData" :env-map="envMap"
|
||||
@runRefresh="runRefresh" @errorRefresh="errorRefresh" ref="runTest"/>
|
||||
<!--批量编辑-->
|
||||
<ms-batch-edit ref="batchEdit" @batchEdit="batchEdit" :typeArr="typeArr" :data-count="selectdCases.length" :value-arr="valueArr"/>
|
||||
|
||||
<ms-task-center ref="taskCenter" :show-menu="false"/>
|
||||
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
|
@ -61,22 +51,24 @@
|
|||
import ApiCaseHeader from "./ApiCaseHeader";
|
||||
import {getCurrentProjectID, getUUID} from "@/common/js/utils";
|
||||
import MsDrawer from "../../../../common/components/MsDrawer";
|
||||
import {CASE_ORDER, CASE_PRIORITY, DUBBO_METHOD, REQ_METHOD, SQL_METHOD, TCP_METHOD} from "../../model/JsonData";
|
||||
import {CASE_ORDER} from "../../model/JsonData";
|
||||
import {API_CASE_CONFIGS} from "@/business/components/common/components/search/search-components";
|
||||
|
||||
export default {
|
||||
name: 'ApiCaseList',
|
||||
components: {
|
||||
MsDrawer,
|
||||
MsRun: () => import("../Run"),
|
||||
ApiCaseHeader,
|
||||
MsRun: () => import("../Run"),
|
||||
ApiCaseItem: () => import("./ApiCaseItem"),
|
||||
MsBatchEdit: () => import("../basis/BatchEdit"),
|
||||
MsTaskCenter: () => import("../../../../task/TaskCenter"),
|
||||
},
|
||||
props: {
|
||||
createCase: String,
|
||||
loaded: Boolean,
|
||||
loaded: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
refreshSign: String,
|
||||
currentApi: {
|
||||
type: Object
|
||||
|
@ -85,11 +77,7 @@ export default {
|
|||
data() {
|
||||
return {
|
||||
result: {},
|
||||
grades: [],
|
||||
environment: "",
|
||||
isReadOnly: false,
|
||||
selectedEvent: Object,
|
||||
selectSize: 0,
|
||||
priorities: CASE_ORDER,
|
||||
apiCaseList: [],
|
||||
batchLoadingIds: [],
|
||||
|
@ -97,28 +85,13 @@ export default {
|
|||
singleRunId: "",
|
||||
runResult: {},
|
||||
runData: [],
|
||||
selectdCases: [],
|
||||
reportId: "",
|
||||
testCaseId: "",
|
||||
checkedCases: new Set(),
|
||||
visible: false,
|
||||
condition: {
|
||||
components: API_CASE_CONFIGS
|
||||
},
|
||||
api: {},
|
||||
typeArr: [
|
||||
{id: 'priority', name: this.$t('test_track.case.priority')}
|
||||
],
|
||||
priorityFilters: [
|
||||
{text: 'P0', value: 'P0'},
|
||||
{text: 'P1', value: 'P1'},
|
||||
{text: 'P2', value: 'P2'},
|
||||
{text: 'P3', value: 'P3'}
|
||||
],
|
||||
valueArr: {
|
||||
priority: CASE_PRIORITY,
|
||||
method: REQ_METHOD,
|
||||
},
|
||||
envMap: new Map,
|
||||
maintainerOptions: [],
|
||||
};
|
||||
|
@ -160,16 +133,6 @@ export default {
|
|||
this.maintainerOptions = response.data;
|
||||
});
|
||||
},
|
||||
apiCaseSelected() {
|
||||
this.selectSize = 0;
|
||||
if (this.apiCaseList.length > 0) {
|
||||
this.apiCaseList.forEach(item => {
|
||||
if (item.selected && item.id) {
|
||||
this.selectSize++;
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
open(api, testCaseId) {
|
||||
this.api = api;
|
||||
// testCaseId 不为空则为用例编辑页面
|
||||
|
@ -204,11 +167,14 @@ export default {
|
|||
this.visible = true;
|
||||
},
|
||||
runTestCase(api, testCaseId) {
|
||||
this.api = api;
|
||||
// testCaseId 不为空则为用例编辑页面
|
||||
this.testCaseId = testCaseId;
|
||||
this.condition = {components: API_CASE_CONFIGS};
|
||||
this.getApiTestToRunTestCase(testCaseId);
|
||||
if (api && testCaseId) {
|
||||
this.api = api;
|
||||
this.testCaseId = testCaseId;
|
||||
this.condition = {components: API_CASE_CONFIGS};
|
||||
this.getTestCase().then(() => {
|
||||
this.singleRun(this.apiCaseList[0]);
|
||||
});
|
||||
}
|
||||
this.visible = true;
|
||||
},
|
||||
saveApiAndCase(api) {
|
||||
|
@ -230,7 +196,6 @@ export default {
|
|||
this.addCase();
|
||||
}
|
||||
},
|
||||
|
||||
apiCaseClose() {
|
||||
this.apiCaseList = [];
|
||||
this.visible = false;
|
||||
|
@ -243,13 +208,6 @@ export default {
|
|||
this.batchLoadingIds = [];
|
||||
this.singleLoading = false;
|
||||
this.singleRunId = "";
|
||||
if (this.$refs.header.isSelectAll) {
|
||||
this.$refs.header.isSelectAll = false;
|
||||
} else {
|
||||
this.apiCaseList.forEach(item => {
|
||||
this.$set(item, 'selected', false);
|
||||
});
|
||||
}
|
||||
// 批量更新最后执行环境
|
||||
let obj = {envId: this.environment, show: true};
|
||||
this.batchEdit(obj);
|
||||
|
@ -257,111 +215,78 @@ export default {
|
|||
this.$refs.apiCaseItem.runLoading = false;
|
||||
this.$success(this.$t('organization.integration.successful_operation'));
|
||||
this.$store.state.currentApiCase = {refresh: true};
|
||||
this.getApiTest();
|
||||
this.getTestCase();
|
||||
},
|
||||
errorRefresh() {
|
||||
this.batchLoadingIds = [];
|
||||
this.singleLoading = false;
|
||||
this.singleRunId = "";
|
||||
this.$refs.apiCaseItem.runLoading = false;
|
||||
//this.$emit("refresh");
|
||||
},
|
||||
refresh() {
|
||||
this.$emit('refresh');
|
||||
},
|
||||
reLoadCase(){
|
||||
reLoadCase() {
|
||||
this.$emit('reLoadCase');
|
||||
},
|
||||
selectAll(isSelectAll) {
|
||||
this.apiCaseList.forEach(item => {
|
||||
this.$set(item, 'selected', isSelectAll);
|
||||
formatCase(apiCase) {
|
||||
if (apiCase.tags && apiCase.tags.length > 0) {
|
||||
apiCase.tags = JSON.parse(apiCase.tags);
|
||||
}
|
||||
if (Object.prototype.toString.call(apiCase.request).match(/\[object (\w+)\]/)[1].toLowerCase() !== 'object') {
|
||||
apiCase.request = JSON.parse(apiCase.request);
|
||||
}
|
||||
if (!apiCase.request.hashTree) {
|
||||
apiCase.request.hashTree = [];
|
||||
}
|
||||
const index = this.runData.findIndex(d => d.name === apiCase.id);
|
||||
if (index !== -1) {
|
||||
apiCase.active = true;
|
||||
} else {
|
||||
if (this.condition.id && this.condition.id != "") {
|
||||
apiCase.active = true;
|
||||
}
|
||||
}
|
||||
if (apiCase && apiCase.request && apiCase.request.useEnvironment) {
|
||||
this.environment = apiCase.request.useEnvironment;
|
||||
}
|
||||
},
|
||||
getTestCase() {
|
||||
return new Promise((resolve) => {
|
||||
this.environment = "";
|
||||
this.result = this.$get("/api/testcase/findById/" + this.testCaseId, response => {
|
||||
let apiCase = response.data;
|
||||
if (apiCase) {
|
||||
this.formatCase(apiCase);
|
||||
this.apiCaseList = [apiCase];
|
||||
}
|
||||
resolve();
|
||||
});
|
||||
});
|
||||
},
|
||||
getApiTest(addCase) {
|
||||
this.environment = "";
|
||||
getApiLoadCase() {
|
||||
if (this.api) {
|
||||
this.condition.projectId = this.projectId;
|
||||
if (this.isCaseEdit) {
|
||||
this.condition.id = this.testCaseId;
|
||||
}
|
||||
this.condition.apiDefinitionId = this.api.id;
|
||||
this.result = this.$post("/api/testcase/list", this.condition, response => {
|
||||
let data = [];
|
||||
if (response.data) {
|
||||
data = response.data;
|
||||
}
|
||||
data.forEach(apiCase => {
|
||||
if (apiCase.tags && apiCase.tags.length > 0) {
|
||||
apiCase.tags = JSON.parse(apiCase.tags);
|
||||
this.$set(apiCase, 'selected', false);
|
||||
}
|
||||
if (Object.prototype.toString.call(apiCase.request).match(/\[object (\w+)\]/)[1].toLowerCase() !== 'object') {
|
||||
apiCase.request = JSON.parse(apiCase.request);
|
||||
}
|
||||
if (!apiCase.request.hashTree) {
|
||||
apiCase.request.hashTree = [];
|
||||
}
|
||||
const index = this.runData.findIndex(d => d.name === apiCase.id);
|
||||
if (index !== -1) {
|
||||
apiCase.active = true;
|
||||
} else {
|
||||
if (this.condition.id && this.condition.id != "") {
|
||||
apiCase.active = true;
|
||||
}
|
||||
}
|
||||
});
|
||||
this.apiCaseList = data;
|
||||
if (this.apiCaseList[0] && this.apiCaseList[0].request && this.apiCaseList[0].request.useEnvironment) {
|
||||
this.environment = this.apiCaseList[0].request.useEnvironment;
|
||||
}
|
||||
if (addCase && this.apiCaseList.length === 0 && !this.loaded) {
|
||||
this.addCase();
|
||||
let data = response.data;
|
||||
if (data) {
|
||||
data.forEach(apiCase => {
|
||||
this.formatCase(apiCase);
|
||||
});
|
||||
this.apiCaseList = data;
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
getApiTestToRunTestCase(testCaseId) {
|
||||
if (this.api) {
|
||||
this.condition.projectId = this.projectId;
|
||||
if (this.isCaseEdit) {
|
||||
this.condition.id = this.testCaseId;
|
||||
}
|
||||
if (this.api) {
|
||||
this.condition.apiDefinitionId = this.api.id;
|
||||
}
|
||||
|
||||
this.result = this.$post("/api/testcase/list", this.condition, response => {
|
||||
let data = [];
|
||||
if (response.data) {
|
||||
data = response.data;
|
||||
}
|
||||
data.forEach(apiCase => {
|
||||
if (apiCase.tags && apiCase.tags.length > 0) {
|
||||
apiCase.tags = JSON.parse(apiCase.tags);
|
||||
this.$set(apiCase, 'selected', false);
|
||||
}
|
||||
if (Object.prototype.toString.call(apiCase.request).match(/\[object (\w+)\]/)[1].toLowerCase() !== 'object') {
|
||||
apiCase.request = JSON.parse(apiCase.request);
|
||||
}
|
||||
if (!apiCase.request.hashTree) {
|
||||
apiCase.request.hashTree = [];
|
||||
}
|
||||
|
||||
});
|
||||
this.apiCaseList = data;
|
||||
if (this.apiCaseList[0] && this.apiCaseList[0].request && this.apiCaseList[0].request.useEnvironment) {
|
||||
this.environment = this.apiCaseList[0].request.useEnvironment;
|
||||
}
|
||||
if (this.apiCaseList.length === 0 && !this.loaded) {
|
||||
getApiTest(addCase) {
|
||||
if (this.loaded) {
|
||||
this.getApiLoadCase();
|
||||
} else {
|
||||
this.getTestCase().then(() => {
|
||||
if (addCase && !this.loaded && this.apiCaseList.length === 0) {
|
||||
this.addCase();
|
||||
}
|
||||
this.apiCaseList.forEach(apicase => {
|
||||
if (apicase.id === testCaseId) {
|
||||
let data = apicase;
|
||||
data.message = true;
|
||||
this.singleRun(data);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
},
|
||||
|
@ -398,14 +323,11 @@ export default {
|
|||
this.visible = false;
|
||||
this.$emit('showExecResult', row);
|
||||
},
|
||||
|
||||
singleRun(row) {
|
||||
if (this.currentApi.protocol !== "SQL" && this.currentApi.protocol !== "DUBBO" && this.currentApi.protocol !== "dubbo://" && !this.environment) {
|
||||
this.$warning(this.$t('api_test.environment.select_environment'));
|
||||
return;
|
||||
}
|
||||
this.selectdCases = [];
|
||||
this.selectdCases.push(row.id);
|
||||
this.runData = [];
|
||||
this.singleLoading = true;
|
||||
this.singleRunId = row.id;
|
||||
|
@ -427,67 +349,11 @@ export default {
|
|||
this.$success(this.$t('report.test_stop_success'));
|
||||
});
|
||||
},
|
||||
|
||||
batchRun() {
|
||||
if (this.currentApi.protocol !== "SQL" && this.currentApi.protocol !== "DUBBO" && this.currentApi.protocol !== "dubbo://" && !this.environment) {
|
||||
this.$warning(this.$t('api_test.environment.select_environment'));
|
||||
return;
|
||||
}
|
||||
this.envMap = new Map();
|
||||
this.envMap.set(getCurrentProjectID(), this.environment);
|
||||
this.runData = [];
|
||||
this.batchLoadingIds = [];
|
||||
this.selectdCases = [];
|
||||
if (this.apiCaseList.length > 0) {
|
||||
this.apiCaseList.forEach(item => {
|
||||
if (item.selected && item.id) {
|
||||
item.request.name = item.id;
|
||||
item.request.useEnvironment = this.environment;
|
||||
this.runData.push(item.request);
|
||||
this.batchLoadingIds.push(item.id);
|
||||
this.selectdCases.push(item.id);
|
||||
}
|
||||
});
|
||||
if (this.runData.length > 0) {
|
||||
/*触发执行操作*/
|
||||
this.reportId = getUUID().substring(0, 8);
|
||||
} else {
|
||||
this.$warning("请勾选要执行的用例!");
|
||||
}
|
||||
} else {
|
||||
this.$warning("没有可执行的用例!");
|
||||
}
|
||||
},
|
||||
batchEditCase() {
|
||||
if (this.apiCaseList.length > 0) {
|
||||
this.apiCaseList.forEach(item => {
|
||||
if (item.selected && item.id) {
|
||||
this.selectdCases.push(item.id);
|
||||
}
|
||||
});
|
||||
}
|
||||
if (this.selectdCases.length === 0) {
|
||||
this.$warning("请选择用例!");
|
||||
return;
|
||||
}
|
||||
// //根据不同的接口,注入不同的参数
|
||||
if (this.currentApi.protocol === 'HTTP') {
|
||||
this.valueArr.method = REQ_METHOD;
|
||||
} else if (this.currentApi.protocol === 'TCP') {
|
||||
this.valueArr.method = TCP_METHOD;
|
||||
} else if (this.currentApi.protocol === 'SQL') {
|
||||
this.valueArr.method = SQL_METHOD;
|
||||
} else if (this.currentApi.protocol === 'DUBBO') {
|
||||
this.valueArr.method = DUBBO_METHOD;
|
||||
}
|
||||
|
||||
this.$refs.batchEdit.open();
|
||||
},
|
||||
batchEdit(form) {
|
||||
let param = {};
|
||||
if (form) {
|
||||
param[form.type] = form.value;
|
||||
param.ids = this.selectdCases;
|
||||
param.ids = [this.testCaseId];
|
||||
param.projectId = this.projectId;
|
||||
param.envId = form.envId;
|
||||
if (this.api) {
|
||||
|
@ -501,16 +367,7 @@ export default {
|
|||
if (!form.show) {
|
||||
this.$success(this.$t('commons.save_success'));
|
||||
}
|
||||
this.selectdCases = [];
|
||||
this.getResult();
|
||||
});
|
||||
},
|
||||
getResult() {
|
||||
this.apiCaseList.forEach(apiCase => {
|
||||
const index = this.runData.findIndex(d => d.name === apiCase.id);
|
||||
if (index !== -1) {
|
||||
apiCase.active = true;
|
||||
}
|
||||
this.apiCaseList[0].active = true;
|
||||
});
|
||||
},
|
||||
showHistory(id) {
|
||||
|
|
Loading…
Reference in New Issue