package rpc import ( "encoding/json" "github.com/spiral/roadrunner/service" "github.com/stretchr/testify/assert" "runtime" "testing" ) type testCfg struct{ cfg string } func (cfg *testCfg) Get(name string) service.Config { return nil } func (cfg *testCfg) Unmarshal(out interface{}) error { return json.Unmarshal([]byte(cfg.cfg), out) } func Test_Config_Hydrate(t *testing.T) { cfg := &testCfg{`{"enable": true, "listen": "tcp://:18001"}`} c := &Config{} assert.NoError(t, c.Hydrate(cfg)) } func Test_Config_Hydrate_Error(t *testing.T) { cfg := &testCfg{`{"enable": true, "listen": "invalid"}`} c := &Config{} assert.Error(t, c.Hydrate(cfg)) } func Test_Config_Hydrate_Error2(t *testing.T) { cfg := &testCfg{`{"enable": true, "listen": "invalid"`} c := &Config{} assert.Error(t, c.Hydrate(cfg)) } func TestConfig_Listener(t *testing.T) { cfg := &Config{Listen: "tcp://:18001"} ln, err := cfg.Listener() assert.NoError(t, err) assert.NotNil(t, ln) defer ln.Close() assert.Equal(t, "tcp", ln.Addr().Network()) assert.Equal(t, "[::]:18001", ln.Addr().String()) } func TestConfig_ListenerUnix(t *testing.T) { if runtime.GOOS == "windows" { t.Skip("not supported on " + runtime.GOOS) } cfg := &Config{Listen: "unix://file.sock"} ln, err := cfg.Listener() assert.NoError(t, err) assert.NotNil(t, ln) defer ln.Close() assert.Equal(t, "unix", ln.Addr().Network()) assert.Equal(t, "file.sock", ln.Addr().String()) } func Test_Config_Error(t *testing.T) { if runtime.GOOS == "windows" { t.Skip("not supported on " + runtime.GOOS) } cfg := &Config{Listen: "uni:unix.sock"} ln, err := cfg.Listener() assert.Nil(t, ln) assert.Error(t, err) assert.Equal(t, "Invalid DSN (tcp://:6001, unix://file.sock)", err.Error()) } func Test_Config_ErrorMethod(t *testing.T) { cfg := &Config{Listen: "xinu://unix.sock"} ln, err := cfg.Listener() assert.Nil(t, ln) assert.Error(t, err) } func TestConfig_Dialer(t *testing.T) { cfg := &Config{Listen: "tcp://:18001"} ln, _ := cfg.Listener() defer ln.Close() conn, err := cfg.Dialer() assert.NoError(t, err) assert.NotNil(t, conn) defer conn.Close() assert.Equal(t, "tcp", conn.RemoteAddr().Network()) assert.Equal(t, "127.0.0.1:18001", conn.RemoteAddr().String()) } func TestConfig_DialerUnix(t *testing.T) { if runtime.GOOS == "windows" { t.Skip("not supported on " + runtime.GOOS) } cfg := &Config{Listen: "unix://file.sock"} ln, _ := cfg.Listener() defer ln.Close() conn, err := cfg.Dialer() assert.NoError(t, err) assert.NotNil(t, conn) defer conn.Close() assert.Equal(t, "unix", conn.RemoteAddr().Network()) assert.Equal(t, "file.sock", conn.RemoteAddr().String()) } func Test_Config_DialerError(t *testing.T) { if runtime.GOOS == "windows" { t.Skip("not supported on " + runtime.GOOS) } cfg := &Config{Listen: "uni:unix.sock"} ln, err := cfg.Dialer() assert.Nil(t, ln) assert.Error(t, err) assert.Equal(t, "invalid socket DSN (tcp://:6001, unix://file.sock)", err.Error()) } func Test_Config_DialerErrorMethod(t *testing.T) { cfg := &Config{Listen: "xinu://unix.sock"} ln, err := cfg.Dialer() assert.Nil(t, ln) assert.Error(t, err) } func Test_Config_Defaults(t *testing.T) { c := &Config{} c.InitDefaults() assert.Equal(t, true, c.Enable) assert.Equal(t, "tcp://127.0.0.1:6001", c.Listen) }