1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
package gzip
import (
"testing"
json "github.com/json-iterator/go"
"github.com/sirupsen/logrus"
"github.com/sirupsen/logrus/hooks/test"
"github.com/spiral/roadrunner/service"
rrhttp "github.com/spiral/roadrunner/service/http"
"github.com/stretchr/testify/assert"
)
type testCfg struct {
gzip string
httpCfg string
target string
}
func (cfg *testCfg) Get(name string) service.Config {
if name == rrhttp.ID {
return &testCfg{target: cfg.httpCfg}
}
if name == ID {
return &testCfg{target: cfg.gzip}
}
return nil
}
func (cfg *testCfg) Unmarshal(out interface{}) error {
j := json.ConfigCompatibleWithStandardLibrary
return j.Unmarshal([]byte(cfg.target), out)
}
func Test_Disabled(t *testing.T) {
logger, _ := test.NewNullLogger()
logger.SetLevel(logrus.DebugLevel)
c := service.NewContainer(logger)
c.Register(ID, &Service{cfg: &Config{Enable: true}})
assert.NoError(t, c.Init(&testCfg{
httpCfg: `{
"address": ":6029",
"workers":{
"command": "php ../../tests/http/client.php echo pipes",
}
}`,
gzip: `{"enable":false}`,
}))
s, st := c.Get(ID)
assert.NotNil(t, s)
assert.Equal(t, service.StatusInactive, st)
}
// TEST bug #275
func Test_Bug275(t *testing.T) {
logger, _ := test.NewNullLogger()
logger.SetLevel(logrus.DebugLevel)
c := service.NewContainer(logger)
c.Register(ID, &Service{})
assert.Error(t, c.Init(&testCfg{
httpCfg: "",
gzip: `{"enable":true}`,
}))
s, st := c.Get(ID)
assert.NotNil(t, s)
assert.Equal(t, service.StatusInactive, st)
}
|