Skip to content

[BUG] The API entered an inconsistent state due to an error when setting the current revision. #759

@ehalas

Description

@ehalas

Release version

v6.0.1.4

Describe the bug

In the attempt to set the revision as current, after the error occurred, the API entered an inconsistent state, losing the version. Consequently, all subsequent attempts to adjust the version failed, as the API became an ‘original’ API, preventing us from creating a v3 or deploying an API with the same name.

the erro that caused the issue:

`info: publisher[0]

  Changing current revision on ***center-v3 from 4 to 5...

info: publisher[0]

  Putting API ***center-v3...

##[debug]Agent environment resources - Disk: / Available 276932.38 MB out of 347161.04 MB, Memory: Used 1552.00 MB out of 7929.00 MB, CPU: Usage 62.03%

info: publisher[0]

  Putting API release apiops-set-current in API ***center-v3...

info: publisher[0]

  Deleting API release apiops-set-current from API ***center-v3...

crit: publisher[0]

  Application failed.

  System.Net.Http.HttpRequestException: HTTP request to URI https://management.azure.com/subscription/***/resourceGroups/***/providers/Microsoft.ApiManagement/service/***/apis/***center-v3/releases/apiops-set-current?api-version=2023-09-01-preview failed with status code 409. Content is '{"error":{"code":"ScopeLocked","message":"The scope '/subscriptions/***/resourceGroups/***/providers/Microsoft.ApiManagement/service/***/apis/***center-v3/releases/apiops-set-current' cannot perform delete operation because following scope(s) are locked: '/subscriptions/***/resourceGroups/***'. Please remove the lock and try again."}}'.

`

after that error the api lost the "v3"(***-center/v3) and become just ***-center

Image

Expected behavior

It should revert the changes made in the steps prior to the error and also should not update the revision to one that didn't have any version in the base path.

Actual behavior

Since the incidente, all the versions conflict with the ***-center v3, once the base path is ***-center and not ***-center/v3. PS: it's part of the same version set.

##[error]System.Net.Http.HttpRequestException: HTTP request to URI https://management.azure.com/subscriptions/***/resourceGroups/***-rg/providers/Microsoft.ApiManagement/service/***/apis/***center-v1;rev=6?api-version=2023-09-01-preview failed with status code 400. Content is '{"error":{"code":"ValidationError","message":"One or more fields contain incorrect values:","details":[{"code":"ValidationError","target":"path","message":"Cannot create API '***center-v1' with the same Path '***-center' as API '***center-v3'  unless it's a part of the same version set"}]}}'.

Reproduction Steps

Set the resource group to ScopeLocked for deletion in Azure APIM; after the error, the API lost the version from the base path.

Metadata

Metadata

Labels

bugSomething isn't working

Type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions