From 13753dad589cbb20b1ad3f2cf16d6e6c6cf1109e Mon Sep 17 00:00:00 2001 From: "Harter, Nicholas (Contractor)" Date: Thu, 1 Jun 2017 16:35:33 -0700 Subject: [PATCH 1/5] integrating webhook code. get and update handlers need to be used still --- src/caduceus/caduceus.go | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/src/caduceus/caduceus.go b/src/caduceus/caduceus.go index 9429c4f2..ad13cbb6 100644 --- a/src/caduceus/caduceus.go +++ b/src/caduceus/caduceus.go @@ -55,7 +55,7 @@ func caduceus(arguments []string) int { Duration: caduceusConfig.ProfilerDuration, QueueSize: caduceusConfig.ProfilerQueueSize, } - + tr := &http.Transport{TLSClientConfig: &tls.Config{InsecureSkipVerify: true}} timeout := time.Duration(caduceusConfig.SenderClientTimeout) * time.Second @@ -116,6 +116,31 @@ func caduceus(arguments []string) int { mux.Handle("/api/v1/run", caduceusHandler.Then(serverWrapper)) mux.Handle("/api/v1/profile", caduceusHandler.Then(profileWrapper)) + + + webhookFactory, err := WH.NewFactory(v) + if err != nil { + fmt.Fprintf(os.Stderr, "Error creating new webhook factory: %s\n", err) + return 1 + } + + // TODO: register webhook end points here? +// mux.Handle("/api/v1/hook", caduceusHandler.Then(WH.)) +// mux.Handle("/api/v1/hooks", caduceusHandler.Then(WH.)) + + list, handler := webhookFactory.NewListAndHandler() + list.SetList( WH.NewRegistry(nil, webhookFactory.PublishMessage) ) + + selfURL := &url.URL{ + Scheme: "https", + Host: v.GetString("fqdn") + v.GetString("primary.address"), + } + + webhookFactory.Initialize(mux, selfURL, handler, logger) + webhookFactory.PrepareAndStart() + + + caduceusHealth := &CaduceusHealth{} var runnable concurrent.Runnable From 2858fe71a1ede372a9ae692e2380bc07fd3e85e9 Mon Sep 17 00:00:00 2001 From: "Harter, Nicholas (Contractor)" Date: Wed, 7 Jun 2017 13:36:15 -0700 Subject: [PATCH 2/5] webhook integration in. need to test, but there are some other build errors --- src/caduceus/caduceus.go | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/src/caduceus/caduceus.go b/src/caduceus/caduceus.go index ad13cbb6..75641369 100644 --- a/src/caduceus/caduceus.go +++ b/src/caduceus/caduceus.go @@ -4,14 +4,16 @@ import ( "crypto/tls" "fmt" "github.com/Comcast/webpa-common/concurrent" - "github.com/Comcast/webpa-common/handler" "github.com/Comcast/webpa-common/secure" + "github.com/Comcast/webpa-common/secure/handler" "github.com/Comcast/webpa-common/server" + "github.com/Comcast/webpa-common/webhook" "github.com/gorilla/mux" "github.com/justinas/alice" "github.com/spf13/pflag" "github.com/spf13/viper" "net/http" + "net/url" "os" "os/signal" "time" @@ -118,25 +120,26 @@ func caduceus(arguments []string) int { - webhookFactory, err := WH.NewFactory(v) + webhookFactory, err := webhook.NewFactory(v) if err != nil { fmt.Fprintf(os.Stderr, "Error creating new webhook factory: %s\n", err) return 1 } - // TODO: register webhook end points here? -// mux.Handle("/api/v1/hook", caduceusHandler.Then(WH.)) -// mux.Handle("/api/v1/hooks", caduceusHandler.Then(WH.)) - - list, handler := webhookFactory.NewListAndHandler() - list.SetList( WH.NewRegistry(nil, webhookFactory.PublishMessage) ) + webhookList, webhookHandler := webhookFactory.NewListAndHandler() + webhookRegistry := webhook.NewRegistry(nil, webhookFactory.PublishMessage) + webhookFactory.SetList( webhookRegistry ) + + // register webhook end points for api + mux.Handle("/api/v1/hook", caduceusHandler.ThenFunc(webhookRegistry.UpdateRegistry)) + mux.Handle("/api/v1/hooks", caduceusHandler.ThenFunc(webhookRegistry.GetRegistry)) selfURL := &url.URL{ Scheme: "https", Host: v.GetString("fqdn") + v.GetString("primary.address"), } - webhookFactory.Initialize(mux, selfURL, handler, logger) + webhookFactory.Initialize(mux, selfURL, webhookHandler, logger) webhookFactory.PrepareAndStart() From 89b8e7a99d08e7a7bba4bd08f66458ea72960c5d Mon Sep 17 00:00:00 2001 From: "Harter, Nicholas (Contractor)" Date: Wed, 7 Jun 2017 17:00:24 -0700 Subject: [PATCH 3/5] build errors removed with new webhook integration. tests failing. --- src/caduceus/caduceus.go | 2 +- src/caduceus/outboundSender.go | 53 +++--- src/caduceus/outboundSender_test.go | 280 ++++++++++++++++------------ src/caduceus/senderWrapper_test.go | 49 ++--- 4 files changed, 204 insertions(+), 180 deletions(-) diff --git a/src/caduceus/caduceus.go b/src/caduceus/caduceus.go index 75641369..5923148e 100644 --- a/src/caduceus/caduceus.go +++ b/src/caduceus/caduceus.go @@ -126,7 +126,7 @@ func caduceus(arguments []string) int { return 1 } - webhookList, webhookHandler := webhookFactory.NewListAndHandler() + _, webhookHandler := webhookFactory.NewListAndHandler() webhookRegistry := webhook.NewRegistry(nil, webhookFactory.PublishMessage) webhookFactory.SetList( webhookRegistry ) diff --git a/src/caduceus/outboundSender.go b/src/caduceus/outboundSender.go index 4a72e17b..a7c32e81 100644 --- a/src/caduceus/outboundSender.go +++ b/src/caduceus/outboundSender.go @@ -88,7 +88,7 @@ type CaduceusOutboundSender struct { client *http.Client secret []byte events []*regexp.Regexp - matcher map[string][]*regexp.Regexp + matcher []*regexp.Regexp queueSize int queue chan outboundRequest profiler ServerProfiler @@ -101,7 +101,7 @@ type CaduceusOutboundSender struct { // New creates a new OutboundSender object from the factory, or returns an error. func (osf OutboundSenderFactory) New() (obs OutboundSender, err error) { - if _, err = url.ParseRequestURI(osf.Listener.URL); nil != err { + if _, err = url.ParseRequestURI(osf.Listener.Config.URL); nil != err { return } @@ -136,8 +136,8 @@ func (osf OutboundSenderFactory) New() (obs OutboundSender, err error) { }, } - if "" != osf.Listener.Secret { - caduceusOutboundSender.secret = []byte(osf.Listener.Secret) + if "" != osf.Listener.Config.Secret { + caduceusOutboundSender.secret = []byte(osf.Listener.Config.Secret) } if "" != osf.Listener.FailureURL { @@ -170,30 +170,19 @@ func (osf OutboundSenderFactory) New() (obs OutboundSender, err error) { } // Create the matcher regex objects - if nil != osf.Listener.Matchers { - caduceusOutboundSender.matcher = make(map[string][]*regexp.Regexp) - for key, value := range osf.Listener.Matchers { - var list []*regexp.Regexp - for _, item := range value { - if ".*" == item { - // Match everything - skip the filtering - caduceusOutboundSender.matcher = nil - break - } - var re *regexp.Regexp - if re, err = regexp.Compile(item); nil != err { - err = fmt.Errorf("Invalid matcher item: Matcher['%s'] = '%s'", value, item) - return - } - list = append(list, re) - } - - if nil == caduceusOutboundSender.matcher { - break - } - - caduceusOutboundSender.matcher[key] = list + for _, item := range osf.Listener.Matcher.DeviceId { + if ".*" == item { + // Match everything - skip the filtering + caduceusOutboundSender.matcher = nil + break + } + + var re *regexp.Regexp + if re, err = regexp.Compile(item); nil != err { + err = fmt.Errorf("Invalid matcher item: '%s'", item) + return } + caduceusOutboundSender.matcher = append(caduceusOutboundSender.matcher, re) } caduceusOutboundSender.wg.Add(osf.NumWorkers) @@ -261,7 +250,7 @@ func (obs *CaduceusOutboundSender) QueueJSON(req CaduceusRequest, if eventRegex.MatchString(eventType) { matchDevice := (nil == obs.matcher) if nil != obs.matcher { - for _, deviceRegex := range obs.matcher["device_id"] { + for _, deviceRegex := range obs.matcher { if deviceRegex.MatchString(deviceID) { matchDevice = true break @@ -305,13 +294,14 @@ func (obs *CaduceusOutboundSender) QueueWrp(req CaduceusRequest, metaData map[st if eventRegex.MatchString(eventType) { matchDevice := (nil == obs.matcher) if nil != obs.matcher { - for _, deviceRegex := range obs.matcher["device_id"] { + for _, deviceRegex := range obs.matcher { if deviceRegex.MatchString(deviceID) { matchDevice = true break } } } + /* // if the device id matches then we want to look through all the metadata // and make sure that the obs metadata matches the metadata provided if matchDevice { @@ -333,6 +323,7 @@ func (obs *CaduceusOutboundSender) QueueWrp(req CaduceusRequest, metaData map[st } } } + */ if matchDevice { if len(obs.queue) < obs.queueSize { outboundReq := outboundRequest{req: req, @@ -375,10 +366,10 @@ func (obs *CaduceusOutboundSender) worker(id int) { now := time.Now() if now.Before(deliverUntil) && now.After(dropUntil) { payload := bytes.NewReader(work.req.Payload) - req, err := http.NewRequest("POST", obs.listener.URL, payload) + req, err := http.NewRequest("POST", obs.listener.Config.URL, payload) if nil != err { // Report drop - obs.logger.Error("http.NewRequest(\"POST\", '%s', payload) failed: %s", obs.listener.URL, err) + obs.logger.Error("http.NewRequest(\"POST\", '%s', payload) failed: %s", obs.listener.Config.URL, err) } else { req.Header.Set("Content-Type", work.contentType) req.Header.Set("X-Webpa-Event", work.event) diff --git a/src/caduceus/outboundSender_test.go b/src/caduceus/outboundSender_test.go index 90106814..3b7746b1 100644 --- a/src/caduceus/outboundSender_test.go +++ b/src/caduceus/outboundSender_test.go @@ -40,24 +40,25 @@ func getLogger() logging.Logger { return logger } -func simpleSetup(trans *transport, cutOffPeriod time.Duration, matcher map[string][]string) (obs OutboundSender, err error) { +func simpleSetup(trans *transport, cutOffPeriod time.Duration, matcher []string) (obs OutboundSender, err error) { trans.fn = func(req *http.Request, count int) (resp *http.Response, err error) { resp = &http.Response{Status: "200 OK", StatusCode: 200, } return } - + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + w.Config.Secret = "123456" + w.Matcher.DeviceId = matcher + obs, err = OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Secret: "123456", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot", "test"}, - Matchers: matcher, - }, - + Listener: w, Client: &http.Client{Transport: trans}, CutOffPeriod: cutOffPeriod, NumWorkers: 10, @@ -114,8 +115,7 @@ func TestSimpleJSONWithMatchers(t *testing.T) { assert := assert.New(t) - m := make(map[string][]string) - m["device_id"] = []string{"mac:112233445566", "mac:112233445565"} + m := []string{"mac:112233445566", "mac:112233445565"} trans := &transport{} obs, err := simpleSetup(trans, time.Second, m) @@ -140,8 +140,7 @@ func TestSimpleJSONWithWildcardMatchers(t *testing.T) { trans := &transport{} - m := make(map[string][]string) - m["device_id"] = []string{"mac:112233445566", ".*"} + m := []string{"mac:112233445566", ".*"} obs, err := simpleSetup(trans, time.Second, m) assert.Nil(err) @@ -184,8 +183,7 @@ func TestSimpleWrpWithMatchers(t *testing.T) { assert := assert.New(t) - m := make(map[string][]string) - m["device_id"] = []string{"mac:112233445566", "mac:112233445565"} + m := []string{"mac:112233445566", "mac:112233445565"} trans := &transport{} obs, err := simpleSetup(trans, time.Second, m) @@ -210,8 +208,7 @@ func TestSimpleWrpWithWildcardMatchers(t *testing.T) { trans := &transport{} - m := make(map[string][]string) - m["device_id"] = []string{"mac:112233445566", ".*"} + m := []string{"mac:112233445566", ".*"} obs, err := simpleSetup(trans, time.Second, m) assert.Nil(err) @@ -228,6 +225,7 @@ func TestSimpleWrpWithWildcardMatchers(t *testing.T) { assert.Equal(int32(4), trans.i) } +/* // Simple test that covers the normal successful case with extra matchers func TestSimpleWrpWithMetadata(t *testing.T) { @@ -255,7 +253,7 @@ func TestSimpleWrpWithMetadata(t *testing.T) { assert.Equal(int32(2), trans.i) } - +*//* // Simple test that covers the normal successful case with extra matchers func TestInvalidWrpMetadata(t *testing.T) { @@ -283,7 +281,7 @@ func TestInvalidWrpMetadata(t *testing.T) { assert.Equal(int32(0), trans.i) } - +*/ // Simple test that checks for invalid match regex func TestInvalidMatchRegex(t *testing.T) { @@ -291,8 +289,7 @@ func TestInvalidMatchRegex(t *testing.T) { trans := &transport{} - m := make(map[string][]string) - m["device_id"] = []string{"[[:112233445566"} + m := []string{"[[:112233445566"} obs, err := simpleSetup(trans, time.Second, m) assert.Nil(obs) @@ -315,14 +312,16 @@ func TestInvalidCutOffPeriod(t *testing.T) { func TestInvalidEventRegex(t *testing.T) { assert := assert.New(t) - + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"[[:123"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"[[:123"}, - }, + Listener: w, Client: &http.Client{}, NumWorkers: 10, QueueSize: 10, @@ -338,14 +337,16 @@ func TestInvalidEventRegex(t *testing.T) { func TestInvalidUrl(t *testing.T) { assert := assert.New(t) - + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot"}, + } + w.Config.URL = "invalid" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "invalid", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot"}, - }, + Listener: w, Client: &http.Client{}, NumWorkers: 10, QueueSize: 10, @@ -355,12 +356,14 @@ func TestInvalidUrl(t *testing.T) { assert.Nil(obs) assert.NotNil(err) + w2 := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot"}, + } + w2.Config.ContentType = "application/json" + obs, err = OutboundSenderFactory{ - Listener: webhook.W{ - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot"}, - }, + Listener: w2, Client: &http.Client{}, NumWorkers: 10, QueueSize: 10, @@ -375,13 +378,16 @@ func TestInvalidUrl(t *testing.T) { // Simple test that checks for invalid Client func TestInvalidClient(t *testing.T) { assert := assert.New(t) + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot"}, - }, + Listener: w, CutOffPeriod: time.Second, NumWorkers: 10, QueueSize: 10, @@ -395,13 +401,16 @@ func TestInvalidClient(t *testing.T) { // Simple test that checks for no logger func TestInvalidLogger(t *testing.T) { assert := assert.New(t) + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot"}, - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -415,14 +424,17 @@ func TestInvalidLogger(t *testing.T) { // Simple test that checks for FailureURL behavior func TestFailureURL(t *testing.T) { assert := assert.New(t) + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + FailureURL: "invalid", + Events: []string{"iot"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot"}, - FailureURL: "invalid", - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -437,12 +449,15 @@ func TestFailureURL(t *testing.T) { // Simple test that checks for no events func TestInvalidEvents(t *testing.T) { assert := assert.New(t) + + w := webhook.W{ + Until: time.Now().Add(60 * time.Second), + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -453,13 +468,15 @@ func TestInvalidEvents(t *testing.T) { assert.Nil(obs) assert.NotNil(err) + w2 := webhook.W{ + Until: time.Now().Add(60 * time.Second), + Events: []string{"iot(.*"}, + } + w2.Config.URL = "http://localhost:9999/foo" + w2.Config.ContentType = "application/json" + obs, err = OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(60 * time.Second), - Events: []string{"iot(.*"}, - }, + Listener: w2, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -475,13 +492,16 @@ func TestInvalidEvents(t *testing.T) { // Simple test that checks for no profiler func TestInvalidProfilerFactory(t *testing.T) { assert := assert.New(t) + + w := webhook.W{ + Until: time.Now(), + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now(), - Events: []string{"iot", "test"}, - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -499,13 +519,15 @@ func TestExtend(t *testing.T) { assert := assert.New(t) now := time.Now() + w := webhook.W{ + Until: now, + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: now, - Events: []string{"iot", "test"}, - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -536,14 +558,16 @@ func TestOverflowNoFailureURL(t *testing.T) { var output bytes.Buffer loggerFactory := logging.DefaultLoggerFactory{&output} logger, _ := loggerFactory.NewLogger("test") - + + w := webhook.W{ + Until: time.Now(), + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now(), - Events: []string{"iot", "test"}, - }, + Listener: w, Client: &http.Client{}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -583,15 +607,17 @@ func TestOverflowValidFailureURL(t *testing.T) { } return } - + + w := webhook.W{ + Until: time.Now(), + FailureURL: "http://localhost:12345/bar", + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now(), - Events: []string{"iot", "test"}, - FailureURL: "http://localhost:12345/bar", - }, + Listener: w, Client: &http.Client{Transport: trans}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -631,16 +657,18 @@ func TestOverflowValidFailureURLWithSecret(t *testing.T) { } return } - + + w := webhook.W{ + Until: time.Now(), + FailureURL: "http://localhost:12345/bar", + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + w.Config.Secret = "123456" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now(), - Secret: "123456", - Events: []string{"iot", "test"}, - FailureURL: "http://localhost:12345/bar", - }, + Listener: w, Client: &http.Client{Transport: trans}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -672,15 +700,17 @@ func TestOverflowValidFailureURLError(t *testing.T) { err = fmt.Errorf("My Error.") return } - + + w := webhook.W{ + Until: time.Now(), + FailureURL: "http://localhost:12345/bar", + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now(), - Events: []string{"iot", "test"}, - FailureURL: "http://localhost:12345/bar", - }, + Listener: w, Client: &http.Client{Transport: trans}, CutOffPeriod: time.Second, NumWorkers: 10, @@ -724,15 +754,17 @@ func TestOverflow(t *testing.T) { } return } - + + w := webhook.W{ + Until: time.Now().Add(30 * time.Second), + FailureURL: "http://localhost:12345/bar", + Events: []string{"iot", "test"}, + } + w.Config.URL = "http://localhost:9999/foo" + w.Config.ContentType = "application/json" + obs, err := OutboundSenderFactory{ - Listener: webhook.W{ - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(30 * time.Second), - Events: []string{"iot", "test"}, - FailureURL: "http://localhost:12345/bar", - }, + Listener: w, Client: &http.Client{Transport: trans}, CutOffPeriod: 4 * time.Second, NumWorkers: 1, diff --git a/src/caduceus/senderWrapper_test.go b/src/caduceus/senderWrapper_test.go index 3678c19b..37244133 100644 --- a/src/caduceus/senderWrapper_test.go +++ b/src/caduceus/senderWrapper_test.go @@ -128,21 +128,22 @@ func TestSwSimple(t *testing.T) { assert.Equal(int32(0), trans.i) - // Add 2 listeners - list := []webhook.W{ - { - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(6 * time.Second), - Events: []string{"iot"}, - }, - { - URL: "http://localhost:9999/bar", - ContentType: "application/json", - Until: time.Now().Add(4 * time.Second), - Events: []string{"iot", "test", "wrp"}, - }, + w1 := webhook.W{ + Until: time.Now().Add(6 * time.Second), + Events: []string{"iot"}, } + w1.Config.URL = "http://localhost:9999/foo" + w1.Config.ContentType = "application/json" + + w2 := webhook.W{ + Until: time.Now().Add(4 * time.Second), + Events: []string{"iot", "test", "wrp"}, + } + w2.Config.URL = "http://localhost:9999/foo" + w2.Config.ContentType = "application/json" + + // Add 2 listeners + list := []webhook.W{w1, w2} sw.Update(list) @@ -166,17 +167,17 @@ func TestSwSimple(t *testing.T) { sw.Queue(test) time.Sleep(time.Second) assert.Equal(int32(4), atomic.LoadInt32(&trans.i)) - - // We get a registration - list = []webhook.W{ - { - URL: "http://localhost:9999/foo", - ContentType: "application/json", - Until: time.Now().Add(5 * time.Second), - Events: []string{"iot"}, - }, + + w3 := webhook.W{ + Until: time.Now().Add(5 * time.Second), + Events: []string{"iot"}, } - sw.Update(list) + w3.Config.URL = "http://localhost:9999/foo" + w3.Config.ContentType = "application/json" + + // We get a registration + list2 := []webhook.W{w3} + sw.Update(list2) time.Sleep(time.Second) // Send iot From 9844905df0cb9fd4e7306e742c577cb7f7d72f98 Mon Sep 17 00:00:00 2001 From: "Harter, Nicholas (Contractor)" Date: Fri, 9 Jun 2017 16:56:37 -0700 Subject: [PATCH 4/5] fixed bug in tests, now passing. --- src/caduceus/outboundSender.go | 2 +- src/caduceus/senderWrapper_test.go | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/caduceus/outboundSender.go b/src/caduceus/outboundSender.go index a7c32e81..12d1cb9b 100644 --- a/src/caduceus/outboundSender.go +++ b/src/caduceus/outboundSender.go @@ -168,7 +168,7 @@ func (osf OutboundSenderFactory) New() (obs OutboundSender, err error) { err = errors.New("Events must not be empty.") return } - + // Create the matcher regex objects for _, item := range osf.Listener.Matcher.DeviceId { if ".*" == item { diff --git a/src/caduceus/senderWrapper_test.go b/src/caduceus/senderWrapper_test.go index 37244133..42bb7c75 100644 --- a/src/caduceus/senderWrapper_test.go +++ b/src/caduceus/senderWrapper_test.go @@ -129,18 +129,22 @@ func TestSwSimple(t *testing.T) { assert.Equal(int32(0), trans.i) w1 := webhook.W{ + Duration: 6 * time.Second, Until: time.Now().Add(6 * time.Second), Events: []string{"iot"}, } - w1.Config.URL = "http://localhost:9999/foo" + w1.Config.URL = "http://localhost:8888/foo" w1.Config.ContentType = "application/json" + w1.Matcher.DeviceId = []string{"mac:112233445566"} w2 := webhook.W{ + Duration: 4 * time.Second, Until: time.Now().Add(4 * time.Second), Events: []string{"iot", "test", "wrp"}, } w2.Config.URL = "http://localhost:9999/foo" w2.Config.ContentType = "application/json" + w2.Matcher.DeviceId = []string{"mac:112233445566"} // Add 2 listeners list := []webhook.W{w1, w2} From bf182037e89513a4b45d72c0a9996ba2fef44697 Mon Sep 17 00:00:00 2001 From: "Harter, Nicholas (Contractor)" Date: Mon, 12 Jun 2017 16:24:08 -0700 Subject: [PATCH 5/5] glide update --- src/glide.lock | 70 +++++++++++++++++++++++++++++++++++--------------- src/glide.yaml | 6 +++++ 2 files changed, 56 insertions(+), 20 deletions(-) diff --git a/src/glide.lock b/src/glide.lock index fd70cd7a..8952aec6 100644 --- a/src/glide.lock +++ b/src/glide.lock @@ -1,12 +1,40 @@ -hash: 6684fdfcee777e1e8e3c2467479ef051a3db07d6c07a66506d1f859fa495ae06 -updated: 2017-03-27T13:24:14.343069944-07:00 +hash: 7c84fda85fd0f2d1335f40f346b65391fe63e4e70d752d137bcf377220479aef +updated: 2017-06-12T16:14:22.811127772-07:00 imports: +- name: github.com/aws/aws-sdk-go + version: 7be45195c3af1b54a609812f90c05a7e492e2491 + subpackages: + - aws + - service + - aws/credentials + - aws/session + - service/sns + - service/sns/snsiface + - aws/awserr + - aws/endpoints + - aws/client + - aws/corehandlers + - aws/credentials/stscreds + - aws/defaults + - aws/request + - aws/awsutil + - aws/client/metadata + - aws/signer/v4 + - private/protocol + - private/protocol/query + - service/sts + - aws/credentials/ec2rolecreds + - aws/credentials/endpointcreds + - aws/ec2metadata + - private/protocol/rest + - private/protocol/query/queryutil + - private/protocol/xml/xmlutil - name: github.com/c9s/goprocinfo version: 19cb9f127a9c8d2034cf59ccb683cdb94b9deb6c subpackages: - linux - name: github.com/Comcast/webpa-common - version: b210bf658a81f6389d14ef2d99aa3a9454f49b5b + version: 9dfc3db86d11729a233b1b788f00b501c59c1fff subpackages: - concurrent - handler @@ -15,12 +43,12 @@ imports: - server - webhook - health - - device - - fact - - hash + - secure/handler + - wrp - secure/key - logging/golog - - wrp + - httperror + - webhook/aws - resource - types - name: github.com/davecgh/go-spew @@ -28,15 +56,15 @@ imports: subpackages: - spew - name: github.com/fsnotify/fsnotify - version: ff7bc41d4007f67e5456703c34342df4e0113f64 + version: 4da3e2cfbabc9f751898f250b49f2439785783a1 +- name: github.com/go-ini/ini + version: d3de07a94d22b4a0972deb4b96d790c2c0ce8333 - name: github.com/gorilla/context version: 08b5f424b9271eedf6f9f0ce86cb9396ed337a42 - name: github.com/gorilla/mux - version: 599cba5e7b6137d46ddf58fb1765f5d928e69604 -- name: github.com/gorilla/websocket - version: 3ab3a8b8831546bd18fd182c20687ca853b2bb13 + version: 392c28fe23e1c45ddba891b0320b3b5df220beea - name: github.com/hashicorp/hcl - version: 630949a3c5fa3c613328e1b8256052cbc2327c9b + version: 392dba7d905ed5d04a5794ba89f558b27e2ba1ca subpackages: - hcl/ast - hcl/parser @@ -53,6 +81,8 @@ imports: - layout - levels - logger +- name: github.com/jmespath/go-jmespath + version: bd40a432e4c76585ef6b72d3fd96fb9b6dc7b68d - name: github.com/jtacoma/uritemplates version: 307ae868f90f4ee1b73ebe4596e0394237dacce8 - name: github.com/justinas/alice @@ -60,11 +90,11 @@ imports: - name: github.com/magiconair/properties version: 51463bfca2576e06c62a8504b5c0f06d61312647 - name: github.com/mitchellh/mapstructure - version: 53818660ed4955e899c0bcafa97299a388bd7c8e + version: d0303fe809921458f417bcf828397a65db30a7e4 - name: github.com/pelletier/go-buffruneio version: c37440a7cf42ac63b919c752ca73a85067e05992 - name: github.com/pelletier/go-toml - version: f6e7596e8daafd44dc9e5c208dc73035020c8481 + version: fe7536c3dee2596cdd23ee9976a17c22bdaae286 - name: github.com/philhofer/fwd version: 98c11a7a6ec829d672b03833c3d69a7fae1ca972 - name: github.com/pmezard/go-difflib @@ -82,9 +112,9 @@ imports: subpackages: - mem - name: github.com/spf13/cast - version: ce135a4ebeee6cfe9a26c93ee0d37825f26113c7 + version: acbeb36b902d72a7a4c18e8f3241075e7ab763e4 - name: github.com/spf13/jwalterweatherman - version: fa7ca7e836cf3a8bb4ebf799f472c12d7e903d66 + version: 0efa5202c04663c757d84f90f5219c1250baf94f - name: github.com/spf13/pflag version: 9ff6c6923cfffbcd502984b8e0c80539a94968b7 - name: github.com/spf13/viper @@ -110,14 +140,14 @@ imports: subpackages: - codec - name: golang.org/x/sys - version: afadfcc7779c1f4db0f6f6438afcb108d9c9c7cd + version: 0b25a408a50076fbbcae6b7ac0ea5fbb0b085e79 subpackages: - unix - name: golang.org/x/text - version: fc7fa097411d30e6708badff276c4c164425590c + version: 210eee5cf7323015d097341bcf7166130d001cd8 subpackages: - transform - unicode/norm - name: gopkg.in/yaml.v2 - version: a3f3340b5840cee44f372bddb5880fcbc419b46a -testImports: [] + version: cd8b52f8269e0feb286dfeef29f8fe4d5b397e0b +devImports: [] diff --git a/src/glide.yaml b/src/glide.yaml index 3c50775f..c3f84a8f 100644 --- a/src/glide.yaml +++ b/src/glide.yaml @@ -1,6 +1,7 @@ package: . import: - package: github.com/Comcast/webpa-common + version: 9dfc3db86d11729a233b1b788f00b501c59c1fff subpackages: - concurrent - handler @@ -9,11 +10,16 @@ import: - server - webhook - package: github.com/justinas/alice + version: 1051eaf52fcafdd87ead59d28b065f1fcb8274ec - package: github.com/spf13/pflag + version: 9ff6c6923cfffbcd502984b8e0c80539a94968b7 - package: github.com/spf13/viper + version: 5ed0fc31f7f453625df314d8e66b9791e8d13003 - package: github.com/stretchr/testify + version: 69483b4bd14f5845b5a1e55bca19e954e827f1d0 subpackages: - mock - assert - require - package: github.com/gorilla/mux + version: 392c28fe23e1c45ddba891b0320b3b5df220beea