Add tests for websocket connection
Co-authored-by: Konrad Hanff <konrad.hanff@student.hpi.uni-potsdam.de>
This commit is contained in:
@ -89,7 +89,7 @@ func findRunnerMiddleware(runnerPool environment.RunnerPool) func(handler http.H
|
|||||||
runnerId := mux.Vars(request)[RunnerIdKey]
|
runnerId := mux.Vars(request)[RunnerIdKey]
|
||||||
r, ok := runnerPool.Get(runnerId)
|
r, ok := runnerPool.Get(runnerId)
|
||||||
if !ok {
|
if !ok {
|
||||||
writer.WriteHeader(http.StatusNotFound)
|
writeNotFound(writer, errors.New("no runner with this id"))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx := runner.NewContext(request.Context(), r.(runner.Runner))
|
ctx := runner.NewContext(request.Context(), r.(runner.Runner))
|
||||||
|
@ -15,20 +15,24 @@ var connUpgrade = websocket.Upgrader{
|
|||||||
|
|
||||||
// connectToRunner is a placeholder for now and will become the endpoint for websocket connections.
|
// connectToRunner is a placeholder for now and will become the endpoint for websocket connections.
|
||||||
func connectToRunner(writer http.ResponseWriter, request *http.Request) {
|
func connectToRunner(writer http.ResponseWriter, request *http.Request) {
|
||||||
r, ok := runner.FromContext(request.Context())
|
r, _ := runner.FromContext(request.Context())
|
||||||
|
executionId := request.URL.Query().Get(ExecutionIdKey)
|
||||||
|
executionRequest, ok := r.Execution(runner.ExecutionId(executionId))
|
||||||
if !ok {
|
if !ok {
|
||||||
log.Error("Runner not set in request context.")
|
writeNotFound(writer, errors.New("executionId does not exist"))
|
||||||
writeInternalServerError(writer, errors.New("findRunnerMiddleware failure"), dto.ErrorUnknown)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
executionId := request.URL.Query().Get(ExecutionIdKey)
|
log.
|
||||||
|
WithField("executionId", executionId).
|
||||||
|
WithField("command", executionRequest.Command).
|
||||||
|
Info("Running execution")
|
||||||
connClient, err := connUpgrade.Upgrade(writer, request, nil)
|
connClient, err := connUpgrade.Upgrade(writer, request, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
writeInternalServerError(writer, err, dto.ErrorUnknown)
|
writeInternalServerError(writer, err, dto.ErrorUnknown)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer func(connClient *websocket.Conn) {
|
defer func(connClient *websocket.Conn) {
|
||||||
err := connClient.Close()
|
err := connClient.WriteMessage(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
writeInternalServerError(writer, err, dto.ErrorUnknown)
|
writeInternalServerError(writer, err, dto.ErrorUnknown)
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,91 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"github.com/gorilla/mux"
|
||||||
|
"github.com/gorilla/websocket"
|
||||||
|
"github.com/stretchr/testify/suite"
|
||||||
|
"gitlab.hpi.de/codeocean/codemoon/poseidon/api/dto"
|
||||||
|
"gitlab.hpi.de/codeocean/codemoon/poseidon/environment/pool"
|
||||||
|
"gitlab.hpi.de/codeocean/codemoon/poseidon/runner"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
"net/url"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestInvalidExecutionId(t *testing.T) {
|
type WebsocketTestSuite struct {
|
||||||
|
suite.Suite
|
||||||
|
runner runner.Runner
|
||||||
|
server *httptest.Server
|
||||||
|
router *mux.Router
|
||||||
|
executionId runner.ExecutionId
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEstablishWebsocketConnection(t *testing.T) {
|
func (suite *WebsocketTestSuite) SetupSuite() {
|
||||||
|
runnerPool := pool.NewLocalRunnerPool()
|
||||||
|
suite.runner = runner.NewExerciseRunner("testRunner")
|
||||||
|
runnerPool.AddRunner(suite.runner)
|
||||||
|
var err error
|
||||||
|
suite.executionId, err = suite.runner.AddExecution(dto.ExecutionRequest{
|
||||||
|
Command: "command",
|
||||||
|
TimeLimit: 10,
|
||||||
|
Environment: nil,
|
||||||
|
})
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
router := mux.NewRouter()
|
||||||
|
router.Use(findRunnerMiddleware(runnerPool))
|
||||||
|
router.HandleFunc(fmt.Sprintf("%s/{%s}%s", RouteRunners, RunnerIdKey, WebsocketPath), connectToRunner).Methods(http.MethodGet).Name(WebsocketPath)
|
||||||
|
suite.server = httptest.NewServer(router)
|
||||||
|
suite.router = router
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *WebsocketTestSuite) url(scheme, runnerId string, executionId runner.ExecutionId) (*url.URL, error) {
|
||||||
|
websocketUrl, err := url.Parse(suite.server.URL)
|
||||||
|
if !suite.NoError(err, "Error: parsing test server url") {
|
||||||
|
return nil, errors.New("could not parse server url")
|
||||||
|
}
|
||||||
|
path, err := suite.router.Get(WebsocketPath).URL(RunnerIdKey, runnerId)
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return nil, errors.New("could not set runnerId")
|
||||||
|
}
|
||||||
|
websocketUrl.Scheme = scheme
|
||||||
|
websocketUrl.Path = path.Path
|
||||||
|
websocketUrl.RawQuery = fmt.Sprintf("executionId=%s", executionId)
|
||||||
|
return websocketUrl, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *WebsocketTestSuite) TearDownSuite() {
|
||||||
|
suite.server.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestWebsocketTestSuite(t *testing.T) {
|
||||||
|
suite.Run(t, new(WebsocketTestSuite))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *WebsocketTestSuite) TestEstablishWebsocketConnection() {
|
||||||
|
path, err := suite.url("ws", suite.runner.Id(), suite.executionId)
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
_, _, err = websocket.DefaultDialer.Dial(path.String(), nil)
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *WebsocketTestSuite) TestWebsocketReturns404IfExecutionDoesNotExist() {
|
||||||
|
wsUrl, err := suite.url("http", suite.runner.Id(), "invalid-execution-id")
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
response, err := http.Get(wsUrl.String())
|
||||||
|
if !suite.NoError(err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
suite.Equal(http.StatusNotFound, response.StatusCode)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user