mirror of
https://github.com/foss42/apidash.git
synced 2025-08-06 13:51:20 +08:00
python http.client update
This commit is contained in:
@ -1,8 +1,7 @@
|
|||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'package:jinja/jinja.dart' as jj;
|
import 'package:jinja/jinja.dart' as jj;
|
||||||
import 'package:apidash/utils/utils.dart'
|
import 'package:apidash/utils/utils.dart' show getValidRequestUri;
|
||||||
show getValidRequestUri, padMultilineString;
|
|
||||||
import 'package:apidash/models/models.dart' show RequestModel;
|
import 'package:apidash/models/models.dart' show RequestModel;
|
||||||
import 'package:apidash/consts.dart';
|
import 'package:apidash/consts.dart';
|
||||||
|
|
||||||
@ -20,7 +19,6 @@ queryParams = {{params}}
|
|||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
""";
|
""";
|
||||||
int kParamsPadding = 14;
|
|
||||||
|
|
||||||
String kTemplateBody = """
|
String kTemplateBody = """
|
||||||
|
|
||||||
@ -36,8 +34,6 @@ headers = {{headers}}
|
|||||||
String kTemplateFormHeaderContentType = '''
|
String kTemplateFormHeaderContentType = '''
|
||||||
multipart/form-data; boundary={{boundary}}''';
|
multipart/form-data; boundary={{boundary}}''';
|
||||||
|
|
||||||
int kHeadersPadding = 10;
|
|
||||||
|
|
||||||
String kTemplateConnection = """
|
String kTemplateConnection = """
|
||||||
|
|
||||||
conn = http.client.HTTP{{isHttps}}Connection("{{authority}}")""";
|
conn = http.client.HTTP{{isHttps}}Connection("{{authority}}")""";
|
||||||
@ -116,43 +112,38 @@ body = b'\r\n'.join(dataList)
|
|||||||
hasQuery = true;
|
hasQuery = true;
|
||||||
var templateParams = jj.Template(kTemplateParams);
|
var templateParams = jj.Template(kTemplateParams);
|
||||||
var paramsString = kEncoder.convert(params);
|
var paramsString = kEncoder.convert(params);
|
||||||
paramsString = padMultilineString(paramsString, kParamsPadding);
|
|
||||||
result += templateParams.render({"params": paramsString});
|
result += templateParams.render({"params": paramsString});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var method = requestModel.method;
|
if (requestModel.hasData) {
|
||||||
var requestBody = requestModel.requestBody;
|
|
||||||
if (kMethodsWithBody.contains(method) &&
|
|
||||||
requestBody != null &&
|
|
||||||
!requestModel.hasFormData) {
|
|
||||||
var contentLength = utf8.encode(requestBody).length;
|
|
||||||
if (contentLength > 0) {
|
|
||||||
hasBody = true;
|
hasBody = true;
|
||||||
|
if (requestModel.hasJsonData || requestModel.hasTextData) {
|
||||||
var templateBody = jj.Template(kTemplateBody);
|
var templateBody = jj.Template(kTemplateBody);
|
||||||
result += templateBody.render({"body": requestBody});
|
result += templateBody.render({"body": requestModel.requestBody});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var headersList = requestModel.enabledRequestHeaders;
|
var headersList = requestModel.enabledRequestHeaders;
|
||||||
if (headersList != null || hasBody) {
|
if (headersList != null || hasBody) {
|
||||||
var headers = requestModel.enabledHeadersMap;
|
var headers = requestModel.enabledHeadersMap;
|
||||||
if (requestModel.hasFormData) {
|
|
||||||
var formHeaderTemplate =
|
|
||||||
jj.Template(kTemplateFormHeaderContentType);
|
|
||||||
headers[HttpHeaders.contentTypeHeader] = formHeaderTemplate.render({
|
|
||||||
"boundary": boundary,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (headers.isNotEmpty || hasBody) {
|
if (headers.isNotEmpty || hasBody) {
|
||||||
hasHeaders = true;
|
hasHeaders = true;
|
||||||
if (hasBody && !requestModel.hasContentTypeHeader) {
|
if (hasBody && !requestModel.hasContentTypeHeader) {
|
||||||
|
if (requestModel.hasJsonData || requestModel.hasTextData) {
|
||||||
headers[HttpHeaders.contentTypeHeader] =
|
headers[HttpHeaders.contentTypeHeader] =
|
||||||
requestModel.requestBodyContentType.header;
|
requestModel.requestBodyContentType.header;
|
||||||
|
} else if (requestModel.hasFormData) {
|
||||||
|
var formHeaderTemplate =
|
||||||
|
jj.Template(kTemplateFormHeaderContentType);
|
||||||
|
headers[HttpHeaders.contentTypeHeader] =
|
||||||
|
formHeaderTemplate.render({
|
||||||
|
"boundary": boundary,
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
var headersString = kEncoder.convert(headers);
|
var headersString = kEncoder.convert(headers);
|
||||||
headersString = padMultilineString(headersString, kHeadersPadding);
|
|
||||||
var templateHeaders = jj.Template(kTemplateHeaders);
|
var templateHeaders = jj.Template(kTemplateHeaders);
|
||||||
result += templateHeaders.render({"headers": headersString});
|
result += templateHeaders.render({"headers": headersString});
|
||||||
}
|
}
|
||||||
@ -174,7 +165,7 @@ body = b'\r\n'.join(dataList)
|
|||||||
|
|
||||||
var templateRequest = jj.Template(kTemplateRequest);
|
var templateRequest = jj.Template(kTemplateRequest);
|
||||||
result += templateRequest.render({
|
result += templateRequest.render({
|
||||||
"method": method.name.toUpperCase(),
|
"method": requestModel.method.name.toUpperCase(),
|
||||||
"path": uri.path,
|
"path": uri.path,
|
||||||
"queryParamsStr": hasQuery ? " + queryParamsStr" : "",
|
"queryParamsStr": hasQuery ? " + queryParamsStr" : "",
|
||||||
});
|
});
|
||||||
|
@ -30,7 +30,7 @@ from urllib.parse import urlencode
|
|||||||
|
|
||||||
queryParams = {
|
queryParams = {
|
||||||
"code": "US"
|
"code": "US"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
@ -53,7 +53,7 @@ from urllib.parse import urlencode
|
|||||||
|
|
||||||
queryParams = {
|
queryParams = {
|
||||||
"code": "IND"
|
"code": "IND"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
@ -80,7 +80,7 @@ queryParams = {
|
|||||||
"system": "SS",
|
"system": "SS",
|
||||||
"add_space": "true",
|
"add_space": "true",
|
||||||
"trailing_zeros": "true"
|
"trailing_zeros": "true"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
@ -102,7 +102,7 @@ print(data.decode("utf-8"))
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent"
|
"User-Agent": "Test Agent"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.github.com")
|
conn = http.client.HTTPSConnection("api.github.com")
|
||||||
conn.request("GET", "/repos/foss42/apidash",
|
conn.request("GET", "/repos/foss42/apidash",
|
||||||
@ -125,12 +125,12 @@ from urllib.parse import urlencode
|
|||||||
|
|
||||||
queryParams = {
|
queryParams = {
|
||||||
"raw": "true"
|
"raw": "true"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent"
|
"User-Agent": "Test Agent"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.github.com")
|
conn = http.client.HTTPSConnection("api.github.com")
|
||||||
conn.request("GET", "/repos/foss42/apidash" + queryParamsStr,
|
conn.request("GET", "/repos/foss42/apidash" + queryParamsStr,
|
||||||
@ -170,12 +170,12 @@ from urllib.parse import urlencode
|
|||||||
|
|
||||||
queryParams = {
|
queryParams = {
|
||||||
"raw": "true"
|
"raw": "true"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent"
|
"User-Agent": "Test Agent"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.github.com")
|
conn = http.client.HTTPSConnection("api.github.com")
|
||||||
conn.request("GET", "/repos/foss42/apidash" + queryParamsStr,
|
conn.request("GET", "/repos/foss42/apidash" + queryParamsStr,
|
||||||
@ -199,7 +199,7 @@ from urllib.parse import urlencode
|
|||||||
queryParams = {
|
queryParams = {
|
||||||
"num": "8700000",
|
"num": "8700000",
|
||||||
"add_space": "true"
|
"add_space": "true"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
@ -221,7 +221,7 @@ print(data.decode("utf-8"))
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent"
|
"User-Agent": "Test Agent"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("GET", "/humanize/social",
|
conn.request("GET", "/humanize/social",
|
||||||
@ -248,12 +248,12 @@ from urllib.parse import urlencode
|
|||||||
queryParams = {
|
queryParams = {
|
||||||
"num": "8700000",
|
"num": "8700000",
|
||||||
"digits": "3"
|
"digits": "3"
|
||||||
}
|
}
|
||||||
queryParamsStr = '?' + urlencode(queryParams)
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent"
|
"User-Agent": "Test Agent"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("GET", "/humanize/social" + queryParamsStr,
|
conn.request("GET", "/humanize/social" + queryParamsStr,
|
||||||
@ -334,7 +334,7 @@ body = r'''{
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"content-type": "text/plain"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/case/lower",
|
||||||
@ -366,7 +366,7 @@ body = r'''{
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "application/json"
|
"content-type": "application/json"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/case/lower",
|
||||||
@ -394,7 +394,7 @@ body = r'''{
|
|||||||
headers = {
|
headers = {
|
||||||
"User-Agent": "Test Agent",
|
"User-Agent": "Test Agent",
|
||||||
"content-type": "application/json"
|
"content-type": "application/json"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/case/lower",
|
||||||
@ -414,17 +414,38 @@ print(data.decode("utf-8"))
|
|||||||
|
|
||||||
test('POST 4', () {
|
test('POST 4', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
body = r'''{
|
from codecs import encode
|
||||||
"text": "I LOVE Flutter"
|
|
||||||
}'''
|
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"content-type": "multipart/form-data; boundary=b9826c20-773c-1f0c-814d-a1b3d90cd6b3"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--b9826c20-773c-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--b9826c20-773c-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"text","value":"API","type":"text"},{"name":"sep","value":"|","type":"text"},{"name":"times","value":"3","type":"text"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/form",
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -435,23 +456,46 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost4, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost4, "https",
|
||||||
|
boundary: "b9826c20-773c-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
test('POST 5', () {
|
test('POST 5', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
body = r'''{
|
from codecs import encode
|
||||||
"text": "I LOVE Flutter"
|
|
||||||
}'''
|
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"User-Agent": "Test Agent",
|
||||||
}
|
"content-type": "multipart/form-data; boundary=929dc910-7714-1f0c-814d-a1b3d90cd6b3"
|
||||||
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--929dc910-7714-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--929dc910-7714-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"text","value":"API","type":"text"},{"name":"sep","value":"|","type":"text"},{"name":"times","value":"3","type":"text"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/form",
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -462,23 +506,45 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost5, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost5, "https",
|
||||||
|
boundary: "929dc910-7714-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
test('POST 6', () {
|
test('POST 6', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
body = r'''{
|
from codecs import encode
|
||||||
"text": "I LOVE Flutter"
|
|
||||||
}'''
|
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"content-type": "multipart/form-data; boundary=9b1374c0-76e0-1f0c-814d-a1b3d90cd6b3"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--9b1374c0-76e0-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--9b1374c0-76e0-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"token","value":"xyz","type":"text"},{"name":"imfile","value":"/Documents/up/1.png","type":"file"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/img",
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -489,23 +555,45 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost6, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost6, "https",
|
||||||
|
boundary: "9b1374c0-76e0-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
test('POST 7', () {
|
test('POST 7', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
body = r'''{
|
from codecs import encode
|
||||||
"text": "I LOVE Flutter"
|
|
||||||
}'''
|
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"content-type": "multipart/form-data; boundary=defdf240-76b4-1f0c-814d-a1b3d90cd6b3"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--defdf240-76b4-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--defdf240-76b4-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"token","value":"xyz","type":"text"},{"name":"imfile","value":"/Documents/up/1.png","type":"file"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/img",
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -516,23 +604,52 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost7, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost7, "https",
|
||||||
|
boundary: "defdf240-76b4-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
test('POST 8', () {
|
test('POST 8', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
|
from codecs import encode
|
||||||
|
from urllib.parse import urlencode
|
||||||
|
|
||||||
body = r'''{
|
queryParams = {
|
||||||
"text": "I LOVE Flutter"
|
"size": "2",
|
||||||
}'''
|
"len": "3"
|
||||||
|
}
|
||||||
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"content-type": "multipart/form-data; boundary=a990b150-7683-1f0c-814d-a1b3d90cd6b3"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--a990b150-7683-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--a990b150-7683-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"text","value":"API","type":"text"},{"name":"sep","value":"|","type":"text"},{"name":"times","value":"3","type":"text"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/form" + queryParamsStr,
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -543,23 +660,54 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost8, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost8, "https",
|
||||||
|
boundary: "a990b150-7683-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
test('POST 9', () {
|
test('POST 9', () {
|
||||||
const expectedCode = r"""import http.client
|
const expectedCode = r"""import http.client
|
||||||
|
import mimetypes
|
||||||
|
from codecs import encode
|
||||||
|
from urllib.parse import urlencode
|
||||||
|
|
||||||
body = r'''{
|
queryParams = {
|
||||||
"text": "I LOVE Flutter"
|
"size": "2",
|
||||||
}'''
|
"len": "3"
|
||||||
|
}
|
||||||
|
queryParamsStr = '?' + urlencode(queryParams)
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "text/plain"
|
"User-Agent": "Test Agent",
|
||||||
}
|
"Keep-Alive": "true",
|
||||||
|
"content-type": "multipart/form-data; boundary=79088e00-75ec-1f0c-814d-a1b3d90cd6b3"
|
||||||
|
}
|
||||||
|
|
||||||
|
def build_data_list(fields):
|
||||||
|
dataList = []
|
||||||
|
for field in fields:
|
||||||
|
name = field.get('name', '')
|
||||||
|
value = field.get('value', '')
|
||||||
|
type_ = field.get('type', 'text')
|
||||||
|
dataList.append(encode('--79088e00-75ec-1f0c-814d-a1b3d90cd6b3'))
|
||||||
|
if type_ == 'text':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"'))
|
||||||
|
dataList.append(encode('Content-Type: text/plain'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(encode(value))
|
||||||
|
elif type_ == 'file':
|
||||||
|
dataList.append(encode(f'Content-Disposition: form-data; name="{name}"; filename="{value}"'))
|
||||||
|
dataList.append(encode(f'Content-Type: {mimetypes.guess_type(value)[0] or "application/octet-stream"}'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
dataList.append(open(value, 'rb').read())
|
||||||
|
dataList.append(encode(f'--79088e00-75ec-1f0c-814d-a1b3d90cd6b3--'))
|
||||||
|
dataList.append(encode(''))
|
||||||
|
return dataList
|
||||||
|
|
||||||
|
dataList = build_data_list([{"name":"token","value":"xyz","type":"text"},{"name":"imfile","value":"/Documents/up/1.png","type":"file"}])
|
||||||
|
body = b'\r\n'.join(dataList)
|
||||||
conn = http.client.HTTPSConnection("api.apidash.dev")
|
conn = http.client.HTTPSConnection("api.apidash.dev")
|
||||||
conn.request("POST", "/case/lower",
|
conn.request("POST", "/io/img" + queryParamsStr,
|
||||||
body= body,
|
body= body,
|
||||||
headers= headers)
|
headers= headers)
|
||||||
|
|
||||||
@ -570,10 +718,11 @@ print(data.decode("utf-8"))
|
|||||||
""";
|
""";
|
||||||
expect(
|
expect(
|
||||||
codeGen.getCode(
|
codeGen.getCode(
|
||||||
CodegenLanguage.pythonHttpClient, requestModelPost9, "https"),
|
CodegenLanguage.pythonHttpClient, requestModelPost9, "https",
|
||||||
|
boundary: "79088e00-75ec-1f0c-814d-a1b3d90cd6b3"),
|
||||||
expectedCode);
|
expectedCode);
|
||||||
});
|
});
|
||||||
}, skip: true);
|
});
|
||||||
|
|
||||||
group('PUT Request', () {
|
group('PUT Request', () {
|
||||||
test('PUT 1', () {
|
test('PUT 1', () {
|
||||||
@ -586,7 +735,7 @@ body = r'''{
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "application/json"
|
"content-type": "application/json"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("reqres.in")
|
conn = http.client.HTTPSConnection("reqres.in")
|
||||||
conn.request("PUT", "/api/users/2",
|
conn.request("PUT", "/api/users/2",
|
||||||
@ -616,7 +765,7 @@ body = r'''{
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "application/json"
|
"content-type": "application/json"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("reqres.in")
|
conn = http.client.HTTPSConnection("reqres.in")
|
||||||
conn.request("PATCH", "/api/users/2",
|
conn.request("PATCH", "/api/users/2",
|
||||||
@ -663,7 +812,7 @@ body = r'''{
|
|||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"content-type": "application/json"
|
"content-type": "application/json"
|
||||||
}
|
}
|
||||||
|
|
||||||
conn = http.client.HTTPSConnection("reqres.in")
|
conn = http.client.HTTPSConnection("reqres.in")
|
||||||
conn.request("DELETE", "/api/users/2",
|
conn.request("DELETE", "/api/users/2",
|
||||||
|
Reference in New Issue
Block a user