This commit is contained in:
Ankit Mahato
2024-03-14 03:11:53 +05:30
parent f9bb3f54ea
commit 872c5a5cd3
3 changed files with 96 additions and 75 deletions

View File

@ -65,7 +65,7 @@ class Codegen {
return RustUreqCodeGen().getCode(rM, boundary: boundary); return RustUreqCodeGen().getCode(rM, boundary: boundary);
case CodegenLanguage.goHttp: case CodegenLanguage.goHttp:
return GoHttpCodeGen().getCode(rM); return GoHttpCodeGen().getCode(rM);
case CodegenLanguage.juliaHttpRequests: case CodegenLanguage.juliaHttp:
return JuliaHttpClientCodeGen().getCode(rM); return JuliaHttpClientCodeGen().getCode(rM);
} }
} }

View File

@ -9,7 +9,6 @@ import 'package:apidash/models/models.dart' show RequestModel;
class JuliaHttpClientCodeGen { class JuliaHttpClientCodeGen {
final String kTemplateStart = """using HTTP,JSON final String kTemplateStart = """using HTTP,JSON
url = "{{url}}" url = "{{url}}"
"""; """;
@ -96,10 +95,7 @@ println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
String? getCode( String? getCode(RequestModel requestModel) {
RequestModel requestModel,
String defaultUriScheme,
) {
try { try {
String result = ""; String result = "";
bool hasQuery = false; bool hasQuery = false;
@ -108,13 +104,8 @@ println("Response Body:", String(response.body))
bool hasJsonBody = false; bool hasJsonBody = false;
String uuid = getNewUuid(); String uuid = getNewUuid();
String url = requestModel.url;
if (!url.contains("://") && url.isNotEmpty) {
url = "$defaultUriScheme://$url";
}
var rec = getValidRequestUri( var rec = getValidRequestUri(
url, requestModel.url,
requestModel.enabledRequestParams, requestModel.enabledRequestParams,
); );
Uri? uri = rec.$1; Uri? uri = rec.$1;
@ -122,7 +113,6 @@ println("Response Body:", String(response.body))
var templateStartUrl = jj.Template(kTemplateStart); var templateStartUrl = jj.Template(kTemplateStart);
result += templateStartUrl.render({ result += templateStartUrl.render({
"url": stripUriParams(uri), "url": stripUriParams(uri),
'isFormDataRequest': requestModel.isFormDataRequest
}); });
if (uri.hasQuery) { if (uri.hasQuery) {
@ -136,27 +126,20 @@ println("Response Body:", String(response.body))
} }
} }
var method = requestModel.method; if (requestModel.hasJsonData) {
var requestBody = requestModel.requestBody; hasJsonBody = true;
if (kMethodsWithBody.contains(method) && requestBody != null) { var templateBody = jj.Template(kTemplateJson);
var contentLength = utf8.encode(requestBody).length; result += templateBody.render({"body": requestModel.requestBody});
if (contentLength > 0) { } else if (requestModel.hasTextData) {
if (requestModel.requestBodyContentType == ContentType.json) { hasBody = true;
hasJsonBody = true; var templateBody = jj.Template(kTemplateBody);
var templateBody = jj.Template(kTemplateJson); result += templateBody.render({"body": requestModel.requestBody});
result += templateBody.render({"body": requestBody});
} else {
hasBody = true;
var templateBody = jj.Template(kTemplateBody);
result += templateBody.render({"body": 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.isFormDataRequest) { if (requestModel.hasFormData) {
var formHeaderTemplate = var formHeaderTemplate =
jj.Template(kTemplateFormHeaderContentType); jj.Template(kTemplateFormHeaderContentType);
headers[HttpHeaders.contentTypeHeader] = formHeaderTemplate.render({ headers[HttpHeaders.contentTypeHeader] = formHeaderTemplate.render({
@ -175,7 +158,7 @@ println("Response Body:", String(response.body))
result += templateHeaders.render({"headers": headersString}); result += templateHeaders.render({"headers": headersString});
} }
} }
if (requestModel.isFormDataRequest) { if (requestModel.hasFormData) {
var formDataBodyData = jj.Template(kStringFormDataBody); var formDataBodyData = jj.Template(kStringFormDataBody);
result += formDataBodyData.render( result += formDataBodyData.render(
{ {
@ -186,22 +169,22 @@ println("Response Body:", String(response.body))
} }
var templateRequest = jj.Template(kTemplateRequest); var templateRequest = jj.Template(kTemplateRequest);
result += templateRequest.render({ result += templateRequest.render({
"method": method.name.toLowerCase(), "method": requestModel.method.name.toLowerCase(),
}); });
if (hasQuery) { if (hasQuery) {
result += kStringRequestParams; result += kStringRequestParams;
} }
if (hasBody || requestModel.isFormDataRequest) { if (hasBody || requestModel.hasFormData) {
result += kStringRequestBody; result += kStringRequestBody;
} }
if (hasJsonBody || requestModel.isFormDataRequest) { if (hasJsonBody || requestModel.hasFormData) {
result += kStringRequestJson; result += kStringRequestJson;
} }
if (hasHeaders || requestModel.isFormDataRequest) { if (hasHeaders || requestModel.hasFormData) {
result += kStringRequestHeaders; result += kStringRequestHeaders;
} }

View File

@ -1,15 +1,16 @@
import 'package:apidash/codegen/julia/http.dart'; import 'package:apidash/codegen/codegen.dart';
import '../request_models.dart'; import 'package:apidash/consts.dart';
import 'package:test/test.dart'; import 'package:test/test.dart';
import '../request_models.dart';
void main() { void main() {
final juliaHttpClientCodeGen = JuliaHttpClientCodeGen(); final codeGen = Codegen();
group('GET Request', () { group('GET Request', () {
test('GET 1', () { test('GET 1', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com" url = "https://api.apidash.dev"
response = HTTP.get(url) response = HTTP.get(url)
@ -17,13 +18,14 @@ response = HTTP.get(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet1, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet1, "https"),
expectedCode); expectedCode);
}); });
test('GET 2', () { test('GET 2', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/country/data" url = "https://api.apidash.dev/country/data"
params = Dict( params = Dict(
@ -35,13 +37,14 @@ response = HTTP.get(url, query=params)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet2, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet2, "https"),
expectedCode); expectedCode);
}); });
test('GET 3', () { test('GET 3', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/country/data" url = "https://api.apidash.dev/country/data"
params = Dict( params = Dict(
@ -53,13 +56,14 @@ response = HTTP.get(url, query=params)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet3, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet3, "https"),
expectedCode); expectedCode);
}); });
test('GET 4', () { test('GET 4', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/humanize/social" url = "https://api.apidash.dev/humanize/social"
params = Dict( params = Dict(
@ -75,7 +79,8 @@ response = HTTP.get(url, query=params)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet4, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet4, "https"),
expectedCode); expectedCode);
}); });
@ -94,7 +99,8 @@ response = HTTP.get(url, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet5, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet5, "https"),
expectedCode); expectedCode);
}); });
@ -117,14 +123,15 @@ response = HTTP.get(url, query=params, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet6, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet6, "https"),
expectedCode); expectedCode);
}); });
test('GET 7', () { test('GET 7', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com" url = "https://api.apidash.dev"
response = HTTP.get(url) response = HTTP.get(url)
@ -132,7 +139,8 @@ response = HTTP.get(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet7, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet7, "https"),
expectedCode); expectedCode);
}); });
@ -155,14 +163,15 @@ response = HTTP.get(url, query=params, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet8, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet8, "https"),
expectedCode); expectedCode);
}); });
test('GET 9', () { test('GET 9', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/humanize/social" url = "https://api.apidash.dev/humanize/social"
params = Dict( params = Dict(
@ -175,14 +184,15 @@ response = HTTP.get(url, query=params)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet9, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelGet9, "https"),
expectedCode); expectedCode);
}); });
test('GET 10', () { test('GET 10', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/humanize/social" url = "https://api.apidash.dev/humanize/social"
headers = Dict( headers = Dict(
@ -194,14 +204,16 @@ response = HTTP.get(url, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet10, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelGet10, "https"),
expectedCode); expectedCode);
}); });
test('GET 11', () { test('GET 11', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/humanize/social" url = "https://api.apidash.dev/humanize/social"
params = Dict( params = Dict(
@ -218,14 +230,16 @@ response = HTTP.get(url, query=params, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet11, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelGet11, "https"),
expectedCode); expectedCode);
}); });
test('GET 12', () { test('GET 12', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/humanize/social" url = "https://api.apidash.dev/humanize/social"
response = HTTP.get(url) response = HTTP.get(url)
@ -233,7 +247,9 @@ response = HTTP.get(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelGet12, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelGet12, "https"),
expectedCode); expectedCode);
}); });
}); });
@ -242,7 +258,7 @@ println("Response Body:", String(response.body))
test('HEAD 1', () { test('HEAD 1', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com" url = "https://api.apidash.dev"
response = HTTP.head(url) response = HTTP.head(url)
@ -250,14 +266,16 @@ response = HTTP.head(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelHead1, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelHead1, "https"),
expectedCode); expectedCode);
}); });
test('HEAD 2', () { test('HEAD 2', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com" url = "https://api.apidash.dev"
response = HTTP.head(url) response = HTTP.head(url)
@ -265,7 +283,9 @@ response = HTTP.head(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelHead2, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelHead2, "https"),
expectedCode); expectedCode);
}); });
}); });
@ -274,7 +294,7 @@ println("Response Body:", String(response.body))
test('POST 1', () { test('POST 1', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/case/lower" url = "https://api.apidash.dev/case/lower"
payload = Dict( payload = Dict(
@ -290,18 +310,25 @@ response = HTTP.post(url, payload=payload, headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelPost1, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelPost1, "https"),
expectedCode); expectedCode);
}); });
test('POST 2', () { test('POST 2', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/case/lower" url = "https://api.apidash.dev/case/lower"
payload = Dict( payload = Dict(
"text"=> "I LOVE Flutter" "text"=> "I LOVE Flutter",
"flag"=> null,
"male"=> true,
"female"=> false,
"no"=> 1.2,
"arr"=> ["null", "true", "false", null]
) )
response = HTTP.post(url, JSON.json(payload)) response = HTTP.post(url, JSON.json(payload))
@ -309,13 +336,15 @@ response = HTTP.post(url, JSON.json(payload))
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelPost2, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelPost2, "https"),
expectedCode); expectedCode);
}); });
test('POST 3', () { test('POST 3', () {
const expectedCode = r"""using HTTP,JSON const expectedCode = r"""using HTTP,JSON
url = "https://api.foss42.com/case/lower" url = "https://api.apidash.dev/case/lower"
payload = Dict( payload = Dict(
@ -331,7 +360,9 @@ response = HTTP.post(url, JSON.json(payload), headers=headers)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelPost3, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelPost3, "https"),
expectedCode); expectedCode);
}); });
}); });
@ -352,7 +383,8 @@ response = HTTP.put(url, JSON.json(payload))
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelPut1, "https"), expect(
codeGen.getCode(CodegenLanguage.juliaHttp, requestModelPut1, "https"),
expectedCode); expectedCode);
}); });
}); });
@ -373,7 +405,9 @@ response = HTTP.patch(url, JSON.json(payload))
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelPatch1, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelPatch1, "https"),
expectedCode); expectedCode);
}); });
}); });
@ -389,7 +423,9 @@ response = HTTP.delete(url)
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelDelete1, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelDelete1, "https"),
expectedCode); expectedCode);
}); });
test('DELETE 2', () { test('DELETE 2', () {
@ -408,7 +444,9 @@ response = HTTP.delete(url, JSON.json(payload))
println("Status Code:", response.status) println("Status Code:", response.status)
println("Response Body:", String(response.body)) println("Response Body:", String(response.body))
"""; """;
expect(juliaHttpClientCodeGen.getCode(requestModelDelete2, "https"), expect(
codeGen.getCode(
CodegenLanguage.juliaHttp, requestModelDelete2, "https"),
expectedCode); expectedCode);
}); });
}); });