fix(cmd/scm): avoid masking invalid core.json
Some checks failed
Security Scan / security (push) Failing after 13s
Test / test (push) Successful in 2m12s

Co-Authored-By: Virgil <virgil@lethean.io>
This commit is contained in:
Virgil 2026-04-02 07:20:33 +00:00
parent 1bccde8828
commit 8292f3ae79
4 changed files with 119 additions and 6 deletions

View file

@ -4,6 +4,7 @@ package scm
import (
fmt "dappco.re/go/core/scm/internal/ax/fmtx"
os "dappco.re/go/core/scm/internal/ax/osx"
"dappco.re/go/core/io"
"dappco.re/go/core/scm/manifest"
@ -16,7 +17,7 @@ func addExportCommand(parent *cli.Command) {
cmd := &cli.Command{
Use: "export",
Short: "Export compiled manifest as JSON",
Long: "Read core.json from the project root and print it to stdout. Falls back to compiling .core/manifest.yaml if core.json is not found.",
Long: "Read core.json from the project root and print it to stdout. Falls back to compiling .core/manifest.yaml only when core.json is missing.",
RunE: func(cmd *cli.Command, args []string) error {
return runExport(dir)
},
@ -33,10 +34,18 @@ func runExport(dir string) error {
return cli.WrapVerb(err, "open", dir)
}
// Try core.json first.
cm, err := manifest.LoadCompiled(medium, ".")
var cm *manifest.CompiledManifest
// Prefer core.json if it exists and is valid.
if raw, readErr := medium.Read("core.json"); readErr == nil {
cm, err = manifest.ParseCompiled([]byte(raw))
if err != nil {
// Fall back to compiling from source.
return err
}
} else if !os.IsNotExist(readErr) {
return cli.WrapVerb(readErr, "read", "core.json")
} else {
// Fall back to compiling from source only when the compiled artifact is absent.
m, loadErr := manifest.Load(medium, ".")
if loadErr != nil {
return cli.WrapVerb(loadErr, "load", "manifest")

View file

@ -0,0 +1,64 @@
// SPDX-License-Identifier: EUPL-1.2
package scm
import (
filepath "dappco.re/go/core/scm/internal/ax/filepathx"
os "dappco.re/go/core/scm/internal/ax/osx"
"testing"
"dappco.re/go/core/scm/manifest"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestRunExport_Good_CompiledManifest_Good(t *testing.T) {
dir := t.TempDir()
cm := &manifest.CompiledManifest{
Manifest: manifest.Manifest{
Code: "compiled-mod",
Name: "Compiled Module",
Version: "1.0.0",
},
Commit: "abc123",
}
data, err := manifest.MarshalJSON(cm)
require.NoError(t, err)
require.NoError(t, os.WriteFile(filepath.Join(dir, "core.json"), data, 0644))
err = runExport(dir)
require.NoError(t, err)
}
func TestRunExport_Good_FallsBackToSource_Good(t *testing.T) {
dir := t.TempDir()
coreDir := filepath.Join(dir, ".core")
require.NoError(t, os.MkdirAll(coreDir, 0755))
require.NoError(t, os.WriteFile(filepath.Join(coreDir, "manifest.yaml"), []byte(`
code: source-mod
name: Source Module
version: 1.0.0
`), 0644))
err := runExport(dir)
require.NoError(t, err)
}
func TestRunExport_Bad_InvalidCompiledManifest_Good(t *testing.T) {
dir := t.TempDir()
coreDir := filepath.Join(dir, ".core")
require.NoError(t, os.MkdirAll(coreDir, 0755))
require.NoError(t, os.WriteFile(filepath.Join(coreDir, "manifest.yaml"), []byte(`
code: source-mod
name: Source Module
version: 1.0.0
`), 0644))
require.NoError(t, os.WriteFile(filepath.Join(dir, "core.json"), []byte("{not-json"), 0644))
err := runExport(dir)
require.Error(t, err)
assert.Contains(t, err.Error(), "manifest.ParseCompiled")
}

View file

@ -49,7 +49,10 @@ func runIndex(dirs []string, output, baseURL, org string) error {
return cli.WrapVerb(err, "build", "index")
}
absOutput, _ := filepath.Abs(output)
absOutput, err := filepath.Abs(output)
if err != nil {
return cli.WrapVerb(err, "resolve", output)
}
if err := marketplace.WriteIndex(absOutput, idx); err != nil {
return err
}

37
cmd/scm/cmd_index_test.go Normal file
View file

@ -0,0 +1,37 @@
// SPDX-License-Identifier: EUPL-1.2
package scm
import (
filepath "dappco.re/go/core/scm/internal/ax/filepathx"
os "dappco.re/go/core/scm/internal/ax/osx"
"testing"
"dappco.re/go/core/io"
"dappco.re/go/core/scm/marketplace"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestRunIndex_Good_WritesIndex_Good(t *testing.T) {
root := t.TempDir()
modDir := filepath.Join(root, "mod-a")
require.NoError(t, os.MkdirAll(filepath.Join(modDir, ".core"), 0755))
require.NoError(t, os.WriteFile(filepath.Join(modDir, ".core", "manifest.yaml"), []byte(`
code: mod-a
name: Module A
version: 1.0.0
sign: key-a
`), 0644))
output := filepath.Join(root, "index.json")
err := runIndex([]string{root}, output, "https://forge.example.com", "core")
require.NoError(t, err)
idx, err := marketplace.LoadIndex(io.Local, output)
require.NoError(t, err)
require.Len(t, idx.Modules, 1)
assert.Equal(t, "mod-a", idx.Modules[0].Code)
assert.Equal(t, "https://forge.example.com/core/mod-a.git", idx.Modules[0].Repo)
}