mirror of
https://git.mills.io/prologic/zs
synced 2024-11-25 14:56:12 +03:00
added integration test for build procedure
This commit is contained in:
parent
39484fddb0
commit
9803539c0f
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +1,2 @@
|
|||||||
zs
|
zs
|
||||||
|
.pub
|
||||||
|
0
testdata/empty/.empty
vendored
Normal file
0
testdata/empty/.empty
vendored
Normal file
6
testdata/page/.test/index.html
vendored
Normal file
6
testdata/page/.test/index.html
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<h1>Hello
|
||||||
|
</h1>
|
||||||
|
</body>
|
||||||
|
</html>
|
5
testdata/page/index.html
vendored
Normal file
5
testdata/page/index.html
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<h1>{{ echo Hello }}</h1>
|
||||||
|
</body>
|
||||||
|
</html>
|
72
zs_build_test.go
Normal file
72
zs_build_test.go
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/md5"
|
||||||
|
"encoding/hex"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
const TESTDIR = ".test"
|
||||||
|
|
||||||
|
func TestBuild(t *testing.T) {
|
||||||
|
files, _ := ioutil.ReadDir("testdata")
|
||||||
|
for _, f := range files {
|
||||||
|
if f.IsDir() {
|
||||||
|
testBuild(filepath.Join("testdata", f.Name()), t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func testBuild(path string, t *testing.T) {
|
||||||
|
wd, _ := os.Getwd()
|
||||||
|
os.Chdir(path)
|
||||||
|
args := os.Args[:]
|
||||||
|
os.Args = []string{"zs", "build"}
|
||||||
|
t.Log("--- BUILD", path)
|
||||||
|
main()
|
||||||
|
|
||||||
|
compare(PUBDIR, TESTDIR, t)
|
||||||
|
|
||||||
|
os.Chdir(wd)
|
||||||
|
os.Args = args
|
||||||
|
}
|
||||||
|
|
||||||
|
func compare(pub, test string, t *testing.T) {
|
||||||
|
a := md5dir(pub)
|
||||||
|
b := md5dir(test)
|
||||||
|
for k, v := range a {
|
||||||
|
if s, ok := b[k]; !ok {
|
||||||
|
t.Error("Unexpected file:", k, v)
|
||||||
|
} else if s != v {
|
||||||
|
t.Error("Different file:", k, v, s)
|
||||||
|
} else {
|
||||||
|
t.Log("Matching file", k, v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for k, v := range b {
|
||||||
|
if _, ok := a[k]; !ok {
|
||||||
|
t.Error("Missing file:", k, v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func md5dir(path string) map[string]string {
|
||||||
|
files := map[string]string{}
|
||||||
|
filepath.Walk(path, func(s string, info os.FileInfo, err error) error {
|
||||||
|
if err == nil && !info.IsDir() {
|
||||||
|
if f, err := os.Open(s); err == nil {
|
||||||
|
defer f.Close()
|
||||||
|
hash := md5.New()
|
||||||
|
io.Copy(hash, f)
|
||||||
|
files[strings.TrimPrefix(s, path)] = hex.EncodeToString(hash.Sum(nil))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
return files
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user