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
 |