/* Real-time Online/Offline Charging System (OerS) 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 */ package ees import ( "encoding/json" "net/http" "net/http/httptest" "reflect" "testing" "github.com/cgrates/cgrates/config" "github.com/cgrates/cgrates/engine" "github.com/cgrates/cgrates/utils" ) func TestHttpJsonMapID(t *testing.T) { httpEE := &HTTPjsonMapEE{ id: "3", } if rcv := httpEE.ID(); !reflect.DeepEqual(rcv, "3") { t.Errorf("Expected %+v but got %+v", "3", rcv) } } func TestHttpJsonMapGetMetrics(t *testing.T) { dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE := &HTTPjsonMapEE{ dc: dc, } if rcv := httpEE.GetMetrics(); !reflect.DeepEqual(rcv, httpEE.dc) { t.Errorf("Expected %+v \n but got %+v", utils.ToJSON(rcv), utils.ToJSON(httpEE.dc)) } } func TestHttpJsonMapExportEvent1(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaSQSjsonMap cgrEv := new(utils.CGREvent) newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrEv.Event = map[string]interface{}{ "test": "string", } errExpect := `Post "/var/spool/cgrates/ees": unsupported protocol scheme ""` if err := httpEE.ExportEvent(cgrEv); err == nil || err.Error() != errExpect { t.Errorf("Expected %q but received %q", errExpect, err) } dcExpect := int64(1) if !reflect.DeepEqual(dcExpect, httpEE.dc[utils.NumberOfEvents]) { t.Errorf("Expected %q but received %q", dcExpect, httpEE.dc[utils.NumberOfEvents]) } } func TestHttpJsonMapExportEvent2(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaSQSjsonMap cgrEv := new(utils.CGREvent) newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } bodyExpect := map[string]interface{}{ "2": "*req.field2", } srv := httptest.NewServer(http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) { defer r.Body.Close() var body map[string]interface{} if err := json.NewDecoder(r.Body).Decode(&body); err != nil { t.Fatal(err) } if !reflect.DeepEqual(body, bodyExpect) { t.Errorf("Expected %q but received %q", bodyExpect, body) } rw.WriteHeader(http.StatusOK) })) defer srv.Close() cgrCfg.EEsCfg().Exporters[0].ExportPath = srv.URL + "/" httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrEv.Event = map[string]interface{}{ "test": "string", } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*exp.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field1", utils.InfieldSep), }, { Path: "*exp.2", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("*req.field2", utils.InfieldSep), }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() if err := httpEE.ExportEvent(cgrEv); err != nil { t.Error(err) } dcExpect := int64(1) if !reflect.DeepEqual(dcExpect, httpEE.dc[utils.NumberOfEvents]) { t.Errorf("Expected %q but received %q", dcExpect, httpEE.dc[utils.NumberOfEvents]) } } func TestHttpJsonMapExportEvent3(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaSQSjsonMap cgrEv := new(utils.CGREvent) newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrEv.Event = map[string]interface{}{ "test": "string", } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*exp.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field1", utils.InfieldSep), Filters: []string{"*wrong-type"}, }, { Path: "*exp.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field1", utils.InfieldSep), Filters: []string{"*wrong-type"}, }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() errExpect := "inline parse error for string: <*wrong-type>" if err := httpEE.ExportEvent(cgrEv); err == nil || err.Error() != errExpect { t.Errorf("Expected %q but received %q", errExpect, err) } dcExpect := int64(1) if !reflect.DeepEqual(dcExpect, httpEE.dc[utils.NumberOfEvents]) { t.Errorf("Expected %q but received %q", dcExpect, httpEE.dc[utils.NumberOfEvents]) } } func TestHttpJsonMapExportEvent4(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaSQSjsonMap cgrEv := new(utils.CGREvent) newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrEv.Event = map[string]interface{}{ "test": "string", } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*exp.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field1", utils.InfieldSep), }, { Path: "*exp.2", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field2", utils.InfieldSep), }, { Path: "*hdr.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field2", utils.InfieldSep), Filters: []string{"*wrong-type"}, }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() errExpect := "inline parse error for string: <*wrong-type>" if err := httpEE.ExportEvent(cgrEv); err == nil || err.Error() != errExpect { t.Errorf("Expected %q but received %q", errExpect, err) } dcExpect := int64(1) if !reflect.DeepEqual(dcExpect, httpEE.dc[utils.NumberOfEvents]) { t.Errorf("Expected %q but received %q", dcExpect, httpEE.dc[utils.NumberOfEvents]) } } func TestHttpJsonMapExportEvent5(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaSQSjsonMap cgrEv := new(utils.CGREvent) newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrEv.Event = map[string]interface{}{ "test": "string", } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*exp.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field1", utils.InfieldSep), }, { Path: "*exp.2", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("~*req.field2", utils.InfieldSep), }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() cgrEv.Event = map[string]interface{}{ "test": make(chan int), } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{{}} for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() errExpect := "json: unsupported type: chan int" if err := httpEE.ExportEvent(cgrEv); err == nil || err.Error() != errExpect { t.Errorf("Expected %q but received %q", errExpect, err) } dcExpect := int64(1) if !reflect.DeepEqual(dcExpect, httpEE.dc[utils.NumberOfEvents]) { t.Errorf("Expected %q but received %q", dcExpect, httpEE.dc[utils.NumberOfEvents]) } httpEE.OnEvicted("test", "test") } func TestHttpJsonMapComposeHeader(t *testing.T) { cgrCfg := config.NewDefaultCGRConfig() cgrCfg.EEsCfg().Exporters[0].Type = utils.MetaHTTPjson newIDb := engine.NewInternalDB(nil, nil, true) newDM := engine.NewDataManager(newIDb, cgrCfg.CacheCfg(), nil) filterS := engine.NewFilterS(cgrCfg, nil, newDM) dc, err := newEEMetrics(utils.FirstNonEmpty( "Local", utils.EmptyString, )) if err != nil { t.Error(err) } httpEE, err := NewHTTPjsonMapEE(cgrCfg, 0, filterS, dc) if err != nil { t.Error(err) } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*hdr.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("field1", utils.InfieldSep), }, { Path: "*hdr.2", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("field2", utils.InfieldSep), }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } if _, err := httpEE.composeHeader(); err != nil { t.Error(err) } cgrCfg.EEsCfg().Exporters[0].ComputeFields() if _, err := httpEE.composeHeader(); err != nil { t.Error(err) } cgrCfg.EEsCfg().Exporters[0].Fields = []*config.FCTemplate{ { Path: "*hdr.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("field1", utils.InfieldSep), Filters: []string{"*wrong-type"}, }, { Path: "*hdr.1", Type: utils.MetaVariable, Value: config.NewRSRParsersMustCompile("field1", utils.InfieldSep), Filters: []string{"*wrong-type"}, }, } for _, field := range cgrCfg.EEsCfg().Exporters[0].Fields { field.ComputePath() } cgrCfg.EEsCfg().Exporters[0].ComputeFields() errExpect := "inline parse error for string: <*wrong-type>" if _, err := httpEE.composeHeader(); err == nil || err.Error() != errExpect { t.Errorf("Expected %q but received %q", errExpect, err) } }