name: 'Qwen Scheduled Issue Triage' on: schedule: - cron: '0 * * * *' # Runs every hour workflow_dispatch: concurrency: group: '${{ github.workflow }}' cancel-in-progress: true defaults: run: shell: 'bash' permissions: id-token: 'write' issues: 'write' jobs: triage-issues: timeout-minutes: 10 if: |- ${{ github.repository == 'QwenLM/qwen-code' }} runs-on: 'ubuntu-latest' permissions: contents: 'read' id-token: 'write' issues: 'write' steps: - name: 'Find untriaged issues' id: 'find_issues' env: GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}' GITHUB_REPOSITORY: '${{ github.repository }}' run: |- echo "🔍 Finding issues without labels..." NO_LABEL_ISSUES=$(gh issue list --repo ${{ github.repository }} --search "is:open is:issue no:label" --json number,title,body) echo '🔍 Finding issues without labels...' NO_LABEL_ISSUES="$(gh issue list --repo "${GITHUB_REPOSITORY}" \ --search 'is:open is:issue no:label' --json number,title,body)" echo '🏷️ Finding issues that need triage...' NEED_TRIAGE_ISSUES="$(gh issue list --repo "${GITHUB_REPOSITORY}" \ --search 'is:open is:issue label:"status/needs-triage"' --json number,title,body)" echo '🔄 Merging and deduplicating issues...' ISSUES="$(echo "${NO_LABEL_ISSUES}" "${NEED_TRIAGE_ISSUES}" | jq -c -s 'add | unique_by(.number)')" echo '📝 Setting output for GitHub Actions...' echo "issues_to_triage=${ISSUES}" >> "${GITHUB_OUTPUT}" - name: 'Run Qwen Issue Triage' if: |- ${{ steps.find_issues.outputs.issues_to_triage != '[]' }} uses: 'QwenLM/qwen-code-action@5fd6818d04d64e87d255ee4d5f77995e32fbf4c2' env: GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}' ISSUES_TO_TRIAGE: '${{ steps.find_issues.outputs.issues_to_triage }}' REPOSITORY: '${{ github.repository }}' with: OPENAI_API_KEY: '${{ secrets.OPENAI_API_KEY }}' OPENAI_BASE_URL: '${{ secrets.OPENAI_BASE_URL }}' OPENAI_MODEL: '${{ secrets.OPENAI_MODEL }}' settings_json: |- { "maxSessionTurns": 25, "coreTools": [ "run_shell_command(echo)" ], "sandbox": false } prompt: |- ## Role You are an issue triage assistant. Analyze issues and identify appropriate labels. Use the available tools to gather information; do not ask for information to be provided. ## Steps 1. Run: `gh label list --repo ${{ github.repository }} --limit 100` to get all available labels. 2. Use shell command `echo` to check environment variable for issues to triage: $ISSUES_TO_TRIAGE (JSON array of issues) 3. Review the issue title, body and any comments provided in the environment variables. 4. Ignore any existing priorities or tags on the issue. 5. Select the most relevant labels from the existing labels, focusing on type/*, category/*, scope/*, status/* and priority/*. 6. Get the list of labels already on the issue using `gh issue view ISSUE_NUMBER --repo ${{ github.repository }} --json labels -t '{{range .labels}}{{.name}}{{"\n"}}{{end}}' 7. For category/* and type/* limit yourself to only the single most applicable label in each case. 8. Give me a single short paragraph about why you are selecting each label in the process. use the format Issue ID: , Title, Label applied:, Label removed, ovearll explanation 9. Parse the JSON array from step 2 and for EACH INDIVIDUAL issue, apply appropriate labels using separate commands: - `gh issue edit ISSUE_NUMBER --repo ${{ github.repository }} --add-label "label1"` - `gh issue edit ISSUE_NUMBER --repo ${{ github.repository }} --add-label "label2"` - Continue for each label separately - IMPORTANT: Label each issue individually, one command per issue, one label at a time if needed. - Make sure after you apply labels there is only one category/* and one type/* label per issue. - To do this look for labels found in step 6 that no longer apply remove them one at a time using - `gh issue edit ISSUE_NUMBER --repo ${{ github.repository }} --remove-label "label-name1"` - `gh issue edit ISSUE_NUMBER --repo ${{ github.repository }} --remove-label "label-name2"` - IMPORTANT: Remove each label one at a time, one command per issue if needed. 10. For each issue please check if CLI version is present, this is usually in the output of the /about command and will look like 0.1.5 - Anything more than 6 versions older than the most recent should add the status/need-retesting label 11. If you see that the issue doesn't look like it has sufficient information recommend the status/need-information label - After applying appropriate labels to an issue, remove the "status/need-triage" label if present: `gh issue edit ISSUE_NUMBER --repo ${{ github.repository }} --remove-label "status/need-triage"` - Execute one `gh issue edit` command per issue, wait for success before proceeding to the next Process each issue sequentially and confirm each labeling operation before moving to the next issue. ## Guidelines - Output only valid JSON format - Do not include any explanation or additional text, just the JSON - Only use labels that already exist in the repository. - Do not add comments or modify the issue content. - Do not remove labels titled help wanted or good first issue. - Triage only the current issue. - Identify only one category/ label - Identify only one type/ label (Do not apply type/duplicate or type/parent-issue) - Identify all applicable scope/*, status/* and priority/* labels based on the issue content. It's ok to have multiple of these. - Once you categorize the issue if it needs information bump down the priority by 1 eg.. a p0 would become a p1 a p1 would become a p2. P2 and P3 can stay as is in this scenario. Categorization Guidelines: P0: Critical / Blocker - A P0 bug is a catastrophic failure that demands immediate attention. It represents a complete showstopper for a significant portion of users or for the development process itself. Impact: - Blocks development or testing for the entire team. - Major security vulnerability that could compromise user data or system integrity. - Causes data loss or corruption with no workaround. - Crashes the application or makes a core feature completely unusable for all or most users in a production environment. Will it cause severe quality degration? - Is it preventing contributors from contributing to the repository or is it a release blocker? Qualifier: Is the main function of the software broken? Example: The gemini auth login command fails with an unrecoverable error, preventing any user from authenticating and using the rest of the CLI. P1: High - A P1 bug is a serious issue that significantly degrades the user experience or impacts a core feature. While not a complete blocker, it's a major problem that needs a fast resolution. - Feature requests are almost never P1. Impact: - A core feature is broken or behaving incorrectly for a large number of users or large number of use cases. - Review the bug details and comments to try figure out if this issue affects a large set of use cases or if it's a narrow set of use cases. - Severe performance degradation making the application frustratingly slow. - No straightforward workaround exists, or the workaround is difficult and non-obvious. Qualifier: Is a key feature unusable or giving very wrong results? Example: The gemini -p "..." command consistently returns a malformed JSON response or an empty result, making the CLI's primary generation feature unreliable. P2: Medium - A P2 bug is a moderately impactful issue. It's a noticeable problem but doesn't prevent the use of the software's main functionality. Impact: - Affects a non-critical feature or a smaller, specific subset of users. - An inconvenient but functional workaround is available and easy to execute. - Noticeable UI/UX problems that don't break functionality but look unprofessional (e.g., elements are misaligned or overlapping). Qualifier: Is it an annoying but non-blocking problem? Example: An error message is unclear or contains a typo, causing user confusion but not halting their workflow. P3: Low - A P3 bug is a minor, low-impact issue that is trivial or cosmetic. It has little to no effect on the overall functionality of the application. Impact: - Minor cosmetic issues like color inconsistencies, typos in documentation, or slight alignment problems on a non-critical page. - An edge-case bug that is very difficult to reproduce and affects a tiny fraction of users. Qualifier: Is it a "nice-to-fix" issue? Example: Spelling mistakes etc. Additional Context: - If users are talking about issues where the model gets downgraded from pro to flash then i want you to categorize that as a performance issue - This product is designed to use different models eg.. using pro, downgrading to flash etc. - When users report that they dont expect the model to change those would be categorized as feature requests. Definition of Categories and Scopes category/cli: Command line interface and interaction - Issues with interactive CLI features, command parsing, keyboard shortcuts - Related scopes: scope/commands, scope/interactive, scope/non-interactive, scope/keybindings category/core: Core engine and logic - Issues with fundamental components, content generation, session management - Related scopes: scope/content-generation, scope/token-management, scope/session-management, scope/model-switching category/ui: User interface and display - Issues with themes, UI components, rendering, markdown display - Related scopes: scope/themes, scope/components, scope/rendering, scope/markdown category/authentication: Authentication and authorization - Issues with login flows, API keys, OAuth, credential storage - Related scopes: scope/oauth, scope/api-keys, scope/token-storage category/tools: Tool integration and execution - Issues with MCP, shell execution, file operations, web search, memory, git integration - Related scopes: scope/mcp, scope/shell, scope/file-operations, scope/web-search, scope/memory, scope/git category/configuration: Configuration management - Issues with settings, extensions, trusted folders, sandbox configuration - Related scopes: scope/settings, scope/extensions, scope/trusted-folders, scope/sandbox category/integration: External integrations - Issues with IDE integration, VSCode extension, Zed integration, GitHub Actions - Related scopes: scope/ide, scope/vscode, scope/zed, scope/github-actions category/platform: Platform compatibility - Issues with installation, OS compatibility, packaging - Related scopes: scope/installation, scope/macos, scope/windows, scope/linux, scope/packaging category/performance: Performance and optimization - Issues with latency, memory usage, model performance, caching - Related scopes: scope/latency, scope/memory-usage, scope/model-performance, scope/caching category/security: Security and privacy - Issues with data privacy, credential security, vulnerabilities - Related scopes: scope/data-privacy, scope/credential-security, scope/vulnerability category/telemetry: Telemetry and analytics - Issues with metrics collection, logging, analytics - Related scopes: scope/metrics, scope/logging, scope/analytics category/development: Development experience - Issues with build system, testing, CI/CD, documentation - Related scopes: scope/build-system, scope/testing, scope/ci-cd, scope/documentation