rdev/cookbooks/trees/full-stack-feature.yaml
jordan a8c8a0a14d
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
feat: add GCS-based persistent media storage, AI generation pipeline, and composable skeleton packages
Adds complete media storage pipeline with GCS presigned uploads, AI image/video/text generation
via queue-based workers, realtime SSE event streaming, and comprehensive skeleton packages
(storage, mediagen, textgen, generation, realtime, persona, routing, ai-client). Includes
security fixes for media delete authorization, nil pointer guards in handlers, video persistence
via download-then-upload, consistent signed URLs, and Image→ImageIcon rename to avoid DOM collision.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-19 21:29:09 -07:00

186 lines
5.6 KiB
YAML

name: full-stack-feature
description: "End-to-end enterprise feature development: Spec -> Design -> Implementation (DB + API) -> Verification"
version: 1
vars:
project_name: "" # Required
service_name: "api"
feature_slug: "todos-crud"
steps:
# --- Phase 1: Infrastructure ---
create-project:
description: Create project with monorepo skeleton
action: api
method: POST
endpoint: /project
body:
name: "{{ .vars.project_name }}"
description: "Full Stack Feature Test"
outputs:
- project_id: .data.name
- domain: .data.domain
add-service:
description: Add backend service component
depends_on: [create-project]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/components"
body:
type: service
name: "{{ .vars.service_name }}"
template: service
outputs:
- service_path: .data.path
wait-init-pipeline:
description: Wait for initial build
depends_on: [add-service]
action: wait_pipeline
project_id: "{{ .outputs.create-project.project_id }}"
max_attempts: 120
# --- Phase 2: SDLC Process (Spec & Design) ---
create-feature:
description: Register feature
depends_on: [wait-init-pipeline]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/sdlc/features"
body:
slug: "{{ .vars.feature_slug }}"
title: "Manage Todos"
generate-spec:
description: Agent writes the Spec
depends_on: [create-feature]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/builds"
body:
prompt: "/spec-feature {{ .vars.feature_slug }}"
auto_commit: true
auto_push: true
git_clone_url: "https://git.threesix.ai/jordan/{{ .outputs.create-project.project_id }}.git"
outputs:
- build_id: .data.task_id
wait-spec:
description: Wait for spec generation
depends_on: [generate-spec]
action: wait_build
build_id: "{{ .outputs.generate-spec.build_id }}"
max_attempts: 120
poll_interval: 5
approve-spec:
description: Approve the Spec artifact
depends_on: [wait-spec]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/sdlc/features/{{ .vars.feature_slug }}/artifacts/spec/approve"
body: {}
generate-design:
description: Agent writes the Technical Design
depends_on: [approve-spec]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/builds"
body:
prompt: "/design-feature {{ .vars.feature_slug }}"
auto_commit: true
auto_push: true
git_clone_url: "https://git.threesix.ai/jordan/{{ .outputs.create-project.project_id }}.git"
outputs:
- build_id: .data.task_id
wait-design:
description: Wait for design generation
depends_on: [generate-design]
action: wait_build
build_id: "{{ .outputs.generate-design.build_id }}"
max_attempts: 120
poll_interval: 5
approve-design:
description: Approve the Design artifact
depends_on: [wait-design]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/sdlc/features/{{ .vars.feature_slug }}/artifacts/design/approve"
body: {}
# --- Phase 3: Implementation ---
# We manually inject tasks to ensure deterministic IDs for the runner, simulating a PM refining the plan
create-task-backend:
description: Create backend implementation task
depends_on: [approve-design]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/sdlc/features/{{ .vars.feature_slug }}/tasks"
body:
title: "Implement Todo domain model and in-memory handler"
outputs:
- task_id: .data.id
implement-backend:
description: Agent writes the Golang code
depends_on: [create-task-backend]
action: api
method: POST
endpoint: "/projects/{{ .outputs.create-project.project_id }}/builds"
body:
prompt: "/implement-task {{ .vars.feature_slug }} {{ .outputs.create-task-backend.task_id }}"
auto_commit: true
auto_push: true
git_clone_url: "https://git.threesix.ai/jordan/{{ .outputs.create-project.project_id }}.git"
outputs:
- build_id: .data.task_id
wait-implementation:
description: Wait for code generation
depends_on: [implement-backend]
action: wait_build
build_id: "{{ .outputs.implement-backend.build_id }}"
max_attempts: 120
poll_interval: 5
wait-deploy:
description: Wait for CI/CD to deploy the new feature
depends_on: [wait-implementation]
action: wait_pipeline
project_id: "{{ .outputs.create-project.project_id }}"
max_attempts: 120
# --- Phase 4: Verification ---
verify-crud:
description: Functional test of the new endpoint
depends_on: [wait-deploy]
action: shell
command: |
# Give the pod a moment to settle
sleep 10
DOMAIN="{{ .outputs.create-project.domain }}"
echo "Testing https://$DOMAIN/api/todos..."
# 1. Create
curl -s -X POST "https://$DOMAIN/api/todos" -d '{"title":"Test Todo"}' -H "Content-Type: application/json"
# 2. List and verify
RESP=$(curl -s "https://$DOMAIN/api/todos")
if echo "$RESP" | grep -q "Test Todo"; then
echo "SUCCESS: Found created todo"
exit 0
else
echo "FAILURE: Todo not found in response: $RESP"
exit 1
fi
teardown:
- description: Delete project
action: api
method: DELETE
endpoint: "/project/{{ .outputs.create-project.project_id }}"