10 KiB
phase, plan, type, wave, depends_on, files_modified, autonomous, requirements, must_haves
| phase | plan | type | wave | depends_on | files_modified | autonomous | requirements | must_haves | |||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 03-tier-3-9-providers | 08 | execute | 2 |
|
|
true |
|
|
Purpose: Satisfy all 7 Phase 3 requirements (PROV-03..PROV-09) with a single enforceable test. Any future change that drops a provider, renames one, or introduces a non-compiling regex will break this test in CI.
Output: 1 test file with 10+ test functions. Total registry provider count locked at 108.
Addresses PROV-03, PROV-04, PROV-05, PROV-06, PROV-07, PROV-08, PROV-09.
<execution_context> @$HOME/.claude/get-shit-done/workflows/execute-plan.md @$HOME/.claude/get-shit-done/templates/summary.md </execution_context>
@.planning/ROADMAP.md @.planning/phases/03-tier-3-9-providers/03-CONTEXT.md @pkg/providers/tier12_test.go @pkg/providers/schema.go Replicate the `tier12_test.go` pattern exactly. Registry API: `NewRegistry()`, `Stats()`, `Get(name)`, `List()`.Expected provider name sets (must match plans 03-01..03-07 exactly):
- Tier 3 (12): perplexity, you, voyage, jina, unstructured, assemblyai, deepgram, elevenlabs, stability, runway, midjourney, huggingface
- Tier 4 (16): deepseek, zhipu, moonshot, qwen, baidu, bytedance, 01ai, minimax, baichuan, stepfun, sensetime, iflytek, tencent, siliconflow, 360ai, kuaishou
- Tier 5 (11): openrouter, litellm, cloudflare-ai, vercel-ai, portkey, helicone, martian, kong, bricksai, aether, notdiamond
- Tier 6 (15): reka, aleph-alpha, lamini, writer, jasper, typeface, comet, wandb, langsmith, pinecone, weaviate, qdrant, chroma, milvus, neon
- Tier 7 (10): github-copilot, cursor, tabnine, codeium, sourcegraph, codewhisperer, replit-ai, codestral, watsonx, oracle-ai
- Tier 8 (10): ollama, vllm, localai, lmstudio, llamacpp, gpt4all, text-gen-webui, tensorrt-llm, triton, jan
- Tier 9 (8): salesforce-einstein, servicenow, sap-ai-core, palantir, databricks, snowflake, oracle-genai, hpe-greenlake
Total Tier 3-9: 82. Combined with Tier 1-2 (26): 108 total.
Task 1: Create tier39_test.go guardrail test file pkg/providers/tier39_test.go - pkg/providers/tier12_test.go (pattern to replicate) - pkg/providers/schema.go (Registry API) Create `pkg/providers/tier39_test.go` with the following contents. The expected name slices MUST match the names in each plan's files exactly.package providers
import (
"testing"
)
// expectedTier3 lists all 12 Tier 3 Specialized provider names (PROV-03).
var expectedTier3 = []string{
"perplexity", "you", "voyage", "jina", "unstructured", "assemblyai",
"deepgram", "elevenlabs", "stability", "runway", "midjourney", "huggingface",
}
// expectedTier4 lists all 16 Tier 4 Chinese/Regional provider names (PROV-04).
var expectedTier4 = []string{
"deepseek", "zhipu", "moonshot", "qwen", "baidu", "bytedance",
"01ai", "minimax", "baichuan", "stepfun", "sensetime", "iflytek",
"tencent", "siliconflow", "360ai", "kuaishou",
}
// expectedTier5 lists all 11 Tier 5 Infrastructure/Gateway provider names (PROV-05).
var expectedTier5 = []string{
"openrouter", "litellm", "cloudflare-ai", "vercel-ai", "portkey",
"helicone", "martian", "kong", "bricksai", "aether", "notdiamond",
}
// expectedTier6 lists all 15 Tier 6 Emerging/Niche provider names (PROV-06).
var expectedTier6 = []string{
"reka", "aleph-alpha", "lamini", "writer", "jasper", "typeface",
"comet", "wandb", "langsmith", "pinecone", "weaviate", "qdrant",
"chroma", "milvus", "neon",
}
// expectedTier7 lists all 10 Tier 7 Code/Dev Tools provider names (PROV-07).
var expectedTier7 = []string{
"github-copilot", "cursor", "tabnine", "codeium", "sourcegraph",
"codewhisperer", "replit-ai", "codestral", "watsonx", "oracle-ai",
}
// expectedTier8 lists all 10 Tier 8 Self-Hosted provider names (PROV-08).
var expectedTier8 = []string{
"ollama", "vllm", "localai", "lmstudio", "llamacpp",
"gpt4all", "text-gen-webui", "tensorrt-llm", "triton", "jan",
}
// expectedTier9 lists all 8 Tier 9 Enterprise provider names (PROV-09).
var expectedTier9 = []string{
"salesforce-einstein", "servicenow", "sap-ai-core", "palantir",
"databricks", "snowflake", "oracle-genai", "hpe-greenlake",
}
func TestTier3Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[3]; got != 12 {
t.Errorf("Tier 3 count = %d, want 12", got)
}
}
func TestTier4Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[4]; got != 16 {
t.Errorf("Tier 4 count = %d, want 16", got)
}
}
func TestTier5Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[5]; got != 11 {
t.Errorf("Tier 5 count = %d, want 11", got)
}
}
func TestTier6Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[6]; got != 15 {
t.Errorf("Tier 6 count = %d, want 15", got)
}
}
func TestTier7Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[7]; got != 10 {
t.Errorf("Tier 7 count = %d, want 10", got)
}
}
func TestTier8Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[8]; got != 10 {
t.Errorf("Tier 8 count = %d, want 10", got)
}
}
func TestTier9Count(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().ByTier[9]; got != 8 {
t.Errorf("Tier 9 count = %d, want 8", got)
}
}
func TestTotalProviderCount(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
if got := reg.Stats().Total; got != 108 {
t.Errorf("Total provider count = %d, want 108", got)
}
}
func TestTier39ProviderNames(t *testing.T) {
reg, err := NewRegistry()
if err != nil {
t.Fatalf("NewRegistry failed: %v", err)
}
checks := []struct {
tier int
names []string
}{
{3, expectedTier3},
{4, expectedTier4},
{5, expectedTier5},
{6, expectedTier6},
{7, expectedTier7},
{8, expectedTier8},
{9, expectedTier9},
}
for _, c := range checks {
for _, name := range c.names {
p, ok := reg.Get(name)
if !ok {
t.Errorf("Tier %d provider %q not found in registry", c.tier, name)
continue
}
if p.Tier != c.tier {
t.Errorf("provider %q tier = %d, want %d", name, p.Tier, c.tier)
}
}
}
}
Note: Do NOT add package-level imports for regexp — TestAllPatternsCompile and TestAllProvidersHaveKeywords already exist in tier12_test.go and will exercise every provider (including Tier 3-9) once the registry loads them.
cd /home/salva/Documents/apikey && go test ./pkg/providers/... -count=1 -v -run 'TestTier[3-9]|TestTotalProviderCount|TestTier39ProviderNames|TestAllPatternsCompile|TestAllProvidersHaveKeywords' && go test ./... -count=1
<acceptance_criteria>
- pkg/providers/tier39_test.go exists
- grep -c "^func Test" pkg/providers/tier39_test.go returns ≥ 9
- go test ./pkg/providers/... -run TestTotalProviderCount -v passes with Total == 108
- go test ./pkg/providers/... -run TestTier3Count -v passes
- go test ./pkg/providers/... -run TestTier4Count -v passes
- go test ./pkg/providers/... -run TestTier5Count -v passes
- go test ./pkg/providers/... -run TestTier6Count -v passes
- go test ./pkg/providers/... -run TestTier7Count -v passes
- go test ./pkg/providers/... -run TestTier8Count -v passes
- go test ./pkg/providers/... -run TestTier9Count -v passes
- go test ./pkg/providers/... -run TestTier39ProviderNames -v passes (all 82 names resolve)
- go test ./pkg/providers/... -run TestAllPatternsCompile -v passes (inherited from tier12_test.go — all Tier 3-9 regexes compile under RE2)
- go test ./pkg/providers/... -run TestAllProvidersHaveKeywords -v passes (every provider ≥1 keyword)
- Phase 2 guardrails still pass: go test ./pkg/providers/... -run 'TestTier1|TestTier2' green
- Full repo regression: go test ./... -count=1 green (engine, storage, providers)
</acceptance_criteria>
Tier 3-9 guardrail test file exists, 9+ test functions pass, total provider count locked at 108, all 82 Tier 3-9 provider names verified, no regression in Phase 1/2 tests.
<success_criteria>
- tier39_test.go created with ≥9 test functions
- Total provider count locked at 108
- All 82 Tier 3-9 provider names locked against drift
- All regex patterns compile under RE2 (via existing TestAllPatternsCompile)
- Every provider has ≥1 keyword (via existing TestAllProvidersHaveKeywords)
- Full repo
go test ./...green </success_criteria>