ResearchPlanAssignOps
ResearchPlanAssignOps is a four-phase development pattern that moves from automated discovery to merged code with human control at every decision point. A research agent surfaces insights, a planning agent converts them into actionable issues, a coding agent implements the work by assigning issues to GitHub Copilot, and a human reviews and merges.
The Four Phases
Section titled “The Four Phases”flowchart LR
research([Research]) --> plan[Plan issues]
plan --> assign[Assign to Copilot]
assign --> merge[Review & merge]
Each phase produces a concrete artifact consumed by the next, and every transition is a human checkpoint.
Phase 1: Research
Section titled “Phase 1: Research”A scheduled workflow investigates the codebase from a specific angle and publishes its findings as a GitHub discussion. The discussion is the contract between the research phase and everything that follows—it contains the analysis, recommendations, and context a planner needs.
The go-fan workflow is a live example: it runs each weekday, picks one Go dependency, compares current usage against upstream best practices, and creates a [go-fan] discussion under the audits category.
---name: Go Fan
on: schedule: daily on weekdays workflow_dispatch:
engine: claude
safe-outputs: create-discussion: title-prefix: "[go-fan] " category: "audits" max: 1 close-older-discussions: true
tools: cache-memory: true github: toolsets: [default]---
Analyze today's Go dependency. Compare current usage in thisrepository against upstream best practices and recent releases.Save a summary to scratchpad/mods/ and create a discussionwith findings and improvement recommendations.The research agent uses cache-memory to track which modules have been reviewed so it rotates through them systematically across runs.
Phase 2: Plan
Section titled “Phase 2: Plan”After reading the research discussion, a developer triggers the /plan command on it. The plan workflow reads the discussion, extracts concrete work items, and creates up to five sub-issues grouped under a parent tracking issue.
/plan focus on the quick wins and API simplificationsThe planner formats each sub-issue for a coding agent: a clear objective, the files to touch, step-by-step implementation guidance, and acceptance criteria. Issues are tagged [plan] and ai-generated.
[!TIP] The
/plancommand accepts inline guidance. Steer it toward high-priority findings or away from lower-priority ones before it generates issues.
Phase 3: Assign
Section titled “Phase 3: Assign”With well-scoped issues in hand, the developer assigns them to Copilot for automated implementation. Copilot opens a pull request and posts progress updates as it works.
Issues can be assigned individually through the GitHub UI, or pre-assigned in bulk via an orchestrator workflow:
---name: Auto-assign plan issues to Copilot
on: issues: types: [labeled]
engine: copilot
safe-outputs: assign-to-user: target: "*" add-comment: target: "*"---
When an issue is labeled `plan` and has no assignee,assign it to Copilot and add a comment indicatingautomated assignment.For multi-issue plans, assignments can run in parallel—Copilot works independently on each issue and opens separate PRs.
Phase 4: Merge
Section titled “Phase 4: Merge”Copilot’s pull request is reviewed by a human maintainer. The maintainer checks correctness, runs tests, and merges. The tracking issue created in Phase 2 closes automatically when all sub-issues are resolved.
End-to-End Example
Section titled “End-to-End Example”A full cycle driven by go-fan:
- Monday 7 AM —
go-fanposts a discussion “[go-fan] Go Module Review: spf13/cobra” recommending context propagation via cobra’sSetContextand shared setup viaPersistentPreRunE. - Monday afternoon — A developer types
/planon the discussion. The planner opens a[plan] cobra improvementstracking issue with three sub-issues (context propagation,PersistentPreRunErefactor, cancellation tests), then assigns the first two to Copilot, which opens PRs within minutes. - Tuesday — The developer reviews the PRs, requests one minor change, and merges both. The tracking issue closes automatically.
Workflow Configuration Patterns
Section titled “Workflow Configuration Patterns”The Phase 1 example already shows the core research config (create-discussion with close-older-discussions: true, plus cache-memory). Two more safe-output knobs shape the later phases.
Plan: group sub-issues
Section titled “Plan: group sub-issues”group: true creates the parent tracking issue automatically—do not create it manually:
safe-outputs: create-issue: expires: 2d title-prefix: "[plan] " labels: [plan, ai-generated] max: 5 group: trueAssign: skip planning with assignees
Section titled “Assign: skip planning with assignees”When research produces self-contained, well-scoped issues, assign directly and skip the manual plan phase—as duplicate-code-detector does for narrow duplication fixes:
safe-outputs: create-issue: title-prefix: "[fix] " labels: [ai-generated] assignees: copilotCustomization
Section titled “Customization”Adapt the pattern by varying the research focus (static analysis, performance, documentation quality, security, code duplication, test coverage), the frequency (daily, weekly, on-demand), the report format (discussions for open-ended findings, issues for self-contained tasks), and the assignment method (pre-assign in the research workflow, bulk-assign via an orchestrator, or assign individually through the GitHub UI).
Limitations
Section titled “Limitations”The multi-phase approach takes longer than direct execution and requires developers to review research reports and generated issues. Research agents may surface findings that don’t require action (false positives), and each phase transition needs clear handoffs. Research agents often require specialized MCPs (Serena, Tavily, etc.) for deeper analysis.
When to Use ResearchPlanAssignOps
Section titled “When to Use ResearchPlanAssignOps”This pattern fits when:
- The scope of work is unknown until analysis runs
- Issues need human prioritization before implementation
- Research findings vary in quality (some runs find nothing actionable)
- Multiple work items can be executed in parallel
Prefer a simpler pattern when:
- The work is already well-defined (use IssueOps)
- Issues can go directly to Copilot without review (use the
assignees: copilotshortcut in your research workflow) - Work spans multiple repositories (use MultiRepoOps)
Existing Workflows
Section titled “Existing Workflows”| Phase | Workflow | Description |
|---|---|---|
| Research | go-fan | Daily Go dependency analysis with best-practice comparison |
| Research | copilot-cli-deep-research | Weekly analysis of Copilot CLI feature usage |
| Research | static-analysis-report | Daily security scan with clustered findings |
| Research | duplicate-code-detector | Daily semantic duplication analysis (auto-assigns) |
| Plan | plan | /plan slash command—converts issues or discussions into sub-issues |
| Assign | GitHub UI / workflow | Assign issues to Copilot for automated PR creation |
Related Documentation
Section titled “Related Documentation”- DispatchOps — Manually triggered research and one-off investigations
- WorkQueueOps — Sequential queue processing for large backlogs
- Safe Outputs — Secure write operations
- Assign to Copilot — Assigning issues to GitHub Copilot