All checks were successful
		
		
	
	Check usage of free licenses / check-licenses (pull_request) Successful in 1m38s
				
			Add copyright notice / copyright_notice (pull_request) Successful in 3m16s
				
			Run unit tests / unit_tests (pull_request) Successful in 5m31s
				
			Build Nginx-based docker image / build-static-assets (pull_request) Successful in 41m31s
				
			
		
			
				
	
	
		
			111 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # Copyright (C) 2024-2025 LibreWeddingPlanner contributors
 | |
| 
 | |
| # frozen_string_literal: true
 | |
| 
 | |
| require 'swagger_helper'
 | |
| 
 | |
| RSpec.describe 'groups' do
 | |
|   path '/{slug}/groups' do
 | |
|     get('list groups') do
 | |
|       tags 'Groups'
 | |
|       produces 'application/json'
 | |
|       parameter Swagger::Schema::SLUG
 | |
|       response(200, 'successful') do
 | |
|         schema type: :array,
 | |
|                items: {
 | |
|                  type: :object,
 | |
|                  required: %i[id name icon parent_id color attendance],
 | |
|                  properties: {
 | |
|                    id: { type: :string, format: :uuid, required: true },
 | |
|                    name: { type: :string },
 | |
|                    icon: { type: :string, example: 'pi pi-crown', description: 'The CSS classes used by the icon' },
 | |
|                    parent_id: { type: :string, format: :uuid },
 | |
|                    color: { type: :string, pattern: '^#(?:[0-9a-fA-F]{3}){1,2}$' },
 | |
|                    attendance: {
 | |
|                      type: :object,
 | |
|                      required: %i[total considered invited confirmed declined tentative],
 | |
|                      properties: {
 | |
|                        total: { type: :integer, minimum: 0, description: 'Total number of guests in any status' },
 | |
|                        considered: { type: :integer, minimum: 0 },
 | |
|                        invited: { type: :integer, minimum: 0 },
 | |
|                        confirmed: { type: :integer, minimum: 0 },
 | |
|                        declined: { type: :integer, minimum: 0 },
 | |
|                        tentative: { type: :integer, minimum: 0 }
 | |
|                      }
 | |
|                    }
 | |
|                  }
 | |
|                }
 | |
|         xit
 | |
|       end
 | |
|       regular_api_responses
 | |
|     end
 | |
| 
 | |
|     post('create group') do
 | |
|       tags 'Groups'
 | |
|       consumes 'application/json'
 | |
|       produces 'application/json'
 | |
|       parameter Swagger::Schema::SLUG
 | |
|       parameter name: :body, in: :body, schema: {
 | |
|         type: :object,
 | |
|         required: %i[group],
 | |
|         properties: {
 | |
|           group: {
 | |
|             type: :object,
 | |
|             required: %i[name],
 | |
|             properties: Swagger::Schema::GROUP
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|       response(201, 'created') do
 | |
|         schema type: :object, properties: {
 | |
|           id: { type: :string, format: :uuid, required: true },
 | |
|           **Swagger::Schema::GROUP
 | |
|         }
 | |
| 
 | |
|         xit
 | |
|       end
 | |
|       regular_api_responses
 | |
|     end
 | |
| 
 | |
|     path '/{slug}/groups/{id}' do
 | |
|       put('update group') do
 | |
|         tags 'Groups'
 | |
|         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[group],
 | |
|           properties: {
 | |
|             group: {
 | |
|               type: :object,
 | |
|               required: %i[name],
 | |
|               properties: Swagger::Schema::GROUP
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|         response(200, 'updated') do
 | |
|           schema type: :object, properties: {
 | |
|             id: { type: :string, format: :uuid, required: true },
 | |
|             **Swagger::Schema::GROUP
 | |
|           }
 | |
| 
 | |
|           xit
 | |
|         end
 | |
|         regular_api_responses
 | |
|       end
 | |
| 
 | |
|       delete('delete group') do
 | |
|         tags 'Groups'
 | |
|         produces 'application/json'
 | |
|         parameter Swagger::Schema::SLUG
 | |
|         parameter name: :id, in: :path, type: :string, format: :uuid
 | |
| 
 | |
|         response_empty200
 | |
|         regular_api_responses
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |