- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.5k
TypeSpec Validation
To ensure you see the same results from TypeSpecValidation in your PR check and tsv on your local machine:
- Merge latest from parent (e.g. mainorRPSaaSMaster) to your PR branch
- Run locally
- 
git clean -xdf(may revert any local changes)
- git pull
- npm ci
- npx tsv specification/contosowidgetmanager/Contoso.Management
- git status
- If any changes, git add,git commit,git pushto update your PR.
 
- 
- If you are still having problems, try cloning your branch to a new folder, or try on another machine.
- If the problem can be reproduced on a clean machine, request assistance from the TypeSpec Discussion teams channel.
If you are having problems with diffs from "tsp compile" related to examples, ensure you understand how examples flow from source to destination.
The source of examples is under your TypeSpec source code folder, and the destination of examples is under the Swagger folder. The TypeSpec compiler copies from source to destination. In our sample:
- source
- destination
If you are changing examples, you must first change the copy under your TypeSpec folder, and then run tsp compile (or tsv which calls compile) to update the copies in your Swagger folder.
You can suppress specific validation rules within TypeSpecValidation by creating or modifying a suppressions.yaml file in the root directory of your service specification.
Note: Currently, only the
SdkTspConfigValidationrule supports suppression.
The SdkTspConfigValidation rule is responsible for validating emitter options and parameters defined in your tspconfig.yaml file. You have the flexibility to suppress this rule entirely or target specific sub-rules within it.
If you need to skip all validation checks for emitter options and parameters within a particular tspconfig.yaml file, you can suppress the entire SdkTspConfigValidation rule.
To do this, add or update the suppressions.yaml file in your service's root folder with the following content:
- tool: TypeSpecValidation
  paths:
    # Specify the path to the tspconfig.yaml file where suppression should apply
    - /path/to/tspconfig.yaml
  rules:
    - SdkTspConfigValidation
  reason: the-reason-you-want-to-suppress # Explain why this suppression is necessaryIf you only need to bypass validation for specific emitter options or parameters, you can suppress individual sub-rules.
Add or update your suppressions.yaml file with the following structure, specifying the sub-rules to ignore:
Sub-rule Syntax:
- For parameters: parameters.<parameter-key>.default
- For emitter options: options.<emitter-name>.<option-key>
- For nested options (e.g., package-details: name: "xxx"), use dot notation:options.<emitter-name>.package-details.name
- tool: TypeSpecValidation
  paths:
    # Specify the path to the tspconfig.yaml file where suppression should apply
    - /path/to/tspconfig.yaml
  rules:
    - SdkTspConfigValidation
  sub-rules:
    # Example: Suppress validation for a specific parameter's default value
    - parameters.<key-to-validate>.default 
    # Example: Suppress validation for a specific emitter option
    - options.<emitter-name>.<key-to-validate>
    # Example: Suppress validation for a nested emitter option
    - options.<emitter-name>.package-details.name 
  reason: the-reason-you-want-to-suppress # Explain why this suppression is necessary- 
parameters.default.service-dir- Allowed values: strings that matches the regex /^sdk\/.*$/
- example: sdk/aaa
 
- Allowed values: strings that matches the regex 
Please follow the below steps to configure. If you encounter any issues, please seek help in the JS channel
- 
@azure-tools/typespec-ts.options.experimental-extensible-enums- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-ts.options.package-dir- Allowed values: strings that matches the regex /^arm-[^\/]+$/
- example: arm-aaa-bbb
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-ts.options.package-details.name- Allowed values: strings that matches the regex /^\@azure\/arm(?:-[a-z]+)+$/
- example: @azure/arm-aaa-bbb
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-ts.options.package-dir- Allowed values: strings that matches the regex /^(?:[a-z]+-)+rest$/
- example: arm-aaa-rest
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-ts.options.package-details.name- Allowed values: strings that matches the regex /^\@azure-rest\/[a-z]+(?:-[a-z]+)*$/
- example: @azure-rest/aaa-bbb
 
- Allowed values: strings that matches the regex 
Please follow the below steps to configure. If you encounter any issues, please seek help in the python channel
- 
@azure-tools/typespec-python.options.package-dir- Allowed values: strings that matches the regex /^azure-mgmt(-[a-z]+){1,2}$/
- example: azure-mgmt-aaa
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-python.options.namespace- Allowed values: strings that matches the regex /^azure\.mgmt(\.[a-z]+){1,2}$/
- example: azure.mgmt.aaa
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-python.options.generate-test- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-python.options.generate-sample- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-python.options.package-dir- Allowed values: strings that matches the regex /^azure(-[a-z]+){1,3}$/
- example: azure-aaa-bbb-ccc
 
- Allowed values: strings that matches the regex 
Please follow the below steps to configure. If you encounter any issues, please seek help in the go channel
- 
@azure-tools/typespec-go.options.service-dir- Allowed values: strings that matches the regex /^(\{output-dir\}\/)?sdk\/resourcemanager\/[^\/]*$/orundefined
- example: {output-dir}/sdk/resourcemanager/contoso,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.emitter-output-dir- Allowed values: strings that matches the regex /^(\{output-dir\}\/)?(\{service-dir\}|sdk\/resourcemanager\/)[^\/]*\/arm.*/
- example: {service-dir}/armcontoso
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.module- Allowed values: strings that matches the regex /^github.com\/Azure\/azure-sdk-for-go\/.*$/orundefined
- example: github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/contoso/armcontoso,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.containing-module- Allowed values: strings that matches the regex /^github.com\/Azure\/azure-sdk-for-go\/.*$/orundefined
- example: github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/contoso/armcontoso,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.generate-samples- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-go.options.generate-fakes- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-go.options.head-as-boolean- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-go.options.inject-spans- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-go.options.emitter-output-dir- Allowed values: strings that matches the regex /^(\{output-dir\}\/)?(\{service-dir\}|sdk\/).*\/az.*/
- example: {service-dir}/azmanager
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.service-dir- Allowed values: strings that matches the regex /^(\{output-dir\}\/)?sdk\/.*$/orundefined
- example: {output-dir}/sdk/contosowidget,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.module- Allowed values: strings that matches the regex /^github.com\/Azure\/azure-sdk-for-go\/.*$/orundefined
- example: github.com/Azure/azure-sdk-for-go/sdk/contosowidget/azmanager,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.containing-module- Allowed values: strings that matches the regex /^github.com\/Azure\/azure-sdk-for-go\/.*$/orundefined
- example: github.com/Azure/azure-sdk-for-go/sdk/contosowidget/azmanager,undefined
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-go.options.inject-spans- Allowed values: true
 
- Allowed values: 
Please follow the below steps to configure. If you encounter any issues, please seek help in the java channel
- 
@azure-tools/typespec-java.options.package-dir- Allowed values: strings that matches the regex /^azure-resourcemanager-[^\/]+$/
- example: azure-resourcemanager-servicename
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-java.options.namespace- Allowed values: strings that matches the regex /^com\.azure\.resourcemanager\.[^\.]+$/
- example: com.azure.resourcemanager.servicename
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-java.options.package-dir- Allowed values: strings that matches the regex /^azure(-\w+)+$/
- example: azure-aaa
 
- Allowed values: strings that matches the regex 
Please follow the below steps to configure. If you encounter any issues, please seek help in the .Net channel
- 
@azure-tools/typespec-csharp.options.package-dir- Allowed values: strings that matches the regex /^Azure\.ResourceManager\./
- example: Azure.ResourceManager.AAA
 
- Allowed values: strings that matches the regex 
- 
@azure-tools/typespec-csharp.options.namespace- Allowed values: package-diror{package-dir}
- example: package-dir,Azure.ResourceManager.AAA
 
- Allowed values: 
- 
@azure-tools/typespec-csharp.options.clear-output-folder- Allowed values: true
 
- Allowed values: 
- 
@azure-tools/typespec-csharp.options.package-dir- Allowed values: strings that start with Azure.
- example: Azure.aaa
 
- Allowed values: strings that start with 
- 
@azure-tools/typespec-csharp.options.namespace- Allowed values: package-diror{package-dir}
- example: package-dir,Azure.aaa
 
- Allowed values: 
- 
@azure-tools/typespec-csharp.options.clear-output-folder- Allowed values: true
 
- Allowed values: