annotate zs_test.go @ 17:0214b1b5f5eb draft

added amber and gcss compilers
author zaitsev.serge
date Sat, 29 Aug 2015 15:47:16 +0000
parents cb66f5b86616
children ae3116ea938b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
1 package main
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
2
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
3 import (
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
4 "bytes"
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
5 "fmt"
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
6 "io/ioutil"
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
7 "log"
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
8 "os"
5
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
9 "os/exec"
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
10 "strings"
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
11 "testing"
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
12 )
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
13
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
14 func TestSplit2(t *testing.T) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
15 if a, b := split2("a:b", ":"); a != "a" || b != "b" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
16 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
17 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
18 if a, b := split2(":b", ":"); a != "" || b != "b" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
19 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
20 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
21 if a, b := split2("a:", ":"); a != "a" || b != "" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
22 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
23 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
24 if a, b := split2(":", ":"); a != "" || b != "" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
25 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
26 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
27 if a, b := split2("a", ":"); a != "a" || b != "" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
28 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
29 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
30 if a, b := split2("", ":"); a != "" || b != "" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
31 t.Fail()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
32 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
33 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
34
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
35 func tmpfile(path, s string) string {
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
36 ioutil.WriteFile(path, []byte(s), 0644)
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
37 return path
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
38 }
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
39
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
40 func TestMD(t *testing.T) {
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
41 defer os.Remove("foo.md")
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
42 v, body, _ := md(tmpfile("foo.md", `
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
43 title: Hello, world!
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
44 keywords: foo, bar, baz
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
45 empty:
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
46 bayan: [:|||:]
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
47
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
48 this: is a content`))
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
49 if v["title"] != "Hello, world!" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
50 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
51 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
52 if v["keywords"] != "foo, bar, baz" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
53 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
54 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
55 if s, ok := v["empty"]; !ok || len(s) != 0 {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
56 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
57 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
58 if v["bayan"] != "[:|||:]" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
59 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
60 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
61 if body != "this: is a content" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
62 t.Error(body)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
63 }
2
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
64
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
65 // Test empty md
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
66 v, body, _ = md(tmpfile("foo.md", ""))
2
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
67 if len(v) != 0 || len(body) != 0 {
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
68 t.Error(v, body)
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
69 }
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
70
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
71 // Test empty header
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
72 v, body, _ = md(tmpfile("foo.md", "Hello"))
2
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
73 if len(v) != 0 || body != "Hello" {
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
74 t.Error(v, body)
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 1
diff changeset
75 }
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
76 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
77
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
78 func TestRender(t *testing.T) {
17
0214b1b5f5eb added amber and gcss compilers
zaitsev.serge
parents: 6
diff changeset
79 eval := func(a []string, vars Vars) (string, error) {
1
d647affd8ae9 fixed eval func prototype in tests
zaitsev.serge
parents: 0
diff changeset
80 return "hello", nil
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
81 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
82 vars := map[string]string{"foo": "bar"}
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
83
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
84 if s, err := render("plain text", vars, eval); err != nil || s != "plain text" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
85 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
86 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
87 if s, err := render("a {{greet}} text", vars, eval); err != nil || s != "a hello text" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
88 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
89 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
90 if s, err := render("{{greet}} x{{foo}}z", vars, eval); err != nil || s != "hello xbarz" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
91 t.Error()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
92 }
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
93 // Test error case
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
94 if s, err := render("a {{greet text ", vars, eval); err == nil || len(s) != 0 {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
95 t.Error()
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
96 }
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
97 }
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
98
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
99 func TestEnv(t *testing.T) {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
100 e := env(map[string]string{"foo": "bar", "baz": "hello world"})
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
101 mustHave := []string{"ZS=" + os.Args[0], "ZS_FOO=bar", "ZS_BAZ=hello world", "PATH="}
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
102 for _, s := range mustHave {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
103 found := false
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
104 for _, v := range e {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
105 if strings.HasPrefix(v, s) {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
106 found = true
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
107 break
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
108 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
109 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
110 if !found {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
111 t.Error("Missing", s)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
112 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
113 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
114 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
115
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
116 func TestRun(t *testing.T) {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
117 out := bytes.NewBuffer(nil)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
118 err := run("some_unbelievable_command_name", []string{}, map[string]string{}, out)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
119 if err == nil {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
120 t.Error()
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
121 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
122
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
123 out = bytes.NewBuffer(nil)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
124 err = run(os.Args[0], []string{"-test.run=TestHelperProcess"},
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
125 map[string]string{"helper": "1", "out": "foo", "err": "bar"}, out)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
126 if err != nil {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
127 t.Error(err)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
128 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
129 if out.String() != "foo\n" {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
130 t.Error(out.String())
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
131 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
132 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
133
5
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
134 func TestEvalCommand(t *testing.T) {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
135 s, err := eval([]string{"echo", "hello"}, map[string]string{})
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
136 if err != nil {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
137 t.Error(err)
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
138 }
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
139 if s != "hello\n" {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
140 t.Error(s)
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
141 }
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
142 _, err = eval([]string{"cat", "bogus/file"}, map[string]string{})
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
143 if _, ok := err.(*exec.ExitError); !ok {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
144 t.Error("expected ExitError")
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
145 }
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
146 _, err = eval([]string{"missing command"}, map[string]string{})
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
147 if err != nil {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
148 t.Error("missing command should be ignored")
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
149 }
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
150 }
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
151
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
152 func TestHelperProcess(*testing.T) {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
153 if os.Getenv("ZS_HELPER") != "1" {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
154 return
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
155 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
156 defer os.Exit(0) // TODO check exit code
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
157 log.Println(os.Getenv("ZS_ERR")) // stderr
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
158 fmt.Println(os.Getenv("ZS_OUT")) // stdout
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 2
diff changeset
159 }