swaps-enhancements #19

Merged
bustikiller merged 4 commits from swaps-enhancements into main 2024-08-01 18:59:56 +00:00
2 changed files with 34 additions and 0 deletions
Showing only changes of commit 2dd11bb83d - Show all commits

View File

@ -7,6 +7,7 @@ module Tables
def initialize(min_per_table:, max_per_table:) def initialize(min_per_table:, max_per_table:)
@min_per_table = min_per_table @min_per_table = min_per_table
@max_per_table = max_per_table @max_per_table = max_per_table
@tables = []
end end
def random_distribution(people) def random_distribution(people)

View File

@ -0,0 +1,33 @@
require 'rails_helper'
module Tables
RSpec.describe Swap do
describe '#each' do
let(:initial_solution) do
Distribution.new(min_per_table: 2, max_per_table: 2).tap do |distribution|
distribution.tables << %i[a b]
distribution.tables << %i[c d]
end
end
let(:swaps) do
acc = []
described_class.new(initial_solution).each do |solution|
acc << solution.tables.map(&:dup)
end
acc
end
it 'yields all possible swaps' do
expect(swaps.count).to eq(4)
end
it 'swaps the people' do
expect(swaps).to include([%i[a d], %i[c b]])
expect(swaps).to include([%i[b c], %i[d a]])
expect(swaps).to include([%i[a c], %i[d b]])
expect(swaps).to include([%i[b d], %i[c a]])
end
end
end
end