Skip to content

Latest commit

 

History

History
94 lines (62 loc) · 6.7 KB

workflow.md

File metadata and controls

94 lines (62 loc) · 6.7 KB

Workflow

In here we describe the general workflow guidelines the NuGet developer/contributor.

Basics

Pull requests & Code reviews

To help ensure that only the highest quality code makes its way into the project, all code changes need to be submitted to GitHub as PRs.

In general a PR should be approved by a Subject Matter Expert (SME) of that code. For example, a change to the Banana project should be signed off by @Monkey, and not by @Giraffe. If you don't know the SME, someone on the team will help you identify them. Of course, sometimes it's the SME who is making a change, in which case a secondary person will have to sign off on the change (e.g. @JuniorMonkey).

To commit the PR to the repo use the GitHub Squash and Merge button. We can't stress this enough. Always use Squash and Merge unless an exception is explicitly stated in this document.

This repo has bots that manage all stale PRs. Stale PRs will be autoclosed.

  • Do follow the pull request template, as it helps the maintainers drive quality across the product.
  • Do favor having more than 1 reviewer.
  • Do not merge too quickly. Wait for at least 24h after the last significant changes before merging unless the change is urgent.
  • Do address all feedback. Not necessarily by accepting it, but by reaching a resolution with the reviewer. All comments need to be marked as resolved before merging.
  • Do use GitHub's tooling. Re-request review after all feedback has been addressed.
  • Do pay special attention to the commit message. Ensure the merge message is appropriate and helpful to the future reader. See merge commit considerations.

Pull Request Etiquette and Best Practices

  • Leaving suggested changes is welcomed, but please never commit them for a PR you did not create.
  • Make sure your intent is clear. Is your comment about just trying to understand the code? Use softer language, such as "I'm curious ...". Do you have a knowledge that the change could introduce a regression? Make your comment emphasize that!
  • For comments that are just optional suggestions or are explicitly non-blocking, prefix them with "nit: " or "non-blocking: ".
  • When to mark a PR as "Approved"
    • You feel confident that the code meets a high quality bar, has adequate test coverage, is ready to merge.
    • You have left comments that are uncontroversial and there is a shared understanding with the author that the comments can be addressed or resolved either within this PR or a follow up PR, without a significant change to the design or approach. If the author pushes a new change addressing those comments, you may need to re-approve as it's required that the latest iteration of a PR is approved.
  • When to leave comments without approval
    • You do not feel confident that your review alone is sufficient to call the PR ready to merge.
    • You have feedback that may require detailed discussion or may indicate a need to change the current design or approach in a non-trivial way.
  • When to mark a PR as "Request Changes"
    • You have significant concerns that must be addressed before this PR should be merged such as unintentional breaking changes, security issues, or potential data loss.

Merge commit considerations

GitHub merges have 2 means to specify a commit message when squash merging. Inspect both! In most scenarios, you will want to delete the commit by commit messages. Only leave the messages when they are helpful to a user in the future.

Good Commit Message

Good Commit Message With More Details

Bad Commit Message

Draft Pull Requests

Draft pull requests are allowed, but should have a clear plan for transition to a review ready pull request.

Branching strategy

The active development branch in our repo is dev. What we ship comes from the release-major.minor.x branches.

Adding fixes in release branches

NuGet primarily works on the dev branch and that's where most of the commmits will be merged. At a certain point, NuGet branches to a release branch during the release stabilization phase and the last few commits usually go into that branch.

In most cases, a fix will be originally developed on the dev branch and then moved to the release branch. When moving to the release branch the recommended approach is the following:

  • Create a new branch based on the release branch.
  • Cherry pick the commit of interest
  • Push
  • Create a Pull Request against the release branch.

The cherry-picked request does not need to be reviewed, but when the build passes it can be merged. Normally, you would only cherry pick on commit per Pull Request, so that in case a change needs reverted, only that single commit will be affected. The recommended pattern for release branches is slightly different. We should preserve the original commit message one can follow the original Pull Request.

Good Release branch Commit Message

Solution and project folder structure and naming

The NuGet.Client repo currently has only one solution file named NuGet.sln. We do not want/need to have more than one solution file. We have some Solution Filters (.slnf files), currently for projects specific to working with NuGet's Command line, VS, or UnitTests directly, and can consider more based on team and community feedback.

  • Every project in the NuGet.Client repo should be PackageReference-based based and if possible (read this as not .NET Framework WPF), an SDK-based one.
  • The production source code is under the src folder.
  • The test source code is under the test folder.
  • The files affecting build are located under the build folder.
  • The PowerShell files that are not part of the Package Manager Console are located under the scripts folder.

Follow the existing pattern for new project files (for example, if NuGet.Commands imports common.props at some point, so should NuGet.MyNewProject). Test projects have a different convention for the build customization files they import, so be mindful of that.

Project naming pattern

The general naming pattern is NuGet.<area>.<subarea>.

  • All NuGet assemblies ship together and follow the same assembly versioning, save for some exceptions like NuGet.VisualStudio.Interop.
  • All assemblies have the same name as their project.
  • All package versions are the same. No exceptions.