only write jsonnnet files if we made changes (#56)

Adding a dep, or updating a dependency version makes writes to the
jsonnet files.

We evaluate the changes on each of the files. An empty jsonnetfile.json
does not create a corresponding lockfile, as a missing lockfile is not
different from its previous (non existent).
This commit is contained in:
David Genest 2019-11-08 09:36:13 -05:00 committed by sh0rez
parent 7fc7c31856
commit f4417ac665
3 changed files with 124 additions and 12 deletions

View file

@ -34,14 +34,20 @@ func installCommand(dir, jsonnetHome string, uris []string) int {
dir = "."
}
jsonnetFile, err := jsonnetfile.Load(filepath.Join(dir, jsonnetfile.File))
jbfilebytes, err := ioutil.ReadFile(filepath.Join(dir, jsonnetfile.File))
kingpin.FatalIfError(err, "failed to load jsonnetfile")
lockFile, err := jsonnetfile.Load(filepath.Join(dir, jsonnetfile.LockFile))
jsonnetFile, err := jsonnetfile.Unmarshal(jbfilebytes)
kingpin.FatalIfError(err, "")
jblockfilebytes, err := ioutil.ReadFile(filepath.Join(dir, jsonnetfile.LockFile))
if !os.IsNotExist(err) {
kingpin.FatalIfError(err, "failed to load lockfile")
}
lockFile, err := jsonnetfile.Unmarshal(jblockfilebytes)
kingpin.FatalIfError(err, "")
kingpin.FatalIfError(
os.MkdirAll(filepath.Join(dir, jsonnetHome, ".tmp"), os.ModePerm),
"creating vendor folder")
@ -65,10 +71,11 @@ func installCommand(dir, jsonnetHome string, uris []string) int {
kingpin.FatalIfError(err, "failed to install packages")
kingpin.FatalIfError(
writeJSONFile(filepath.Join(dir, jsonnetfile.File), jsonnetFile),
writeChangedJsonnetFile(jbfilebytes, &jsonnetFile, filepath.Join(dir, jsonnetfile.File)),
"updating jsonnetfile.json")
kingpin.FatalIfError(
writeJSONFile(filepath.Join(dir, jsonnetfile.LockFile), spec.JsonnetFile{Dependencies: locked}),
writeChangedJsonnetFile(jblockfilebytes, &spec.JsonnetFile{Dependencies: locked}, filepath.Join(dir, jsonnetfile.LockFile)),
"updating jsonnetfile.lock.json")
return 0
@ -91,3 +98,16 @@ func writeJSONFile(name string, d interface{}) error {
return ioutil.WriteFile(name, b, 0644)
}
func writeChangedJsonnetFile(originalBytes []byte, modified *spec.JsonnetFile, path string) error {
origJsonnetFile, err := jsonnetfile.Unmarshal(originalBytes)
if err != nil {
return err
}
if reflect.DeepEqual(origJsonnetFile, *modified) {
return nil
}
return writeJSONFile(path, *modified)
}

View file

@ -24,6 +24,7 @@ import (
"github.com/stretchr/testify/assert"
"github.com/jsonnet-bundler/jsonnet-bundler/pkg/jsonnetfile"
"github.com/jsonnet-bundler/jsonnet-bundler/spec"
)
func TestInstallCommand(t *testing.T) {
@ -35,10 +36,9 @@ func TestInstallCommand(t *testing.T) {
ExpectedJsonnetLockFile []byte
}{
{
Name: "NoURLs",
ExpectedCode: 0,
ExpectedJsonnetFile: []byte(`{"dependencies":null}`),
ExpectedJsonnetLockFile: []byte(`{"dependencies":null}`),
Name: "NoURLs",
ExpectedCode: 0,
ExpectedJsonnetFile: []byte(`{}`),
}, {
Name: "OneURL",
URIs: []string{"github.com/jsonnet-bundler/jsonnet-bundler@v0.1.0"},
@ -77,7 +77,9 @@ func TestInstallCommand(t *testing.T) {
installCommand("", "vendor", tc.URIs)
jsonnetFileContent(t, jsonnetfile.File, tc.ExpectedJsonnetFile)
jsonnetFileContent(t, jsonnetfile.LockFile, tc.ExpectedJsonnetLockFile)
if tc.ExpectedJsonnetLockFile != nil {
jsonnetFileContent(t, jsonnetfile.LockFile, tc.ExpectedJsonnetLockFile)
}
})
}
@ -93,3 +95,85 @@ func jsonnetFileContent(t *testing.T, filename string, content []byte) {
t.Log(string(bytes))
}
}
func TestWriteChangedJsonnetFile(t *testing.T) {
testcases := []struct {
Name string
JsonnetFileBytes []byte
NewJsonnetFile spec.JsonnetFile
ExpectWrite bool
}{
{
Name: "NoDiffEmpty",
JsonnetFileBytes: []byte(`{}`),
NewJsonnetFile: spec.New(),
ExpectWrite: false,
},
{
Name: "NoDiffNotEmpty",
JsonnetFileBytes: []byte(`{"dependencies": [{"name": "foobar"}]}`),
NewJsonnetFile: spec.JsonnetFile{
Dependencies: map[string]spec.Dependency{
"foobar": {
Name: "foobar",
},
},
},
ExpectWrite: false,
},
{
Name: "DiffVersion",
JsonnetFileBytes: []byte(`{"dependencies": [{"name": "foobar", "version": "1.0"}]}`),
NewJsonnetFile: spec.JsonnetFile{
Dependencies: map[string]spec.Dependency{
"foobar": {
Name: "foobar",
Version: "2.0",
},
},
},
ExpectWrite: true,
},
{
Name: "Diff",
JsonnetFileBytes: []byte(`{}`),
NewJsonnetFile: spec.JsonnetFile{
Dependencies: map[string]spec.Dependency{
"foobar": {
Name: "foobar",
Source: spec.Source{
GitSource: &spec.GitSource{
Remote: "https://github.com/foobar/foobar",
Subdir: "",
},
},
Version: "master",
DepSource: "",
}},
},
ExpectWrite: true,
},
}
outputjsonnetfile := "changedjsonnet.json"
for _, tc := range testcases {
_ = t.Run(tc.Name, func(t *testing.T) {
clean := func() {
_ = os.Remove(outputjsonnetfile)
}
clean()
defer clean()
err := writeChangedJsonnetFile(tc.JsonnetFileBytes, &tc.NewJsonnetFile, outputjsonnetfile)
assert.NoError(t, err)
if tc.ExpectWrite {
assert.FileExists(t, outputjsonnetfile)
} else {
_, err := os.Lstat(outputjsonnetfile)
if err != nil {
assert.True(t, os.IsNotExist(err))
}
}
})
}
}