go-devops/cmd/dev/cmd_workflow_test.go
Snider 907c5fa64c fix(devops): address CodeRabbit findings on PR #2
15+ findings dispositioned. AX-6-conformant — no testify reintroduced.

Code fixes:
- cmd/dev/service.go: no-op now returns OK:true, unchecked prompt type assertion guarded
- cmd/workspace/config.go: relative parent traversal blocked + regression test, fmt.Errorf wrapping
- cmd/dev/cmd_issues.go + cmd_reviews.go: import ordering
- tests/cli/devops/main.go: raw WalkDir errors wrapped
- tests/cli/devops/Taskfile.yaml: strict shell flags
- cmd/vanity-import/Dockerfile + docs/development.md: Go 1.26 alignment
- locales/embed.go: missing dappco.re/go/i18n checksum

Test infra:
- New local test helpers in cmd/dev, cmd/setup, devkit, snapshot
- All testify usages already absent — local stdlib helpers preferred
  per AX-6 ban
- Test naming aligned (Test{Filename}_{Function}_{Good,Bad,Ugly} per AX-10)

Disposition replies (RESOLVED-COMMENT, no testify added):
- cmd/dev/cmd_apply_test.go, cmd/setup/cmd_ci_test.go, snapshot_test.go,
  devkit/coverage_test.go: CodeRabbit testify suggestions get reasoning
  reply per AX-6 ban; local helpers are convention.
- SonarCloud/GHAS: no PR checks/annotations found; code-scanning API
  returned no analysis, secret scanning disabled.

Verification: gofmt clean, git diff --check clean, no testify imports.
Targeted go vet + go test pass for cmd/workspace + devkit + snapshot.
Full go vet ./... blocked by pre-existing dappco.re/go/scm
codeberg.org/forgejo/go-sdk auth/replacement issue (out of scope).

Closes findings on https://github.com/dAppCore/go-devops/pull/2

Co-authored-by: Codex <noreply@openai.com>
2026-04-27 15:07:24 +01:00

96 lines
2.5 KiB
Go

package dev
import (
"maps"
"path/filepath"
"slices"
"testing"
"dappco.re/go/io"
)
func TestFindWorkflows_Good(t *testing.T) {
// Create a temp directory with workflow files
tmpDir := t.TempDir()
workflowsDir := filepath.Join(tmpDir, ".github", "workflows")
mustNoError(t, io.Local.EnsureDir(workflowsDir))
// Create some workflow files
for _, name := range []string{"qa.yml", "tests.yml", "codeql.yaml"} {
mustNoError(t, io.Local.Write(filepath.Join(workflowsDir, name), "name: Test"))
}
// Create a non-workflow file (should be ignored)
mustNoError(t, io.Local.Write(filepath.Join(workflowsDir, "readme.md"), "# Workflows"))
workflows := findWorkflows(tmpDir)
mustLen(t, workflows, 3)
// Check that all expected workflows are found
found := make(map[string]bool)
for _, wf := range workflows {
found[wf] = true
}
for _, expected := range []string{"qa.yml", "tests.yml", "codeql.yaml"} {
mustTrue(t, found[expected])
}
}
func TestFindWorkflows_NoWorkflowsDir_Bad(t *testing.T) {
tmpDir := t.TempDir()
workflows := findWorkflows(tmpDir)
mustLen(t, workflows, 0)
}
func TestFindTemplateWorkflow_Good(t *testing.T) {
tmpDir := t.TempDir()
templatesDir := filepath.Join(tmpDir, ".github", "workflow-templates")
mustNoError(t, io.Local.EnsureDir(templatesDir))
templateContent := "name: QA\non: [push]"
mustNoError(t, io.Local.Write(filepath.Join(templatesDir, "qa.yml"), templateContent))
// Test finding with .yml extension
result := findTemplateWorkflow(tmpDir, "qa.yml")
mustTrue(t, result != "")
// Test finding without extension (should auto-add .yml)
result = findTemplateWorkflow(tmpDir, "qa")
mustTrue(t, result != "")
}
func TestFindTemplateWorkflow_FallbackToWorkflows_Good(t *testing.T) {
tmpDir := t.TempDir()
workflowsDir := filepath.Join(tmpDir, ".github", "workflows")
mustNoError(t, io.Local.EnsureDir(workflowsDir))
templateContent := "name: Tests\non: [push]"
mustNoError(t, io.Local.Write(filepath.Join(workflowsDir, "tests.yml"), templateContent))
result := findTemplateWorkflow(tmpDir, "tests.yml")
mustTrue(t, result != "")
}
func TestFindTemplateWorkflow_NotFound_Bad(t *testing.T) {
tmpDir := t.TempDir()
result := findTemplateWorkflow(tmpDir, "nonexistent.yml")
mustEqual(t, "", result)
}
func TestTemplateNames_Good(t *testing.T) {
templateSet := map[string]bool{
"z.yml": true,
"a.yml": true,
"m.yml": true,
}
names := slices.Sorted(maps.Keys(templateSet))
mustLen(t, names, 3)
mustEqual(t, "a.yml", names[0])
mustEqual(t, "m.yml", names[1])
mustEqual(t, "z.yml", names[2])
}