This commit is contained in:
shiziyuan9527 2020-07-15 23:23:20 +08:00
commit 10344e477e
7 changed files with 63 additions and 1180 deletions

View File

@ -167,6 +167,11 @@ curl -sSL https://github.com/metersphere/metersphere/releases/latest/download/qu
- 基础设施: [Docker](https://www.docker.com/), [Kubernetes](https://kubernetes.io/) - 基础设施: [Docker](https://www.docker.com/), [Kubernetes](https://kubernetes.io/)
- 测试引擎: [JMeter](https://jmeter.apache.org/) - 测试引擎: [JMeter](https://jmeter.apache.org/)
## 加入 MeterSphere 团队
我们正在招聘 MeterSphere 技术布道师,一起打造开源明星项目,请发简历到 metersphere@fit2cloud.com
点击查看 [岗位详情](https://www.zhipin.com/job_detail/b151c4b3d594688733Ny3dy1GFI~.html)
## 微信群 ## 微信群
![wechat-group](https://metersphere.io/images/contact/wechat-group.png) ![wechat-group](https://metersphere.io/images/contact/wechat-group.png)

File diff suppressed because one or more lines are too long

View File

@ -255,7 +255,7 @@
return this.test.isValid() && !this.change; return this.test.isValid() && !this.change;
}, },
isDisabled() { isDisabled() {
return !(this.test.isValid() && this.change) return !(this.test.isValid())
} }
}, },

View File

@ -90,14 +90,14 @@
activeName: "parameters", activeName: "parameters",
rules: { rules: {
name: [ name: [
{max: 100, message: this.$t('commons.input_limit', [0, 100]), trigger: 'blur'} {max: 100, message: this.$t('commons.input_limit', [1, 100]), trigger: 'blur'}
], ],
url: [ url: [
{max: 500, required: true, message: this.$t('commons.input_limit', [0, 500]), trigger: 'blur'}, {max: 500, required: true, message: this.$t('commons.input_limit', [1, 500]), trigger: 'blur'},
{validator: validateURL, trigger: 'blur'} {validator: validateURL, trigger: 'blur'}
], ],
path: [ path: [
{max: 500, required: true, message: this.$t('commons.input_limit', [0, 500]), trigger: 'blur'}, {max: 500, required: true, message: this.$t('commons.input_limit', [1, 500]), trigger: 'blur'},
] ]
} }
} }
@ -143,6 +143,7 @@
this.$error(this.$t('api_test.request.please_add_environment_to_scenario'), 2000); this.$error(this.$t('api_test.request.please_add_environment_to_scenario'), 2000);
this.request.useEnvironment = false; this.request.useEnvironment = false;
} }
this.$refs["request"].clearValidate();
}, },
addProtocol(url) { addProtocol(url) {
if (url) { if (url) {

View File

@ -8,6 +8,11 @@
<el-select :disabled="isReadOnly" v-model="scenario.environmentId" class="environment-select" @change="environmentChange" clearable> <el-select :disabled="isReadOnly" v-model="scenario.environmentId" class="environment-select" @change="environmentChange" clearable>
<el-option v-for="(environment, index) in environments" :key="index" :label="environment.name + ': ' + environment.protocol + '://' + environment.socket" :value="environment.id"/> <el-option v-for="(environment, index) in environments" :key="index" :label="environment.name + ': ' + environment.protocol + '://' + environment.socket" :value="environment.id"/>
<el-button class="environment-button" size="mini" type="primary" @click="openEnvironmentConfig">{{$t('api_test.environment.environment_config')}}</el-button> <el-button class="environment-button" size="mini" type="primary" @click="openEnvironmentConfig">{{$t('api_test.environment.environment_config')}}</el-button>
<template v-slot:empty>
<div class="empty-environment">
<el-button class="environment-button" size="mini" type="primary" @click="openEnvironmentConfig">{{$t('api_test.environment.environment_config')}}</el-button>
</div>
</template>
</el-select> </el-select>
</el-form-item> </el-form-item>
@ -65,18 +70,32 @@
} }
} }
}, },
watch: {
projectId() {
this.getEnvironments();
}
},
methods: { methods: {
getEnvironments() { getEnvironments() {
if (this.projectId) { if (this.projectId) {
this.result = this.$get('/api/environment/list/' + this.projectId, response => { this.result = this.$get('/api/environment/list/' + this.projectId, response => {
this.environments = response.data; this.environments = response.data;
let hasEnvironment = false;
for (let i in this.environments) { for (let i in this.environments) {
if (this.environments[i].id === this.scenario.environmentId) { if (this.environments[i].id === this.scenario.environmentId) {
this.scenario.environment = this.environments[i]; this.scenario.environment = this.environments[i];
hasEnvironment = true;
break; break;
} }
} }
if (!hasEnvironment) {
this.scenario.environmentId = '';
this.scenario.environment = undefined;
}
}); });
} else {
this.scenario.environmentId = '';
this.scenario.environment = undefined;
} }
}, },
environmentChange(value) { environmentChange(value) {
@ -97,6 +116,10 @@
} }
}, },
openEnvironmentConfig() { openEnvironmentConfig() {
if (!this.projectId) {
this.$error(this.$t('api_test.select_project'));
return;
}
this.$refs.environmentConfig.open(this.projectId); this.$refs.environmentConfig.open(this.projectId);
}, },
environmentConfigClose() { environmentConfigClose() {
@ -117,4 +140,8 @@
padding: 7px; padding: 7px;
} }
.empty-environment {
padding: 10px 0px;
}
</style> </style>

View File

@ -61,7 +61,10 @@
return { return {
result: {}, result: {},
rules: { rules: {
name :[{required: true, message: this.$t('commons.input_name'), trigger: 'blur'}], name :[
{required: true, message: this.$t('commons.input_name'), trigger: 'blur'},
{max: 64, message: this.$t('commons.input_limit', [1, 64]), trigger: 'blur'}
],
socket :[{required: true, validator: socketValidator, trigger: 'blur'}], socket :[{required: true, validator: socketValidator, trigger: 'blur'}],
}, },
} }
@ -83,7 +86,9 @@
url = '/api/environment/update'; url = '/api/environment/update';
} }
this.result = this.$post(url, param, response => { this.result = this.$post(url, param, response => {
this.environment.id = response.data; if (!param.id) {
this.environment.id = response.data;
}
this.$success(this.$t('commons.save_success')); this.$success(this.$t('commons.save_success'));
}); });
}, },

View File

@ -169,9 +169,6 @@ export class Scenario extends BaseConfig {
return false; return false;
} }
} }
if (!this.name) {
return false;
}
return true; return true;
} }
} }
@ -396,8 +393,6 @@ class JMXRequest {
constructor(request) { constructor(request) {
if (request && request instanceof Request && (request.url || request.path)) { if (request && request instanceof Request && (request.url || request.path)) {
this.useEnvironment = request.useEnvironment; this.useEnvironment = request.useEnvironment;
this.environment = request.environment;
this.path = decodeURIComponent(request.path);
this.method = request.method; this.method = request.method;
if (!request.useEnvironment) { if (!request.useEnvironment) {
let url = new URL(request.url); let url = new URL(request.url);
@ -405,19 +400,28 @@ class JMXRequest {
this.pathname = decodeURIComponent(url.pathname); this.pathname = decodeURIComponent(url.pathname);
this.port = url.port; this.port = url.port;
this.protocol = url.protocol.split(":")[0]; this.protocol = url.protocol.split(":")[0];
} this.pathname = this.getPostQueryParameters(request, this.pathname);
} else {
if (this.method.toUpperCase() !== "GET") { this.environment = request.environment;
// this.pathname += url.search.replace('&', '&amp;'); this.port = request.environment.port;
this.pathname += '?'; this.path = decodeURIComponent(request.path);
request.parameters.forEach(parameter => { this.path = this.getPostQueryParameters(request, this.path);
if (parameter.name) {
this.pathname += (parameter.name + '=' + parameter.value + '&');
}
});
} }
} }
} }
getPostQueryParameters(request, path) {
if (this.method.toUpperCase() !== "GET") {
path += '?';
request.parameters.forEach(parameter => {
if (parameter.name) {
path += (parameter.name + '=' + parameter.value + '&');
}
});
}
return path;
}
} }
class JMeterTestPlan extends Element { class JMeterTestPlan extends Element {