azure-sdk-tools/tools/sdk-testgen
dependabot[bot] 3e821cacfa
Bump oav from 3.4.0 to 3.5.1 in /tools/sdk-testgen (#9205)
Bumps [oav](https://github.com/azure/oav) from 3.4.0 to 3.5.1.
- [Release notes](https://github.com/azure/oav/releases)
- [Changelog](https://github.com/Azure/oav/blob/develop/ChangeLog.md)
- [Commits](https://github.com/azure/oav/commits)

---
updated-dependencies:
- dependency-name: oav
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-10-28 13:33:41 +08:00
..
docs
src [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
swagger/specification add option --explicit-types to allow customize tagged types in exported code model. (#3976) 2022-08-22 11:43:37 +08:00
test [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
.eslintrc.json
.gitattributes
.gitignore
.prettierignore [testmodeler] load apiscenario 1.2 with oav@3.0 (#3613) 2022-07-21 15:28:22 +08:00
.prettierrc
CHANGELOG.json [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
CHANGELOG.md [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
LICENSE
README.md [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
ci.yml [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
index.ts [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
jest.config.js
jest.unittest.config.js [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
package-lock.json Bump oav from 3.4.0 to 3.5.1 in /tools/sdk-testgen (#9205) 2024-10-28 13:33:41 +08:00
package.json Bump oav from 3.4.0 to 3.5.1 in /tools/sdk-testgen (#9205) 2024-10-28 13:33:41 +08:00
tsconfig.json [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
tsconfig.spec.json [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00
webpack.config.js [sdk-testgen] change sdk-testgen manager from rushjs to npm (#9072) 2024-10-02 11:35:00 -07:00

README.md

AutoRest SDK Test Generation Tools


Packages

Name Changelog Latest
@autorest/testmodeler Changelog
@autorest/gotest Changelog

Contributing

For instructions on cloning/building/etc, see Development

Contributor License Agreement Requirements

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.

When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

Code of Conduct

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Autorest Extension for Test Modeler

Generate *.md config files in Azure REST API specification:

https://github.com/Azure/azure-rest-api-specs

How to Generate Test Model

autorest --version=3.7.3 --use=<test model extension> --output-folder=<RP package path> --testmodeler.export-codemodel --clear-output-folder=false --debug <RP config md file path>

Contribution

The testmodeler use rush managing the projects. So if there is changes on package.json, remember to execute rush update updated.

> rush update

Configurations

Below are options can be used for autorest.testmodeler

--debug

Generate modeler files in [output-foler]/__debuger for debug purpose.

--testmodeler.mock.send-example-id

In generated mock test, send swagger example-id to mock service host in each request. This implicitly ask the mock service host to verify request body by swagger example content. Default true.

--testmodeler.mock.verify-response

In generated mock test, response value will be verified with the example files. Default true.

--testmodeler.mock.disabled-examples

This is an array parameter can be assigned in autorest readme file. For instance, examples Extensions_Get and Extensions_Delete will not be used in mock test generation with below configuration.

testmodeler:
    mock:
        disabled-examples:
            - Extensions_Get
            - Extensions_Delete

--testmodeler.scenario.variable-defaults.location

Set location used in scenario test, for instance:

testmodeler:
    scenario:
        variable-defaults:
            location: eastus

--testmodeler.scenario.codemodel-restcall-only

If there is no 'test-resources' defined in readme file and the readme is located in local file system, testmodeler will search all available api-scenario and try to load them as test scenario. In this context, option codemodel-restcall-only defined whether testmodeler abandon api-scenarios who contains restcall steps that can't be linked to an operation in codemodel.

The default value of this option is true.

--testmodeler.use-example-model

This option switch whether ExampleModel in generated in test model. While default to be true, it can be disabled like below:

testmodeler:
    use-example-model: false

--testmodeler.add-armtemplate-payload-string

This option switch whether StepArmTemplateModel.armTemplatePayloadString is added into testmodeler. While default to be false, it can be enabled like below:

testmodeler:
    add-armtemplate-payload-string: true

--testmodeler.api-scenario-loader-option

The api-scenarios are loaded from the autorest input-files by default. This option provide a gate to load api-scenario from other remote/branch/commit. This option are passed through directly to oav scenario loader, refer to https://github.com/Azure/oav/blob/develop/lib/apiScenario/apiScenarioLoader.ts#L60 for more detail of it. A sample for this option:

testmodeler:
    api-scenario-loader-option:
        fileRoot: https://github.com/Azure/azure-rest-api-specs/blob/eb829ed4739fccb03dd2327b7762392e74c80ae4/specification/appplatform/resource-manager
        swaggerFilePaths:
          - 'Microsoft.AppPlatform/preview/2020-11-01-preview/appplatform.json'

--test-resources

The list of api-scenarios want to get loaded into testmodeler. Below is a sample:

test-resources:
    - test: Microsoft.AppPlatform/preview/2020-11-01-preview/scenarios/Spring.yaml

--testmodeler.export-explicit-type

Whether to export codemodel with tags on primitive types, default as false. Demonstrate on the output values:

// with primitive types:
isDataAction: !!bool false
count: !!int 64


// with no types:
isDataAction: false
count: 64

--testmodeler.explicit-types

A list for types need to explicitly tagged when export-explicit-type is true. The default explicitTypes are ['bool', 'int', 'float', 'timestamp']. Test generators can change it like below:

testmodeler:
    explicit-types:
        - bool
        - int
        - float

Autorest Pipeline Configurations

clear-output-folder: false

try-require:
    - ./readme.test.md
    - ./readme.testmodeler.md

version: 3.9.7

use-extension:
  "@autorest/modelerfour" : "4.25.0"

pipeline:
    test-modeler:
        input: modelerfour/identity
        output-artifact: source-file-test-modeler
    testmodeler/emitter:
        input: test-modeler
        scope: scope-testmodeler/emitter

scope-testmodeler/emitter:
    input-artifact:
        - source-file-test-modeler
    output-uri-expr: $key
    
testmodeler:
    split-parents-value: true
testmodeler:
    export-codemodel: true