fix(接口测试): swagger 定时同步,请求参数无法关闭问题修复

--bug=1009615 --user=周骏弘 【接口测试】swagger定时同步,请求参数无法关闭 https://www.tapd.cn/55049933/s/1093058
This commit is contained in:
junhong 2022-01-17 19:34:27 +08:00 committed by john1298308460
parent 87c216f01c
commit 0f1a6b6f7e
4 changed files with 48 additions and 18 deletions

View File

@ -1408,13 +1408,15 @@ public class ApiDefinitionService {
/*swagger定时导入*/ /*swagger定时导入*/
public void createSchedule(ScheduleRequest request) { public void createSchedule(ScheduleRequest request) {
String config = setAuthParams(request);
/*保存swaggerUrl*/ /*保存swaggerUrl*/
SwaggerUrlProject swaggerUrlProject = new SwaggerUrlProject(); SwaggerUrlProject swaggerUrlProject = new SwaggerUrlProject();
BeanUtils.copyBean(swaggerUrlProject, request); BeanUtils.copyBean(swaggerUrlProject, request);
swaggerUrlProject.setId(UUID.randomUUID().toString()); swaggerUrlProject.setId(UUID.randomUUID().toString());
// 设置鉴权信息 // 设置鉴权信息
swaggerUrlProject.setConfig(config); if(request.getHeaders() !=null || request.getArguments() !=null || request.getAuthManager() != null){
String config = setAuthParams(request);
swaggerUrlProject.setConfig(config);
}
scheduleService.addSwaggerUrlSchedule(swaggerUrlProject); scheduleService.addSwaggerUrlSchedule(swaggerUrlProject);
request.setResourceId(swaggerUrlProject.getId()); request.setResourceId(swaggerUrlProject.getId());
@ -1435,11 +1437,15 @@ public class ApiDefinitionService {
} }
public void updateSchedule(ScheduleRequest request) { public void updateSchedule(ScheduleRequest request) {
String config = setAuthParams(request);
SwaggerUrlProject swaggerUrlProject = new SwaggerUrlProject(); SwaggerUrlProject swaggerUrlProject = new SwaggerUrlProject();
BeanUtils.copyBean(swaggerUrlProject, request); BeanUtils.copyBean(swaggerUrlProject, request);
// 设置鉴权信息 // 设置鉴权信息
swaggerUrlProject.setConfig(config); if(request.getHeaders() !=null || request.getArguments() !=null || request.getAuthManager() != null){
String config = setAuthParams(request);
swaggerUrlProject.setConfig(config);
}else{
swaggerUrlProject.setConfig(null);
}
scheduleService.updateSwaggerUrlSchedule(swaggerUrlProject); scheduleService.updateSwaggerUrlSchedule(swaggerUrlProject);
// 只修改表达式和名称 // 只修改表达式和名称
Schedule schedule = new Schedule(); Schedule schedule = new Schedule();

View File

@ -64,7 +64,7 @@ public class ScheduleService {
} }
public void updateSwaggerUrlSchedule(SwaggerUrlProject swaggerUrlProject) { public void updateSwaggerUrlSchedule(SwaggerUrlProject swaggerUrlProject) {
swaggerUrlProjectMapper.updateByPrimaryKeySelective(swaggerUrlProject); swaggerUrlProjectMapper.updateByPrimaryKeyWithBLOBs(swaggerUrlProject);
} }
public ApiSwaggerUrlDTO selectApiSwaggerUrlDTO(String id) { public ApiSwaggerUrlDTO selectApiSwaggerUrlDTO(String id) {

View File

@ -72,7 +72,7 @@
<el-form-item :label="'Swagger URL'" prop="swaggerUrl" class="swagger-url"> <el-form-item :label="'Swagger URL'" prop="swaggerUrl" class="swagger-url">
<el-input size="small" v-model="formData.swaggerUrl" clearable show-word-limit/> <el-input size="small" v-model="formData.swaggerUrl" clearable show-word-limit/>
</el-form-item> </el-form-item>
<el-switch v-model="authEnable" :active-text="$t('api_test.api_import.add_request_params')"></el-switch> <el-switch v-model="authEnable" :active-text="$t('api_test.api_import.add_request_params')" @change="changeAuthEnable"></el-switch>
</el-col> </el-col>
<el-col :span="14" v-show="isSwagger2 && authEnable && swaggerUrlEnable"> <el-col :span="14" v-show="isSwagger2 && authEnable && swaggerUrlEnable">
@ -90,7 +90,7 @@
<div style="margin-top: 10px"> <div style="margin-top: 10px">
<span>{{$t('api_test.definition.request.auth_config')}}{{$t('api_test.api_import.optional')}}</span> <span>{{$t('api_test.definition.request.auth_config')}}{{$t('api_test.api_import.optional')}}</span>
</div> </div>
<ms-api-auth-config :is-read-only="isReadOnly" :request="authConfig" :encryptShow="false"/> <ms-api-auth-config :is-read-only="isReadOnly" :request="authConfig" :encryptShow="false" ref="importAuth"/>
</el-col> </el-col>
<el-col :span="12" <el-col :span="12"
@ -142,6 +142,7 @@
import MsApiAuthConfig from "../auth/ApiAuthConfig"; import MsApiAuthConfig from "../auth/ApiAuthConfig";
import {REQUEST_HEADERS} from "@/common/js/constants"; import {REQUEST_HEADERS} from "@/common/js/constants";
import {ELEMENT_TYPE, TYPE_TO_C} from "@/business/components/api/automation/scenario/Setting"; import {ELEMENT_TYPE, TYPE_TO_C} from "@/business/components/api/automation/scenario/Setting";
import {KeyValue} from "../../model/ApiTestModel";
export default { export default {
name: "ApiImport", name: "ApiImport",
@ -394,6 +395,19 @@
this.formData.moduleId = id; this.formData.moduleId = id;
this.formData.modulePath = data.path; this.formData.modulePath = data.path;
}, },
clearAuthInfo(){
this.headers = [];
this.queryArguments = [];
this.headers.push(new KeyValue({enable: true}));
this.queryArguments.push(new KeyValue({enable: true}));
this.authConfig = {hashTree: [], authManager: {}};
this.$refs.importAuth.initData();
},
changeAuthEnable() {
if(!this.authEnable){
this.clearAuthInfo();
}
},
buildParam() { buildParam() {
let param = {}; let param = {};
Object.assign(param, this.formData); Object.assign(param, this.formData);
@ -407,7 +421,8 @@
param.projectId = this.projectId; param.projectId = this.projectId;
if (!this.swaggerUrlEnable) { if (!this.swaggerUrlEnable) {
param.swaggerUrl = undefined; param.swaggerUrl = undefined;
}else{ }
if(this.authEnable){
// //
param.headers = this.headers; param.headers = this.headers;
// query // query

View File

@ -32,7 +32,7 @@
</el-col> </el-col>
<el-col :span="12" style="margin-left: 50px"> <el-col :span="12" style="margin-left: 50px">
<el-switch v-model="authEnable" :active-text="$t('api_test.api_import.add_request_params')"></el-switch> <el-switch v-model="authEnable" :active-text="$t('api_test.api_import.add_request_params')" @change="changeAuthEnable"></el-switch>
</el-col> </el-col>
<el-col :span="19" v-show="authEnable" style="margin-top: 10px; margin-left: 50px" class="request-tabs"> <el-col :span="19" v-show="authEnable" style="margin-top: 10px; margin-left: 50px" class="request-tabs">
@ -239,6 +239,11 @@ export default {
currentUser: () => { currentUser: () => {
return getCurrentUser(); return getCurrentUser();
}, },
changeAuthEnable() {
if(!this.authEnable){
this.clearAuthInfo();
}
},
clear() { clear() {
this.formData.id = null; this.formData.id = null;
this.formData.moduleId = null; this.formData.moduleId = null;
@ -279,13 +284,19 @@ export default {
this.formData.projectId = getCurrentProjectID(); this.formData.projectId = getCurrentProjectID();
this.formData.workspaceId = getCurrentWorkspaceId(); this.formData.workspaceId = getCurrentWorkspaceId();
this.formData.value = this.formData.rule; this.formData.value = this.formData.rule;
// query if(this.authEnable){
this.formData.headers = this.headers; // query
this.formData.arguments = this.queryArguments; this.formData.headers = this.headers;
// BaseAuth this.formData.arguments = this.queryArguments;
if(this.authConfig.authManager != undefined){ // BaseAuth
this.authConfig.authManager.clazzName = TYPE_TO_C.get("AuthManager"); if(this.authConfig.authManager != undefined){
this.formData.authManager = this.authConfig.authManager; this.authConfig.authManager.clazzName = TYPE_TO_C.get("AuthManager");
this.formData.authManager = this.authConfig.authManager;
}
}else {
this.formData.headers = undefined;
this.formData.arguments = undefined;
this.formData.authManager = undefined;
} }
let url = ''; let url = '';
if (this.formData.id) { if (this.formData.id) {
@ -300,7 +311,6 @@ export default {
this.clear(); this.clear();
}); });
}, },
intervalShortValidate() { intervalShortValidate() {
if (this.getIntervalTime() < 3 * 60 * 1000) { if (this.getIntervalTime() < 3 * 60 * 1000) {
this.$info(this.$t('schedule.cron_expression_interval_short_error')); this.$info(this.$t('schedule.cron_expression_interval_short_error'));
@ -348,7 +358,6 @@ export default {
this.authConfig = {hashTree: [], authManager: {}}; this.authConfig = {hashTree: [], authManager: {}};
this.authEnable = false; this.authEnable = false;
} }
}, },
computed: { computed: {
isTesterPermission() { isTesterPermission() {