Add basic nomad integration and runner provider
This commit is contained in:
111
environment/execution_environment_test.go
Normal file
111
environment/execution_environment_test.go
Normal file
@ -0,0 +1,111 @@
|
||||
package environment
|
||||
|
||||
import (
|
||||
"github.com/stretchr/testify/assert"
|
||||
"github.com/stretchr/testify/mock"
|
||||
"github.com/stretchr/testify/suite"
|
||||
"gitlab.hpi.de/codeocean/codemoon/poseidon/environment/pool"
|
||||
"gitlab.hpi.de/codeocean/codemoon/poseidon/mocks"
|
||||
"gitlab.hpi.de/codeocean/codemoon/poseidon/runner"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
||||
const runnerId = "s0m3-r4nd0m-1d"
|
||||
const anotherRunnerId = "4n0th3r-1d"
|
||||
const jobId = "4n0th3r-1d"
|
||||
|
||||
func TestGetNextRunnerTestSuite(t *testing.T) {
|
||||
suite.Run(t, new(GetNextRunnerTestSuite))
|
||||
}
|
||||
|
||||
type GetNextRunnerTestSuite struct {
|
||||
suite.Suite
|
||||
nomadExecutionEnvironment *NomadExecutionEnvironment
|
||||
exerciseRunner runner.Runner
|
||||
}
|
||||
|
||||
func (suite *GetNextRunnerTestSuite) SetupTest() {
|
||||
suite.nomadExecutionEnvironment = &NomadExecutionEnvironment{
|
||||
availableRunners: make(chan runner.Runner, 50),
|
||||
allRunners: pool.NewLocalRunnerPool(),
|
||||
}
|
||||
suite.exerciseRunner = runner.NewExerciseRunner(runnerId)
|
||||
}
|
||||
|
||||
func (suite *GetNextRunnerTestSuite) TestGetNextRunnerReturnsRunnerIfAvailable() {
|
||||
suite.nomadExecutionEnvironment.availableRunners <- suite.exerciseRunner
|
||||
|
||||
receivedRunner, err := suite.nomadExecutionEnvironment.NextRunner()
|
||||
suite.NoError(err)
|
||||
suite.Equal(suite.exerciseRunner, receivedRunner)
|
||||
}
|
||||
|
||||
func (suite *GetNextRunnerTestSuite) TestGetNextRunnerChangesStatusOfRunner() {
|
||||
suite.nomadExecutionEnvironment.availableRunners <- suite.exerciseRunner
|
||||
|
||||
receivedRunner, _ := suite.nomadExecutionEnvironment.NextRunner()
|
||||
suite.Equal(runner.StatusRunning, receivedRunner.Status())
|
||||
}
|
||||
|
||||
func (suite *GetNextRunnerTestSuite) TestGetNextRunnerDoesNotReturnTheSameRunnerTwice() {
|
||||
suite.nomadExecutionEnvironment.availableRunners <- suite.exerciseRunner
|
||||
suite.nomadExecutionEnvironment.availableRunners <- runner.NewExerciseRunner(anotherRunnerId)
|
||||
|
||||
firstReceivedRunner, _ := suite.nomadExecutionEnvironment.NextRunner()
|
||||
secondReceivedRunner, _ := suite.nomadExecutionEnvironment.NextRunner()
|
||||
suite.NotEqual(firstReceivedRunner, secondReceivedRunner)
|
||||
}
|
||||
|
||||
func (suite *GetNextRunnerTestSuite) TestGetNextRunnerThrowsAnErrorIfNoRunnersAvailable() {
|
||||
receivedRunner, err := suite.nomadExecutionEnvironment.NextRunner()
|
||||
suite.Nil(receivedRunner)
|
||||
suite.Error(err)
|
||||
}
|
||||
|
||||
func TestRefreshFetchRunners(t *testing.T) {
|
||||
apiMock, environment := newRefreshMock([]string{runnerId}, pool.NewLocalRunnerPool())
|
||||
// ToDo: Terminate Refresh when test finished (also in other tests)
|
||||
go environment.Refresh()
|
||||
_, _ = environment.NextRunner()
|
||||
apiMock.AssertCalled(t, "LoadRunners", jobId)
|
||||
}
|
||||
|
||||
func TestRefreshFetchesRunnersIntoChannel(t *testing.T) {
|
||||
_, environment := newRefreshMock([]string{runnerId}, pool.NewLocalRunnerPool())
|
||||
go environment.Refresh()
|
||||
availableRunner, _ := environment.NextRunner()
|
||||
assert.Equal(t, availableRunner.Id(), runnerId)
|
||||
}
|
||||
|
||||
func TestRefreshScalesJob(t *testing.T) {
|
||||
apiMock, environment := newRefreshMock([]string{runnerId}, pool.NewLocalRunnerPool())
|
||||
go environment.Refresh()
|
||||
_, _ = environment.NextRunner()
|
||||
time.Sleep(100 * time.Millisecond) // ToDo: Be safe this test is not flaky
|
||||
apiMock.AssertCalled(t, "SetJobScaling", jobId, 52, "Runner Requested")
|
||||
}
|
||||
|
||||
func TestRefreshAddsRunnerToPool(t *testing.T) {
|
||||
runnersInUse := pool.NewLocalRunnerPool()
|
||||
_, environment := newRefreshMock([]string{runnerId}, runnersInUse)
|
||||
go environment.Refresh()
|
||||
availableRunner, _ := environment.NextRunner()
|
||||
poolRunner, ok := runnersInUse.GetRunner(availableRunner.Id())
|
||||
assert.True(t, ok, "The requested runner is added to the pool")
|
||||
assert.Equal(t, availableRunner, poolRunner, "The requested runner equals the runner added to the pool")
|
||||
}
|
||||
|
||||
func newRefreshMock(returnedRunnerIds []string, allRunners pool.RunnerPool) (apiClient *mocks.ExecutorApi, environment *NomadExecutionEnvironment) {
|
||||
apiClient = &mocks.ExecutorApi{}
|
||||
apiClient.On("LoadRunners", jobId).Return(returnedRunnerIds, nil)
|
||||
apiClient.On("GetJobScale", jobId).Return(len(returnedRunnerIds), nil)
|
||||
apiClient.On("SetJobScaling", jobId, mock.AnythingOfType("int"), "Runner Requested").Return(nil)
|
||||
environment = &NomadExecutionEnvironment{
|
||||
jobId: jobId,
|
||||
availableRunners: make(chan runner.Runner, 50),
|
||||
allRunners: allRunners,
|
||||
nomadApiClient: apiClient,
|
||||
}
|
||||
return
|
||||
}
|
Reference in New Issue
Block a user