From f3edafc569fa5bbe03056be42a66941e34334f6d Mon Sep 17 00:00:00 2001 From: Joseph Birkner Date: Mon, 15 Jul 2024 17:17:28 +0200 Subject: [PATCH] Add test for serverIndex. --- libs/pyzswagcl/py-openapi-client.cpp | 3 +-- libs/zswag/test/calc/client.py | 2 +- libs/zswag/test/client.cpp | 30 ++++++++++++----------- libs/zswagcl/include/zswagcl/oaclient.hpp | 5 ++-- libs/zswagcl/src/oaclient.cpp | 5 ++-- 5 files changed, 24 insertions(+), 21 deletions(-) diff --git a/libs/pyzswagcl/py-openapi-client.cpp b/libs/pyzswagcl/py-openapi-client.cpp index 5b5fe0c..cb06d99 100644 --- a/libs/pyzswagcl/py-openapi-client.cpp +++ b/libs/pyzswagcl/py-openapi-client.cpp @@ -97,8 +97,7 @@ PyOpenApiClient::PyOpenApiClient(std::string const& openApiUrl, std::ifstream fs(openApiUrl); return parseOpenAPIConfig(fs); } - else - return fetchOpenAPIConfig(openApiUrl, *httpClient, httpConfig); + return fetchOpenAPIConfig(openApiUrl, *httpClient, httpConfig); }(); client_ = std::make_unique( diff --git a/libs/zswag/test/calc/client.py b/libs/zswag/test/calc/client.py index e6b984b..d47eac7 100644 --- a/libs/zswag/test/calc/client.py +++ b/libs/zswag/test/calc/client.py @@ -21,7 +21,7 @@ def run_test(aspect, request, fn, expect, auth_args): try: print(f"[py-test-client] Test#{counter}: {aspect}", flush=True) print(f"[py-test-client] -> Instantiating client.", flush=True) - oa_client = OAClient(f"http://{host}:{port}/openapi.json", **auth_args) + oa_client = OAClient(f"http://{host}:{port}/openapi.json", **auth_args, server_index=0) # Just make sure that OpenAPI JSON content is parsable assert oa_client.config().content and json.loads(oa_client.config().content) client = api.Calculator.Client(oa_client) diff --git a/libs/zswag/test/client.cpp b/libs/zswag/test/client.cpp index 8b32d18..7df0032 100644 --- a/libs/zswag/test/client.cpp +++ b/libs/zswag/test/client.cpp @@ -19,7 +19,7 @@ int main (int argc, char* argv[]) { spdlog::info("[cpp-test-client] Starting integration tests with {}", specUrl); - auto runTest = [&] (auto const& fn, auto expect, std::string const& aspect, std::function const& authFun) + auto runTest = [&] (auto const& fn, auto expect, std::string const& aspect, std::function const& authFun) { ++testCounter; spdlog::info("[cpp-test-client] Executing test #{}: {} ...", testCounter, aspect); @@ -28,9 +28,11 @@ int main (int argc, char* argv[]) { spdlog::info("[cpp-test-client] => Instantiating client."); auto httpClient = std::make_unique(); auto openApiConfig = fetchOpenAPIConfig(specUrl, *httpClient); - httpcl::Config authHttpConf; + // See https://github.com/spec-first/connexion/issues/1139 + openApiConfig.servers.insert(openApiConfig.servers.begin(), URIComponents::fromStrPath("/bad/path/we/dont/access")); + Config authHttpConf; authFun(authHttpConf); - auto oaClient = OAClient(openApiConfig, std::move(httpClient), authHttpConf); + auto oaClient = OAClient(openApiConfig, std::move(httpClient), authHttpConf, 1); spdlog::info("[cpp-test-client] => Running request."); calculator::Calculator::Client calcClient(oaClient); auto response = fn(calcClient); @@ -49,13 +51,13 @@ int main (int argc, char* argv[]) { calculator::BaseAndExponent req(calculator::I32(2), calculator::I32(3), 0, "", .0, std::vector{}); return calcClient.powerMethod(req); }, 8., "Pass fields in path and header", - [](httpcl::Config& conf){}); + [](Config& conf){}); runTest([](calculator::Calculator::Client& calcClient){ calculator::Integers req(std::vector{100, -200, 400}); return calcClient.intSumMethod(req); }, 300., "Pass hex-encoded array in query", - [](httpcl::Config& conf){ + [](Config& conf){ conf.headers.insert({"Authorization", "Bearer 123"}); }); @@ -63,8 +65,8 @@ int main (int argc, char* argv[]) { calculator::Bytes req(std::vector{8, 16, 32, 64}); return calcClient.byteSumMethod(req); }, 120., "Pass base64url-encoded byte array in path", - [](httpcl::Config& conf){ - conf.auth = httpcl::Config::BasicAuthentication{ + [](Config& conf){ + conf.auth = Config::BasicAuthentication{ "u", "pw", "" }; }); @@ -73,7 +75,7 @@ int main (int argc, char* argv[]) { calculator::Integers req(std::vector{1, 2, 3, 4}); return calcClient.intMulMethod(req); }, 24., "Pass base64-encoded long array in path", - [](httpcl::Config& conf){ + [](Config& conf){ conf.query.insert({"api-key", "42"}); }); @@ -81,7 +83,7 @@ int main (int argc, char* argv[]) { calculator::Doubles req(std::vector{34.5, 2.}); return calcClient.floatMulMethod(req); }, 69., "Pass float array in query.", - [](httpcl::Config& conf){ + [](Config& conf){ conf.cookies.insert({"api-cookie", "42"}); }); @@ -89,7 +91,7 @@ int main (int argc, char* argv[]) { calculator::Bools req(std::vector{true, false}); return calcClient.bitMulMethod(req); }, false, "Pass bool array in query (expect false).", - [](httpcl::Config& conf){ + [](Config& conf){ conf.apiKey = "42"; }); @@ -97,7 +99,7 @@ int main (int argc, char* argv[]) { calculator::Bools req(std::vector{true, true}); return calcClient.bitMulMethod(req); }, true, "Pass bool array in query (expect true).", - [](httpcl::Config& conf){ + [](Config& conf){ conf.headers.insert({"X-Generic-Token", "42"}); }); @@ -105,7 +107,7 @@ int main (int argc, char* argv[]) { calculator::Double req(1.); return calcClient.identityMethod(req); }, 1., "Pass request as blob in body", - [](httpcl::Config& conf){ + [](Config& conf){ conf.cookies.insert({"api-cookie", "42"}); }); @@ -113,7 +115,7 @@ int main (int argc, char* argv[]) { calculator::Strings req(std::vector{"foo", "bar"}); return calcClient.concatMethod(req); }, std::string("foobar"), "Pass base64-encoded strings.", - [](httpcl::Config& conf){ + [](Config& conf){ conf.headers.insert({"Authorization", "Bearer 123"}); }); @@ -121,7 +123,7 @@ int main (int argc, char* argv[]) { calculator::EnumWrapper req(calculator::Enum::TEST_ENUM_0); return calcClient.nameMethod(req); }, std::string("TEST_ENUM_0"), "Pass enum.", - [](httpcl::Config& conf){ + [](Config& conf){ conf.apiKey = "42"; }); diff --git a/libs/zswagcl/include/zswagcl/oaclient.hpp b/libs/zswagcl/include/zswagcl/oaclient.hpp index 66b6b5b..3b00a33 100644 --- a/libs/zswagcl/include/zswagcl/oaclient.hpp +++ b/libs/zswagcl/include/zswagcl/oaclient.hpp @@ -12,9 +12,10 @@ class OAClient : public ::zserio::IServiceClient { public: OAClient( - zswagcl::OpenAPIConfig config, + OpenAPIConfig config, std::unique_ptr client, - httpcl::Config httpConfig = {}); + httpcl::Config httpConfig = {}, + uint32_t serverIndex = 0); std::vector callMethod( zserio::StringView methodName, diff --git a/libs/zswagcl/src/oaclient.cpp b/libs/zswagcl/src/oaclient.cpp index b539d3d..85a1e1f 100644 --- a/libs/zswagcl/src/oaclient.cpp +++ b/libs/zswagcl/src/oaclient.cpp @@ -9,8 +9,9 @@ namespace zswagcl OAClient::OAClient(zswagcl::OpenAPIConfig config, std::unique_ptr client, - httpcl::Config httpConfig) - : client_(std::move(config), std::move(httpConfig), std::move(client)) + httpcl::Config httpConfig, + uint32_t serverIndex) + : client_(std::move(config), std::move(httpConfig), std::move(client), serverIndex) {} template