Flussi di lavoro
Questa guida copre i pattern di flusso di lavoro comuni per OpenSpec e quando utilizzare ciascuno di essi. Per la configurazione di base, consulta Guida introduttiva. Per il riferimento ai comandi, consulta Comandi.
Filosofia: Azioni, non fasi
I flussi di lavoro tradizionali ti costringono a passare attraverso fasi: pianificazione, poi implementazione, poi completamento. Ma il lavoro reale non si adatta perfettamente a queste caselle.
OPSX adotta un approccio diverso:
text
Tradizionale (a fasi bloccate):
PIANIFICAZIONE ────────► IMPLEMENTAZIONE ────────► COMPLETATO
│ │
│ "Non si può tornare" │
└────────────────────────┘
OPSX (azioni fluide):
proposta ──► specifiche ──► progettazione ──► compiti ──► implementazionePrincipi chiave:
- Azioni, non fasi - I comandi sono cose che puoi fare, non stadi in cui sei bloccato
- Le dipendenze sono abilitatori - Mostrano cosa è possibile, non cosa è richiesto successivamente
Personalizzazione: I flussi di lavoro OPSX sono guidati da schemi che definiscono sequenze di artefatti. Consulta Personalizzazione per i dettagli sulla creazione di schemi personalizzati.
Due Modalità
Percorso Rapido Predefinito (profilo core)
Le nuove installazioni utilizzano per impostazione predefinita core, che fornisce:
/opsx:propose/opsx:explore/opsx:apply/opsx:sync/opsx:archive
Flusso tipico:
text
/opsx:propose ──► /opsx:apply ──► /opsx:sync ──► /opsx:archiveFlusso di Lavoro Espanso/Completo (selezione personalizzata)
Se desideri comandi espliciti per scaffold e build (/opsx:new, /opsx:continue, /opsx:ff, /opsx:verify, /opsx:bulk-archive, /opsx:onboard, /opsx:onboard), abilitali con:
bash
openspec config profile
openspec updatePattern di Flusso di Lavoro (Modalità Espansa)
Funzionalità Rapida
Quando sai cosa vuoi costruire e devi solo eseguire:
text
/opsx:new ──► /opsx:ff ──► /opsx:apply ──► /opsx:verify ──► /opsx:archiveEsempio di conversazione:
text
You: /opsx:new add-logout-button
AI: Created openspec/changes/add-logout-button/
Ready to create: proposal
You: /opsx:ff
AI: Creating all planning artifacts...
✓ proposal.md
✓ specs/
✓ design.md
✓ tasks.md
Ready for implementation!
You: /opsx:apply
AI: Working through tasks...
✓ Added logout button to header
✓ Implemented session clearing
✓ Added confirmation dialog
All tasks complete!
You: /opsx:archive
AI: ✓ Merged specs
✓ Archived changeIdeale per: Funzionalità da piccole a medie, correzione di bug, modifiche dirette.
Esplorativo
Quando i requisiti non sono chiari o è necessario prima investigare:
text
/opsx:explore ──► /opsx:new ──► /opsx:continue ──► ... ──► /opsx:applyEsempio di conversazione:
text
You: /opsx:explore
AI: What would you like to explore?
You: I want to improve page load performance but I'm not sure
where the bottlenecks are.
AI: Let me help investigate...
[Analyzes bundle sizes, identifies slow queries, reviews
component render patterns]
I found three main bottlenecks:
1. Large unoptimized images
2. Synchronous data fetching in ProductList
3. Re-renders from context changes
Which would you like to address first?
You: Let's tackle the data fetching issue.
You: /opsx:new optimize-product-list-fetching
AI: Created change. Ready to create: proposal
You: /opsx:continue
AI: Creating proposal based on our exploration...
[Writes proposal incorporating investigation insights]
Ready to create: specs, design
Which would you like next?
You: /opsx:continue
AI: Creating specs...Ideale per: Ottimizzazione delle prestazioni, debugging, decisioni architetturali, requisiti non chiari.
Modifiche in Parallelo
Lavora su più modifiche contemporaneamente:
text
Modifica A: /opsx:new ──► /opsx:ff ──► /opsx:apply (in corso)
│
cambio contesto
│
Modifica B: /opsx:new ──► /opsx:ff ──────► /opsx:applyEsempio di conversazione:
text
You: I'm working on add-dark-mode but got pulled into a bug fix
You: /opsx:new fix-login-redirect
AI: Created openspec/changes/fix-login-redirect/
You: /opsx:ff
AI: ✓ Created planning artifacts
You: /opsx:apply
AI: Working on fix-login-redirect...
[Implements the fix]
All tasks complete!
You: /opsx:archive
AI: ✓ Archived fix-login-redirect
You: Let's get back to dark mode
You: /opsx:apply add-dark-mode
AI: Resuming add-dark-mode...
Picking up at task 2.3: Update Header...Ideale per: Flussi di lavoro paralleli, interruzioni urgenti, collaborazione di team.
Quando hai più modificate completate, usa /opsx:bulk-archive:
text
You: /opsx:bulk-archive
AI: Found 3 completed changes:
- add-dark-mode (all tasks done)
- fix-login-redirect (all tasks done)
- update-footer (all tasks done)
Checking for spec conflicts...
⚠ add-dark-mode and update-footer both touch specs/ui/
Inspecting codebase to resolve...
Both changes are implemented. Will apply in chronological order.
Archive all 3 changes?
You: Yes
AI: ✓ Archived add-dark-mode
✓ Archived fix-login-redirect
✓ Archived update-footer
Specs merged in order: add-dark-mode → update-footerL'archiviazione in blocco rileva quando più modifiche toccano le stesse specifiche e risolve i conflitti verificando ciò che è effettivamente implementato.
Completare una Modifica
Il flusso di completamento consigliato:
text
/opsx:apply ──► /opsx:verify ──► /opsx:archive
│ │
valida propone la sincronizzazione
l'implementazione se necessarioVerifica: Controlla il Lavoro
/opsx:verify valida l'implementazione rispetto ai tuoi artefatti su tre dimensioni:
text
You: /opsx:verify
AI: Verifying add-auth...
COMPLETENESS
✓ All 12 tasks in tasks.md are checked
✓ All requirements in specs have corresponding code
⚠ Scenario "Session timeout after inactivity" not tested
CORRECTNESS
✓ Implementation matches spec intent
✓ Edge cases from scenarios are handled
✓ Error states match spec definitions
COHERENCE
✓ Design decisions reflected in code structure
✓ Naming conventions consistent with design.md
⚠ Design mentions "event-driven" but implementation uses polling
SUMMARY
─────────────────────────────
Critical issues: 0
Warnings: 2
Ready to archive: Yes (with warnings)
Recommendations:
1. Add test for session timeout scenario
2. Consider refactoring to event-driven as designed, or update design.mdCosa verifica la funzione di verifica:
| Dimensione | Cosa valida |
|---|---|
| Completezza | Tutte le attività completate, tutti i requisiti implementati, scenari coperti |
| Correttezza | L'implementazione corrisponde all'intento delle specifiche, i casi limite gestiti |
| Coerenza | Le decisioni progettuali riflesse nel codice, pattern coerenti |
La verifica non bloccherà l'archiviazione, ma evidenzia problemi che potresti voler affrontare prima.
Archiviazione: Finalizza la Modifica
/opsx:archive completa la modifica e la sposta nell'archivio:
text
You: /opsx:archive
AI: Archiving add-auth...
Artifact status:
✓ proposal.md exists
✓ specs/ exists
✓ design.md exists
✓ tasks.md exists (12/12 tasks complete)
Delta specs: Not yet synced to main
→ Would you like to sync now?
You: Yes
AI: ✓ Synced specs to openspec/specs/auth/spec.md
✓ Moved to openspec/changes/archive/2025-01-24-add-auth/
Change archived successfully.L'archiviazione chiederà se le specifiche non sono sincronizzate. Non bloccherà per attività incomplete, ma avviserà.
Quando Usare Cosa
/opsx:ff vs /opsx:continue
| Situazione | Usa |
|---|---|
| Requisiti chiari, pronto per costruire | /opsx:ff |
| Esplorazione, vuoi rivedere ogni passaggio | /opsx:continue |
| Vuoi iterare sulla proposta prima delle specifiche | /opsx:continue |
| Pressione temporale, bisogna procedere rapidamente | /opsx:ff |
| Modifica complessa, vuoi controllo | /opsx:continue |
Regola pratica: Se riesci a descrivere l'intero ambito in anticipo, usa /opsx:ff. Se lo stai definendo man mano, usa /opsx:continue.
Quando Aggiornare vs Ricominciare da Zero
Una domanda comune: quando è accettabile aggiornare una modifica esistente e quando è meglio ricominiare da zero?
Aggiorna la modifica esistente quando:
- Stessa intenzione, esecuzione raffinata
- L'ambito si restringe (prima MVP, il resto dopo)
- Correzioni guidate dall'apprendimento (la base di codice non è come previsto)
- Aggiustamenti progettuali basati sulle scoperte durante l'implementazione
Inizia una nuova modifica quando:
- L'intenzione è cambiata fondamentalmente
- L'ambito è esploso in un lavoro completamente diverso
- La modifica originale può essere contrassegnata come "completata" in modo autonomo
- Le patch confonderebbero più che chiarire
text
┌─────────────────────────────────────┐
│ È lo stesso lavoro? │
└──────────────┬──────────────────────┘
│
┌──────────────────┼──────────────────┐
│ │ │
▼ ▼ ▼
Stessa intenzione? Sovrapposizione >50%? La modifica
Stesso problema? Stesso ambito? originale può
│ │ essere "completata"
│ │ senza queste modifiche?
┌────────┴────────┐ ┌──────┴──────┐ ┌───────┴───────┐
│ │ │ │ │ │
SÌ NO SÌ NO NO SÌ
│ │ │ │ │ │
▼ ▼ ▼ ▼ ▼ ▼
AGGIORNA NUOVA AGGIORNA NUOVA AGGIORNA NUOVAEsempio: "Aggiungi modalità scura"
- "Bisogna supportare anche temi personalizzati" → Nuova modifica (ambito esploso)
- "Il rilevamento delle preferenze di sistema è più difficile del previsto" → Aggiornamento (stessa intenzione)
- "Spediamo prima l'interruttore, aggiungiamo le preferenze dopo" → Aggiornamento, poi archiviazione, poi nuova modifica
Best Practice
Mantieni le Modifiche Focalizzate
Un'unità logica di lavoro per modifica. Se stai facendo "aggiungi funzionalità X e refactoring di Y", considera due modifiche separate.
Perché è importante:
- Più facile da revisionare e comprendere
- Cronologia archivio più pulita
- Possibilità di spedire indipendentemente
- Rollback più semplice se necessario
Usa /opsx:explore per Requisiti Non Chiari
Prima di impegnarti in una modifica, esplora lo spazio del problema:
text
You: /opsx:explore
AI: What would you like to explore?
You: How should we handle rate limiting for our API?
AI: Let me investigate your current setup and options...
[Researches codebase, considers patterns]
I see three approaches we could take:
1. Middleware-based (simple, per-endpoint)
2. Redis-backed (scalable, shared state)
3. Token bucket per user (fair, complex)
Your current stack suggests #1 or #2. What's your scale?L'esplorazione chiarisce il pensiero prima di creare gli artefatti.
Verifica Prima di Archiviare
Usa /opsx:verify per verificare che l'implementazione corrisponda agli artefatti:
text
You: /opsx:verify
AI: Verifying add-dark-mode...
✓ All tasks in tasks.md are checked
✓ Requirements in specs have corresponding code
✓ Design decisions are reflected in implementation
Ready to archive!Rileva discrepanze prima di chiudere la modifica.
Nomina le Modifiche in Modo Chiaro
Nomi buoni rendono openspec list utile:
text
Buoni: Evita:
add-dark-mode feature-1
fix-login-redirect update
optimize-product-query changes
implement-2fa wipRiferimento Rapido ai Comandi
Per i dettagli completi sui comandi e le opzioni, consulta Comandi.
| Comando | Scopo | Quando utilizzare |
|---|---|---|
/opsx:propose | Crea modifiche + artefatti di pianificazione | Percorso predefinito rapido (profilo core) |
/opsx:explore | Analizzare le idee | Requisiti poco chiari, indagine |
/opsx:new | Avviare uno scaffold per una modifica | Modalità espansa, controllo esplicito degli artefatti |
/opsx:continue | Creare l'artefatto successivo | Modalità espansa, creazione passo-passo degli artefatti |
/opsx:ff | Creare tutti gli artefatti di pianificazione | Modalità espansa, ambito chiaro |
/opsx:apply | Implementare i task | Pronto per scrivere codice |
/opsx:verify | Validare l'implementazione | Modalità espansa, prima dell'archiviazione |
/opsx:sync | Unire le specifiche delta | Modalità espansa, opzionale |
/opsx:archive | Completare la modifica | Tutti i lavori conclusi |
/opsx:bulk-archive | Archiviare più modifiche | Modalità espansa, lavoro parallelo |
Prossimi Passi
- Comandi - Riferimento completo ai comandi con opzioni
- Concetti - Approfondimento su specifiche, artefatti e schemi
- Personalizzazione - Creare flussi di lavoro personalizzati