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

migrate issue links in source to moved issues #59187

Closed
Tracked by #59165
pq opened this issue Jun 14, 2023 · 8 comments
Closed
Tracked by #59165

migrate issue links in source to moved issues #59187

pq opened this issue Jun 14, 2023 · 8 comments
Labels
analyzer-linter Issues with the analyzer's support for the linter package area-analyzer Use area-analyzer for Dart analyzer issues, including the analysis server and code completion. P2 A bug or feature request we're likely to work on type-question A question about expected behavior or functionality type-task A well-defined stand-alone task

Comments

@pq
Copy link
Member

pq commented Jun 14, 2023

I admit I don't totally know what's involved here so I'd very much welcome insights. The rub is in source we've got a handful of issue references that will need to be evaluated and updated when we migrate issues to the SDK tracker. Some are probably stale and can reasonably be deleted but in at least the case of failing tests annotated like this:

  @FailingTest(issue: 'https://github.com/dart-lang/linter/issues/3516')
  test_matchingArg_dynamicParameterToOtherArg_positional() async { ... }

I would like to preserve the context of linked issues.

@srawlins: not sure if this is an issue for dartdoc, but FYI.

Also fyi @parlough, in case you have any thoughts.

@pq pq added type-question A question about expected behavior or functionality P2 A bug or feature request we're likely to work on type-task A well-defined stand-alone task labels Jun 14, 2023
@parlough
Copy link
Member

parlough commented Jun 14, 2023

I just tried moving an issue between repositories, and it seems if you use GitHub's built-in transfer functionality, it preserves the issue timeline and adds a redirect from the original repository's issue link to the new location.

Perhaps a little script to run that transfer for every issue, and once transferred add the area-analyzer and analyzer-linter labels?

Then those old issue references will still work and can be revisited/updated as needed?

Edit: I'm however not sure if this persists if/when the linter is moved to the dart-archive organization, but those redirects usually work fine, so I'm assuming they will continue to work.

@srawlins
Copy link
Member

Yeah we should just use GitHub's "Transfer issue", available with the GitHub commandline tool.

Old issue URLs are preserved as redirects to the new ones, so we don't have to clean up references. We can but we don't have to.

@srawlins
Copy link
Member

This script looks good for bulk transfering: https://jloh.co/posts/bulk-migrate-issues-github-cli/

@pq
Copy link
Member Author

pq commented Jun 14, 2023

Awesome! Hopefully these redirects will work even when a repo is archived? 🤞

@whesse
Copy link
Contributor

whesse commented Jun 28, 2023

I am not worried about migrating the issues. That can be done or not done.

But the issue references in the commit messages (and the pr references, in almost every commit) are of the form #1234 and implicitly refer to the current repository. So they will all change to refer to SDK issues. When merging (adding the commits to the SDK repo), I think there will be notifications on all the SDK issues that these refer to, that there is a new commit that references them.

The documentation for autolinked references is
https://docs.github.com/en/get-started/writing-on-github/working-with-advanced-formatting/autolinked-references-and-urls

A tool that could rewrite the commit messages to expand them all to include the original repo, so #1234 would go to dart-lang/linter#1234, is

https://github.com/newren/git-filter-repo/

An example of using regexps to modify the commit message is at
https://github.com/newren/git-filter-repo/blob/main/Documentation/git-filter-repo.txt#L762

@sigurdm gave me this information.

@whesse
Copy link
Contributor

whesse commented Jun 28, 2023

We are already getting spurious notifications on old SDK issues, when a DEPS roll has a commit message that includes the titles of the commits we are rolling to.

If those commit titles, copied into the DEPS roll commit message, have PR numbers, then the SDK issue with that number gets a notification that a commit mentioning them has been uploaded, see the example at issue #3453

@whesse
Copy link
Contributor

whesse commented Aug 4, 2023

I modified all the issue links in the linter repo to read dart-lang/linter[hash symbol]1234 instead of [hash symbol]1234, and uploaded it to https://github.com/whesse/linter . There were 2595 cases where I added dart-lang/linter, and 49 cases where the issue reference was already to a different repo. Take a look and see if it looks good to you.

@pq
Copy link
Member Author

pq commented Aug 4, 2023

LGTM! (fyi @stereotype441)

@pq pq closed this as completed Aug 31, 2023
@devoncarew devoncarew added analyzer-linter Issues with the analyzer's support for the linter package area-analyzer Use area-analyzer for Dart analyzer issues, including the analysis server and code completion. labels Nov 19, 2024
@devoncarew devoncarew transferred this issue from dart-lang/linter Nov 19, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
analyzer-linter Issues with the analyzer's support for the linter package area-analyzer Use area-analyzer for Dart analyzer issues, including the analysis server and code completion. P2 A bug or feature request we're likely to work on type-question A question about expected behavior or functionality type-task A well-defined stand-alone task
Projects
None yet
Development

No branches or pull requests

5 participants