2025-01-13 20:38:47 +00:00
|
|
|
# Copyright (C) 2024 Manuel Bustillo
|
|
|
|
|
2025-01-13 21:37:02 +01:00
|
|
|
# Copyright (C) 2024-2025 LibreWeddingPlanner contributors
|
2024-10-28 22:07:35 +00:00
|
|
|
|
2024-12-28 18:37:47 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2024-08-01 20:45:01 +02:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
module Tables
|
|
|
|
RSpec.describe Swap do
|
|
|
|
describe '#each' do
|
|
|
|
let(:swaps) do
|
|
|
|
acc = []
|
2024-12-28 18:07:22 +01:00
|
|
|
described_class.new(initial_solution).each do |solution| # rubocop:disable Style/MapIntoArray -- #map is not implemented
|
2024-08-01 20:45:01 +02:00
|
|
|
acc << solution.tables.map(&:dup)
|
|
|
|
end
|
|
|
|
acc
|
|
|
|
end
|
|
|
|
|
2024-08-01 20:49:07 +02:00
|
|
|
context 'when there are two tables with two people each' do
|
|
|
|
let(:initial_solution) do
|
|
|
|
Distribution.new(min_per_table: 2, max_per_table: 2).tap do |distribution|
|
2024-11-10 17:30:01 +01:00
|
|
|
distribution.tables << Set[:a, :b].to_table
|
|
|
|
distribution.tables << Set[:c, :d].to_table
|
2024-08-01 20:49:07 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'yields all possible swaps between the tables' do
|
|
|
|
expect(swaps).to contain_exactly(
|
2024-11-10 17:30:01 +01:00
|
|
|
[Set[:a, :d], Set[:c, :b]],
|
|
|
|
[Set[:b, :c], Set[:d, :a]],
|
|
|
|
[Set[:a, :c], Set[:d, :b]],
|
|
|
|
[Set[:b, :d], Set[:c, :a]]
|
2024-08-01 20:49:07 +02:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there are two tables with three people each' do
|
|
|
|
let(:initial_solution) do
|
|
|
|
Distribution.new(min_per_table: 3, max_per_table: 3).tap do |distribution|
|
2024-11-10 17:30:01 +01:00
|
|
|
distribution.tables << Set[:a, :b, :c].to_table
|
|
|
|
distribution.tables << Set[:d, :e, :f].to_table
|
2024-08-01 20:49:07 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'yields all possible swaps between the tables' do
|
|
|
|
expect(swaps).to contain_exactly(
|
2024-11-10 17:30:01 +01:00
|
|
|
[Set[:b, :c, :d], Set[:e, :f, :a]],
|
|
|
|
[Set[:b, :c, :e], Set[:f, :d, :a]],
|
|
|
|
[Set[:b, :c, :f], Set[:d, :e, :a]],
|
|
|
|
[Set[:c, :a, :d], Set[:e, :f, :b]],
|
|
|
|
[Set[:c, :a, :e], Set[:f, :d, :b]],
|
|
|
|
[Set[:c, :a, :f], Set[:d, :e, :b]],
|
|
|
|
[Set[:a, :b, :d], Set[:e, :f, :c]],
|
|
|
|
[Set[:a, :b, :e], Set[:f, :d, :c]],
|
|
|
|
[Set[:a, :b, :f], Set[:d, :e, :c]]
|
2024-08-01 20:49:07 +02:00
|
|
|
)
|
|
|
|
end
|
2024-08-01 20:45:01 +02:00
|
|
|
end
|
2024-08-01 20:50:26 +02:00
|
|
|
|
|
|
|
context 'when there are three tables with two people each' do
|
|
|
|
let(:initial_solution) do
|
|
|
|
Distribution.new(min_per_table: 2, max_per_table: 2).tap do |distribution|
|
2024-11-10 17:30:01 +01:00
|
|
|
distribution.tables << Set[:a, :b].to_table
|
|
|
|
distribution.tables << Set[:c, :d].to_table
|
|
|
|
distribution.tables << Set[:e, :f].to_table
|
2024-08-01 20:50:26 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'yields all possible swaps between the tables' do
|
|
|
|
expect(swaps).to contain_exactly(
|
2024-11-10 17:30:01 +01:00
|
|
|
[Set[:b, :c], Set[:d, :a], Set[:e, :f]],
|
|
|
|
[Set[:b, :d], Set[:c, :a], Set[:e, :f]],
|
|
|
|
[Set[:a, :c], Set[:d, :b], Set[:e, :f]],
|
|
|
|
[Set[:a, :d], Set[:c, :b], Set[:e, :f]],
|
|
|
|
[Set[:b, :e], Set[:c, :d], Set[:f, :a]],
|
|
|
|
[Set[:b, :f], Set[:c, :d], Set[:e, :a]],
|
|
|
|
[Set[:a, :e], Set[:c, :d], Set[:f, :b]],
|
|
|
|
[Set[:a, :f], Set[:c, :d], Set[:e, :b]],
|
|
|
|
[Set[:a, :b], Set[:d, :e], Set[:f, :c]],
|
|
|
|
[Set[:a, :b], Set[:d, :f], Set[:e, :c]],
|
|
|
|
[Set[:a, :b], Set[:c, :e], Set[:f, :d]],
|
|
|
|
[Set[:a, :b], Set[:c, :f], Set[:e, :d]]
|
2024-08-01 20:50:26 +02:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2024-08-01 20:45:01 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|