mirror of
https://github.com/TECHNOFAB11/jsonnet-bundler.git
synced 2025-12-12 08:00:05 +01:00
cmd/jb: Create integration tests for init and install
This commit is contained in:
parent
f71ef86d48
commit
d95948a351
2 changed files with 95 additions and 0 deletions
22
cmd/jb/init_test.go
Normal file
22
cmd/jb/init_test.go
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
// +build integration
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestInitCommand(t *testing.T) {
|
||||||
|
tempDir, err := ioutil.TempDir("", "jb-init")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(tempDir)
|
||||||
|
|
||||||
|
code := initCommand(tempDir)
|
||||||
|
assert.Equal(t, 0, code)
|
||||||
|
}
|
||||||
73
cmd/jb/install_test.go
Normal file
73
cmd/jb/install_test.go
Normal file
|
|
@ -0,0 +1,73 @@
|
||||||
|
// +build integration
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/jsonnet-bundler/jsonnet-bundler/pkg/jsonnetfile"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestInstallCommand(t *testing.T) {
|
||||||
|
testcases := []struct {
|
||||||
|
Name string
|
||||||
|
URLs []*url.URL
|
||||||
|
ExpectedCode int
|
||||||
|
ExpectedJsonnetFile []byte
|
||||||
|
ExpectedJsonnetLockFile []byte
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
Name: "NoURLs",
|
||||||
|
ExpectedCode: 0,
|
||||||
|
ExpectedJsonnetFile: []byte(`{"dependencies":null}`),
|
||||||
|
ExpectedJsonnetLockFile: []byte(`{"dependencies":null}`),
|
||||||
|
}, {
|
||||||
|
Name: "OneURL",
|
||||||
|
URLs: []*url.URL{
|
||||||
|
{
|
||||||
|
Scheme: "https",
|
||||||
|
Host: "github.com",
|
||||||
|
Path: "jsonnet-bundler/jsonnet-bundler",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ExpectedCode: 0,
|
||||||
|
ExpectedJsonnetFile: []byte(`{"dependencies": [{"name": "jsonnet-bundler", "source": {"git": {"remote": "https://github.com/jsonnet-bundler/jsonnet-bundler", "subdir": ""}}, "version": "master"}]}`),
|
||||||
|
ExpectedJsonnetLockFile: []byte(`{"dependencies": [{"name": "jsonnet-bundler", "source": {"git": {"remote": "https://github.com/jsonnet-bundler/jsonnet-bundler", "subdir": ""}}, "version": "080f157c7fb85ad0281ea78f6c641eaa570a582f"}]}`),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tc := range testcases {
|
||||||
|
t.Run(tc.Name, func(t *testing.T) {
|
||||||
|
tempDir, err := ioutil.TempDir("", "jb-install")
|
||||||
|
assert.NoError(t, err)
|
||||||
|
defer os.Remove(tempDir)
|
||||||
|
|
||||||
|
jsonnetFile := filepath.Join(tempDir, jsonnetfile.File)
|
||||||
|
jsonnetLockFile := filepath.Join(tempDir, jsonnetfile.LockFile)
|
||||||
|
|
||||||
|
code := initCommand(tempDir)
|
||||||
|
assert.Equal(t, 0, code)
|
||||||
|
|
||||||
|
jsonnetFileContent(t, jsonnetFile, []byte(`{}`))
|
||||||
|
|
||||||
|
code = installCommand(tempDir, "vendor", tc.URLs...)
|
||||||
|
assert.Equal(t, tc.ExpectedCode, code)
|
||||||
|
|
||||||
|
jsonnetFileContent(t, jsonnetFile, tc.ExpectedJsonnetFile)
|
||||||
|
jsonnetFileContent(t, jsonnetLockFile, tc.ExpectedJsonnetLockFile)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func jsonnetFileContent(t *testing.T, filename string, content []byte) {
|
||||||
|
bytes, err := ioutil.ReadFile(filename)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
if eq := assert.JSONEq(t, string(content), string(bytes)); !eq {
|
||||||
|
t.Log(string(bytes))
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue