211 lines
5.9 KiB
YAML
211 lines
5.9 KiB
YAML
# These test run against the Events API with no data preloaded into the
|
|
# datastore. This allows us to verify that requests are still processed
|
|
# normally even if data is missing for that endpoint.
|
|
fixtures:
|
|
- ConfigFixture
|
|
|
|
tests:
|
|
|
|
# this attempts to get all the events and expects an empty list back
|
|
- name: get all events
|
|
url: /v2/events
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# this attempts to get all the events with no role/user/project
|
|
# info in header and expects a 403
|
|
- name: get events with bad headers
|
|
url: /v2/events
|
|
status: 403
|
|
|
|
# this attempts to get all the events with no user/project
|
|
# info in header and expects a 403
|
|
- name: get events with admin only header
|
|
url: /v2/events
|
|
request_headers:
|
|
X-Roles: admin
|
|
status: 403
|
|
|
|
# this attempts to get all the events with no project
|
|
# info in header and expects a 403
|
|
- name: get events with no project header
|
|
url: /v2/events
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
status: 403
|
|
|
|
# this attempts to get all the events with no user
|
|
# info in header and expects a 403
|
|
- name: get events with no user header
|
|
url: /v2/events
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-Project-Id: project1
|
|
status: 403
|
|
|
|
# this attempts to get all the events with invalid parameters and expects a 400
|
|
- name: get events with bad params
|
|
url: /v2/events?bad_Stuff_here
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
status: 400
|
|
|
|
# this attempts to query the events with the correct parameterized query syntax
|
|
# and expects an empty list
|
|
- name: get events that match query
|
|
url: /v2/events?q.field=event_type&q.op=eq&q.type=string&q.value=cookies_chocolate.chip
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# this attempts to query the events with the correct data query syntax and
|
|
# expects an empty list
|
|
- name: get events that match query via request data
|
|
url: /v2/events
|
|
request_headers:
|
|
content-type: application/json
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
data:
|
|
q:
|
|
- field: event_type
|
|
op: eq
|
|
type: string
|
|
value: cookies_chocolate.chip
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# this attempts to query the events with the correct parameterized query syntax
|
|
# but a bad field name and expects an empty list
|
|
- name: get events that match bad query
|
|
url: /v2/events?q.field=bad_field&q.op=eq&q.type=string&q.value=cookies_chocolate.chip
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# this attempts to query the events with the correct data query syntax and
|
|
# a bad field name and expects an empty list
|
|
- name: get events that match bad query via request data
|
|
url: /v2/events
|
|
request_headers:
|
|
content-type: application/json
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
data:
|
|
q:
|
|
- field: bad_field
|
|
op: eq
|
|
type: string
|
|
value: cookies_chocolate.chip
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# this attempts to query the events with the wrong data query syntax missing the
|
|
# q object but supplying the field list and a bad field name and expects a 400
|
|
- name: get events that match bad query via request data malformed list
|
|
url: /v2/events
|
|
request_headers:
|
|
content-type: application/json
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
data:
|
|
- field: bad_field
|
|
op: eq
|
|
type: string
|
|
value: cookies_chocolate.chip
|
|
status: 400
|
|
|
|
# this attempts to query the events with the wrong data query syntax missing the
|
|
# q object but supplying the field list along with a bad content-type. Should
|
|
# return a 400
|
|
- name: get events that match bad query via request data wrong type
|
|
url: /v2/events
|
|
request_headers:
|
|
content-type: text/plain
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
data:
|
|
"field: bad_field op: eq type: string value: cookies_chocolate.chip xfail: True"
|
|
status: 415
|
|
|
|
# Get a single event by message_id no data is present so should return a 404
|
|
- name: get a single event
|
|
url: /v2/events/fea1b15a-1d47-4175-85a5-a4bb2c729240
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
status: 404
|
|
|
|
# Get all the event types should return an empty list
|
|
- name: get all event types
|
|
url: /v2/event_types
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# Get a single event type by name, this API is unused and should return a 404
|
|
- name: get event types for good event_type unused api
|
|
url: /v2/event_types/cookies_chocolate.chip
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
status: 404
|
|
|
|
# Get all traits for an event type should return an empty list
|
|
- name: get all traits for event type
|
|
url: /v2/event_types/cookies_chocolate.chip/traits
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|
|
|
|
# Get all traits named ate for an event type should return an empty list
|
|
- name: get all traits named ate for event type
|
|
url: /v2/event_types/cookies_chocolate.chip/traits/ate
|
|
request_headers:
|
|
X-Roles: admin
|
|
X-User-Id: user1
|
|
X-Project-Id: project1
|
|
response_headers:
|
|
content-type: application/json
|
|
response_strings:
|
|
- "[]"
|