219 lines
6.1 KiB
Go
219 lines
6.1 KiB
Go
package actions_test
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/actions/actions-runner-controller/github/actions"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestGetRunner(t *testing.T) {
|
|
ctx := context.Background()
|
|
auth := &actions.ActionsAuth{
|
|
Token: "token",
|
|
}
|
|
|
|
t.Run("Get Runner", func(t *testing.T) {
|
|
var runnerID int64 = 1
|
|
want := &actions.RunnerReference{
|
|
Id: int(runnerID),
|
|
Name: "self-hosted-ubuntu",
|
|
}
|
|
response := []byte(`{"id": 1, "name": "self-hosted-ubuntu"}`)
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(response)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
got, err := client.GetRunner(ctx, runnerID)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, want, got)
|
|
})
|
|
|
|
t.Run("Default retries on server error", func(t *testing.T) {
|
|
var runnerID int64 = 1
|
|
retryWaitMax := 1 * time.Millisecond
|
|
retryMax := 1
|
|
|
|
actualRetry := 0
|
|
expectedRetry := retryMax + 1
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
actualRetry++
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth, actions.WithRetryMax(retryMax), actions.WithRetryWaitMax(retryWaitMax))
|
|
require.NoError(t, err)
|
|
|
|
_, err = client.GetRunner(ctx, runnerID)
|
|
require.Error(t, err)
|
|
assert.Equalf(t, actualRetry, expectedRetry, "A retry was expected after the first request but got: %v", actualRetry)
|
|
})
|
|
}
|
|
|
|
func TestGetRunnerByName(t *testing.T) {
|
|
ctx := context.Background()
|
|
auth := &actions.ActionsAuth{
|
|
Token: "token",
|
|
}
|
|
|
|
t.Run("Get Runner by Name", func(t *testing.T) {
|
|
var runnerID int64 = 1
|
|
var runnerName = "self-hosted-ubuntu"
|
|
want := &actions.RunnerReference{
|
|
Id: int(runnerID),
|
|
Name: runnerName,
|
|
}
|
|
response := []byte(`{"count": 1, "value": [{"id": 1, "name": "self-hosted-ubuntu"}]}`)
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(response)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
got, err := client.GetRunnerByName(ctx, runnerName)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, want, got)
|
|
})
|
|
|
|
t.Run("Get Runner by name with not exist runner", func(t *testing.T) {
|
|
var runnerName = "self-hosted-ubuntu"
|
|
response := []byte(`{"count": 0, "value": []}`)
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(response)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
got, err := client.GetRunnerByName(ctx, runnerName)
|
|
require.NoError(t, err)
|
|
assert.Nil(t, got)
|
|
})
|
|
|
|
t.Run("Default retries on server error", func(t *testing.T) {
|
|
var runnerName = "self-hosted-ubuntu"
|
|
|
|
retryWaitMax := 1 * time.Millisecond
|
|
retryMax := 1
|
|
|
|
actualRetry := 0
|
|
expectedRetry := retryMax + 1
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
actualRetry++
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth, actions.WithRetryMax(retryMax), actions.WithRetryWaitMax(retryWaitMax))
|
|
require.NoError(t, err)
|
|
|
|
_, err = client.GetRunnerByName(ctx, runnerName)
|
|
require.Error(t, err)
|
|
assert.Equalf(t, actualRetry, expectedRetry, "A retry was expected after the first request but got: %v", actualRetry)
|
|
})
|
|
}
|
|
|
|
func TestDeleteRunner(t *testing.T) {
|
|
ctx := context.Background()
|
|
auth := &actions.ActionsAuth{
|
|
Token: "token",
|
|
}
|
|
|
|
t.Run("Delete Runner", func(t *testing.T) {
|
|
var runnerID int64 = 1
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) {
|
|
w.WriteHeader(http.StatusNoContent)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
err = client.RemoveRunner(ctx, runnerID)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Default retries on server error", func(t *testing.T) {
|
|
var runnerID int64 = 1
|
|
|
|
retryWaitMax := 1 * time.Millisecond
|
|
retryMax := 1
|
|
|
|
actualRetry := 0
|
|
expectedRetry := retryMax + 1
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) {
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
actualRetry++
|
|
}))
|
|
|
|
client, err := actions.NewClient(
|
|
server.configURLForOrg("my-org"),
|
|
auth,
|
|
actions.WithRetryMax(retryMax),
|
|
actions.WithRetryWaitMax(retryWaitMax),
|
|
)
|
|
require.NoError(t, err)
|
|
|
|
err = client.RemoveRunner(ctx, runnerID)
|
|
require.Error(t, err)
|
|
assert.Equalf(t, actualRetry, expectedRetry, "A retry was expected after the first request but got: %v", actualRetry)
|
|
})
|
|
}
|
|
|
|
func TestGetRunnerGroupByName(t *testing.T) {
|
|
ctx := context.Background()
|
|
auth := &actions.ActionsAuth{
|
|
Token: "token",
|
|
}
|
|
|
|
t.Run("Get RunnerGroup by Name", func(t *testing.T) {
|
|
var runnerGroupID int64 = 1
|
|
var runnerGroupName = "test-runner-group"
|
|
want := &actions.RunnerGroup{
|
|
ID: runnerGroupID,
|
|
Name: runnerGroupName,
|
|
}
|
|
response := []byte(`{"count": 1, "value": [{"id": 1, "name": "test-runner-group"}]}`)
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(response)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
got, err := client.GetRunnerGroupByName(ctx, runnerGroupName)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, want, got)
|
|
})
|
|
|
|
t.Run("Get RunnerGroup by name with not exist runner group", func(t *testing.T) {
|
|
var runnerGroupName = "test-runner-group"
|
|
response := []byte(`{"count": 0, "value": []}`)
|
|
|
|
server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(response)
|
|
}))
|
|
|
|
client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
|
|
require.NoError(t, err)
|
|
|
|
got, err := client.GetRunnerGroupByName(ctx, runnerGroupName)
|
|
assert.ErrorContains(t, err, "no runner group found with name")
|
|
assert.Nil(t, got)
|
|
})
|
|
}
|