From 4c4200b2946398648ad9e06fe64da390cc93f77b Mon Sep 17 00:00:00 2001 From: song-tianyang Date: Tue, 14 Jun 2022 12:23:47 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E9=A1=B9=E7=9B=AE=E8=AE=BE=E7=BD=AE):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E8=87=AA=E5=AE=9A=E4=B9=89=E4=BB=A3=E7=A0=81?= =?UTF-8?q?=E7=89=87=E6=AE=B5=E4=BB=8Eapi=E5=AE=9A=E4=B9=89=E5=AF=BC?= =?UTF-8?q?=E5=85=A5=E4=B8=8D=E4=BC=9A=E8=A1=A5=E5=85=85=E8=AF=B7=E6=B1=82?= =?UTF-8?q?=E4=BD=93=E5=8F=82=E6=95=B0=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1013992 --user=宋天阳 【接口测试】GitHub#14178,创建代码片段,从API定义导入,导入的代码没有自动填充请求体参数 https://www.tapd.cn/55049933/s/1180685 --- .../mock/Components/MockScriptNavMenu.vue | 12 +- .../project/menu/function/ScriptNavMenu.vue | 21 +++- .../project/menu/function/custom-function.js | 109 +++++++++++++++--- 3 files changed, 119 insertions(+), 23 deletions(-) diff --git a/frontend/src/business/components/api/definition/components/mock/Components/MockScriptNavMenu.vue b/frontend/src/business/components/api/definition/components/mock/Components/MockScriptNavMenu.vue index 9938531d62..59a928fa19 100644 --- a/frontend/src/business/components/api/definition/components/mock/Components/MockScriptNavMenu.vue +++ b/frontend/src/business/components/api/definition/components/mock/Components/MockScriptNavMenu.vue @@ -110,6 +110,8 @@ export default { let requestRest = new Map(); let requestMethod = ""; let requestBody = ""; + let requestBodyKvs = new Map(); + let bodyType = ""; let requestPath = ""; let request = JSON.parse(data.request); // 拼接发送请求需要的参数 @@ -142,8 +144,16 @@ export default { let body = request.body; if (body.json) { requestBody = body.raw; + bodyType = "json"; + } else if (body.kvs) { + bodyType = "kvs"; + body.kvs.forEach(arg => { + if (arg.name) { + requestBodyKvs.set(arg.name, arg.value); + } + }) } - return {requestPath, requestHeaders, requestMethod, requestBody, requestArguments, requestRest} + return {requestPath, requestHeaders, requestMethod, requestBody, requestBodyKvs, bodyType, requestArguments, requestRest} }, apiClose() { diff --git a/frontend/src/business/components/project/menu/function/ScriptNavMenu.vue b/frontend/src/business/components/project/menu/function/ScriptNavMenu.vue index 300f80ecbd..6e527cc350 100644 --- a/frontend/src/business/components/project/menu/function/ScriptNavMenu.vue +++ b/frontend/src/business/components/project/menu/function/ScriptNavMenu.vue @@ -11,20 +11,23 @@ - {{menu.title}} + {{ menu.title }}
- {{child.title}} + + {{ child.title }} +
- + @@ -117,6 +120,8 @@ export default { let requestRest = new Map(); let requestMethod = ""; let requestBody = ""; + let requestBodyKvs = new Map(); + let bodyType = ""; let requestPath = ""; let request = JSON.parse(data.request); // 拼接发送请求需要的参数 @@ -149,8 +154,16 @@ export default { let body = request.body; if (body.json) { requestBody = body.raw; + bodyType = "json"; + } else if (body.kvs) { + bodyType = "kvs"; + body.kvs.forEach(arg => { + if (arg.name) { + requestBodyKvs.set(arg.name, arg.value); + } + }) } - return {requestPath, requestHeaders, requestMethod, requestBody, requestArguments, requestRest} + return {requestPath, requestHeaders, requestMethod, requestBody, requestBodyKvs, bodyType, requestArguments, requestRest} }, apiClose() { diff --git a/frontend/src/business/components/project/menu/function/custom-function.js b/frontend/src/business/components/project/menu/function/custom-function.js index 01ed36881a..e3f271d1de 100644 --- a/frontend/src/business/components/project/menu/function/custom-function.js +++ b/frontend/src/business/components/project/menu/function/custom-function.js @@ -25,8 +25,10 @@ export function getCodeTemplate(language, requestObj) { } function groovyCode(requestObj) { - let {requestHeaders = new Map(), requestBody = "", requestPath = "", - requestMethod = "", host = "", protocol = "", requestArguments = new Map(), requestRest = new Map()} = requestObj; + let { + requestHeaders = new Map(), requestBody = "", requestPath = "", + requestMethod = "", host = "", protocol = "", requestArguments = new Map(), requestRest = new Map() + } = requestObj; let requestUrl = ""; requestPath = getRequestPath(requestArguments, requestPath); requestPath = replaceRestParams(requestPath, requestRest); @@ -40,8 +42,18 @@ function groovyCode(requestObj) { } function pythonCode(requestObj) { - let {requestHeaders = new Map(), requestBody = "", requestPath = "/", - requestMethod = "", host = "", protocol = "http", requestArguments = new Map(), requestRest = new Map()} = requestObj; + let { + requestHeaders = new Map(), + requestBody = "", + requestPath = "/", + requestMethod = "", + host = "", + protocol = "http", + requestArguments = new Map(), + requestBodyKvs = new Map(), + bodyType, + requestRest = new Map() + } = requestObj; let connType = "HTTPConnection"; if (protocol === 'https') { connType = "HTTPSConnection"; @@ -50,7 +62,7 @@ function pythonCode(requestObj) { requestBody = requestBody ? JSON.stringify(requestBody) : "{}"; requestPath = getRequestPath(requestArguments, requestPath); requestPath = replaceRestParams(requestPath, requestRest); - let obj = {requestBody, headers, host, requestPath, requestMethod, connType}; + let obj = {requestBody, headers, host, requestPath, requestMethod, requestBodyKvs, bodyType, connType}; return _pythonCodeTemplate(obj); } @@ -86,17 +98,27 @@ function getHeaders(requestHeaders) { } // 拼装 headers += `'${k}':'${v}'`; - index ++; + index++; } headers = headers + "}" return headers; } function _pythonCodeTemplate(obj) { - let {requestBody, headers, host, requestPath, requestMethod, connType} = obj; - return `import httplib -params = ${requestBody} #例 {'username':'test'} -headers = ${headers} #例 {'Content-Type':'application/json'} + let {requestBody, requestBodyKvs, bodyType, headers, host, requestPath, requestMethod, connType} = obj; + let reqBody = obj.requestBody; + if (obj.bodyType !== 'json' && obj.requestBodyKvs) { + reqBody = 'urllib.urlencode({'; + // 设置post参数 + for (let [k, v] of requestBodyKvs) { + reqBody += `\'${k}\':\'${v}\'`; + } + reqBody += `})`; + } + + return `import httplib,urllib +params = ${reqBody} #例 {'username':'test'} +headers = ${headers} #例 {'Content-Type':'application/json'} 或 {'Content-type': 'application/x-www-form-urlencoded', 'Accept': 'text/plain'} host = '${host}' path = '${requestPath}' method = '${requestMethod}' # POST/GET @@ -111,7 +133,7 @@ log.info(data) function _groovyCodeTemplate(obj) { let {requestUrl, requestMethod, headers, body} = obj; - let params = `[ + let params = `[ 'url': '${requestUrl}', 'method': '${requestMethod}', // POST/GET 'headers': ${headers}, // 请求headers 例:{'Content-type':'application/json'} @@ -143,8 +165,20 @@ log.info(conn.content.text) } function _beanshellTemplate(obj) { - let {requestHeaders = new Map(), requestBody = "", requestPath = "/", - requestMethod = "GET", protocol = "http", requestArguments = new Map(), domain = "", port = "", requestRest = new Map()} = obj; + let { + requestHeaders = new Map(), + requestBody = "", + requestBodyKvs = new Map(), + bodyType = "", + requestPath = "/", + requestMethod = "GET", + protocol = "http", + requestArguments = new Map(), + domain = "", + port = "", + requestRest = new Map() + } = obj; + requestPath = replaceRestParams(requestPath, requestRest); let uri = `new URIBuilder() .setScheme("${protocol}") @@ -158,6 +192,21 @@ function _beanshellTemplate(obj) { for (let [k, v] of requestArguments) { uri = uri + `.setParameter("${k}", "${v}")`; } + + + let postKvsParam = ""; + if (method === 'Post') { + // 设置post参数 + for (let [k, v] of requestBodyKvs) { + postKvsParam += ` + nameValueList.add(new BasicNameValuePair("${k}", "${v}"));\r\n`; + } + if (postKvsParam !== "") { + postKvsParam = ` + List nameValueList = new ArrayList();\r\n` + postKvsParam; + } + } + if (port) { uri += `.setPort(${port}) // int类型端口 `; @@ -170,16 +219,26 @@ function _beanshellTemplate(obj) { // 设置请求头 let setHeader = ""; for (let [k, v] of requestHeaders) { - setHeader = setHeader + `request.setHeader("${k}", "${v}");` +'\n'; + setHeader = setHeader + `request.setHeader("${k}", "${v}");` + '\n'; } try { requestBody = JSON.stringify(requestBody); } catch (e) { requestBody = ""; } + let postMethodCode = ""; + if (requestMethod === "POST") { + if (bodyType === "json") { + postMethodCode = ` + request.setEntity(new StringEntity(StringEscapeUtils.unescapeJava(payload))); + `; + } else { + postMethodCode = postKvsParam + "\r\n" + ` + request.setEntity(new UrlEncodedFormEntity(nameValueList, "UTF-8")); + `; + } + } - let postMethodCode = requestMethod === "POST" ? - `request.setEntity(new StringEntity(StringEscapeUtils.unescapeJava(payload)));` : ""; return `import java.net.URI; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.*; @@ -190,6 +249,11 @@ import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import org.apache.http.entity.StringEntity; +import java.util. *; +import org.apache.http.NameValuePair; +import org.apache.http.message.BasicNameValuePair; +import org.apache.http.client.entity.UrlEncodedFormEntity; + // 创建Httpclient对象 CloseableHttpClient httpclient = HttpClients.createDefault(); // 参数 @@ -213,8 +277,17 @@ if (response.getStatusLine().getStatusCode() == 200) { } function _jsTemplate(obj) { - let {requestHeaders = new Map(), requestBody = "", requestPath = "/", - requestMethod = "GET", protocol = "http", requestArguments = new Map(), domain = "", port = "", requestRest = new Map()} = obj; + let { + requestHeaders = new Map(), + requestBody = "", + requestPath = "/", + requestMethod = "GET", + protocol = "http", + requestArguments = new Map(), + domain = "", + port = "", + requestRest = new Map() + } = obj; let url = ""; requestPath = replaceRestParams(requestPath, requestRest); if (protocol && domain && port) {