mirror of
https://github.com/Team254/cheesy-arena-lite.git
synced 2026-03-09 21:56:50 -04:00
361 lines
14 KiB
Go
361 lines
14 KiB
Go
// Copyright 2014 Team 254. All Rights Reserved.
|
|
// Author: pat@patfairbank.com (Patrick Fairbank)
|
|
|
|
package main
|
|
|
|
import (
|
|
"github.com/stretchr/testify/assert"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestAssignTeam(t *testing.T) {
|
|
clearDb()
|
|
defer clearDb()
|
|
var err error
|
|
db, err = OpenDatabase(testDbPath)
|
|
assert.Nil(t, err)
|
|
defer db.Close()
|
|
team := Team{Id: 254}
|
|
err = db.CreateTeam(&team)
|
|
assert.Nil(t, err)
|
|
err = db.CreateTeam(&Team{Id: 1114})
|
|
assert.Nil(t, err)
|
|
mainArena.Setup()
|
|
|
|
err = mainArena.AssignTeam(254, "B1")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, team, *mainArena.allianceStations["B1"].team)
|
|
dsConn := mainArena.allianceStations["B1"].driverStationConnection
|
|
assert.Equal(t, 254, dsConn.TeamId)
|
|
assert.Equal(t, "B1", dsConn.AllianceStation)
|
|
|
|
// Nothing should happen if the same team is assigned to the same station.
|
|
err = mainArena.AssignTeam(254, "B1")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, team, *mainArena.allianceStations["B1"].team)
|
|
dsConn2 := mainArena.allianceStations["B1"].driverStationConnection
|
|
assert.Equal(t, dsConn, dsConn2) // Pointer equality
|
|
|
|
// Test reassignment to another team.
|
|
err = mainArena.AssignTeam(1114, "B1")
|
|
assert.Nil(t, err)
|
|
assert.NotEqual(t, team, *mainArena.allianceStations["B1"].team)
|
|
assert.Equal(t, 1114, mainArena.allianceStations["B1"].driverStationConnection.TeamId)
|
|
err = dsConn.conn.Close()
|
|
assert.NotNil(t, err) // Connection should have already been closed.
|
|
|
|
// Check assigning an unknown team.
|
|
err = mainArena.AssignTeam(1503, "R1")
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Invalid team number")
|
|
}
|
|
|
|
// Check assigning zero as the team number.
|
|
err = mainArena.AssignTeam(0, "R2")
|
|
assert.Nil(t, err)
|
|
assert.Nil(t, mainArena.allianceStations["R2"].team)
|
|
assert.Nil(t, mainArena.allianceStations["R2"].driverStationConnection)
|
|
|
|
// Check assigning to a non-existent station.
|
|
err = mainArena.AssignTeam(254, "R4")
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Invalid alliance station")
|
|
}
|
|
}
|
|
|
|
func TestArenaMatchFlow(t *testing.T) {
|
|
clearDb()
|
|
defer clearDb()
|
|
var err error
|
|
db, err = OpenDatabase(testDbPath)
|
|
assert.Nil(t, err)
|
|
defer db.Close()
|
|
db.CreateTeam(&Team{Id: 254})
|
|
mainArena.Setup()
|
|
err = mainArena.AssignTeam(254, "B3")
|
|
assert.Nil(t, err)
|
|
|
|
// Check pre-match state and packet timing.
|
|
assert.Equal(t, PRE_MATCH, mainArena.matchState)
|
|
mainArena.Update()
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
lastPacketCount := mainArena.allianceStations["B3"].driverStationConnection.packetCount
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-10 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, lastPacketCount, mainArena.allianceStations["B3"].driverStationConnection.packetCount)
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, lastPacketCount+1, mainArena.allianceStations["B3"].driverStationConnection.packetCount)
|
|
|
|
// Check match start, autonomous and transition to teleop.
|
|
mainArena.allianceStations["R1"].bypass = true
|
|
mainArena.allianceStations["R2"].bypass = true
|
|
mainArena.allianceStations["R3"].bypass = true
|
|
mainArena.allianceStations["B1"].bypass = true
|
|
mainArena.allianceStations["B2"].bypass = true
|
|
mainArena.allianceStations["B3"].driverStationConnection.DriverStationStatus.RobotLinked = true
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
mainArena.Update()
|
|
assert.Equal(t, AUTO_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.Update()
|
|
assert.Equal(t, AUTO_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.matchStartTime = time.Now().Add(-autoDurationSec * time.Second)
|
|
mainArena.Update()
|
|
assert.Equal(t, PAUSE_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.Update()
|
|
assert.Equal(t, PAUSE_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.matchStartTime = time.Now().Add(-(autoDurationSec + pauseDurationSec) * time.Second)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
|
|
// Check e-stop and bypass.
|
|
mainArena.allianceStations["B3"].emergencyStop = true
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.allianceStations["B3"].bypass = true
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.allianceStations["B3"].emergencyStop = false
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.allianceStations["B3"].bypass = false
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, TELEOP_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
|
|
// Check endgame and match end.
|
|
mainArena.matchStartTime = time.Now().
|
|
Add(-(autoDurationSec + pauseDurationSec + teleopDurationSec - endgameTimeLeftSec) * time.Second)
|
|
mainArena.Update()
|
|
assert.Equal(t, ENDGAME_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.Update()
|
|
assert.Equal(t, ENDGAME_PERIOD, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.matchStartTime = time.Now().Add(-(autoDurationSec + pauseDurationSec + teleopDurationSec) * time.Second)
|
|
mainArena.Update()
|
|
assert.Equal(t, POST_MATCH, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
mainArena.Update()
|
|
assert.Equal(t, POST_MATCH, mainArena.matchState)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
|
|
mainArena.ResetMatch()
|
|
mainArena.lastDsPacketTime = mainArena.lastDsPacketTime.Add(-300 * time.Millisecond)
|
|
mainArena.Update()
|
|
assert.Equal(t, PRE_MATCH, mainArena.matchState)
|
|
assert.Equal(t, true, mainArena.allianceStations["B3"].driverStationConnection.Auto)
|
|
assert.Equal(t, false, mainArena.allianceStations["B3"].driverStationConnection.Enabled)
|
|
}
|
|
|
|
func TestArenaStateEnforcement(t *testing.T) {
|
|
mainArena.Setup()
|
|
mainArena.allianceStations["R1"].bypass = true
|
|
mainArena.allianceStations["R2"].bypass = true
|
|
mainArena.allianceStations["R3"].bypass = true
|
|
mainArena.allianceStations["B1"].bypass = true
|
|
mainArena.allianceStations["B2"].bypass = true
|
|
mainArena.allianceStations["B3"].bypass = true
|
|
|
|
err := mainArena.LoadMatch(new(Match))
|
|
assert.Nil(t, err)
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
err = mainArena.ResetMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot reset match while")
|
|
}
|
|
mainArena.matchState = AUTO_PERIOD
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
err = mainArena.ResetMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot reset match while")
|
|
}
|
|
mainArena.matchState = PAUSE_PERIOD
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
err = mainArena.ResetMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot reset match while")
|
|
}
|
|
mainArena.matchState = TELEOP_PERIOD
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
err = mainArena.ResetMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot reset match while")
|
|
}
|
|
mainArena.matchState = ENDGAME_PERIOD
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
err = mainArena.ResetMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot reset match while")
|
|
}
|
|
mainArena.matchState = POST_MATCH
|
|
err = mainArena.LoadMatch(new(Match))
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot load match while")
|
|
}
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "Cannot start match while")
|
|
}
|
|
|
|
err = mainArena.ResetMatch()
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, PRE_MATCH, mainArena.matchState)
|
|
assert.Nil(t, mainArena.currentMatch)
|
|
err = mainArena.ResetMatch()
|
|
assert.Nil(t, err)
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "no match is loaded")
|
|
}
|
|
err = mainArena.LoadMatch(new(Match))
|
|
assert.Nil(t, err)
|
|
}
|
|
|
|
func TestMatchStartRobotLinkEnforcement(t *testing.T) {
|
|
clearDb()
|
|
defer clearDb()
|
|
var err error
|
|
db, err = OpenDatabase(testDbPath)
|
|
assert.Nil(t, err)
|
|
defer db.Close()
|
|
db.CreateTeam(&Team{Id: 101})
|
|
db.CreateTeam(&Team{Id: 102})
|
|
db.CreateTeam(&Team{Id: 103})
|
|
db.CreateTeam(&Team{Id: 104})
|
|
db.CreateTeam(&Team{Id: 105})
|
|
db.CreateTeam(&Team{Id: 106})
|
|
match := Match{Red1: 101, Red2: 102, Red3: 103, Blue1: 104, Blue2: 105, Blue3: 106}
|
|
db.CreateMatch(&match)
|
|
mainArena.Setup()
|
|
|
|
err = mainArena.LoadMatch(&match)
|
|
assert.Nil(t, err)
|
|
for _, station := range mainArena.allianceStations {
|
|
station.driverStationConnection.DriverStationStatus.RobotLinked = true
|
|
}
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
mainArena.matchState = PRE_MATCH
|
|
|
|
// Check with a single team e-stopped, not linked and bypassed.
|
|
mainArena.allianceStations["R1"].emergencyStop = true
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "while an emergency stop is active")
|
|
}
|
|
mainArena.allianceStations["R1"].emergencyStop = false
|
|
mainArena.allianceStations["R1"].driverStationConnection.DriverStationStatus.RobotLinked = false
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "until all robots are connected or bypassed")
|
|
}
|
|
mainArena.allianceStations["R1"].bypass = true
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
mainArena.allianceStations["R1"].bypass = false
|
|
mainArena.matchState = PRE_MATCH
|
|
|
|
// Check with a team missing.
|
|
err = mainArena.AssignTeam(0, "R1")
|
|
assert.Nil(t, err)
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "until all robots are connected or bypassed")
|
|
}
|
|
mainArena.allianceStations["R1"].bypass = true
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
mainArena.matchState = PRE_MATCH
|
|
|
|
// Check with no teams present.
|
|
mainArena.LoadMatch(new(Match))
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "until all robots are connected or bypassed")
|
|
}
|
|
mainArena.allianceStations["R1"].bypass = true
|
|
mainArena.allianceStations["R2"].bypass = true
|
|
mainArena.allianceStations["R3"].bypass = true
|
|
mainArena.allianceStations["B1"].bypass = true
|
|
mainArena.allianceStations["B2"].bypass = true
|
|
mainArena.allianceStations["B3"].bypass = true
|
|
mainArena.allianceStations["B3"].emergencyStop = true
|
|
err = mainArena.StartMatch()
|
|
if assert.NotNil(t, err) {
|
|
assert.Contains(t, err.Error(), "while an emergency stop is active")
|
|
}
|
|
mainArena.allianceStations["B3"].emergencyStop = false
|
|
err = mainArena.StartMatch()
|
|
assert.Nil(t, err)
|
|
}
|