Cover + integration tests for server

This commit is contained in:
porosnicuadrian
2021-01-22 18:41:14 +02:00
committed by Dan Christian Bogos
parent 14788e2c4e
commit 6fb6b86349
3 changed files with 368 additions and 30 deletions

View File

@@ -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

View File

@@ -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()
}
*/

View File

@@ -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()
}