Skip to content

Commit

Permalink
test(sdk): Use -race Flag when testing
Browse files Browse the repository at this point in the history
Includes naive fix for one race detected.

Fixes #209

Signed-off-by: Alex Ullrich <[email protected]>
  • Loading branch information
AlexCuse committed Jan 25, 2022
1 parent 221b25e commit c2abb10
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 3 deletions.
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ test-template:
make -C ./app-service-template test

test-sdk:
$(GO) test ./... -coverprofile=coverage.out ./...
$(GO) test -coverprofile=coverage.out ./... -race

vet:
$(GO) vet ./...
Expand Down
2 changes: 1 addition & 1 deletion app-service-template/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ docker:
# The test-attribution-txt.sh scripts are required for upstreaming to EdgeX Foundry.
# TODO: Remove bin folder and reference to script below if NOT upstreaming to EdgeX Foundry.
test:
$(GO) test -coverprofile=coverage.out ./...
$(GO) test -coverprofile=coverage.out ./... --race
$(GO) vet ./...
gofmt -l $$(find . -type f -name '*.go'| grep -v "/vendor/")
[ "`gofmt -l $$(find . -type f -name '*.go'| grep -v "/vendor/")`" = "" ]
Expand Down
7 changes: 6 additions & 1 deletion internal/app/triggermessageprocessor.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@ func (mp *triggerMessageProcessor) MessageReceived(ctx interfaces.AppFunctionCon
lc.Debugf("trigger found %d pipeline(s) that match the incoming topic '%s'", len(pipelines), envelope.ReceivedTopic)

var finalErr error
errorCollectionLock := sync.RWMutex{}

pipelinesWaitGroup := sync.WaitGroup{}

Expand Down Expand Up @@ -133,7 +134,11 @@ func (mp *triggerMessageProcessor) MessageReceived(ctx interfaces.AppFunctionCon
}
lc.Debugf("trigger successfully processed message '%s' in pipeline %s", p.Id, envelope.CorrelationID)
}
}(pipeline, &pipelinesWaitGroup, func(e error) { finalErr = multierror.Append(finalErr, e) })
}(pipeline, &pipelinesWaitGroup, func(e error) {
errorCollectionLock.Lock()
defer errorCollectionLock.Unlock()
finalErr = multierror.Append(finalErr, e)
})
}

pipelinesWaitGroup.Wait()
Expand Down

0 comments on commit c2abb10

Please sign in to comment.