forked from Team254/cheesy-arena
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathschedule_test.go
127 lines (116 loc) · 5.49 KB
/
schedule_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
// Copyright 2014 Team 254. All Rights Reserved.
// Author: [email protected] (Patrick Fairbank)
package main
import (
"github.com/stretchr/testify/assert"
"math/rand"
"os"
"testing"
"time"
)
func TestNonExistentSchedule(t *testing.T) {
teams := make([]Team, 6)
scheduleBlocks := []ScheduleBlock{{time.Unix(0, 0).UTC(), 2, 60}}
_, err := BuildRandomSchedule(teams, scheduleBlocks, "test")
expectedErr := "No schedule template exists for 6 teams and 2 matches"
if assert.NotNil(t, err) {
assert.Equal(t, expectedErr, err.Error())
}
}
func TestMalformedSchedule(t *testing.T) {
scheduleFile, _ := os.Create("schedules/6_1.csv")
defer os.Remove("schedules/6_1.csv")
scheduleFile.WriteString("1,0,2,0,3,0,4,0,5,0,6,0\n6,0,5,0,4,0,3,0,2,0,1,0\n")
scheduleFile.Close()
teams := make([]Team, 6)
scheduleBlocks := []ScheduleBlock{{time.Unix(0, 0).UTC(), 1, 60}}
_, err := BuildRandomSchedule(teams, scheduleBlocks, "test")
expectedErr := "Schedule file contains 2 matches, expected 1"
if assert.NotNil(t, err) {
assert.Equal(t, expectedErr, err.Error())
}
os.Remove("schedules/6_1.csv")
scheduleFile, _ = os.Create("schedules/6_1.csv")
scheduleFile.WriteString("1,0,asdf,0,3,0,4,0,5,0,6,0\n")
scheduleFile.Close()
_, err = BuildRandomSchedule(teams, scheduleBlocks, "test")
if assert.NotNil(t, err) {
assert.Contains(t, err.Error(), "strconv.ParseInt")
}
}
func TestScheduleTeams(t *testing.T) {
rand.Seed(0)
numTeams := 18
teams := make([]Team, numTeams)
for i := 0; i < numTeams; i++ {
teams[i].Id = i + 101
}
scheduleBlocks := []ScheduleBlock{{time.Unix(0, 0).UTC(), 6, 60}}
matches, err := BuildRandomSchedule(teams, scheduleBlocks, "test")
assert.Nil(t, err)
assert.Equal(t, Match{Type: "test", DisplayName: "1", Time: time.Unix(0, 0).UTC(), Red1: 115, Red2: 111,
Red3: 108, Blue1: 109, Blue2: 116, Blue3: 117, RedDefense1: "LB", RedDefense2: "RW", RedDefense3: "RT",
RedDefense4: "R", RedDefense5: "M", BlueDefense1: "LB", BlueDefense2: "RW", BlueDefense3: "RT",
BlueDefense4: "R", BlueDefense5: "M"}, matches[0])
assert.Equal(t, Match{Type: "test", DisplayName: "2", Time: time.Unix(60, 0).UTC(), Red1: 114, Red2: 112,
Red3: 103, Blue1: 101, Blue2: 104, Blue3: 118, RedDefense1: "LB", RedDefense2: "RW", RedDefense3: "RT",
RedDefense4: "R", RedDefense5: "M", BlueDefense1: "LB", BlueDefense2: "RW", BlueDefense3: "RT",
BlueDefense4: "R", BlueDefense5: "M"}, matches[1])
assert.Equal(t, Match{Type: "test", DisplayName: "3", Time: time.Unix(120, 0).UTC(), Red1: 110, Red2: 107,
Red3: 105, Blue1: 106, Blue2: 113, Blue3: 102, RedDefense1: "LB", RedDefense2: "RW", RedDefense3: "RT",
RedDefense4: "R", RedDefense5: "M", BlueDefense1: "LB", BlueDefense2: "RW", BlueDefense3: "RT",
BlueDefense4: "R", BlueDefense5: "M"}, matches[2])
assert.Equal(t, Match{Type: "test", DisplayName: "4", Time: time.Unix(180, 0).UTC(), Red1: 112, Red2: 108,
Red3: 109, Blue1: 101, Blue2: 111, Blue3: 103, RedDefense1: "LB", RedDefense2: "RT", RedDefense3: "M",
RedDefense4: "CDF", RedDefense5: "R", BlueDefense1: "LB", BlueDefense2: "RT", BlueDefense3: "M",
BlueDefense4: "CDF", BlueDefense5: "R"}, matches[3])
assert.Equal(t, Match{Type: "test", DisplayName: "5", Time: time.Unix(240, 0).UTC(), Red1: 113, Red2: 117,
Red3: 115, Blue1: 110, Blue2: 114, Blue3: 102, RedDefense1: "LB", RedDefense2: "RT", RedDefense3: "M",
RedDefense4: "CDF", RedDefense5: "R", BlueDefense1: "LB", BlueDefense2: "RT", BlueDefense3: "M",
BlueDefense4: "CDF", BlueDefense5: "R"}, matches[4])
assert.Equal(t, Match{Type: "test", DisplayName: "6", Time: time.Unix(300, 0).UTC(), Red1: 118, Red2: 105,
Red3: 106, Blue1: 107, Blue2: 104, Blue3: 116, RedDefense1: "LB", RedDefense2: "RT", RedDefense3: "M",
RedDefense4: "CDF", RedDefense5: "R", BlueDefense1: "LB", BlueDefense2: "RT", BlueDefense3: "M",
BlueDefense4: "CDF", BlueDefense5: "R"}, matches[5])
// Check with excess room for matches in the schedule.
scheduleBlocks = []ScheduleBlock{{time.Unix(0, 0).UTC(), 7, 60}}
matches, err = BuildRandomSchedule(teams, scheduleBlocks, "test")
assert.Nil(t, err)
}
func TestScheduleTiming(t *testing.T) {
teams := make([]Team, 18)
scheduleBlocks := []ScheduleBlock{{time.Unix(100, 0).UTC(), 10, 75},
{time.Unix(20000, 0).UTC(), 5, 1000},
{time.Unix(100000, 0).UTC(), 15, 29}}
matches, err := BuildRandomSchedule(teams, scheduleBlocks, "test")
assert.Nil(t, err)
assert.Equal(t, time.Unix(100, 0).UTC(), matches[0].Time)
assert.Equal(t, time.Unix(775, 0).UTC(), matches[9].Time)
assert.Equal(t, time.Unix(20000, 0).UTC(), matches[10].Time)
assert.Equal(t, time.Unix(24000, 0).UTC(), matches[14].Time)
assert.Equal(t, time.Unix(100000, 0).UTC(), matches[15].Time)
assert.Equal(t, time.Unix(100406, 0).UTC(), matches[29].Time)
}
func TestScheduleSurrogates(t *testing.T) {
rand.Seed(0)
numTeams := 38
teams := make([]Team, numTeams)
for i := 0; i < numTeams; i++ {
teams[i].Id = i + 101
}
scheduleBlocks := []ScheduleBlock{{time.Unix(0, 0).UTC(), 64, 60}}
matches, _ := BuildRandomSchedule(teams, scheduleBlocks, "test")
for i, match := range matches {
if i == 13 || i == 14 {
if !match.Red1IsSurrogate || match.Red2IsSurrogate || match.Red3IsSurrogate ||
!match.Blue1IsSurrogate || match.Blue2IsSurrogate || match.Blue3IsSurrogate {
t.Errorf("Surrogates wrong for match %d", i+1)
}
} else {
if match.Red1IsSurrogate || match.Red2IsSurrogate || match.Red3IsSurrogate ||
match.Blue1IsSurrogate || match.Blue2IsSurrogate || match.Blue3IsSurrogate {
t.Errorf("Expected match %d to be free of surrogates", i+1)
}
}
}
}