|
| 1 | +--- |
| 2 | +name: closing-obsolete-issues |
| 3 | +description: Find and close obsolete, stale, or not reproducible issues in the flutter/devtools repository. |
| 4 | +--- |
| 5 | + |
| 6 | +# Closing Obsolete Issues |
| 7 | + |
| 8 | +Use this skill to find old, outdated issues in the `flutter/devtools` repository that can be closed because they have been fixed, are stale, obsolete, or not reproducible. |
| 9 | + |
| 10 | +## Instructions |
| 11 | + |
| 12 | +1. **Identify Target Issues**: |
| 13 | + - Use the GitHub CLI (`gh`) to search for the oldest open issues. |
| 14 | + - Use any label that the user gives you, or none if the user does not specify any issue labels. |
| 15 | + - Sort by creation date (`created-asc`) or last update (`updated-asc`) to find the most likely candidates for being outdated. |
| 16 | + - Fetch at least 20-30 candidates. |
| 17 | + - Example command (with label): `gh issue list --repo flutter/devtools --search "label:bug is:open sort:created-asc" --limit 30 | cat` |
| 18 | + - Example command (without label): `gh issue list --repo flutter/devtools --search "is:open sort:created-asc" --limit 30 | cat` |
| 19 | + |
| 20 | +2. **Investigate Status**: |
| 21 | + - For each candidate, analyze its description and comments. |
| 22 | + - **Pro Tip**: Use the bundled script `scripts/fetch_issue_details.sh <number>` to get a comprehensive view of the issue and its comments. |
| 23 | + - Compare the issue's request or reported bug with the current state of the codebase. |
| 24 | + - Refer to `references/rationale_templates.md` for a library of common reasons issues become outdated in DevTools. |
| 25 | + - **Safety Rule**: Do not assume a bug is fixed or obsolete just because the screen has been updated or the file modified. Verify if the specific bug behavior is still possible. Valid bugs or feature requests should not be closed as stale just because they are old or have no activity. Inactivity alone does not invalidate a feature request or bug report. |
| 26 | + |
| 27 | +3. **Draft and Review Closing Comments (CRITICAL MANDATE)**: |
| 28 | + - For issues identified as candidates for closing, draft a detailed comment for each explaining *why* it can be closed. |
| 29 | + - **Style Constraint**: DO NOT use em dashes (—) in the comments. Use hyphens (-) or colons (:) instead. |
| 30 | + - **Template**: Consult `references/rationale_templates.md` for wording inspiration. |
| 31 | + - Each comment MUST end with: "If there is more work to do here, please let us know by filing a new issue with up to date information. Thanks!" |
| 32 | + - **User Approval Required**: You MUST present the identified issues (including URLs to the issues for easy navigation) and their drafted comments to the user and obtain explicit approval BEFORE running any command that closes an issue. |
| 33 | + |
| 34 | +4. **Iterate on Skill Knowledge (Learning Loop)**: |
| 35 | + - If you discover a new, distinct category of closing rationale that is not covered in `references/rationale_templates.md`, **update the reference file** to include it. |
| 36 | + |
| 37 | +5. **Execute and Summarize**: |
| 38 | + - Once approved, use `gh issue close` with the `-c` flag to post the comment and close the issue. |
| 39 | + - Provide the user with a clean bulleted list of links to each closing comment. |
| 40 | + |
| 41 | +## Tips |
| 42 | + |
| 43 | +- Use available file and content search tools (such as `grep`, `ripgrep`, or environment-specific |
| 44 | +search tools) to check the current codebase for references to the issue or relevant code. |
| 45 | +- Look for related PRs that might have fixed the issue but didn't close it automatically. |
| 46 | +- **Pro Tip**: Use the bundled script `scripts/search_prs.sh <query>` to search for PRs in the repository. |
| 47 | +- For issues reporting specific versions, check the current DevTools version in `packages/devtools_app/pubspec.yaml` |
| 48 | +to determine if the reported version is very old. If the reported version is 1 or more major versions behind or 12 or more |
| 49 | +minor versions behind the current version, this issue is a good candidate for being obsolete. |
0 commit comments