From b0682e7ebb6855f23b54d74f033e1602bc0aa79a Mon Sep 17 00:00:00 2001 From: necusjz Date: Fri, 15 Apr 2022 13:39:54 +0800 Subject: [PATCH 1/2] add a dry run as document --- README.md | 26 +++++++++++++++++++++++++- doc/faq.md | 29 ----------------------------- 2 files changed, 25 insertions(+), 30 deletions(-) diff --git a/README.md b/README.md index e97d7146..a25b0f37 100644 --- a/README.md +++ b/README.md @@ -132,7 +132,31 @@ Users can refer to [this document](https://github.com/Azure/azure-rest-api-specs See [different combination of generation options](https://github.com/Azure/autorest.az/blob/master/doc/how-to-generate-with-different-options.md#most-useful-command-options-combination) for more useful scenarios. -If there is any error while code generation, please check [common errors while code generation](https://github.com/Azure/autorest.az/blob/master/doc/faq.md#common-errors-while-code-generation) for resolutions. +### Use logz extension as a dry run +It's always good to start with a command like that: +```text +$ autorest --version=3.0.6370 --az --use=@autorest/az@latest ..\azure-rest-api-specs\specification\logz\resource-manager\readme.md --azure-cli-extension-folder=./azure-cli-extensions +``` + +Make sure you have these specific versions installed: +| AutoRest Core | AutoRest CLI | Node.js | +|:--------------:|:-------------:|:--------:| +| 3.0.6370 | 3.5.1 | 12.20 | + +Errors you might encounter nowadays: +1. ERROR: Schema violation: Additional properties not allowed: x-ms-identifiers + 1. Append *--pass-thru:schema-validator-swagger* to the command; +2. AttributeError: module 'mistune' has no attribute 'BlockGrammar' + 1. Active the virtual environment within *~/.autorest/@autorest_python@5.4.0/node_modules/@autorest/python/venv*; + 2. Execute *pip install mistune==0.8.4*; +3. ImportError: cannot import name '_unicodefun' from 'click' + 1. Active the virtual environment within *~/.autorest/@autorest_az@1.8.0/node_modules/@autorest/az/venv*; + 2. Execute *pip install click==8.0.2*; + +One more thing, it's a good practice to clean up autorest extensions by: +```text +$ autorest --reset +``` ## Build the Generated Code If you want to do a simple try, please go to the az-output-folder that you specified in your readme.az.md, build the wheel file and add the generated file into Azure CLI. diff --git a/doc/faq.md b/doc/faq.md index d6f03704..1b4a97d2 100644 --- a/doc/faq.md +++ b/doc/faq.md @@ -450,32 +450,3 @@ cli: ``` In this way. we can use `--param-name key1=value1,key2=value2 key1=valuea,key2=valueb` instead of `--param-name key1=value1 key2=value2 key1=valuea key2=valueb` to suggest that we want to input two items (value1, value2) and (valuea, valueb). - -## Common errors while code generation -The specific version information: - -| AutoRest Core | AutoRest CLI | Node.js | -|:--------------:|:-------------:|:--------:| -| 3.0.6370 | 3.5.1 | 12.20 | - -The path of Python virtual environment within "@autorest/python" extension should be like: -```text -~/.autorest/@autorest_python@xx/node_modules/@autorest/python/venv -``` - -> ModuleNotFoundError: No module named 'm2r' - -1. Active the virtual environment within "@autorest/python"; -2. Execute `pip install m2r`; - -> AttributeError: module 'mistune' has no attribute 'BlockGrammar' - -1. Active the virtual environment within "@autorest/python"; -2. Execute `pip install mistune==0.8.4`; - -> Failed to install or start extension '@autorest/az' - -Specify the version of Node.js to **12.20** and the command should be like: -```text -$ autorest --version=3.0.6370 --az --use=@autorest/az@latest --azure-cli-extension-folder= -``` From 039635d321e78d4979c873fe7a5de0320ddf13fe Mon Sep 17 00:00:00 2001 From: necusjz Date: Fri, 15 Apr 2022 13:48:02 +0800 Subject: [PATCH 2/2] refine README.md --- README.md | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index a25b0f37..d380a519 100644 --- a/README.md +++ b/README.md @@ -132,28 +132,29 @@ Users can refer to [this document](https://github.com/Azure/azure-rest-api-specs See [different combination of generation options](https://github.com/Azure/autorest.az/blob/master/doc/how-to-generate-with-different-options.md#most-useful-command-options-combination) for more useful scenarios. -### Use logz extension as a dry run +### Take logz extension as a dry run It's always good to start with a command like that: ```text -$ autorest --version=3.0.6370 --az --use=@autorest/az@latest ..\azure-rest-api-specs\specification\logz\resource-manager\readme.md --azure-cli-extension-folder=./azure-cli-extensions +$ autorest --version=3.0.6370 --az --use=@autorest/az@latest ../azure-rest-api-specs/specification/logz/resource-manager/readme.md --azure-cli-extension-folder=./azure-cli-extensions ``` Make sure you have these specific versions installed: + | AutoRest Core | AutoRest CLI | Node.js | |:--------------:|:-------------:|:--------:| | 3.0.6370 | 3.5.1 | 12.20 | Errors you might encounter nowadays: -1. ERROR: Schema violation: Additional properties not allowed: x-ms-identifiers +- ERROR: Schema violation: Additional properties not allowed: x-ms-identifiers 1. Append *--pass-thru:schema-validator-swagger* to the command; -2. AttributeError: module 'mistune' has no attribute 'BlockGrammar' - 1. Active the virtual environment within *~/.autorest/@autorest_python@5.4.0/node_modules/@autorest/python/venv*; +- AttributeError: module 'mistune' has no attribute 'BlockGrammar' + 1. Active the venv within *~/.autorest/@autorest_python@5.4.0/node_modules/@autorest/python*; 2. Execute *pip install mistune==0.8.4*; -3. ImportError: cannot import name '_unicodefun' from 'click' - 1. Active the virtual environment within *~/.autorest/@autorest_az@1.8.0/node_modules/@autorest/az/venv*; +- ImportError: cannot import name '_unicodefun' from 'click' + 1. Active the venv within *~/.autorest/@autorest_az@1.8.0/node_modules/@autorest/az*; 2. Execute *pip install click==8.0.2*; -One more thing, it's a good practice to clean up autorest extensions by: +One more thing, it's a good practice to clean up AutoRest extensions by: ```text $ autorest --reset ```