Skip to content

AAS - Fix Swagger Correctness v6#12999

Merged
allenjzhang merged 8 commits intoAzure:masterfrom
david-msft:jinh/AAS/Fix_correctness_vv6
Mar 7, 2021
Merged

AAS - Fix Swagger Correctness v6#12999
allenjzhang merged 8 commits intoAzure:masterfrom
david-msft:jinh/AAS/Fix_correctness_vv6

Conversation

@david-msft
Copy link
Contributor

@david-msft david-msft commented Feb 16, 2021

MSFT employees can try out our new experience at OpenAPI Hub - one location for using our validation tools and finding your workflow.

Changelog

Please ensure to add changelog with this PR by answering the following questions.

  1. What's the purpose of the update?
    • new service onboarding
    • new API version
    • update existing version for new feature
    • update existing version to fix swagger quality issue in s360
    • Other, please clarify
  2. When you are targeting to deploy new service/feature to public regions? Please provide date, or month to public if date is not available yet.
  3. When you expect to publish swagger? Please provide date, or month to public if date is not available yet.
  4. If it's an update to existing version, please select SDKs of specific language and CLIs that require refresh after swagger is published.
    • SDK of .NET (need service team to ensure code readiness)
    • SDK of Python
    • SDK of Java
    • SDK of Js
    • SDK of Go
    • PowerShell
    • CLI
    • Terraform
    • No, no need to refresh for updates in this PR

Contribution checklist:

If any further question about AME onboarding or validation tools, please view the FAQ.

ARM API Review Checklist

  • Ensure to check this box if one of the following scenarios meet updates in the PR, so that label “WaitForARMFeedback” will be added automatically to involve ARM API Review. Failure to comply may result in delays for manifest application. Note this does not apply to data plane APIs, all “removals” and “adding a new property” no more require ARM API review.

    • Adding new API(s)
    • Adding a new API version
    • Adding a new service
  • Please ensure you've reviewed following guidelines including ARM resource provider contract and REST guidelines. Estimated time (4 hours). This is required before you can request review from ARM API Review board.

  • If you are blocked on ARM review and want to get the PR merged with urgency, please get the ARM oncall for reviews (RP Manifest Approvers team under Azure Resource Manager service) from IcM and reach out to them.

Breaking Change Review Checklist

If there are following updates in the PR, ensure to request an approval from Breaking Change Review Board as defined in the Breaking Change Policy.

  • Removing API(s) in stable version
  • Removing properties in stable version
  • Removing API version(s) in stable version
  • Updating API in stable or public preview version with Breaking Change Validation errors
  • Updating API(s) in public preview over 1 year (refer to Retirement of Previews)

Action: to initiate an evaluation of the breaking change, create a new intake using the template for breaking changes. Addition details on the process and office hours are on the Breaking change Wiki.

Please follow the link to find more details on PR review process.

@openapi-workflow-bot
Copy link

Hi, @david-msft Thanks for your PR. I am workflow bot for review process. Here are some small tips.

  • Please ensure to do self-check against checklists in first PR comment.
  • PR assignee is the person auto-assigned and responsible for your current PR reviewing and merging.
  • For specs comparison cross API versions, Use API Specs Comparison Report Generator
  • If there is CI failure(s), to fix CI error(s) is mandatory for PR merging; or you need to provide justification in PR comment for explanation. How to fix?

  • Any feedback about review process or workflow bot, pls contact swagger and tools team. vsswagger@microsoft.com

    @openapi-pipeline-app
    Copy link

    openapi-pipeline-app bot commented Feb 16, 2021

    Swagger Validation Report

    ️❌BreakingChange: 11 Errors, 0 Warnings failed [Detail] Only 10 items are listed, please refer to log for more details.

    Rule Message
    1026 - TypeChanged The new version has a different type '' than the previous one 'object'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1526:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1570:9
    1026 - TypeChanged The new version has a different type '' than the previous one 'object'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1336:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1336:9
    1026 - TypeChanged The new version has a different type '' than the previous one 'object'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1407:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1431:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1457:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1533:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1462:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1537:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1472:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1541:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1478:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1546:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1336:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1346:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1336:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1350:9
    1029 - ReadonlyPropertyChanged The read only property has changed from 'false' to 'true'.
    New: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1336:9
    Old: Microsoft.AnalysisServices/stable/2017-08-01/analysisservices.json#L1354:9
    ️️✔️LintDiff succeeded [Detail] [Expand]
    Validation passes for LintDiff.

    ️️✔️Avocado succeeded [Detail] [Expand]
    Validation passes for Avocado.
    ️️✔️ModelValidation succeeded [Detail] [Expand]
    Validation passes for ModelValidation.
    ️️✔️SemanticValidation succeeded [Detail] [Expand]
    Validation passes for SemanticValidation.
    ️️✔️[Staging] Cross Version BreakingChange (Base on preview version) succeeded [Detail] [Expand]
    There are no breaking changes.
    ️️✔️[Staging] Cross Version BreakingChange (Base on stable version) succeeded [Detail] [Expand]
    There are no breaking changes.
    ️️✔️CredScan succeeded [Detail] [Expand]
    There is no credential detected.
    ️⚠️[Staging] SDK Track2 Validation: 7 Warnings warning [Detail]

    Rule Message
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'Operation-display' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'Operation-properties' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'Operation-properties-serviceSpecification' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'OperationListResult' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'ErrorDetail' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/SchemaMissingType "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"The schema 'ErrorAdditionalInfo' with an undefined type and decalared properties is a bit ambigious. This has been auto-corrected to 'type:object'"
    ⚠️ PreCheck/CheckDuplicateSchemas "readme":"analysisservices/resource-manager/readme.md",
    "tag":"package-2017-08",
    "details":"Checking for duplicate schemas,
    this could take a (long) while. Run with --verbose for more detail."
    ️️✔️[Staging] PrettierCheck succeeded [Detail] [Expand]
    Validation passes for PrettierCheck.
    ️️✔️[Staging] SpellCheck succeeded [Detail] [Expand]
    Validation passes for SpellCheck.
    Posted by Swagger Pipeline | How to fix these errors?

    @openapi-pipeline-app
    Copy link

    openapi-pipeline-app bot commented Feb 16, 2021

    Swagger Generation Artifacts

    ️️✔️ azure-sdk-for-js succeeded [Detail] [Expand]
    • ️✔️Succeeded [Logs]Release - Generate from 8e498d1. SDK Automation 14.0.0
      warn	Skip initScript due to not configured
      command	autorest --version=V2 --typescript --license-header=MICROSOFT_MIT_NO_VERSION --use=@microsoft.azure/autorest.typescript@4.4.4 --typescript-sdks-folder=/home/vsts/work/1/s/azure-sdk-for-js/azure-sdk-for-js ../../azure-rest-api-specs/specification/analysisservices/resource-manager/readme.md
    • ️✔️@azure/arm-analysisservices [View full logs]  [Release SDK Changes]
      cmderr	[npmPack] loaded rollup.config.js with warnings
      cmderr	[npmPack] (!) Unused external imports
      cmderr	[npmPack] default imported from external module 'rollup' but never used
      cmderr	[npmPack] ./esm/analysisServicesManagementClient.js → ./dist/arm-analysisservices.js...
      cmderr	[npmPack] created ./dist/arm-analysisservices.js in 288ms
    ️️✔️ azure-sdk-for-go succeeded [Detail] [Expand]
    • ️✔️Succeeded [Logs]Release - Generate from 8e498d1. SDK Automation 14.0.0
      command	sh ./initScript.sh ../../../../../azure-sdk-for-go_tmp/initInput.json ../../../../../azure-sdk-for-go_tmp/initOutput.json
      command	go run ./tools/generator/main.go ../../../../../azure-sdk-for-go_tmp/generateInput.json ../../../../../azure-sdk-for-go_tmp/generateOutput.json
    • ️✔️analysisservices/mgmt/2017-08-01/analysisservices [View full logs]  [Release SDK Changes] Breaking Change Detected
      info	[Changelog] ### Breaking Changes
      info	[Changelog]
      info	[Changelog] - Type of `GatewayListStatusLive.Status` has been changed from `Status` to `*int32`
      info	[Changelog] - Type of `OperationStatus.Error` has been changed from `*ErrorResponse` to `*GatewayError`
      info	[Changelog] - Const `Live` has been removed
      info	[Changelog] - Function `PossibleStatusValues` has been removed
      info	[Changelog] - Field `Message` of struct `ErrorResponse` has been removed
      info	[Changelog] - Field `Code` of struct `ErrorResponse` has been removed
      info	[Changelog]
      info	[Changelog] ### New Content
      info	[Changelog]
      info	[Changelog] - New struct `ErrorAdditionalInfo`
      info	[Changelog] - New struct `LogSpecifications`
      info	[Changelog] - New struct `MetricDimensions`
      info	[Changelog] - New struct `MetricSpecifications`
      info	[Changelog] - New struct `OperationProperties`
      info	[Changelog] - New struct `OperationPropertiesServiceSpecification`
      info	[Changelog] - New field `Sku` in struct `ServerProperties`
      info	[Changelog] - New field `ManagedMode` in struct `ServerProperties`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerProperties`
      info	[Changelog] - New field `ManagedMode` in struct `ServerMutableProperties`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerMutableProperties`
      info	[Changelog] - New field `Description` in struct `OperationDisplay`
      info	[Changelog] - New field `Error` in struct `ErrorResponse`
      info	[Changelog] - New field `Target` in struct `GatewayError`
      info	[Changelog] - New field `SubCode` in struct `GatewayError`
      info	[Changelog] - New field `HTTPStatusCode` in struct `GatewayError`
      info	[Changelog] - New field `TimeStamp` in struct `GatewayError`
      info	[Changelog] - New field `Details` in struct `GatewayError`
      info	[Changelog] - New field `AdditionalInfo` in struct `GatewayError`
      info	[Changelog] - New field `Origin` in struct `Operation`
      info	[Changelog] - New field `Properties` in struct `Operation`
      info	[Changelog] - New field `ResourceType` in struct `SkuDetailsForExistingResource`
      info	[Changelog]
      info	[Changelog] Total 5 breaking change(s), 19 additive change(s).
      info	[Changelog]
    • ️✔️analysisservices/mgmt/2017-07-14/analysisservices [View full logs]  [Release SDK Changes] Breaking Change Detected
      Only show 40 items here, please refer to log for details.
      info	[Changelog] - New function `OperationsClient.ListResponder(*http.Response) (OperationListResult, error)`
      info	[Changelog] - New function `OperationDisplay.MarshalJSON() ([]byte, error)`
      info	[Changelog] - New function `NewOperationsClient(string) OperationsClient`
      info	[Changelog] - New function `OperationsClient.List(context.Context) (OperationListResultPage, error)`
      info	[Changelog] - New function `OperationsClient.ListPreparer(context.Context) (*http.Request, error)`
      info	[Changelog] - New function `NewOperationListResultIterator(OperationListResultPage) OperationListResultIterator`
      info	[Changelog] - New function `OperationsClient.ListSender(*http.Request) (*http.Response, error)`
      info	[Changelog] - New function `OperationListResultPage.Response() OperationListResult`
      info	[Changelog] - New function `*OperationListResultPage.NextWithContext(context.Context) error`
      info	[Changelog] - New function `OperationListResult.IsEmpty() bool`
      info	[Changelog] - New function `*OperationListResultIterator.NextWithContext(context.Context) error`
      info	[Changelog] - New function `OperationListResultPage.NotDone() bool`
      info	[Changelog] - New function `OperationListResultIterator.NotDone() bool`
      info	[Changelog] - New function `OperationDetail.MarshalJSON() ([]byte, error)`
      info	[Changelog] - New function `*OperationListResultPage.Next() error`
      info	[Changelog] - New function `OperationListResultPage.Values() []OperationDetail`
      info	[Changelog] - New struct `ErrorAdditionalInfo`
      info	[Changelog] - New struct `ErrorDetail`
      info	[Changelog] - New struct `ErrorResponseError`
      info	[Changelog] - New struct `LogSpecifications`
      info	[Changelog] - New struct `MetricDimensions`
      info	[Changelog] - New struct `MetricSpecifications`
      info	[Changelog] - New struct `OperationDetail`
      info	[Changelog] - New struct `OperationDetailProperties`
      info	[Changelog] - New struct `OperationDetailPropertiesServiceSpecification`
      info	[Changelog] - New struct `OperationDisplay`
      info	[Changelog] - New struct `OperationListResult`
      info	[Changelog] - New struct `OperationListResultIterator`
      info	[Changelog] - New struct `OperationListResultPage`
      info	[Changelog] - New struct `OperationsClient`
      info	[Changelog] - New struct `OperationsErrorResponse`
      info	[Changelog] - New field `Error` in struct `ErrorResponse`
      info	[Changelog] - New field `ManagedMode` in struct `ServerProperties`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerProperties`
      info	[Changelog] - New field `ResourceType` in struct `SkuDetailsForExistingResource`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerMutableProperties`
      info	[Changelog] - New field `ManagedMode` in struct `ServerMutableProperties`
      info	[Changelog]
      info	[Changelog] Total 4 breaking change(s), 57 additive change(s).
      info	[Changelog]
    • ️✔️analysisservices/mgmt/2016-05-16/analysisservices [View full logs]  [Release SDK Changes] Breaking Change Detected
      Only show 40 items here, please refer to log for details.
      info	[Changelog] - New function `OperationListResultPage.Response() OperationListResult`
      info	[Changelog] - New function `OperationListResultPage.Values() []OperationDetail`
      info	[Changelog] - New function `OperationsClient.ListPreparer(context.Context) (*http.Request, error)`
      info	[Changelog] - New function `OperationDetail.MarshalJSON() ([]byte, error)`
      info	[Changelog] - New function `NewOperationsClientWithBaseURI(string, string) OperationsClient`
      info	[Changelog] - New function `OperationListResultIterator.Value() OperationDetail`
      info	[Changelog] - New function `OperationListResult.IsEmpty() bool`
      info	[Changelog] - New function `OperationsClient.ListComplete(context.Context) (OperationListResultIterator, error)`
      info	[Changelog] - New function `OperationListResultPage.NotDone() bool`
      info	[Changelog] - New function `OperationDisplay.MarshalJSON() ([]byte, error)`
      info	[Changelog] - New function `OperationListResultIterator.Response() OperationListResult`
      info	[Changelog] - New function `NewOperationListResultPage(OperationListResult, func(context.Context, OperationListResult) (OperationListResult, error)) OperationListResultPage`
      info	[Changelog] - New function `*OperationListResultPage.Next() error`
      info	[Changelog] - New function `OperationsClient.ListResponder(*http.Response) (OperationListResult, error)`
      info	[Changelog] - New function `OperationsClient.List(context.Context) (OperationListResultPage, error)`
      info	[Changelog] - New struct `ErrorAdditionalInfo`
      info	[Changelog] - New struct `ErrorDetail`
      info	[Changelog] - New struct `ErrorObject`
      info	[Changelog] - New struct `LogSpecifications`
      info	[Changelog] - New struct `MetricDimensions`
      info	[Changelog] - New struct `MetricSpecifications`
      info	[Changelog] - New struct `OperationDetail`
      info	[Changelog] - New struct `OperationDetailProperties`
      info	[Changelog] - New struct `OperationDetailPropertiesServiceSpecification`
      info	[Changelog] - New struct `OperationDisplay`
      info	[Changelog] - New struct `OperationListResult`
      info	[Changelog] - New struct `OperationListResultIterator`
      info	[Changelog] - New struct `OperationListResultPage`
      info	[Changelog] - New struct `OperationsClient`
      info	[Changelog] - New struct `OperationsErrorResponse`
      info	[Changelog] - New field `Error` in struct `ErrorResponse`
      info	[Changelog] - New field `ResourceType` in struct `SkuDetailsForExistingResource`
      info	[Changelog] - New field `Capacity` in struct `ResourceSku`
      info	[Changelog] - New field `ManagedMode` in struct `ServerProperties`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerProperties`
      info	[Changelog] - New field `ManagedMode` in struct `ServerMutableProperties`
      info	[Changelog] - New field `ServerMonitorMode` in struct `ServerMutableProperties`
      info	[Changelog]
      info	[Changelog] Total 2 breaking change(s), 58 additive change(s).
      info	[Changelog]
    ️️✔️ azure-resource-manager-schemas succeeded [Detail] [Expand]
    • ️✔️Succeeded [Logs]Release - Generate from 8e498d1. Schema Automation 14.0.0
      warn	Skip initScript due to not configured
      command	npx n 12
      command	autorest --use=@autorest/azureresourceschema@3.0.92 --version=3.0.6374 --azureresourceschema --multiapi --title=none --pass-thru:subset-reducer --azureresourceschema-folder=/home/vsts/work/1/s/azure-resource-manager-schemas/azure-resource-manager-schemas ../../azure-rest-api-specs/specification/analysisservices/resource-manager/readme.md
    • ️✔️analysisservices [View full logs]  [Release Schema Changes]
      cmderr	[resource-manager] node-pre-gyp
      cmderr	[resource-manager] WARN Using request for node-pre-gyp https download
      cmderr	[resource-manager] WARN template-schema-validation-tools@1.0.0 No repository field.
      cmderr	[resource-manager]  SKIPPING OPTIONAL DEPENDENCY: fsevents@2.1.3 (node_modules/fsevents):
      cmderr	[resource-manager] npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.1.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
    ️❌ azure-sdk-for-net failed [Detail]
    • Failed [Logs]Release - Generate from 8e498d1. SDK Automation 14.0.0
      warn	Skip initScript due to not configured
      command	sudo apt-get install -y dotnet-sdk-5.0
      command	autorest --version=V2 --csharp --reflect-api-versions --license-header=MICROSOFT_MIT_NO_VERSION --use=@microsoft.azure/autorest.csharp@2.3.82 --csharp-sdks-folder=/home/vsts/work/1/s/azure-sdk-for-net/sdk ../azure-rest-api-specs/specification/analysisservices/resource-manager/readme.md
      cmderr	[Autorest] realpath(): Permission denied
      cmderr	[Autorest] realpath(): Permission denied
      cmderr	[Autorest] realpath(): Permission denied
      cmderr	[Autorest] realpath(): Permission denied
      cmderr	[Autorest] realpath(): Permission denied
      cmderr	[Autorest] realpath(): Permission denied
    • Microsoft.Azure.Management.AnalysisServices [View full logs]  [Release SDK Changes]
      cmdout	[msbuild]      3>/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(386,40): error CS0029: Cannot implicitly convert type 'string' to 'bool?' [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      cmdout	[msbuild]      3>/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(456,66): error CS0029: Cannot implicitly convert type 'string' to 'bool?' [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      cmdout	[msbuild]      3>/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(555,30): error CS0103: The name 'Status' does not exist in the current context [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      cmdout	[msbuild]          /home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(386,40): error CS0029: Cannot implicitly convert type 'string' to 'bool?' [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      cmdout	[msbuild]          /home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(456,66): error CS0029: Cannot implicitly convert type 'string' to 'bool?' [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      cmdout	[msbuild]          /home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/ScenarioTests/ServerOperationsTests.cs(555,30): error CS0103: The name 'Status' does not exist in the current context [/home/vsts/work/1/s/azure-sdk-for-net/sdk/analysisservices/Microsoft.Azure.Management.AnalysisServices/tests/Microsoft.Azure.Management.AnalysisServices.Tests.csproj]
      error	Script return with result [failed] code [1] signal [null] cwd [azure-sdk-for-net]: dotnet
    ️🔄[Staging] ApiDocPreview inProgress [Detail]
    Posted by Swagger Pipeline | How to fix these errors?

    @openapi-workflow-bot
    Copy link

    In the Window Period to fix mismatches between swagger and service, when PR is labelled with “FixS360”, breaking change can be approved by PR assignee; the Azure Breaking Change Board is no longer required to approve the PR. Please ensure to clarify what s360 action items to be solved, and @ mention PR assignee for awareness. Please check this wiki Window to Fix Broken for more details.

    @david-msft
    Copy link
    Contributor Author

    @zhenglaizhang
    Copy link
    Contributor

    /azp run

    @azure-pipelines
    Copy link

    Azure Pipelines successfully started running 2 pipeline(s).

    @openapi-workflow-bot
    Copy link

    Hi @david-msft, one or multiple breaking change(s) is detected in your PR. Please check out the breaking change(s), and provide business justification in the PR comment and @ PR assignee why you must have these change(s), and how external customer impact can be mitigated. Please ensure to follow breaking change policy to request breaking change review and approval before proceeding swagger PR review.
    Action: To initiate an evaluation of the breaking change, create a new intake using the template for breaking changes. Addition details on the process and office hours are on the Breaking change Wiki.
    If you want to know the production traffic statistic, please see ARM Traffic statistic.
    If you think it is false positive breaking change, please provide the reasons in the PR comment, report to Swagger Tooling Team via https://aka.ms/swaggerfeedback.

    @david-msft
    Copy link
    Contributor Author

    @zhenglaizhang what does mean SpellCheck? - My PR does not seem to have change to the Microsoft.Consumption Spec.. Are w good here to merge

    @zhenglaizhang
    Copy link
    Contributor

    /azp run

    @azure-pipelines
    Copy link

    Azure Pipelines successfully started running 2 pipeline(s).

    @david-msft
    Copy link
    Contributor Author

    May I know what is the blocker here?

    @zhenglaizhang
    Copy link
    Contributor

    @david-msft spellcheck issues was resolved now

    "readOnly": true
    }
    }
    "$ref": "#/definitions/ErrorObject"
    Copy link
    Contributor

    @allenjzhang allenjzhang Feb 21, 2021

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    This ErrorObject does NOT conform to the ARM exception standard schema. Did you mean ErrorDetail. Adding ARM Reviewer.

    Copy link
    Contributor Author

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    The ErrorDetail does not contain these three properties:
    "subCode": {
    "description": "The error sub code",
    "type": "integer",
    "format": "int32"
    },
    "httpStatusCode": {
    "description": "The http status code",
    "type": "integer",
    "format": "int32"
    },
    "timeStamp": {
    "description": "the timestamp for the error.",
    "type": "string",
    "readOnly": true
    },

    I mean yes since the two properties are pretty much the same. if we are good to add these three properties in ErrorDetail, we can fix it to use ErrorDetail.

    Copy link
    Member

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    Copy link
    Contributor Author

    @david-msft david-msft Feb 21, 2021

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    @majastrz @allenjzhang hmm. I have all the required parameters in the ErrorObject. The properties in ErrorObject used be live in ErrorResponse but I took them out and made them as a property (schema) since they can be shared with other error responses.
    May I please have your suggestion or recommendation to fix this? Can we include below properties
    "subCode": {
    "description": "The error sub code",
    "type": "integer",
    "format": "int32"
    },
    "httpStatusCode": {
    "description": "The http status code",
    "type": "integer",
    "format": "int32"
    },
    "timeStamp": {
    "description": "the timestamp for the error.",
    "type": "string",
    "readOnly": true
    },

    in ErrorDetail because they do show(catch) in the Swagger live validation.. ex: https://portal.azure-devex-tools.com/amekpis/correctness/detail?errorId=523a5c5c-7749-417d-8ce1-6eab5433338e

    Copy link
    Contributor

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    As ARM reviewer indicated, the ARM's response code is standardized. The subCode can be embedded in additionalInfo. HttpStatusCode is really necessary as it would be captured/reported on the client side. I don't know the scenario if the timeStamp is necessary or leveraged by the user. If you do want to include it as server's timeStamp, please include in the additinalInfo dictionary.

    @allenjzhang allenjzhang added the WaitForARMFeedback <valid label in PR review process> add this label when ARM review is required label Feb 21, 2021
    Copy link
    Contributor

    @allenjzhang allenjzhang left a comment

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    @majastrz , @chiragg4u, can you review this non-standard ErrorObject schema?

    @chiragg4u
    Copy link
    Contributor

    Please go through the contribution checklist added as part of the review and mark them completed. This is a requirement before review can be continued.

    @chiragg4u
    Copy link
    Contributor

    @majastrz , @chiragg4u, can you review this non-standard ErrorObject schema?

    I will only review once the checklist is completed and the reasoning is understood.

    @chiragg4u
    Copy link
    Contributor

    @majastrz , @chiragg4u, can you review this non-standard ErrorObject schema?

    Since this is fixing the SDK runtime error I don't recommend to change the error object completely, as this will cause breaking changes in the existing API surface area.
    This should be considered in the new API version for sure. As long as this is validated I don't have any other comments. I'll mark ARMApproved with changes requested.

    @chiragg4u chiragg4u added ARMSignedOff <valid label in PR review process>add this label when ARM approve updates after review and removed WaitForARMFeedback <valid label in PR review process> add this label when ARM review is required labels Mar 3, 2021
    "error": {
    "description": "The error object",
    "$ref": "#/definitions/ErrorObject"
    "$ref": "#/definitions/ErrorDetail"
    Copy link
    Contributor

    Choose a reason for hiding this comment

    The reason will be displayed to describe this comment to others. Learn more.

    Recommend referring to common definitions "$ref": "../../../../../common-types/resource-management/v1/types.json#/definitions/..." This will enforce the right schema.

    @david-msft
    Copy link
    Contributor Author

    @chiragg4u
    I added the additional properties to ErrorDetail. Referring to the common type, would not help us to resolve this swagger correctness. But, we would definitely consider making the required change on the new API version.

    @david-msft
    Copy link
    Contributor Author

    Hi @allenjzhang,
    Can you please have a second look at this? Got approved from ARM team. As chatted with ARM, we will definitely consider making the required change and conform to the standard error response when there is a new API.

    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

    Labels

    ARMSignedOff <valid label in PR review process>add this label when ARM approve updates after review CI-BreakingChange-Go FixS360

    Projects

    None yet

    Development

    Successfully merging this pull request may close these issues.

    5 participants