Merge pull request 'Modify initial distribution of tables to guarantee there is no single-person table' (#107) from fix/initial-group-creation into main
Some checks failed
Check usage of free licenses / build-static-assets (push) Successful in 31s
Run unit tests / unit_tests (push) Successful in 1m25s
Build Nginx-based docker image / build-static-assets (push) Failing after 3m58s

Reviewed-on: #107
This commit is contained in:
bustikiller 2024-11-10 09:46:53 +00:00
commit 2deaaa64a5
2 changed files with 29 additions and 3 deletions

View File

@ -13,9 +13,10 @@ module Tables
end end
def random_distribution(people) def random_distribution(people)
@tables = [] min_tables = (people.count * 1.0 / @max_per_table).ceil
max_tables = (people.count * 1.0 / @min_per_table).ceil
@tables << Table.new(people.slice!(0..rand(@min_per_table..@max_per_table))) while people.any? @tables = people.in_groups(rand(min_tables..max_tables), false)
.map { |group| Table.new(group) }
end end
def discomfort def discomfort

View File

@ -0,0 +1,25 @@
# Copyright (C) 2024 Manuel Bustillo
require 'rails_helper'
module Tables
RSpec.describe Distribution do
describe '#random_distribution' do
let(:subject) { described_class.new(min_per_table: 5, max_per_table: 10) }
context 'when there are fewer people than the minimum per table' do
it 'creates one table' do
subject.random_distribution([1, 2, 3, 4])
expect(subject.tables.count).to eq(1)
end
end
context 'when there are more people than the maximum per table' do
it 'creates multiple tables' do
subject.random_distribution([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
expect(subject.tables.count).to be > 1
end
end
end
end
end