add script to create kubernetes_asyncio python client (#60)
* feat: package named kubernetes_asyncio * feat: fix rest client * fix: patch rest client to support strategic-merge-patch+json * fix: docs, move patch to ext. file
This commit is contained in:
committed by
Brendan Burns
parent
9a2dd07e0c
commit
55f9ae0366
29
openapi/python-asyncio-rest.py.patch
Normal file
29
openapi/python-asyncio-rest.py.patch
Normal file
@@ -0,0 +1,29 @@
|
||||
21a22,23
|
||||
> import asyncio
|
||||
>
|
||||
81a84,86
|
||||
> def __del__(self):
|
||||
> asyncio.ensure_future(self.pool_manager.close())
|
||||
>
|
||||
130a136,138
|
||||
> if headers['Content-Type'] == 'application/json-patch+json':
|
||||
> if not isinstance(body, list):
|
||||
> headers['Content-Type'] = 'application/strategic-merge-patch+json'
|
||||
164c172,174
|
||||
< async with self.pool_manager.request(**args) as r:
|
||||
---
|
||||
> r = await self.pool_manager.request(**args)
|
||||
> if _preload_content:
|
||||
>
|
||||
168,169c178,179
|
||||
< # log response body
|
||||
< logger.debug("response body: %s", r.data)
|
||||
---
|
||||
> # log response body
|
||||
> logger.debug("response body: %s", r.data)
|
||||
171,172c181,182
|
||||
< if not 200 <= r.status <= 299:
|
||||
< raise ApiException(http_resp=r)
|
||||
---
|
||||
> if not 200 <= r.status <= 299:
|
||||
> raise ApiException(http_resp=r)
|
||||
70
openapi/python-asyncio.sh
Executable file
70
openapi/python-asyncio.sh
Executable file
@@ -0,0 +1,70 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Copyright 2018 The Kubernetes Authors.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
set -o pipefail
|
||||
|
||||
ARGC=$#
|
||||
|
||||
if [ $# -ne 2 ]; then
|
||||
echo "Usage:"
|
||||
echo " python-asyncio.sh OUTPUT_DIR SETTING_FILE_PATH"
|
||||
echo " Setting file should define KUBERNETES_BRANCH, CLIENT_VERSION, and PACKAGE_NAME"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
|
||||
OUTPUT_DIR=$1
|
||||
SETTING_FILE=$2
|
||||
mkdir -p "${OUTPUT_DIR}"
|
||||
|
||||
SCRIPT_ROOT=$(dirname "${BASH_SOURCE}")
|
||||
pushd "${SCRIPT_ROOT}" > /dev/null
|
||||
SCRIPT_ROOT=`pwd`
|
||||
popd > /dev/null
|
||||
|
||||
pushd "${OUTPUT_DIR}" > /dev/null
|
||||
OUTPUT_DIR=`pwd`
|
||||
popd > /dev/null
|
||||
|
||||
source "${SCRIPT_ROOT}/client-generator.sh"
|
||||
source "${SETTING_FILE}"
|
||||
|
||||
SWAGGER_CODEGEN_COMMIT=f9b2839a3076f26db1b8fc61655a26662f2552ee; \
|
||||
CLIENT_LANGUAGE=python-asyncio; \
|
||||
CLEANUP_DIRS=(client/apis client/models docs test); \
|
||||
kubeclient::generator::generate_client "${OUTPUT_DIR}"
|
||||
|
||||
echo "--- Patching generated code..."
|
||||
find "${OUTPUT_DIR}/test" -type f -name \*.py -exec sed -i 's/\bclient/kubernetes_asyncio.client/g' {} +
|
||||
find "${OUTPUT_DIR}" -path "${OUTPUT_DIR}/base" -prune -o -type f -a -name \*.md -exec sed -i 's/\bclient/kubernetes_asyncio.client/g' {} +
|
||||
find "${OUTPUT_DIR}" -path "${OUTPUT_DIR}/base" -prune -o -type f -a -name \*.md -exec sed -i 's/kubernetes_asyncio.client-python/client-python/g' {} +
|
||||
|
||||
# workaround https://github.com/swagger-api/swagger-codegen/pull/7905
|
||||
find "${OUTPUT_DIR}/client" -type f -name \*.py ! -name '__init__.py' -exec sed -i '/^from .*models.*/d' {} \;
|
||||
|
||||
# workaround https://github.com/swagger-api/swagger-codegen/pull/8204
|
||||
# + closing session
|
||||
# + support application/strategic-merge-patch+json
|
||||
patch "${OUTPUT_DIR}/client/rest.py" "${SCRIPT_ROOT}/python-asyncio-rest.py.patch"
|
||||
|
||||
# fix imports
|
||||
find "${OUTPUT_DIR}/client/" -type f -name \*.py -exec sed -i 's/import client\./import kubernetes_asyncio.client./g' {} +
|
||||
find "${OUTPUT_DIR}/client/" -type f -name \*.py -exec sed -i 's/from client/from kubernetes_asyncio.client/g' {} +
|
||||
find "${OUTPUT_DIR}/client/" -type f -name \*.py -exec sed -i 's/getattr(client\.models/getattr(kubernetes_asyncio.client.models/g' {} +
|
||||
|
||||
echo "---Done."
|
||||
55
openapi/python-asyncio.xml
Normal file
55
openapi/python-asyncio.xml
Normal file
@@ -0,0 +1,55 @@
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<groupId>io.kubernetes</groupId>
|
||||
<artifactId>client-python</artifactId>
|
||||
<version>1.0-SNAPSHOT</version>
|
||||
<name>client-python</name>
|
||||
<url>http://kubernetes.io</url>
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>io.swagger</groupId>
|
||||
<artifactId>swagger-codegen-maven-plugin</artifactId>
|
||||
<version>${swagger-codegen-version}</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
<configuration>
|
||||
<inputSpec>${generator.spec.path}</inputSpec>
|
||||
<language>python</language>
|
||||
<library>asyncio</library>
|
||||
<gitUserId>kubernetes-client</gitUserId>
|
||||
<gitRepoId>python</gitRepoId>
|
||||
<configOptions>
|
||||
<packageName>${generator.package.name}</packageName>
|
||||
<packageVersion>${generator.client.version}</packageVersion>
|
||||
<sortParamsByRequiredFlag>true</sortParamsByRequiredFlag>
|
||||
</configOptions>
|
||||
<output>${generator.output.path}</output>
|
||||
</configuration>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
<dependencies>
|
||||
<!-- dependencies are needed for the client being generated -->
|
||||
<dependency>
|
||||
<groupId>io.swagger</groupId>
|
||||
<artifactId>swagger-annotations</artifactId>
|
||||
<version>${swagger-annotations-version}</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
<properties>
|
||||
<swagger-annotations-version>1.5.0</swagger-annotations-version>
|
||||
<maven-plugin-version>1.0.0</maven-plugin-version>
|
||||
|
||||
<!-- Default values for the generator parameters. -->
|
||||
<generator.output.path>.</generator.output.path>
|
||||
<generator.spec.path>swagger.json</generator.spec.path>
|
||||
<generator.package.name>swagger_client</generator.package.name>
|
||||
<generator.client.version>unversioned</generator.client.version>
|
||||
</properties>
|
||||
</project>
|
||||
Reference in New Issue
Block a user