fix: 修改自定义函数报错
This commit is contained in:
parent
ce8de01585
commit
d195499696
|
@ -28,11 +28,6 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
<!-- <el-row>-->
|
|
||||||
<!-- <el-form-item :label="'参数列表'" prop="">-->
|
|
||||||
<!-- <function-params :items="form.params"/>-->
|
|
||||||
<!-- </el-form-item>-->
|
|
||||||
<!-- </el-row>-->
|
|
||||||
<el-row style="margin-right: 10px;">
|
<el-row style="margin-right: 10px;">
|
||||||
<el-col :span="20">
|
<el-col :span="20">
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
|
@ -96,9 +91,9 @@ import MsInputTag from "@/business/components/api/automation/scenario/MsInputTag
|
||||||
import FunctionParams from "@/business/components/settings/project/function/FunctionParams";
|
import FunctionParams from "@/business/components/settings/project/function/FunctionParams";
|
||||||
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
import MsCodeEdit from "@/business/components/common/components/MsCodeEdit";
|
||||||
import MsDropdown from "@/business/components/common/components/MsDropdown";
|
import MsDropdown from "@/business/components/common/components/MsDropdown";
|
||||||
import {FUNC_TEMPLATE, splicingCustomFunc} from "@/business/components/settings/project/function/custom_function";
|
import {FUNC_TEMPLATE} from "@/business/components/settings/project/function/custom-function";
|
||||||
import MsRun from "@/business/components/api/automation/scenario/DebugRun";
|
import MsRun from "@/business/components/api/automation/scenario/DebugRun";
|
||||||
import {getUUID} from "@/common/js/utils";
|
import {getCurrentProjectID, getUUID} from "@/common/js/utils";
|
||||||
import {JSR223Processor} from "@/business/components/api/definition/model/ApiTestModel";
|
import {JSR223Processor} from "@/business/components/api/definition/model/ApiTestModel";
|
||||||
import FunctionRun from "@/business/components/settings/project/function/FunctionRun";
|
import FunctionRun from "@/business/components/settings/project/function/FunctionRun";
|
||||||
import CustomFunctionRelate from "@/business/components/settings/project/function/CustomFunctionRelate";
|
import CustomFunctionRelate from "@/business/components/settings/project/function/CustomFunctionRelate";
|
||||||
|
@ -229,38 +224,7 @@ export default {
|
||||||
console: "无执行结果"
|
console: "无执行结果"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
// watch: {
|
|
||||||
// 'form.name'() {
|
|
||||||
// this.splicingFunc();
|
|
||||||
// },
|
|
||||||
// 'form.params': {
|
|
||||||
// handler() {
|
|
||||||
// this.splicingFunc();
|
|
||||||
// },
|
|
||||||
// deep: true
|
|
||||||
// }
|
|
||||||
// },
|
|
||||||
methods: {
|
methods: {
|
||||||
// _parseFuncParam(funcObj) {
|
|
||||||
// let params = undefined;
|
|
||||||
// if (funcObj.params) {
|
|
||||||
// params = funcObj.params.map(p => p.name);
|
|
||||||
// if (params.length > 0) {
|
|
||||||
// params = params.filter(p => {
|
|
||||||
// return p !== undefined
|
|
||||||
// });
|
|
||||||
// params.join(",\s");
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// // todo 参数拼接问题 删除参数 逗号未去除
|
|
||||||
// return params;
|
|
||||||
// },
|
|
||||||
// splicingFunc() {
|
|
||||||
// let funcObj = this.form;
|
|
||||||
// let funcParams = this._parseFuncParam(funcObj);
|
|
||||||
// this.form.script = splicingCustomFunc(funcObj, funcParams);
|
|
||||||
// this.reloadCodeEdit();
|
|
||||||
// },
|
|
||||||
open(data) {
|
open(data) {
|
||||||
this.activeName = "code";
|
this.activeName = "code";
|
||||||
this.visible = true;
|
this.visible = true;
|
||||||
|
@ -285,11 +249,6 @@ export default {
|
||||||
} else {
|
} else {
|
||||||
this.form.tags = JSON.parse(this.form.tags);
|
this.form.tags = JSON.parse(this.form.tags);
|
||||||
}
|
}
|
||||||
// if (!this.form.params) {
|
|
||||||
// this.form.params = [];
|
|
||||||
// } else {
|
|
||||||
// this.form.params = JSON.parse(this.form.params);
|
|
||||||
// }
|
|
||||||
this.reload();
|
this.reload();
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
@ -357,6 +316,9 @@ export default {
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
update(obj) {
|
update(obj) {
|
||||||
|
if (!obj.projectId) {
|
||||||
|
obj.projectId = getCurrentProjectID();
|
||||||
|
}
|
||||||
this.result = this.$post("/custom/func/update", obj, () => {
|
this.result = this.$post("/custom/func/update", obj, () => {
|
||||||
this.$emit("refresh");
|
this.$emit("refresh");
|
||||||
this.$success(this.$t('commons.modify_success'));
|
this.$success(this.$t('commons.modify_success'));
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
export const FUNC_TEMPLATE = {
|
||||||
|
beanshell: "public static void test() {\n\n\n}",
|
||||||
|
groovy: "public static void test() {\n\n\n}",
|
||||||
|
python: "def test():\n",
|
||||||
|
nashornScript: "function test() {\n\n\n}",
|
||||||
|
rhinoScript: "function test() {\n\n\n}"
|
||||||
|
}
|
|
@ -1,49 +0,0 @@
|
||||||
export const FUNC_TEMPLATE = {
|
|
||||||
beanshell: "public static void test() {\n\n\n}",
|
|
||||||
groovy: "public static void test() {\n\n\n}",
|
|
||||||
python: "def test():\n",
|
|
||||||
nashornScript: "function test() {\n\n\n}",
|
|
||||||
rhinoScript: "function test() {\n\n\n}"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// 拼接函数
|
|
||||||
export function splicingCustomFunc(funcObj, funcParams) {
|
|
||||||
let funcLanguage = funcObj.type || "beanshell";
|
|
||||||
let funcObjScript = funcObj.script;
|
|
||||||
let funcName = funcObj.name;
|
|
||||||
let funcFirstLine = generateFuncFirstLine(funcLanguage, funcName, funcParams);
|
|
||||||
if (!funcObjScript && funcName) {
|
|
||||||
funcObjScript = funcLanguage === "python" ? funcFirstLine : funcFirstLine + "\n\n\n}";
|
|
||||||
}
|
|
||||||
if (funcObjScript) {
|
|
||||||
funcObjScript = funcObjScript.replace(regex[funcLanguage], funcFirstLine);
|
|
||||||
}
|
|
||||||
return funcObjScript;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function generateFuncFirstLine(funcLanguage, funcName, funcParams) {
|
|
||||||
let funcEnd = funcLanguage === "python" ? ":" : "{";
|
|
||||||
return scriptFuncDefinition[funcLanguage] + " " + funcName + "(" + funcParams + ") " + funcEnd;
|
|
||||||
}
|
|
||||||
|
|
||||||
const scriptFuncDefinition = {
|
|
||||||
beanshell: "public static void",
|
|
||||||
python: "def",
|
|
||||||
groovy: "public static void",
|
|
||||||
// nashornScript: "",
|
|
||||||
// rhinoScript: "",
|
|
||||||
}
|
|
||||||
|
|
||||||
const firstFuncRegex = RegExp(".*\(.*\)\\s\{\\r?");
|
|
||||||
const regex = {
|
|
||||||
beanshell: calcRegex(scriptFuncDefinition.beanshell),
|
|
||||||
python: RegExp("^def\\s.*\(.*\)\\s\:"),
|
|
||||||
groovy: calcRegex(scriptFuncDefinition.groovy),
|
|
||||||
// nashornScript: calcRegex(scriptFuncDefinition.nashornScript),
|
|
||||||
// rhinoScript: calcRegex(scriptFuncDefinition.rhinoScript),
|
|
||||||
}
|
|
||||||
|
|
||||||
function calcRegex(str) {
|
|
||||||
return RegExp("^" + str + "\\s.*\(.*\)\\s\{");
|
|
||||||
}
|
|
Loading…
Reference in New Issue