wedding-planner/spec/requests/guests_spec.rb

103 lines
2.7 KiB
Ruby
Raw Normal View History

2024-11-16 01:52:48 +00:00
# Copyright (C) 2024 Manuel Bustillo
# frozen_string_literal: true
require 'swagger_helper'
2024-12-28 18:07:22 +01:00
RSpec.describe 'guests' do
path '/{slug}/guests' do
get('list guests') do
tags 'Guests'
produces 'application/json'
parameter Swagger::Schema::SLUG
response(200, 'successful') do
schema type: :array,
items: {
type: :object,
required: %i[id name status group],
properties: {
id: { type: :string, format: :uuid },
name: { type: :string },
status: { type: :string, enum: Guest.statuses.keys },
group: { type: :object,
required: %i[id name],
properties: {
id: { type: :string, format: :uuid },
name: { type: :string }
} }
}
}
xit
end
regular_api_responses
end
post('create guest') do
tags 'Guests'
consumes 'application/json'
produces 'application/json'
parameter Swagger::Schema::SLUG
parameter name: :body, in: :body, schema: {
type: :object,
required: %i[guest],
properties: {
guest: {
type: :object,
required: %i[name status],
properties: {
name: { type: :string },
group_id: { type: :string, format: :uuid },
status: { type: :string, enum: Guest.statuses.keys }
}
}
}
}
2024-12-28 18:07:22 +01:00
response_empty201
response422
regular_api_responses
end
end
path '/{slug}/guests/{id}' do
patch('update guest') do
tags 'Guests'
consumes 'application/json'
produces 'application/json'
parameter Swagger::Schema::SLUG
parameter name: 'id', in: :path, type: :string, format: :uuid
parameter name: :body, in: :body, schema: {
type: :object,
required: %i[guest],
properties: {
guest: {
type: :object,
required: %i[name status],
properties: {
2024-11-17 17:07:29 +01:00
name: { type: :string },
2024-11-17 20:01:23 +01:00
group_id: { type: :string, format: :uuid },
2024-11-17 17:07:29 +01:00
status: { type: :string, enum: Guest.statuses.keys }
}
}
}
}
2024-12-28 18:07:22 +01:00
response_empty200
response422
response404
regular_api_responses
end
2024-11-17 18:24:43 +01:00
delete('delete guest') do
tags 'Guests'
produces 'application/json'
parameter Swagger::Schema::SLUG
2024-11-17 18:24:43 +01:00
parameter name: 'id', in: :path, type: :string, format: :uuid
2024-12-28 18:07:22 +01:00
response_empty200
response404
regular_api_responses
2024-11-17 18:24:43 +01:00
end
end
end