mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
Cover + integration tests for server
This commit is contained in:
committed by
Dan Christian Bogos
parent
14788e2c4e
commit
6fb6b86349
@@ -403,9 +403,7 @@ func (s *Server) ServeGOBTLS(addr, serverCrt, serverKey, caCert string,
|
||||
if !enabled {
|
||||
return
|
||||
}
|
||||
fmt.Println("am intrat aici")
|
||||
config, err := loadTLSConfig(serverCrt, serverKey, caCert, serverPolicy, serverName)
|
||||
fmt.Println("am iesit de aici")
|
||||
if err != nil {
|
||||
shdChan.CloseOnce()
|
||||
return
|
||||
|
||||
@@ -1 +1,358 @@
|
||||
/*
|
||||
Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments
|
||||
Copyright (C) ITsysCOM GmbH
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>
|
||||
*/
|
||||
|
||||
package cores
|
||||
|
||||
import (
|
||||
"net"
|
||||
"net/rpc/jsonrpc"
|
||||
"runtime"
|
||||
"testing"
|
||||
|
||||
sessions2 "github.com/cgrates/cgrates/sessions"
|
||||
|
||||
"github.com/cenkalti/rpc2"
|
||||
|
||||
"github.com/cgrates/cgrates/config"
|
||||
|
||||
"github.com/cgrates/cgrates/engine"
|
||||
|
||||
"github.com/cgrates/cgrates/utils"
|
||||
)
|
||||
|
||||
var (
|
||||
server *Server
|
||||
|
||||
sTestsServer = []func(t *testing.T){
|
||||
testServeJSONPass,
|
||||
testServeJSONFail,
|
||||
testServeJSONFailRpcEnabled,
|
||||
testServeGOBPass,
|
||||
testServeHHTPPass,
|
||||
testServeHHTPPassUseBasicAuth,
|
||||
testServeHHTPEnableHttp,
|
||||
testServeHHTPFail,
|
||||
testServeHHTPFailEnableRpc,
|
||||
testServeBiJSON,
|
||||
testServeBiJSONEmptyBiRPCServer,
|
||||
testServeBiJSONInvalidPort,
|
||||
}
|
||||
)
|
||||
|
||||
func TestServerIT(t *testing.T) {
|
||||
for _, test := range sTestsServer {
|
||||
t.Run("Running IT serve tests", test)
|
||||
}
|
||||
}
|
||||
|
||||
type mockRegister struct{}
|
||||
|
||||
func (robj *mockRegister) Ping(in string, out *string) error {
|
||||
*out = utils.Pong
|
||||
return nil
|
||||
}
|
||||
|
||||
type mockListener struct{}
|
||||
|
||||
func (mkL *mockListener) Accept() (net.Conn, error) { return nil, utils.ErrDisconnected }
|
||||
func (mkL *mockListener) Close() error { return nil }
|
||||
func (mkL *mockListener) Addr() net.Addr { return nil }
|
||||
|
||||
func testServeJSONPass(t *testing.T) {
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeJSON(":2016", shdChan)
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2016")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeJSONFail(t *testing.T) {
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
l := &mockListener{}
|
||||
go server.accept(l, utils.JSONCaps, newCapsJSONCodec, shdChan)
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":9999")
|
||||
expected := "dial tcp :9999: connect: connection refused"
|
||||
if err == nil || err.Error() != expected {
|
||||
t.Errorf("Expected %+v, received %+v", expected, err)
|
||||
}
|
||||
|
||||
_, ok := <-shdChan.Done()
|
||||
if ok {
|
||||
t.Errorf("Expected to be close")
|
||||
}
|
||||
}
|
||||
|
||||
func testServeJSONFailRpcEnabled(t *testing.T) {
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
server.rpcEnabled = false
|
||||
|
||||
go server.serveCodec(":9999", utils.JSONCaps, newCapsJSONCodec, shdChan)
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeGOBPass(t *testing.T) {
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeGOB(":2019", shdChan)
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2019")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeHHTPPass(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeHTTP(
|
||||
":2021",
|
||||
cfgDflt.HTTPCfg().HTTPJsonRPCURL,
|
||||
cfgDflt.HTTPCfg().HTTPWSURL,
|
||||
cfgDflt.HTTPCfg().HTTPUseBasicAuth,
|
||||
cfgDflt.HTTPCfg().HTTPAuthUsers,
|
||||
shdChan)
|
||||
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2021")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeHHTPPassUseBasicAuth(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeHTTP(
|
||||
":2075",
|
||||
cfgDflt.HTTPCfg().HTTPJsonRPCURL,
|
||||
cfgDflt.HTTPCfg().HTTPWSURL,
|
||||
!cfgDflt.HTTPCfg().HTTPUseBasicAuth,
|
||||
cfgDflt.HTTPCfg().HTTPAuthUsers,
|
||||
shdChan)
|
||||
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2075")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeHHTPEnableHttp(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeHTTP(
|
||||
":2077",
|
||||
utils.EmptyString,
|
||||
utils.EmptyString,
|
||||
!cfgDflt.HTTPCfg().HTTPUseBasicAuth,
|
||||
cfgDflt.HTTPCfg().HTTPAuthUsers,
|
||||
shdChan)
|
||||
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2077")
|
||||
expected := "dial tcp :2077: connect: connection refused"
|
||||
if err == nil || err.Error() != expected {
|
||||
t.Errorf("Expected %+v, received %+v", expected, err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeHHTPFail(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeHTTP(
|
||||
"invalid_portt_format",
|
||||
cfgDflt.HTTPCfg().HTTPJsonRPCURL,
|
||||
cfgDflt.HTTPCfg().HTTPWSURL,
|
||||
cfgDflt.HTTPCfg().HTTPUseBasicAuth,
|
||||
cfgDflt.HTTPCfg().HTTPAuthUsers,
|
||||
shdChan)
|
||||
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":2037")
|
||||
expected := "dial tcp :2037: connect: connection refused"
|
||||
if err == nil || err.Error() != expected {
|
||||
t.Errorf("Expected %+v, received %+v", expected, err)
|
||||
}
|
||||
|
||||
_, ok := <-shdChan.Done()
|
||||
if ok {
|
||||
t.Errorf("Expected to be close")
|
||||
}
|
||||
}
|
||||
|
||||
func testServeHHTPFailEnableRpc(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
shdChan := utils.NewSyncedChan()
|
||||
server.rpcEnabled = false
|
||||
|
||||
go server.ServeHTTP(":1000",
|
||||
cfgDflt.HTTPCfg().HTTPJsonRPCURL,
|
||||
cfgDflt.HTTPCfg().HTTPWSURL,
|
||||
cfgDflt.HTTPCfg().HTTPUseBasicAuth,
|
||||
cfgDflt.HTTPCfg().HTTPAuthUsers,
|
||||
shdChan)
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
func testServeBiJSON(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
server.birpcSrv = rpc2.NewServer()
|
||||
|
||||
data := engine.NewInternalDB(nil, nil, true)
|
||||
dm := engine.NewDataManager(data, cfgDflt.CacheCfg(), nil)
|
||||
|
||||
sessions := sessions2.NewSessionS(cfgDflt, dm, nil)
|
||||
|
||||
go func() {
|
||||
if err := server.ServeBiJSON(":3434", sessions.OnBiJSONConnect, sessions.OnBiJSONDisconnect); err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
}()
|
||||
|
||||
runtime.Gosched()
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":3434")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
func testServeBiJSONEmptyBiRPCServer(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
|
||||
data := engine.NewInternalDB(nil, nil, true)
|
||||
dm := engine.NewDataManager(data, cfgDflt.CacheCfg(), nil)
|
||||
|
||||
sessions := sessions2.NewSessionS(cfgDflt, dm, nil)
|
||||
|
||||
expectedErr := "BiRPCServer should not be nil"
|
||||
go func() {
|
||||
|
||||
if err := server.ServeBiJSON(":3430", sessions.OnBiJSONConnect, sessions.OnBiJSONDisconnect); err == nil || err.Error() != "BiRPCServer should not be nil" {
|
||||
t.Errorf("Expected %+v, received %+v", expectedErr, err)
|
||||
}
|
||||
}()
|
||||
|
||||
runtime.Gosched()
|
||||
expected := "dial tcp :3430: connect: connection refused"
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":3430")
|
||||
if err == nil || err.Error() != expected {
|
||||
t.Errorf("Expected %+v, received %+v", expected, err)
|
||||
}
|
||||
}
|
||||
|
||||
func testServeBiJSONInvalidPort(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(mockRegister))
|
||||
server.birpcSrv = rpc2.NewServer()
|
||||
|
||||
data := engine.NewInternalDB(nil, nil, true)
|
||||
dm := engine.NewDataManager(data, cfgDflt.CacheCfg(), nil)
|
||||
|
||||
sessions := sessions2.NewSessionS(cfgDflt, dm, nil)
|
||||
|
||||
expectedErr := "listen tcp: address invalid_port_format: missing port in address"
|
||||
if err := server.ServeBiJSON("invalid_port_format", sessions.OnBiJSONConnect,
|
||||
sessions.OnBiJSONDisconnect); err == nil || err.Error() != expectedErr {
|
||||
t.Errorf("Expected %+v, received %+v", expectedErr, err)
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
func testServeGOBTLS(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
caps := engine.NewCaps(100, utils.MetaBusy)
|
||||
server = NewServer(caps)
|
||||
server.RpcRegister(new(randomObj))
|
||||
|
||||
shdChan := utils.NewSyncedChan()
|
||||
|
||||
go server.ServeGOBTLS(
|
||||
":1256",
|
||||
cfgDflt.TLSCfg().ServerCerificate,
|
||||
cfgDflt.TLSCfg().ServerKey,
|
||||
cfgDflt.TLSCfg().CaCertificate,
|
||||
cfgDflt.TLSCfg().ServerPolicy,
|
||||
cfgDflt.TLSCfg().ServerName,
|
||||
shdChan,
|
||||
)
|
||||
|
||||
_, err := jsonrpc.Dial(utils.TCP, ":1256")
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
shdChan.CloseOnce()
|
||||
}
|
||||
|
||||
*/
|
||||
|
||||
@@ -19,10 +19,11 @@ along with this program. If not, see <http://www.gnu.org/licenses/>
|
||||
package cores
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"net/http"
|
||||
"net/http/httptest"
|
||||
"os"
|
||||
"reflect"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"github.com/cenkalti/rpc2"
|
||||
@@ -203,43 +204,25 @@ func TestRegisterProfiler(t *testing.T) {
|
||||
rcv.StopBiRPC()
|
||||
}
|
||||
|
||||
type mockWriteResponse struct{}
|
||||
|
||||
func (mk *mockWriteResponse) Header() http.Header { return http.Header{} }
|
||||
func (mk *mockWriteResponse) Write([]byte) (int, error) { return 0, nil }
|
||||
func (mk *mockWriteResponse) WriteHeader(statusCode int) {}
|
||||
|
||||
func TestHandleRequest(t *testing.T) {
|
||||
cfgDflt := config.NewDefaultCGRConfig()
|
||||
cfgDflt.CoreSCfg().CapsStatsInterval = 1
|
||||
caps := engine.NewCaps(0, utils.MetaBusy)
|
||||
rcv := NewServer(caps)
|
||||
|
||||
cfgDflt.AnalyzerSCfg().DBPath = "/tmp/analyzers"
|
||||
if err := os.RemoveAll(cfgDflt.AnalyzerSCfg().DBPath); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if err := os.MkdirAll(cfgDflt.AnalyzerSCfg().DBPath, 0700); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
analz, err := analyzers.NewAnalyzerService(cfgDflt)
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
rcv.SetAnalyzer(analz)
|
||||
rcv.rpcEnabled = true
|
||||
|
||||
req, err := http.NewRequest("POST", "http://www.google.com/search?q=foo&q=bar&both=x&prio=1&orphan=nope&empty=not",
|
||||
strings.NewReader("z=post&both=y&prio=2&=nokey&orphan;empty=&"))
|
||||
req, err := http.NewRequest(http.MethodPost, "https://raw.githubusercontent.com/cgrates/cgrates/master/data/tariffplans/oldtutorial/ActionPlans.csv",
|
||||
bytes.NewBuffer([]byte("1")))
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
mkRespWriter := &mockWriteResponse{}
|
||||
rcv.handleRequest(mkRespWriter, req)
|
||||
|
||||
if err := os.RemoveAll(cfgDflt.AnalyzerSCfg().DBPath); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
w := httptest.NewRecorder()
|
||||
rcv.handleRequest(w, req)
|
||||
if w.Body.String() != utils.EmptyString {
|
||||
t.Errorf("Expected: %q ,received: %q", utils.EmptyString, w.Body.String())
|
||||
}
|
||||
|
||||
rcv.StopBiRPC()
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user