2026-01-29 14:28:23 +00:00
|
|
|
package devops
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"os"
|
|
|
|
|
"os/exec"
|
|
|
|
|
"path/filepath"
|
|
|
|
|
"runtime"
|
|
|
|
|
"testing"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/host-uk/core/pkg/container"
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
"github.com/host-uk/core/pkg/io"
|
2026-01-29 14:28:23 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestImageName(t *testing.T) {
|
|
|
|
|
name := ImageName()
|
|
|
|
|
assert.Contains(t, name, "core-devops-")
|
|
|
|
|
assert.Contains(t, name, runtime.GOOS)
|
|
|
|
|
assert.Contains(t, name, runtime.GOARCH)
|
|
|
|
|
assert.True(t, (name[len(name)-6:] == ".qcow2"))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestImagesDir(t *testing.T) {
|
|
|
|
|
t.Run("default directory", func(t *testing.T) {
|
|
|
|
|
// Unset env if it exists
|
|
|
|
|
orig := os.Getenv("CORE_IMAGES_DIR")
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
_ = os.Unsetenv("CORE_IMAGES_DIR")
|
|
|
|
|
defer func() { _ = os.Setenv("CORE_IMAGES_DIR", orig) }()
|
2026-01-29 14:28:23 +00:00
|
|
|
|
|
|
|
|
dir, err := ImagesDir()
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.Contains(t, dir, ".core/images")
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("environment override", func(t *testing.T) {
|
|
|
|
|
customDir := "/tmp/custom-images"
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", customDir)
|
|
|
|
|
|
|
|
|
|
dir, err := ImagesDir()
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.Equal(t, customDir, dir)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestImagePath(t *testing.T) {
|
|
|
|
|
customDir := "/tmp/images"
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", customDir)
|
|
|
|
|
|
|
|
|
|
path, err := ImagePath()
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
expected := filepath.Join(customDir, ImageName())
|
|
|
|
|
assert.Equal(t, expected, path)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDefaultBootOptions(t *testing.T) {
|
|
|
|
|
opts := DefaultBootOptions()
|
|
|
|
|
assert.Equal(t, 4096, opts.Memory)
|
|
|
|
|
assert.Equal(t, 2, opts.CPUs)
|
|
|
|
|
assert.Equal(t, "core-dev", opts.Name)
|
|
|
|
|
assert.False(t, opts.Fresh)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestIsInstalled_Bad(t *testing.T) {
|
|
|
|
|
t.Run("returns false for non-existent image", func(t *testing.T) {
|
|
|
|
|
// Point to a temp directory that is empty
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create devops instance manually to avoid loading real config/images
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local}
|
2026-01-29 14:28:23 +00:00
|
|
|
assert.False(t, d.IsInstalled())
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestIsInstalled_Good(t *testing.T) {
|
|
|
|
|
t.Run("returns true when image exists", func(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create the image file
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
|
|
|
|
err := os.WriteFile(imagePath, []byte("fake image data"), 0644)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local}
|
2026-01-29 14:28:23 +00:00
|
|
|
assert.True(t, d.IsInstalled())
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type mockHypervisor struct{}
|
|
|
|
|
|
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
|
|
|
func (m *mockHypervisor) Name() string { return "mock" }
|
2026-01-29 14:28:23 +00:00
|
|
|
func (m *mockHypervisor) Available() bool { return true }
|
|
|
|
|
func (m *mockHypervisor) BuildCommand(ctx context.Context, image string, opts *container.HypervisorOptions) (*exec.Cmd, error) {
|
|
|
|
|
return exec.Command("true"), nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Status_Good(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Setup mock container manager
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add a fake running container
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(), // Use our own PID so isProcessRunning returns true
|
|
|
|
|
StartedAt: time.Now().Add(-time.Hour),
|
|
|
|
|
Memory: 2048,
|
|
|
|
|
CPUs: 4,
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
status, err := d.Status(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, status)
|
|
|
|
|
assert.True(t, status.Running)
|
|
|
|
|
assert.Equal(t, "test-id", status.ContainerID)
|
|
|
|
|
assert.Equal(t, 2048, status.Memory)
|
|
|
|
|
assert.Equal(t, 4, status.CPUs)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Status_Good_NotInstalled(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
status, err := d.Status(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, status)
|
|
|
|
|
assert.False(t, status.Installed)
|
|
|
|
|
assert.False(t, status.Running)
|
|
|
|
|
assert.Equal(t, 2222, status.SSHPort)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Status_Good_NoContainer(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image to mark as installed
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
|
|
|
|
err := os.WriteFile(imagePath, []byte("fake"), 0644)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
status, err := d.Status(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, status)
|
|
|
|
|
assert.True(t, status.Installed)
|
|
|
|
|
assert.False(t, status.Running)
|
|
|
|
|
assert.Empty(t, status.ContainerID)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_IsRunning_Good(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
running, err := d.IsRunning(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.True(t, running)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_IsRunning_Bad_NotRunning(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
running, err := d.IsRunning(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.False(t, running)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_IsRunning_Bad_ContainerStopped(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusStopped,
|
|
|
|
|
PID: 12345,
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
running, err := d.IsRunning(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.False(t, running)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_findContainer_Good(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "my-container",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
found, err := d.findContainer(context.Background(), "my-container")
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, found)
|
|
|
|
|
assert.Equal(t, "test-id", found.ID)
|
|
|
|
|
assert.Equal(t, "my-container", found.Name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_findContainer_Bad_NotFound(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
found, err := d.findContainer(context.Background(), "nonexistent")
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.Nil(t, found)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Stop_Bad_NotFound(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = d.Stop(context.Background())
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "not found")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestBootOptions_Custom(t *testing.T) {
|
|
|
|
|
opts := BootOptions{
|
|
|
|
|
Memory: 8192,
|
|
|
|
|
CPUs: 4,
|
|
|
|
|
Name: "custom-dev",
|
|
|
|
|
Fresh: true,
|
|
|
|
|
}
|
|
|
|
|
assert.Equal(t, 8192, opts.Memory)
|
|
|
|
|
assert.Equal(t, 4, opts.CPUs)
|
|
|
|
|
assert.Equal(t, "custom-dev", opts.Name)
|
|
|
|
|
assert.True(t, opts.Fresh)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevStatus_Struct(t *testing.T) {
|
|
|
|
|
status := DevStatus{
|
|
|
|
|
Installed: true,
|
|
|
|
|
Running: true,
|
|
|
|
|
ImageVersion: "v1.2.3",
|
|
|
|
|
ContainerID: "abc123",
|
|
|
|
|
Memory: 4096,
|
|
|
|
|
CPUs: 2,
|
|
|
|
|
SSHPort: 2222,
|
|
|
|
|
Uptime: time.Hour,
|
|
|
|
|
}
|
|
|
|
|
assert.True(t, status.Installed)
|
|
|
|
|
assert.True(t, status.Running)
|
|
|
|
|
assert.Equal(t, "v1.2.3", status.ImageVersion)
|
|
|
|
|
assert.Equal(t, "abc123", status.ContainerID)
|
|
|
|
|
assert.Equal(t, 4096, status.Memory)
|
|
|
|
|
assert.Equal(t, 2, status.CPUs)
|
|
|
|
|
assert.Equal(t, 2222, status.SSHPort)
|
|
|
|
|
assert.Equal(t, time.Hour, status.Uptime)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Boot_Bad_NotInstalled(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = d.Boot(context.Background(), DefaultBootOptions())
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "not installed")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Boot_Bad_AlreadyRunning(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
|
|
|
|
err := os.WriteFile(imagePath, []byte("fake"), 0644)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add a running container
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
err = d.Boot(context.Background(), DefaultBootOptions())
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "already running")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Status_Good_WithImageVersion(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
|
|
|
|
err := os.WriteFile(imagePath, []byte("fake"), 0644)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Manually set manifest with version info
|
|
|
|
|
mgr.manifest.Images[ImageName()] = ImageInfo{
|
|
|
|
|
Version: "v1.2.3",
|
|
|
|
|
Source: "test",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
config: cfg,
|
|
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
status, err := d.Status(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.True(t, status.Installed)
|
|
|
|
|
assert.Equal(t, "v1.2.3", status.ImageVersion)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_findContainer_Good_MultipleContainers(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add multiple containers
|
|
|
|
|
c1 := &container.Container{
|
|
|
|
|
ID: "id-1",
|
|
|
|
|
Name: "container-1",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
c2 := &container.Container{
|
|
|
|
|
ID: "id-2",
|
|
|
|
|
Name: "container-2",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c1)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
err = state.Add(c2)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Find specific container
|
|
|
|
|
found, err := d.findContainer(context.Background(), "container-2")
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, found)
|
|
|
|
|
assert.Equal(t, "id-2", found.ID)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Status_Good_ContainerWithUptime(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
startTime := time.Now().Add(-2 * time.Hour)
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: startTime,
|
|
|
|
|
Memory: 4096,
|
|
|
|
|
CPUs: 2,
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
status, err := d.Status(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.True(t, status.Running)
|
|
|
|
|
assert.GreaterOrEqual(t, status.Uptime.Hours(), float64(1))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_IsRunning_Bad_DifferentContainerName(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add a container with different name
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "other-container",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: os.Getpid(),
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// IsRunning looks for "core-dev", not "other-container"
|
|
|
|
|
running, err := d.IsRunning(context.Background())
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.False(t, running)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Boot_Good_FreshFlag(t *testing.T) {
|
2026-02-04 18:23:29 +00:00
|
|
|
t.Setenv("CORE_SKIP_SSH_SCAN", "true")
|
2026-02-01 06:53:15 +00:00
|
|
|
tempDir, err := os.MkdirTemp("", "devops-test-*")
|
|
|
|
|
require.NoError(t, err)
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
t.Cleanup(func() { _ = os.RemoveAll(tempDir) })
|
2026-01-29 14:28:23 +00:00
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
2026-02-01 06:53:15 +00:00
|
|
|
err = os.WriteFile(imagePath, []byte("fake"), 0644)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add an existing container with non-existent PID (will be seen as stopped)
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "old-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusRunning,
|
|
|
|
|
PID: 99999999, // Non-existent PID - List() will mark it as stopped
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Boot with Fresh=true should try to stop the existing container
|
|
|
|
|
// then run a new one. The mock hypervisor "succeeds" so this won't error
|
|
|
|
|
opts := BootOptions{
|
|
|
|
|
Memory: 4096,
|
|
|
|
|
CPUs: 2,
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Fresh: true,
|
|
|
|
|
}
|
|
|
|
|
err = d.Boot(context.Background(), opts)
|
|
|
|
|
// The mock hypervisor's Run succeeds
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Stop_Bad_ContainerNotRunning(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add a container that's already stopped
|
|
|
|
|
c := &container.Container{
|
|
|
|
|
ID: "test-id",
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Status: container.StatusStopped,
|
|
|
|
|
PID: 99999999,
|
|
|
|
|
StartedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
err = state.Add(c)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
// Stop should fail because container is not running
|
|
|
|
|
err = d.Stop(context.Background())
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Contains(t, err.Error(), "not running")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Boot_Good_FreshWithNoExisting(t *testing.T) {
|
2026-02-04 18:23:29 +00:00
|
|
|
t.Setenv("CORE_SKIP_SSH_SCAN", "true")
|
2026-02-02 00:07:32 +00:00
|
|
|
tempDir, err := os.MkdirTemp("", "devops-boot-fresh-*")
|
|
|
|
|
require.NoError(t, err)
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
t.Cleanup(func() { _ = os.RemoveAll(tempDir) })
|
2026-01-29 14:28:23 +00:00
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
2026-02-02 00:07:32 +00:00
|
|
|
err = os.WriteFile(imagePath, []byte("fake"), 0644)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Boot with Fresh=true but no existing container
|
|
|
|
|
opts := BootOptions{
|
|
|
|
|
Memory: 4096,
|
|
|
|
|
CPUs: 2,
|
|
|
|
|
Name: "core-dev",
|
|
|
|
|
Fresh: true,
|
|
|
|
|
}
|
|
|
|
|
err = d.Boot(context.Background(), opts)
|
|
|
|
|
// The mock hypervisor succeeds
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestImageName_Format(t *testing.T) {
|
|
|
|
|
name := ImageName()
|
|
|
|
|
// Check format: core-devops-{os}-{arch}.qcow2
|
|
|
|
|
assert.Contains(t, name, "core-devops-")
|
|
|
|
|
assert.Contains(t, name, runtime.GOOS)
|
|
|
|
|
assert.Contains(t, name, runtime.GOARCH)
|
|
|
|
|
assert.True(t, filepath.Ext(name) == ".qcow2")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Install_Delegates(t *testing.T) {
|
|
|
|
|
// This test verifies the Install method delegates to ImageManager
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This will fail because no source is available, but it tests delegation
|
|
|
|
|
err = d.Install(context.Background(), nil)
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_CheckUpdate_Delegates(t *testing.T) {
|
|
|
|
|
// This test verifies the CheckUpdate method delegates to ImageManager
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This will fail because image not installed, but it tests delegation
|
|
|
|
|
_, _, _, err = d.CheckUpdate(context.Background())
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Boot_Good_Success(t *testing.T) {
|
2026-02-04 18:23:29 +00:00
|
|
|
t.Setenv("CORE_SKIP_SSH_SCAN", "true")
|
2026-02-01 11:55:10 +00:00
|
|
|
tempDir, err := os.MkdirTemp("", "devops-boot-success-*")
|
|
|
|
|
require.NoError(t, err)
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
t.Cleanup(func() { _ = os.RemoveAll(tempDir) })
|
2026-01-29 14:28:23 +00:00
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
// Create fake image
|
|
|
|
|
imagePath := filepath.Join(tempDir, ImageName())
|
2026-02-01 11:55:10 +00:00
|
|
|
err = os.WriteFile(imagePath, []byte("fake"), 0644)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
statePath := filepath.Join(tempDir, "containers.json")
|
2026-02-04 15:33:22 +00:00
|
|
|
state := container.NewState(io.Local, statePath)
|
2026-01-29 14:28:23 +00:00
|
|
|
h := &mockHypervisor{}
|
2026-02-04 15:33:22 +00:00
|
|
|
cm := container.NewLinuxKitManagerWithHypervisor(io.Local, state, h)
|
2026-01-29 14:28:23 +00:00
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
images: mgr,
|
|
|
|
|
container: cm,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Boot without Fresh flag and no existing container
|
|
|
|
|
opts := DefaultBootOptions()
|
|
|
|
|
err = d.Boot(context.Background(), opts)
|
|
|
|
|
assert.NoError(t, err) // Mock hypervisor succeeds
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDevOps_Config(t *testing.T) {
|
|
|
|
|
tempDir := t.TempDir()
|
|
|
|
|
t.Setenv("CORE_IMAGES_DIR", tempDir)
|
|
|
|
|
|
|
|
|
|
cfg := DefaultConfig()
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
mgr, err := NewImageManager(io.Local, cfg)
|
2026-01-29 14:28:23 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
Migrate pkg/devops to Medium abstraction (#293)
* chore(io): migrate pkg/devops to Medium abstraction
This commit migrates the pkg/devops package to use the io.Medium abstraction instead of direct calls to io.Local or the os package.
Changes:
- Updated DevOps, ImageManager, and Manifest structs to hold an io.Medium.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
This migration improves the testability and flexibility of the devops package by allowing for different storage backends.
* chore(io): migrate pkg/devops to Medium abstraction
This commit completes the migration of the pkg/devops package to the io.Medium abstraction.
Changes:
- Refactored DevOps, ImageManager, and Manifest structs to use io.Medium for storage operations.
- Updated New, NewImageManager, and LoadConfig to accept an io.Medium.
- Updated ImageSource interface and its implementations (GitHubSource, CDNSource) to accept io.Medium in Download method.
- Refactored internal helper functions (hasFile, hasPackageScript, etc.) to use io.Medium.
- Updated all unit tests and CLI entry points to pass the appropriate io.Medium.
- Fixed formatting issues in test files.
This migration enables easier testing and supports alternative storage backends.
2026-02-04 14:58:03 +00:00
|
|
|
d := &DevOps{medium: io.Local,
|
2026-01-29 14:28:23 +00:00
|
|
|
config: cfg,
|
|
|
|
|
images: mgr,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
assert.NotNil(t, d.config)
|
|
|
|
|
assert.Equal(t, "auto", d.config.Images.Source)
|
|
|
|
|
}
|