cloudevents is a tool for testing CloudEvents receivers.
Work in progress.
cloudevents can be installed via:
go get github.com/cloudevents/conformance/cmd/cloudeventsTo update your installation:
go get -u github.com/cloudevents/conformance/cmd/cloudeventscloudevents has three commands at the moment: send, invoke and listen.
send will do a one-off creation of a cloudevent and send to a given target.
cloudevents send http://localhost:8080 --id abc-123 --source cloudevents.conformance.tool --type foo.barinvoke will read yaml files, convert them to http and send them to the given
target.
cloudevents invoke http://localhost:8080 -f ./yaml/v0.3listen will accept http request and write the converted yaml to stdout.
cloudevents listen -v > got.yamlOptionally, you can forward the incoming request to a target.
cloudevents listen -v -t http://localhost:8181 > got.yamldiff compares two yaml event files.
cloudevents diff ./want.yaml ./got.yamlwant.yaml could have fewer fields specified to allow for fuzzy matching.
Example, if you only wanted to compare on type and ignore additional fields:
$ cat ./want.yaml
ContextAttributes:
type: com.example.someevent
$ cat ./got.yaml
Mode: structured
ContextAttributes:
specversion: 1.0
type: com.example.someevent
time: 2018-04-05T03:56:24Z
id: 4321-4321-4321-a
source: /mycontext/subcontext
Extensions:
comexampleextension1 : "value"
comexampleextension2 : |
{"othervalue": 5}
TransportExtensions:
user-agent: "foo"
Data: |
{"world":"hello"}
$ cloudevents diff ./want.yaml ./got.yaml --match type --ignore-additionsThis validates that at least one event of type com.example.someevent is present in the got.yaml file.
If you would like to produce a pre-produced event yaml file, you can use
listen to collect requests. This works with both running event producers that
can be directed at the listen port or directly with send.