refactor: 高级参数设置组件
This commit is contained in:
parent
9ba78978c0
commit
26f29ade01
|
@ -34,107 +34,19 @@
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</div>
|
</div>
|
||||||
|
<ms-api-variable-advance ref="variableAdvance" :environment="environment" :scenario="scenario" :request="request"
|
||||||
<el-dialog :title="$t('api_test.request.parameters_advance')"
|
:current-item="currentItem"/>
|
||||||
:visible.sync="itemValueVisible"
|
|
||||||
class="advanced-item-value"
|
|
||||||
width="70%">
|
|
||||||
<el-tabs tab-position="top" style="height: 50vh;" @tab-click="selectTab">
|
|
||||||
<el-tab-pane :label="$t('api_test.request.parameters_advance_mock')">
|
|
||||||
<el-row type="flex" :gutter="20">
|
|
||||||
<el-col :span="6" class="col-height">
|
|
||||||
<div>
|
|
||||||
<el-input size="small" v-model="filterText"
|
|
||||||
:placeholder="$t('api_test.request.parameters_mock_filter_tips')"/>
|
|
||||||
<el-tree class="filter-tree" ref="tree" :data="mockFuncs" :props="treeProps"
|
|
||||||
default-expand-all @node-click="selectVariable"
|
|
||||||
:filter-node-method="filterNode"></el-tree>
|
|
||||||
</div>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="6" v-for="(itemFunc, itemIndex) in mockVariableFuncs" :key="itemIndex">
|
|
||||||
<div v-for="(func, funcIndex) in funcs"
|
|
||||||
:key="`${itemIndex}-${funcIndex}`">
|
|
||||||
<el-row>
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-radio size="mini" v-model="itemFunc.name" :label="func.name"
|
|
||||||
@change="methodChange(itemFunc, func)"/>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="12" v-if="itemFunc.name === func.name">
|
|
||||||
<div v-for="(p, pIndex) in itemFunc.params" :key="`${itemIndex}-${funcIndex}-${pIndex}`">
|
|
||||||
<el-input :placeholder="p.name" size="mini" v-model="p.value" @change="showPreview"/>
|
|
||||||
</div>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</div>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</el-tab-pane>
|
|
||||||
<el-tab-pane label="变量">
|
|
||||||
<el-row>
|
|
||||||
<el-col :span="6" class="col-height">
|
|
||||||
<div v-if="environment">
|
|
||||||
<p>{{ $t('api_test.environment.environment') }}</p>
|
|
||||||
<el-tree :data="environmentParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
|
||||||
</div>
|
|
||||||
<div v-if="scenario">
|
|
||||||
<p>{{ $t('api_test.scenario.scenario') }}</p>
|
|
||||||
<el-tree :data="scenarioParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
|
||||||
</div>
|
|
||||||
<div v-if="preRequestParams">
|
|
||||||
<p>{{ $t('api_test.request.parameters_pre_request') }}</p>
|
|
||||||
<el-tree :data="preRequestParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
|
||||||
</div>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="6" v-for="(itemFunc, itemIndex) in jmeterVariableFuncs" :key="itemIndex" class="col-height">
|
|
||||||
<div>
|
|
||||||
<div v-for="(func, funcIndex) in jmeterFuncs"
|
|
||||||
:key="`${itemIndex}-${funcIndex}`">
|
|
||||||
<el-row>
|
|
||||||
<el-radio size="mini" v-model="itemFunc.name" :label="func.name"
|
|
||||||
@change="methodChange(itemFunc, func)"/>
|
|
||||||
</el-row>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</el-tab-pane>
|
|
||||||
</el-tabs>
|
|
||||||
<el-form>
|
|
||||||
<el-form-item>
|
|
||||||
<el-input :placeholder="valueText" size="small"
|
|
||||||
v-model="itemValue"/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
<div style="padding-top: 10px;">
|
|
||||||
<el-row type="flex" align="middle">
|
|
||||||
<el-col :span="12">
|
|
||||||
<el-button size="small" type="primary" plain @click="saveAdvanced()">
|
|
||||||
{{ $t('commons.save') }}
|
|
||||||
</el-button>
|
|
||||||
<el-button size="small" type="info" plain @click="addFunc()" v-if="currentTab === 0">
|
|
||||||
{{ $t('api_test.request.parameters_advance_add_func') }}
|
|
||||||
</el-button>
|
|
||||||
<el-button size="small" type="success" plain @click="showPreview()" v-if="currentTab === 0">
|
|
||||||
{{ $t('api_test.request.parameters_preview') }}
|
|
||||||
</el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col>
|
|
||||||
<div> {{ itemValuePreview }}</div>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</div>
|
|
||||||
</el-dialog>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {HttpRequest, KeyValue, Scenario} from "../model/ScenarioModel";
|
import {HttpRequest, KeyValue, Scenario} from "../model/ScenarioModel";
|
||||||
import {JMETER_FUNC, MOCKJS_FUNC} from "@/common/js/constants";
|
import {MOCKJS_FUNC} from "@/common/js/constants";
|
||||||
import {calculate} from "@/business/components/api/test/model/ScenarioModel";
|
import MsApiVariableAdvance from "@/business/components/api/test/components/ApiVariableAdvance";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "MsApiVariable",
|
name: "MsApiVariable",
|
||||||
|
components: {MsApiVariableAdvance},
|
||||||
props: {
|
props: {
|
||||||
keyPlaceholder: String,
|
keyPlaceholder: String,
|
||||||
valuePlaceholder: String,
|
valuePlaceholder: String,
|
||||||
|
@ -148,98 +60,10 @@ export default {
|
||||||
},
|
},
|
||||||
suggestions: Array
|
suggestions: Array
|
||||||
},
|
},
|
||||||
mounted() {
|
|
||||||
if (this.request) {
|
|
||||||
this.parameters = this.request.parameters;
|
|
||||||
}
|
|
||||||
if (this.scenario) {
|
|
||||||
let variables = this.scenario.variables;
|
|
||||||
this.scenarioParams = [
|
|
||||||
{
|
|
||||||
name: this.scenario.name,
|
|
||||||
children: variables.filter(v => v.name).map(v => {
|
|
||||||
return {name: v.name, value: '${' + v.name + '}'}
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
];
|
|
||||||
if (this.environment) {
|
|
||||||
let variables = JSON.parse(this.environment.variables);
|
|
||||||
this.environmentParams = [
|
|
||||||
{
|
|
||||||
name: this.environment.name,
|
|
||||||
children: variables.filter(v => v.name).map(v => {
|
|
||||||
return {name: v.name, value: '${' + v.name + '}'}
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
||||||
let i = this.scenario.requests.indexOf(this.request);
|
|
||||||
this.preRequests = this.scenario.requests.slice(0, i);
|
|
||||||
this.preRequests.forEach(r => {
|
|
||||||
let js = r.extract.json.map(v => {
|
|
||||||
return {name: v.variable, value: v.value}
|
|
||||||
});
|
|
||||||
let xs = r.extract.xpath.map(v => {
|
|
||||||
return {name: v.variable, value: v.value}
|
|
||||||
});
|
|
||||||
let rx = r.extract.regex.map(v => {
|
|
||||||
return {name: v.variable, value: v.value}
|
|
||||||
});
|
|
||||||
let vs = [...js, ...xs, ...rx];
|
|
||||||
if (vs.length > 0) {
|
|
||||||
this.preRequestParams.push({name: r.name, children: vs});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
},
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
filterText: '',
|
currentItem: null,
|
||||||
itemValueVisible: false,
|
|
||||||
itemValue: null,
|
|
||||||
funcs: [
|
|
||||||
{name: "md5"},
|
|
||||||
{name: "base64"},
|
|
||||||
{name: "unbase64"},
|
|
||||||
{
|
|
||||||
name: "substr",
|
|
||||||
params: [{name: "start"}, {name: "length"}]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "concat",
|
|
||||||
params: [{name: "suffix"}]
|
|
||||||
},
|
|
||||||
{name: "lconcat", params: [{name: "prefix"}]},
|
|
||||||
{name: "sha1"},
|
|
||||||
{name: "sha224"},
|
|
||||||
{name: "sha256"},
|
|
||||||
{name: "sha384"},
|
|
||||||
{name: "sha512"},
|
|
||||||
{name: "lower"},
|
|
||||||
{name: "upper"},
|
|
||||||
{name: "length"},
|
|
||||||
{name: "number"}
|
|
||||||
],
|
|
||||||
itemValuePreview: null,
|
|
||||||
mockVariableFuncs: [],
|
|
||||||
jmeterVariableFuncs: [],
|
|
||||||
currentTab: 0,
|
|
||||||
mockFuncs: MOCKJS_FUNC.map(f => {
|
|
||||||
return {name: f.name, value: f.name}
|
|
||||||
}),
|
|
||||||
jmeterFuncs: JMETER_FUNC,
|
|
||||||
environmentParams: [],
|
|
||||||
scenarioParams: [],
|
|
||||||
parameters: [],
|
parameters: [],
|
||||||
preRequests: [],
|
|
||||||
preRequestParams: [],
|
|
||||||
treeProps: {children: 'children', label: 'name'}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
filterText(val) {
|
|
||||||
this.$refs.tree.filter(val);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
@ -250,7 +74,6 @@ export default {
|
||||||
return this.valuePlaceholder || this.$t("api_test.value");
|
return this.valuePlaceholder || this.$t("api_test.value");
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
remove: function (index) {
|
remove: function (index) {
|
||||||
this.parameters.splice(index, 1);
|
this.parameters.splice(index, 1);
|
||||||
|
@ -299,81 +122,14 @@ export default {
|
||||||
return (func.name.toLowerCase().indexOf(queryString.toLowerCase()) > -1);
|
return (func.name.toLowerCase().indexOf(queryString.toLowerCase()) > -1);
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
filterNode(value, data) {
|
|
||||||
if (!value) return true;
|
|
||||||
return data.name.indexOf(value) !== -1;
|
|
||||||
},
|
|
||||||
selectVariable(node) {
|
|
||||||
this.itemValue = node.value;
|
|
||||||
},
|
|
||||||
selectTab(tab) {
|
|
||||||
this.currentTab = +tab.index;
|
|
||||||
this.itemValue = null;
|
|
||||||
this.itemValuePreview = null;
|
|
||||||
},
|
|
||||||
showPreview() {
|
|
||||||
// 找到变量本身
|
|
||||||
if (!this.itemValue) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let index = this.itemValue.indexOf("|");
|
|
||||||
if (index > -1) {
|
|
||||||
this.itemValue = this.itemValue.substring(0, index).trim();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.mockVariableFuncs.forEach(f => {
|
|
||||||
if (!f.name) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this.itemValue += "|" + f.name;
|
|
||||||
if (f.params) {
|
|
||||||
this.itemValue += ":" + f.params.map(p => p.value).join(",");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
this.itemValuePreview = calculate(this.itemValue);
|
|
||||||
},
|
|
||||||
methodChange(itemFunc, func) {
|
|
||||||
let index = this.mockVariableFuncs.indexOf(itemFunc);
|
|
||||||
this.mockVariableFuncs = this.mockVariableFuncs.slice(0, index);
|
|
||||||
// 这里要用 deep copy
|
|
||||||
this.mockVariableFuncs.push(JSON.parse(JSON.stringify(func)));
|
|
||||||
this.showPreview();
|
|
||||||
},
|
|
||||||
addFunc() {
|
|
||||||
if (this.mockVariableFuncs.length > 4) {
|
|
||||||
this.$info(this.$t('api_test.request.parameters_advance_add_func_limit'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (this.mockVariableFuncs.length > 0) {
|
|
||||||
let func = this.mockVariableFuncs[this.mockVariableFuncs.length - 1];
|
|
||||||
if (!func.name) {
|
|
||||||
this.$warning(this.$t('api_test.request.parameters_advance_add_func_error'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (func.params) {
|
|
||||||
for (let j = 0; j < func.params.length; j++) {
|
|
||||||
if (!func.params[j].value) {
|
|
||||||
this.$warning(this.$t('api_test.request.parameters_advance_add_param_error'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.mockVariableFuncs.push({name: '', params: []});
|
|
||||||
},
|
|
||||||
advanced(item) {
|
advanced(item) {
|
||||||
|
this.$refs.variableAdvance.open();
|
||||||
this.currentItem = item;
|
this.currentItem = item;
|
||||||
this.itemValueVisible = true;
|
|
||||||
this.itemValue = '';
|
this.itemValue = '';
|
||||||
this.itemValuePreview = null;
|
|
||||||
this.mockVariableFuncs = [];
|
this.mockVariableFuncs = [];
|
||||||
},
|
},
|
||||||
saveAdvanced() {
|
|
||||||
this.currentItem.value = this.itemValue;
|
|
||||||
this.itemValueVisible = false;
|
|
||||||
this.mockVariableFuncs = [];
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
if (this.parameters.length === 0) {
|
if (this.parameters.length === 0) {
|
||||||
|
@ -408,8 +164,4 @@ export default {
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-height {
|
|
||||||
height: 40vh;
|
|
||||||
overflow: auto;
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -0,0 +1,286 @@
|
||||||
|
<template>
|
||||||
|
<el-dialog :title="$t('api_test.request.parameters_advance')"
|
||||||
|
:visible.sync="itemValueVisible"
|
||||||
|
class="advanced-item-value"
|
||||||
|
width="70%">
|
||||||
|
<el-tabs tab-position="top" style="height: 50vh;" @tab-click="selectTab">
|
||||||
|
<el-tab-pane :label="$t('api_test.request.parameters_advance_mock')">
|
||||||
|
<el-row type="flex" :gutter="20">
|
||||||
|
<el-col :span="6" class="col-height">
|
||||||
|
<div>
|
||||||
|
<el-input size="small" v-model="filterText"
|
||||||
|
:placeholder="$t('api_test.request.parameters_mock_filter_tips')"/>
|
||||||
|
<el-tree class="filter-tree" ref="tree" :data="mockFuncs" :props="treeProps"
|
||||||
|
default-expand-all @node-click="selectVariable"
|
||||||
|
:filter-node-method="filterNode"></el-tree>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="6" v-for="(itemFunc, itemIndex) in mockVariableFuncs" :key="itemIndex">
|
||||||
|
<div v-for="(func, funcIndex) in funcs"
|
||||||
|
:key="`${itemIndex}-${funcIndex}`">
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-radio size="mini" v-model="itemFunc.name" :label="func.name"
|
||||||
|
@change="methodChange(itemFunc, func)"/>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12" v-if="itemFunc.name === func.name">
|
||||||
|
<div v-for="(p, pIndex) in itemFunc.params" :key="`${itemIndex}-${funcIndex}-${pIndex}`">
|
||||||
|
<el-input :placeholder="p.name" size="mini" v-model="p.value" @change="showPreview"/>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-tab-pane>
|
||||||
|
<el-tab-pane label="变量">
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="6" class="col-height">
|
||||||
|
<div v-if="environment">
|
||||||
|
<p>{{ $t('api_test.environment.environment') }}</p>
|
||||||
|
<el-tree :data="environmentParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
||||||
|
</div>
|
||||||
|
<div v-if="scenario">
|
||||||
|
<p>{{ $t('api_test.scenario.scenario') }}</p>
|
||||||
|
<el-tree :data="scenarioParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
||||||
|
</div>
|
||||||
|
<div v-if="preRequestParams">
|
||||||
|
<p>{{ $t('api_test.request.parameters_pre_request') }}</p>
|
||||||
|
<el-tree :data="preRequestParams" :props="treeProps" @node-click="selectVariable"></el-tree>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="6" v-for="(itemFunc, itemIndex) in jmeterVariableFuncs" :key="itemIndex" class="col-height">
|
||||||
|
<div>
|
||||||
|
<div v-for="(func, funcIndex) in jmeterFuncs"
|
||||||
|
:key="`${itemIndex}-${funcIndex}`">
|
||||||
|
<el-row>
|
||||||
|
<el-radio size="mini" v-model="itemFunc.name" :label="func.name"
|
||||||
|
@change="methodChange(itemFunc, func)"/>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-tab-pane>
|
||||||
|
</el-tabs>
|
||||||
|
<el-form>
|
||||||
|
<el-form-item>
|
||||||
|
<el-input :placeholder="valueText" size="small"
|
||||||
|
v-model="itemValue"/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<div style="padding-top: 10px;">
|
||||||
|
<el-row type="flex" align="middle">
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-button size="small" type="primary" plain @click="saveAdvanced()">
|
||||||
|
{{ $t('commons.save') }}
|
||||||
|
</el-button>
|
||||||
|
<el-button size="small" type="info" plain @click="addFunc()" v-if="currentTab === 0">
|
||||||
|
{{ $t('api_test.request.parameters_advance_add_func') }}
|
||||||
|
</el-button>
|
||||||
|
<el-button size="small" type="success" plain @click="showPreview()" v-if="currentTab === 0">
|
||||||
|
{{ $t('api_test.request.parameters_preview') }}
|
||||||
|
</el-button>
|
||||||
|
</el-col>
|
||||||
|
<el-col>
|
||||||
|
<div> {{ itemValuePreview }}</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {calculate, HttpRequest, Scenario} from "@/business/components/api/test/model/ScenarioModel";
|
||||||
|
import {JMETER_FUNC, MOCKJS_FUNC} from "@/common/js/constants";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "MsApiVariableAdvance",
|
||||||
|
props: {
|
||||||
|
request: HttpRequest,
|
||||||
|
environment: Object,
|
||||||
|
scenario: Scenario,
|
||||||
|
currentItem: Object,
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
itemValueVisible: false,
|
||||||
|
filterText: '',
|
||||||
|
environmentParams: [],
|
||||||
|
scenarioParams: [],
|
||||||
|
preRequests: [],
|
||||||
|
preRequestParams: [],
|
||||||
|
treeProps: {children: 'children', label: 'name'},
|
||||||
|
currentTab: 0,
|
||||||
|
itemValue: null,
|
||||||
|
itemValuePreview: null,
|
||||||
|
funcs: [
|
||||||
|
{name: "md5"},
|
||||||
|
{name: "base64"},
|
||||||
|
{name: "unbase64"},
|
||||||
|
{
|
||||||
|
name: "substr",
|
||||||
|
params: [{name: "start"}, {name: "length"}]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "concat",
|
||||||
|
params: [{name: "suffix"}]
|
||||||
|
},
|
||||||
|
{name: "lconcat", params: [{name: "prefix"}]},
|
||||||
|
{name: "sha1"},
|
||||||
|
{name: "sha224"},
|
||||||
|
{name: "sha256"},
|
||||||
|
{name: "sha384"},
|
||||||
|
{name: "sha512"},
|
||||||
|
{name: "lower"},
|
||||||
|
{name: "upper"},
|
||||||
|
{name: "length"},
|
||||||
|
{name: "number"}
|
||||||
|
],
|
||||||
|
mockFuncs: MOCKJS_FUNC.map(f => {
|
||||||
|
return {name: f.name, value: f.name}
|
||||||
|
}),
|
||||||
|
jmeterFuncs: JMETER_FUNC,
|
||||||
|
mockVariableFuncs: [],
|
||||||
|
jmeterVariableFuncs: [],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
valueText() {
|
||||||
|
return this.valuePlaceholder || this.$t("api_test.value");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
this.prepareData();
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
filterText(val) {
|
||||||
|
this.$refs.tree.filter(val);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
open() {
|
||||||
|
this.itemValueVisible = true;
|
||||||
|
},
|
||||||
|
prepareData() {
|
||||||
|
if (this.request) {
|
||||||
|
this.parameters = this.request.parameters;
|
||||||
|
}
|
||||||
|
if (this.scenario) {
|
||||||
|
let variables = this.scenario.variables;
|
||||||
|
this.scenarioParams = [
|
||||||
|
{
|
||||||
|
name: this.scenario.name,
|
||||||
|
children: variables.filter(v => v.name).map(v => {
|
||||||
|
return {name: v.name, value: '${' + v.name + '}'}
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
];
|
||||||
|
if (this.environment) {
|
||||||
|
let variables = JSON.parse(this.environment.variables);
|
||||||
|
this.environmentParams = [
|
||||||
|
{
|
||||||
|
name: this.environment.name,
|
||||||
|
children: variables.filter(v => v.name).map(v => {
|
||||||
|
return {name: v.name, value: '${' + v.name + '}'}
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
let i = this.scenario.requests.indexOf(this.request);
|
||||||
|
this.preRequests = this.scenario.requests.slice(0, i);
|
||||||
|
this.preRequests.forEach(r => {
|
||||||
|
let js = r.extract.json.map(v => {
|
||||||
|
return {name: v.variable, value: v.value}
|
||||||
|
});
|
||||||
|
let xs = r.extract.xpath.map(v => {
|
||||||
|
return {name: v.variable, value: v.value}
|
||||||
|
});
|
||||||
|
let rx = r.extract.regex.map(v => {
|
||||||
|
return {name: v.variable, value: v.value}
|
||||||
|
});
|
||||||
|
let vs = [...js, ...xs, ...rx];
|
||||||
|
if (vs.length > 0) {
|
||||||
|
this.preRequestParams.push({name: r.name, children: vs});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
filterNode(value, data) {
|
||||||
|
if (!value) return true;
|
||||||
|
return data.name.indexOf(value) !== -1;
|
||||||
|
},
|
||||||
|
selectVariable(node) {
|
||||||
|
this.itemValue = node.value;
|
||||||
|
},
|
||||||
|
selectTab(tab) {
|
||||||
|
this.currentTab = +tab.index;
|
||||||
|
this.itemValue = null;
|
||||||
|
this.itemValuePreview = null;
|
||||||
|
},
|
||||||
|
showPreview() {
|
||||||
|
// 找到变量本身
|
||||||
|
if (!this.itemValue) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let index = this.itemValue.indexOf("|");
|
||||||
|
if (index > -1) {
|
||||||
|
this.itemValue = this.itemValue.substring(0, index).trim();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.mockVariableFuncs.forEach(f => {
|
||||||
|
if (!f.name) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.itemValue += "|" + f.name;
|
||||||
|
if (f.params) {
|
||||||
|
this.itemValue += ":" + f.params.map(p => p.value).join(",");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.itemValuePreview = calculate(this.itemValue);
|
||||||
|
},
|
||||||
|
methodChange(itemFunc, func) {
|
||||||
|
let index = this.mockVariableFuncs.indexOf(itemFunc);
|
||||||
|
this.mockVariableFuncs = this.mockVariableFuncs.slice(0, index);
|
||||||
|
// 这里要用 deep copy
|
||||||
|
this.mockVariableFuncs.push(JSON.parse(JSON.stringify(func)));
|
||||||
|
this.showPreview();
|
||||||
|
},
|
||||||
|
addFunc() {
|
||||||
|
if (this.mockVariableFuncs.length > 4) {
|
||||||
|
this.$info(this.$t('api_test.request.parameters_advance_add_func_limit'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (this.mockVariableFuncs.length > 0) {
|
||||||
|
let func = this.mockVariableFuncs[this.mockVariableFuncs.length - 1];
|
||||||
|
if (!func.name) {
|
||||||
|
this.$warning(this.$t('api_test.request.parameters_advance_add_func_error'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (func.params) {
|
||||||
|
for (let j = 0; j < func.params.length; j++) {
|
||||||
|
if (!func.params[j].value) {
|
||||||
|
this.$warning(this.$t('api_test.request.parameters_advance_add_param_error'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.mockVariableFuncs.push({name: '', params: []});
|
||||||
|
},
|
||||||
|
saveAdvanced() {
|
||||||
|
this.currentItem.value = this.itemValue;
|
||||||
|
this.itemValueVisible = false;
|
||||||
|
this.mockVariableFuncs = [];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.col-height {
|
||||||
|
height: 40vh;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue