Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[PR Workflow] Automatic ARM sign-off for TypeSpec-based PRs #7352

Open
rkmanda opened this issue Nov 29, 2023 · 11 comments
Open

[PR Workflow] Automatic ARM sign-off for TypeSpec-based PRs #7352

rkmanda opened this issue Nov 29, 2023 · 11 comments
Assignees
Labels
Central-EngSys This issue is owned by the Engineering System team. openapi-alps Items pertaining to https://devdiv.visualstudio.com/DevDiv/_git/openapi-alps/ Spec PR Tools Tooling that runs in azure-rest-api-specs repo. specs-model Issues requiring logic to be implemented by https://github.com/Azure/azure-sdk-tools/issues/8203

Comments

@rkmanda
Copy link
Member

rkmanda commented Nov 29, 2023

We have now reached a state with the set of linter rule automation that have been put in place where we can start enabling more self-serve scenarios and simplify the PR review process for RP owners.

The first step towards this is to automatically sign-off the PRs that are raised for open api specs that are generated from Typespec. After reviewing a bunch of PRs that were created for Typespec based PRs, we have reached a conclusion that we can automatically sign-off these PRs without requiring a manual review.

Criteria to be met for an automatic sign-off

Mechanism to indicate sign-off

  • Add a new label when the above criteria is met, label name suggestion - "ARMAutomaticSignOff".
  • The automated merging criteria needs to take this label into account. The existence of one of ARMSignedOff or ARMAutomaticSignOff labels will be used as a way to determine whether the PR was signed off by ARM.

Prerequisites before this automation is put in place in production

  • One final linter rule update to production by end of November that has some important fixes

Edit by kojamroz:

Related doc in ARM wiki:

  • Pull Request 9459836: API review best practice and self attestation checklist for Typespec based PRs
@github-actions github-actions bot added the needs-triage Workflow: This is a new issue that needs to be triaged to the appropriate team. label Nov 29, 2023
@konrad-jamrozik konrad-jamrozik added Central-EngSys This issue is owned by the Engineering System team. Spec PR Tools Tooling that runs in azure-rest-api-specs repo. and removed needs-triage Workflow: This is a new issue that needs to be triaged to the appropriate team. labels Nov 29, 2023
@konrad-jamrozik konrad-jamrozik moved this from 🤔 Triage to 📋 Backlog in Azure SDK EngSys 🚢🎉 Nov 29, 2023
@konrad-jamrozik konrad-jamrozik moved this to 📋 Backlog in Spec PR Tools Nov 29, 2023
@konrad-jamrozik
Copy link
Contributor

@rkmanda by this:

No errors reported by the linter rules

Do you mean all linters? These:

  • Swagger LintDiff
  • Swagger LintDiff(RPaaS)
  • TypeSpec Validation
  • Swagger PtettierCheck
  • Swagger SpellCheck
  • Swagger SemanticValidation
  • Swagger ModelValidation
  • Swagger Breaking Change
  • Breaking Change(Cross-Version)

@rkmanda
Copy link
Member Author

rkmanda commented Nov 29, 2023

Sorry I meant the Swagger Lintdiff and Swagger Lintdiff (RPaaS) linter rules @konrad-jamrozik

@konrad-jamrozik
Copy link
Contributor

konrad-jamrozik commented Nov 29, 2023

Note: we will also have to update the https://aka.ms/azsdk/pr-diagram and automated PR comments appropriately.

@konrad-jamrozik konrad-jamrozik changed the title Automatic ARM sign-off for Typespec based PRs [PR Workflow] Automatic ARM sign-off for Typespec based PRs Nov 29, 2023
@konrad-jamrozik konrad-jamrozik added the openapi-alps Items pertaining to https://devdiv.visualstudio.com/DevDiv/_git/openapi-alps/ label Nov 29, 2023
@konrad-jamrozik konrad-jamrozik changed the title [PR Workflow] Automatic ARM sign-off for Typespec based PRs [PR Workflow] Automatic ARM sign-off for TypeSpec based PRs Dec 5, 2023
@konrad-jamrozik
Copy link
Contributor

Bumping to high priority, per @rkmanda. Ideally, to be done by March 2024 at the latest.

@konrad-jamrozik
Copy link
Contributor

konrad-jamrozik commented Dec 8, 2023

Relevant email thread: RE: Discuss automated sign off for Typespec based PRs

The work that needs to be prioritized to make the switch is as follows

  • Identify the labels that will be added to the PR as an indication of the automated sign-off
  • Make changes to the Automated merging requirement check OR any other appropriate trigger to add the agreed upon label(s) once the criteria is met. The criteria for sign-off is as follows
    • Indication that the open api spec was generated using Typespec
    • Step 1 of the PR is approved by breaking change reveiewers
    • No errors are flagged by the swagger lintdiff check
    • No errors are flagged by the Typespec required validation

@konrad-jamrozik
Copy link
Contributor

konrad-jamrozik commented Jan 11, 2024

Currently aiming for turning on the automatic sign-offs at the beginning of February 2024 per the call we just had.

Meeting notes and action items:

  • There were no blockers identified to put the automated ARM sign off in place.
  • We need a list of considerations for the author to be responsible for to be surfaced with the automated sign off.
  • Roopesh Manda has a work item to address this in January.
  • The list of considerations, best practices needs to include a set that captures the client side implications - Mark Cowlishaw to open a work item to address this in January.
  • Konrad to work on the changes required for the automated sign off with a rough ETA of end of January.
    • Additional criteria to be captured for the automated signoff:
    • There should not be any suppressions applied by the author for the Swagger lintdiff checks.

Thanks
Roopesh

@konrad-jamrozik
Copy link
Contributor

konrad-jamrozik commented Feb 22, 2024

We have identified additional work that needs to happen before we can complete this work item. I aggregated it in this issue:

@rkmanda FYI

@rkmanda
Copy link
Member Author

rkmanda commented Feb 27, 2024

Criteria for automated sign-off

  • PR represents incremental changes to an existing resource provider
    The first PR for a new resource provider will still go thru the usual manual review process.
  • Swagger lintdiff check passes for the PR
    This is to ensure that all mandatory guidelines that we as the control plane platform care about are being adhered to.
  • No swagger lintdiff suppressions are applied to the PR
    If any suppressions are applied to these PRs, they will go thru a manual approval process because applying suppressions indicates that some of the mandatory guidelines are attempted to be violated.
  • Authors self-attest the adherence to design best practices that are not automated.
  • (added by kojamroz on 6/11/2024) Not a conversion to TypeSpec.

@konrad-jamrozik konrad-jamrozik changed the title [PR Workflow] Automatic ARM sign-off for TypeSpec based PRs [PR Workflow] Automatic ARM sign-off for TypeSpec-based PRs Feb 27, 2024
@konrad-jamrozik
Copy link
Contributor

konrad-jamrozik commented May 23, 2024

I had a chat @rkmanda. I will provide here a quick summary and elaborate on details later.

TL;DR: Work to do: need a bit extra logic to determine "is this completely new ARM RP doing TypeSpec for the first time?" If not, allow folks to skip arm review, self-attest with label, and merge.

This work item is the most urgent work, above any work related to TypeSpec conversion PRs.

Re:

PR represents incremental changes to an existing resource provider
The first PR for a new resource provider will still go thru the usual manual review process.

If a PR is new for given resource provider then we shall still require a TypeSpec sign-off. The converse is an incremental change for given resource provider.

To figure out which service provider is new, we will piggy-back on the implementation in openapi-alps that determines the label new-rp-provider. Going forward the idea is to require all new service specs dirs of stable and preview to be added under specification/teamName/resource-manager/RPNS/serviceName/ as opposed to the current model of specification/teamName/resource-manager/. See specification/confidentialledger for the old model and specification/containerservice for the new model. ARM is OK with this.

The tooling still need to handle existing cases. If the tooling detects a new service being added to existing RPNS that already has other services, the tooling should still consider this a new service, even though it is in existing RPNS. To do this, the tooling should look at what is inside RPNS folder. If it does not see stable or preview, then it knows it will be a new service in existing RPNS and hence requires a review.

Such validation will happen within public main, private main, and private RPaaSMaster, and it will not compare to any other branches. I.e. each of these 3 branches needs to look only at its contents to do the validation.

Re:

  • Swagger lintdiff check passes for the PR
    This is to ensure that all mandatory guidelines that we as the control plane platform care about are being adhered to.
  • No swagger lintdiff suppressions are applied to the PR
    If any suppressions are applied to these PRs, they will go thru a manual approval process because applying suppressions indicates that some of the mandatory guidelines are attempted to be violated.
  • Authors self-attest the adherence to design best practices that are not automated

If the tooling determines it is an incremental PR and there are no LintDiff issues nor LintDiff suppressions, then ARM review is effectively skipped. The author however will need to add some label that confirms they self-attested they followed the guidelines, only then PR will be unblocked. This is a bit similar to my work item on data-plane merges to public main where we will demand a label the PR author acknowledges they are releasing the spec to public customers.

We are going to stay with some form of "suppression review required" and "suppression review approved" as it proves to be difficult to diffuse the knowledge to ARM reviewers they should look at the suppression changes before they do ARM sign-off. These labels are forcing function that cannot be achieved differently, not even with appropriate line in next steps to merge comment. Related work:

We may consider adding a functionality that will remove ARMSignedOff label if the PR requires LintDiff suppression approval which was not given.

One more note on terminology:

Previously a directory like this one:

specification/containerservice/resource-manager/RPNS/aks was named "service group" but in reality it is "resource type group".
So this:

  • specification/containerservice/resource-manager/RPNS/aks
  • specification/containerservice/resource-manager/RPNS/fleet

Was a effectively a "set of two resource type groups".

Going forward we can fix the terminology and call such aks folder as a "service" folder under given RPNS. Then RPNS will effectively be equivalent to "service group" (service group composed of aks service and fleet service in the example above). ARM is OK with this. Update: the cleaned-up terminology was captured in:

@konrad-jamrozik
Copy link
Contributor

The core part of this work is implementing support for this:

PR represents incremental changes to an existing resource provider
The first PR for a new resource provider will still go thru the usual manual review process.

I am going to do it by implementing support for it inside the "semantic dir structure model" component which needs to be implemented itself:

and then adding appropriate GitHub check calling into this component, similar to this:

@konrad-jamrozik konrad-jamrozik moved this from 📋 Backlog to 🐝 Dev in Azure SDK EngSys 🚢🎉 Jun 11, 2024
@konrad-jamrozik konrad-jamrozik moved this from 📋 Backlog to 🐝 In Progress in Spec PR Tools Jun 11, 2024
@konrad-jamrozik konrad-jamrozik moved this from 🐝 In Progress to 📋 Backlog in Spec PR Tools Jun 27, 2024
@konrad-jamrozik konrad-jamrozik moved this from 🐝 Dev to 📋 Backlog in Azure SDK EngSys 🚢🎉 Jun 27, 2024
@konrad-jamrozik konrad-jamrozik added the specs-model Issues requiring logic to be implemented by https://github.com/Azure/azure-sdk-tools/issues/8203 label Jul 13, 2024
@mikeharder mikeharder moved this from 📋 Backlog to 🐝 Dev in Azure SDK EngSys 🚢🎉 Aug 16, 2024
@mikeharder mikeharder assigned rkmanda and unassigned mikeharder Oct 21, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Central-EngSys This issue is owned by the Engineering System team. openapi-alps Items pertaining to https://devdiv.visualstudio.com/DevDiv/_git/openapi-alps/ Spec PR Tools Tooling that runs in azure-rest-api-specs repo. specs-model Issues requiring logic to be implemented by https://github.com/Azure/azure-sdk-tools/issues/8203
Projects
None yet
Development

No branches or pull requests

3 participants