From ed8cb1754d5f91fd8ce7c2d9921d4dc3c960035a Mon Sep 17 00:00:00 2001 From: Yuchao Yan Date: Fri, 24 Jun 2022 11:22:57 +0800 Subject: [PATCH] [Dpg] update to use global autorest version (#24970) * code * fix * code --- scripts/quickstart_tooling_dpg/main.py | 21 +++++++++++++------ .../quickstart_tooling_dpg/template/setup.py | 4 ++-- swagger_to_sdk_config_dpg.json | 4 ++-- 3 files changed, 19 insertions(+), 10 deletions(-) diff --git a/scripts/quickstart_tooling_dpg/main.py b/scripts/quickstart_tooling_dpg/main.py index bbd407d4d922..8b70a4ae0e6b 100644 --- a/scripts/quickstart_tooling_dpg/main.py +++ b/scripts/quickstart_tooling_dpg/main.py @@ -5,7 +5,8 @@ from jinja2 import Environment, FileSystemLoader from subprocess import check_call import time -from typing import Any, Dict +from typing import Any +import json _LOGGER = logging.getLogger(__name__) @@ -13,6 +14,7 @@ _TEMPLATE_TESTS = Path(__file__).resolve().parent / "template_tests" _TEMPLATE_SAMPLES = Path(__file__).resolve().parent / "template_samples" _TEMPLATE_CI = Path(__file__).resolve().parent / "template_ci" +_CONFIG_FILE = Path(__file__).resolve() / "../../../swagger_to_sdk_config_dpg.json" def check_parameters( @@ -39,7 +41,7 @@ def generate_ci(template_path: Path, folder_path: Path, package_name: str) -> No with open(ci, "r") as file_in: content = file_in.readlines() for line in content: - if f'{package_name}\n' in line: + if f'{package_name}' in line: return content.append(f' - name: {package_name}\n') content.append(f' safeName: {package_name.replace("-", "")}\n') @@ -75,6 +77,13 @@ def generate_swagger_readme(work_path: str, env: Environment, **kwargs: Any) -> return swagger_readme +def get_autorest_version() -> str: + with open(_CONFIG_FILE, 'r') as file_in: + config = json.load(file_in) + autorest_use = " ".join(["--use=" + item for item in config["meta"]["autorest_options"]["use"]]) + return "--version={} {}".format(config["meta"]["autorest_options"]["version"], autorest_use) + + def build_package(**kwargs) -> None: # prepare template render parameters output_folder = kwargs.get("output_folder") @@ -93,7 +102,7 @@ def build_package(**kwargs) -> None: _LOGGER.info("Build start: %s", package_name) check_parameters(output_folder) - #generate ci + # generate ci generate_ci(_TEMPLATE_CI, Path(output_folder).parent, package_name) # generate swagger readme @@ -101,9 +110,9 @@ def build_package(**kwargs) -> None: swagger_readme = generate_swagger_readme(output_folder, env, **kwargs) # generate code with autorest and swagger readme - _LOGGER.info("generate SDK code with autorest") - check_call(f'autorest --version=3.8.1 --use=@autorest/python@5.17.0 --use=@autorest/modelerfour@4.23.5' - f' {swagger_readme}', shell=True) + autorest_cmd = f'autorest {swagger_readme} {get_autorest_version()} ' + _LOGGER.info(f"generate SDK code with autorest: {autorest_cmd}") + check_call(autorest_cmd, shell=True) # generate necessary file(setup.py, CHANGELOG.md, etc) work_path = Path(output_folder) diff --git a/scripts/quickstart_tooling_dpg/template/setup.py b/scripts/quickstart_tooling_dpg/template/setup.py index 95c4d5588532..6d2785d6f41c 100644 --- a/scripts/quickstart_tooling_dpg/template/setup.py +++ b/scripts/quickstart_tooling_dpg/template/setup.py @@ -60,8 +60,8 @@ ] ), install_requires=[ - "azure-core<2.0.0,>=1.23.0", - "msrest>=0.6.21", + "azure-core<2.0.0,>=1.24.0", + "msrest>=0.7.0", ], python_requires=">=3.6", ) diff --git a/swagger_to_sdk_config_dpg.json b/swagger_to_sdk_config_dpg.json index 4900e744c9e8..373db6608830 100644 --- a/swagger_to_sdk_config_dpg.json +++ b/swagger_to_sdk_config_dpg.json @@ -1,8 +1,8 @@ { "meta": { "autorest_options": { - "version": "3.7.2", - "use": ["@autorest/python@5.16.0", "@autorest/modelerfour@4.19.3"], + "version": "3.8.1", + "use": ["@autorest/python@5.19.0", "@autorest/modelerfour@4.23.5"], "python": "", "sdkrel:python-sdks-folder": "./sdk/.", "version-tolerant": ""