2026-01-30 19:28:50 +00:00
|
|
|
package cli
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"net/http"
|
|
|
|
|
"os"
|
|
|
|
|
"path/filepath"
|
|
|
|
|
"testing"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestDetectMode(t *testing.T) {
|
|
|
|
|
t.Run("daemon mode from env", func(t *testing.T) {
|
|
|
|
|
t.Setenv("CORE_DAEMON", "1")
|
|
|
|
|
assert.Equal(t, ModeDaemon, DetectMode())
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("mode string", func(t *testing.T) {
|
|
|
|
|
assert.Equal(t, "interactive", ModeInteractive.String())
|
|
|
|
|
assert.Equal(t, "pipe", ModePipe.String())
|
|
|
|
|
assert.Equal(t, "daemon", ModeDaemon.String())
|
|
|
|
|
assert.Equal(t, "unknown", Mode(99).String())
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestPIDFile(t *testing.T) {
|
|
|
|
|
t.Run("acquire and release", func(t *testing.T) {
|
|
|
|
|
tmpDir := t.TempDir()
|
|
|
|
|
pidPath := filepath.Join(tmpDir, "test.pid")
|
|
|
|
|
|
|
|
|
|
pid := NewPIDFile(pidPath)
|
|
|
|
|
|
|
|
|
|
// Acquire should succeed
|
|
|
|
|
err := pid.Acquire()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// File should exist with our PID
|
|
|
|
|
data, err := os.ReadFile(pidPath)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Contains(t, string(data), "")
|
|
|
|
|
|
|
|
|
|
// Release should remove file
|
|
|
|
|
err = pid.Release()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
_, err = os.Stat(pidPath)
|
|
|
|
|
assert.True(t, os.IsNotExist(err))
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("stale pid file", func(t *testing.T) {
|
|
|
|
|
tmpDir := t.TempDir()
|
|
|
|
|
pidPath := filepath.Join(tmpDir, "stale.pid")
|
|
|
|
|
|
|
|
|
|
// Write a stale PID (non-existent process)
|
|
|
|
|
err := os.WriteFile(pidPath, []byte("999999999"), 0644)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
pid := NewPIDFile(pidPath)
|
|
|
|
|
|
|
|
|
|
// Should acquire successfully (stale PID removed)
|
|
|
|
|
err = pid.Acquire()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
err = pid.Release()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("creates parent directory", func(t *testing.T) {
|
|
|
|
|
tmpDir := t.TempDir()
|
|
|
|
|
pidPath := filepath.Join(tmpDir, "subdir", "nested", "test.pid")
|
|
|
|
|
|
|
|
|
|
pid := NewPIDFile(pidPath)
|
|
|
|
|
|
|
|
|
|
err := pid.Acquire()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
_, err = os.Stat(pidPath)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
err = pid.Release()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("path getter", func(t *testing.T) {
|
|
|
|
|
pid := NewPIDFile("/tmp/test.pid")
|
|
|
|
|
assert.Equal(t, "/tmp/test.pid", pid.Path())
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestHealthServer(t *testing.T) {
|
|
|
|
|
t.Run("health and ready endpoints", func(t *testing.T) {
|
|
|
|
|
hs := NewHealthServer("127.0.0.1:0") // Random port
|
|
|
|
|
|
|
|
|
|
err := hs.Start()
|
|
|
|
|
require.NoError(t, err)
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
defer func() { _ = hs.Stop(context.Background()) }()
|
2026-01-30 19:28:50 +00:00
|
|
|
|
|
|
|
|
addr := hs.Addr()
|
|
|
|
|
require.NotEmpty(t, addr)
|
|
|
|
|
|
|
|
|
|
// Health should be OK
|
|
|
|
|
resp, err := http.Get("http://" + addr + "/health")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
// Ready should be OK by default
|
|
|
|
|
resp, err = http.Get("http://" + addr + "/ready")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
// Set not ready
|
|
|
|
|
hs.SetReady(false)
|
|
|
|
|
|
|
|
|
|
resp, err = http.Get("http://" + addr + "/ready")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusServiceUnavailable, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("with health checks", func(t *testing.T) {
|
|
|
|
|
hs := NewHealthServer("127.0.0.1:0")
|
|
|
|
|
|
|
|
|
|
healthy := true
|
|
|
|
|
hs.AddCheck(func() error {
|
|
|
|
|
if !healthy {
|
|
|
|
|
return assert.AnError
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
err := hs.Start()
|
|
|
|
|
require.NoError(t, err)
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
defer func() { _ = hs.Stop(context.Background()) }()
|
2026-01-30 19:28:50 +00:00
|
|
|
|
|
|
|
|
addr := hs.Addr()
|
|
|
|
|
|
|
|
|
|
// Should be healthy
|
|
|
|
|
resp, err := http.Get("http://" + addr + "/health")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
// Make unhealthy
|
|
|
|
|
healthy = false
|
|
|
|
|
|
|
|
|
|
resp, err = http.Get("http://" + addr + "/health")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusServiceUnavailable, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDaemon(t *testing.T) {
|
|
|
|
|
t.Run("start and stop", func(t *testing.T) {
|
|
|
|
|
tmpDir := t.TempDir()
|
|
|
|
|
|
|
|
|
|
d := NewDaemon(DaemonOptions{
|
|
|
|
|
PIDFile: filepath.Join(tmpDir, "test.pid"),
|
|
|
|
|
HealthAddr: "127.0.0.1:0",
|
|
|
|
|
ShutdownTimeout: 5 * time.Second,
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
err := d.Start()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Health server should be running
|
|
|
|
|
addr := d.HealthAddr()
|
|
|
|
|
require.NotEmpty(t, addr)
|
|
|
|
|
|
|
|
|
|
resp, err := http.Get("http://" + addr + "/health")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
// Stop should succeed
|
|
|
|
|
err = d.Stop()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// PID file should be removed
|
|
|
|
|
_, err = os.Stat(filepath.Join(tmpDir, "test.pid"))
|
|
|
|
|
assert.True(t, os.IsNotExist(err))
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("double start fails", func(t *testing.T) {
|
|
|
|
|
d := NewDaemon(DaemonOptions{
|
|
|
|
|
HealthAddr: "127.0.0.1:0",
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
err := d.Start()
|
|
|
|
|
require.NoError(t, err)
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
defer func() { _ = d.Stop() }()
|
2026-01-30 19:28:50 +00:00
|
|
|
|
|
|
|
|
err = d.Start()
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "already running")
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("run without start fails", func(t *testing.T) {
|
|
|
|
|
d := NewDaemon(DaemonOptions{})
|
|
|
|
|
|
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
|
|
|
cancel()
|
|
|
|
|
|
|
|
|
|
err := d.Run(ctx)
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "not started")
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("set ready", func(t *testing.T) {
|
|
|
|
|
d := NewDaemon(DaemonOptions{
|
|
|
|
|
HealthAddr: "127.0.0.1:0",
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
err := d.Start()
|
|
|
|
|
require.NoError(t, err)
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
defer func() { _ = d.Stop() }()
|
2026-01-30 19:28:50 +00:00
|
|
|
|
|
|
|
|
addr := d.HealthAddr()
|
|
|
|
|
|
|
|
|
|
// Initially ready
|
|
|
|
|
resp, _ := http.Get("http://" + addr + "/ready")
|
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
// Set not ready
|
|
|
|
|
d.SetReady(false)
|
|
|
|
|
|
|
|
|
|
resp, _ = http.Get("http://" + addr + "/ready")
|
|
|
|
|
assert.Equal(t, http.StatusServiceUnavailable, resp.StatusCode)
|
|
|
|
|
resp.Body.Close()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("no health addr returns empty", func(t *testing.T) {
|
|
|
|
|
d := NewDaemon(DaemonOptions{})
|
|
|
|
|
assert.Empty(t, d.HealthAddr())
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("default shutdown timeout", func(t *testing.T) {
|
|
|
|
|
d := NewDaemon(DaemonOptions{})
|
|
|
|
|
assert.Equal(t, 30*time.Second, d.opts.ShutdownTimeout)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestRunWithTimeout(t *testing.T) {
|
|
|
|
|
t.Run("creates shutdown function", func(t *testing.T) {
|
|
|
|
|
// Just test that it returns a function
|
|
|
|
|
shutdown := RunWithTimeout(100 * time.Millisecond)
|
|
|
|
|
assert.NotNil(t, shutdown)
|
|
|
|
|
})
|
|
|
|
|
}
|