All contributions to dotnet/runtime repo are made via pull requests (PRs) rather than through direct commits. The pull requests are reviewed and merged by the repository maintainers after a review and approval from at least one area maintainer.
To merge pull requests, you must have write permissions in the repository. If you are a member of the .NET team or have an official partnership you can request access here.
- Do not mix unrelated changes in one pull request. For example, a code style change should never be mixed with a bug fix.
- All changes should follow the existing code style. You can read more about different code styles at docs/coding-guidelines.
- Use Draft pull requests for changes you are still working on but want early CI loop feedback. When you think your changes are ready for review, change the status of your pull request.
- Avoid rebasing your changes. If you are asked to make changes during the review process do them as a new commit.
Every pull request will have automatically a single area-*
label assigned. The label not only indicates the code segment which the change touches but also the owner. We maintain a list of areas owners for all dotnet/runtime labels. They are responsible for landing pull requests in their area in a timely manner and for helping contributors with their submitted pull request. You can ask them for assistance if you need help with landing your changes.
If during the code review process a merge conflict occurs the area owner is responsible for its resolution. Pull requests should not be on hold due to the author's unwillingness to resolve code conflicts. GitHub makes this easier by allowing simple conflict resolution using the conflict-editor.
Anyone with write access can merge a pull request manually or by setting the auto-merge label when it satisfies all of the following conditions:
- The PR has been approved by at least one reviewer and any other objections are addressed.
- You can request another review from the original reviewer.
- The PR successfully builds and passes all tests in the Continuous Integration (CI) system.
- Depending on your change, you may need to re-run validation. See rerunning validation below.
Typically, PRs are merged as one commit. It creates a simpler history than a Merge Commit. "Special circumstances" are rare, and typically mean that there are a series of cleanly separated changes that will be too hard to understand if squashed together, or for some reason we want to preserve the ability to bisect them.
Validation may fail for several reasons:
- Simply push the fix to your PR branch, and validation will start over.
- Your assumption should be that a failed test indicates a problem in your PR. (If we don't operate this way, chaos ensues.) If the test fails when run again, it is almost surely a failure caused by your PR. However, there are occasions where unrelated failures occur. Here's some ways to know:
- Perhaps you see the same failure in CI results for unrelated active PR's.
- It's a known issue listed in our big tracking issue or tagged
blocking-clean-ci
(query here) - Its otherwise beyond any reasonable doubt that your code changes could not have caused this.
- If the tests pass on rerun, that may suggest it's not related.
- In this situation, you want to re-run but not necessarily rebase on main.
- To rerun just the failed leg(s):
- Click on any leg. Navigate through the Azure DevOps UI, find the "..." button and choose "Retry failed legs"
- Or, on the GitHub Checks tab choose "re-run failed checks". This will not rebase your change.
- To rerun all validation:
- Add a comment
/azp run runtime
- Or, click on "re-run all checks" in the GitHub Checks tab
- Or, simply close and reopen the PR.
- Add a comment
- To rerun just the failed leg(s):
- If you have established that it is an unrelated failure, please ensure we have an active issue for it. See the unrelated failure section below.
- Whoever merges the PR should be satisfied that the failure is unrelated, is not introduced by the change, and that we are appropriately tracking it.
- This is the very rare case where there was a build break in main, and you got unlucky. Hopefully the break has been fixed, and you want CI to rebase your change and rerun validation.
- To rebase and rerun all validation:
- Add a comment
/azp run runtime
- Or, click on "re-run all checks" in the GitHub Checks tab
- Or, simply close and reopen the PR.
- Or, ammend your commit with
--amend --no-edit
and force push to your branch.
- Add a comment
- You can list the available pipelines by adding a comment like
/azp list
or get the available commands by adding a comment likeazp help
. - In the rare case the license/cla check fails to register a response, it can be rerun by issuing a GET request to
https://cla.dotnetfoundation.org/check/dotnet/runtime?pullRequest={pr_number}
. A successful response may be a redirect tohttps://github.com
. - Reach out to the infrastructure team for assistance on Teams channel (for corpnet users) or on Gitter in other cases.
If you have determined the failure is definitely not caused by changes in your PR, please do this:
- Search for an existing issue. Usually the test method name or (if a crash/hang) the test assembly name are good search parameters.
- If there's an existing issue, add a comment with
- a) the link to the build
- b) the affected configuration (ie
net6.0-windows-Release-x64-Windows.81.Amd64.Open
) - c) all console output including the error message and stack trace from the Azure DevOps tab (This is necessary as retention policies are in place that recycle old builds.)
- d) if there's a dump file (see Attachments tab in Azure DevOps) include that
- If the issue is already closed, reopen it and update the labels to reflect the current failure state.
- If there's no existing issue, create an issue with the same information listed above.
- Update the original pull request with a comment linking to the new or existing issue.
- If there's an existing issue, add a comment with
- In a follow-up Pull Request, disable the failing test(s) with the corresponding issue link tracking the disable.
- Update the tracking issue with the label
disabled-test
. - For libraries tests add a
[ActiveIssue(link)]
attribute on the test method. You can narrow the disabling down to runtime variant, flavor, and platform. For an example see File_AppendAllLinesAsync_Encoded - For runtime tests found under
src/tests
, please editissues.targets
. There are several groups for different types of disable (mono vs. coreclr, different platforms, different scenarios). Add the folder containing the test and issue mimicking any of the samples in the file.
- Update the tracking issue with the label
There are plenty of possible bugs, e.g. race conditions, where a failure might highlight a real problem and it won't manifest again on a retry. Therefore these steps should be followed for every iteration of the PR build, e.g. before retrying/rebuilding.
If for whatever reason you would like to move your pull request back to an in-progress status to avoid merging it in the current form, you can do that by adding [WIP] prefix to the pull request title.
From time to time we will review older PR's (> 1 month) and check them for relevance. If we find the PR is inactive or no longer applies, we will close it. As the PR owner, you can simply reopen it if you feel your closed PR needs our attention.