More work on verifying tournament round generation

cat-town
Dan Buch 13 years ago
parent e1f1aa6038
commit 5cf5a8035d

@ -2,7 +2,6 @@ class MashTournament < ActiveRecord::Base
belongs_to :requester belongs_to :requester
has_many :mashes has_many :mashes
has_many :rounds, :class_name => 'MashTournamentRound' has_many :rounds, :class_name => 'MashTournamentRound'
#after_create :create_rounds
#after_save :fill_in_next_round #after_save :fill_in_next_round
def next_unplayed_mash def next_unplayed_mash
@ -19,20 +18,21 @@ class MashTournament < ActiveRecord::Base
) )
end end
def create_rounds def valid_number_of_contenders?(n_contenders)
n_contenders = Map.count [8, 16, 32, 64, 128].include?(n_contenders)
end
#ap "Original n_contenders = #{n_contenders}" def create_rounds(n_contenders)
while n_contenders % 4 != 0 if not valid_number_of_contenders?(n_contenders)
n_contenders -= 1 raise StandardError.new(
"The number of contenders must be 8, 16, 32, 64, or 128! " +
"Got '#{n_contenders}'"
)
end end
#ap "Resulting n_contenders divisible by 4 = #{n_contenders}"
round = 1 round = 1
while n_contenders > 1 while n_contenders > 1
#ap "Generating round #{round}, n_contenders = #{n_contenders}"
create_round(round, n_contenders) create_round(round, n_contenders)
n_contenders = n_contenders / 2 n_contenders = n_contenders / 2
round += 1 round += 1

@ -5,29 +5,42 @@ describe MashTournament do
@valid_attributes = {:requester_id => 1} @valid_attributes = {:requester_id => 1}
end end
before(:each) do
@requester = Requester.make
@requester.save!
subject.requester_id = @requester.id
subject.save!
subject.reload
end
it "should create a new instance given valid attributes" do it "should create a new instance given valid attributes" do
MashTournament.create!(@valid_attributes) MashTournament.create!(@valid_attributes)
end end
context 'creating rounds' do context 'creating rounds' do
it 'should reject invalid numbers of contenders' do
[11, 24, 40].each do |n|
expect do
subject.create_rounds(n)
end.to raise_error
end
end
before(:all) do before(:all) do
Map.destroy_all Map.destroy_all
8.times do 40.times do
Map.make.save Map.make.save
end end
@requester = Requester.make
@requester.save!
end end
before(:each) do [[8, 3], [16, 4], [32, 5]].each do |n_contenders,n_rounds|
subject.requester_id = @requester.id context "for #{n_contenders} total contenders" do
subject.save! it "should create #{n_rounds} rounds" do
subject.reload subject.create_rounds(n_contenders)
end subject.total_rounds.should == n_rounds
end
it 'should create 3 rounds for 8 contenders' do end
subject.create_rounds
subject.total_rounds.should == 3
end end
end end
end end

Loading…
Cancel
Save