172 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
| package actions_test
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"errors"
 | |
| 	"net/http"
 | |
| 	"strings"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/actions/actions-runner-controller/github/actions"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestAcquireJobs(t *testing.T) {
 | |
| 	ctx := context.Background()
 | |
| 	auth := &actions.ActionsAuth{
 | |
| 		Token: "token",
 | |
| 	}
 | |
| 
 | |
| 	t.Run("Acquire Job", func(t *testing.T) {
 | |
| 		want := []int64{1}
 | |
| 		response := []byte(`{"value": [1]}`)
 | |
| 
 | |
| 		session := &actions.RunnerScaleSetSession{
 | |
| 			RunnerScaleSet:          &actions.RunnerScaleSet{Id: 1},
 | |
| 			MessageQueueAccessToken: "abc",
 | |
| 		}
 | |
| 		requestIDs := want
 | |
| 
 | |
| 		server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
 | |
| 			if strings.HasSuffix(r.URL.Path, "/acquirablejobs") {
 | |
| 				w.Write([]byte(`{"count": 1}`))
 | |
| 				return
 | |
| 			}
 | |
| 
 | |
| 			w.Write(response)
 | |
| 		}))
 | |
| 
 | |
| 		client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		_, err = client.GetAcquirableJobs(ctx, 1)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		got, err := client.AcquireJobs(ctx, session.RunnerScaleSet.Id, session.MessageQueueAccessToken, requestIDs)
 | |
| 		require.NoError(t, err)
 | |
| 		assert.Equal(t, want, got)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Default retries on server error", func(t *testing.T) {
 | |
| 		session := &actions.RunnerScaleSetSession{
 | |
| 			RunnerScaleSet:          &actions.RunnerScaleSet{Id: 1},
 | |
| 			MessageQueueAccessToken: "abc",
 | |
| 		}
 | |
| 		var requestIDs []int64 = []int64{1}
 | |
| 
 | |
| 		retryMax := 1
 | |
| 		actualRetry := 0
 | |
| 		expectedRetry := retryMax + 1
 | |
| 
 | |
| 		server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
 | |
| 			if strings.HasSuffix(r.URL.Path, "/acquirablejobs") {
 | |
| 				w.Write([]byte(`{"count": 1}`))
 | |
| 				return
 | |
| 			}
 | |
| 
 | |
| 			w.WriteHeader(http.StatusServiceUnavailable)
 | |
| 			actualRetry++
 | |
| 		}))
 | |
| 
 | |
| 		client, err := actions.NewClient(
 | |
| 			server.configURLForOrg("my-org"),
 | |
| 			auth,
 | |
| 			actions.WithRetryMax(retryMax),
 | |
| 			actions.WithRetryWaitMax(1*time.Millisecond),
 | |
| 		)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		_, err = client.GetAcquirableJobs(ctx, 1)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		_, err = client.AcquireJobs(context.Background(), session.RunnerScaleSet.Id, session.MessageQueueAccessToken, requestIDs)
 | |
| 		assert.NotNil(t, err)
 | |
| 		assert.Equalf(t, actualRetry, expectedRetry, "A retry was expected after the first request but got: %v", actualRetry)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Should return MessageQueueTokenExpiredError when http error is not Unauthorized", func(t *testing.T) {
 | |
| 		want := []int64{1}
 | |
| 
 | |
| 		session := &actions.RunnerScaleSetSession{
 | |
| 			RunnerScaleSet:          &actions.RunnerScaleSet{Id: 1},
 | |
| 			MessageQueueAccessToken: "abc",
 | |
| 		}
 | |
| 		requestIDs := want
 | |
| 
 | |
| 		server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
 | |
| 			if strings.HasSuffix(r.URL.Path, "/acquirablejobs") {
 | |
| 				w.Write([]byte(`{"count": 1}`))
 | |
| 				return
 | |
| 			}
 | |
| 			if r.Method == http.MethodPost {
 | |
| 				http.Error(w, "Session expired", http.StatusUnauthorized)
 | |
| 				return
 | |
| 			}
 | |
| 		}))
 | |
| 
 | |
| 		client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		_, err = client.GetAcquirableJobs(ctx, 1)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		got, err := client.AcquireJobs(ctx, session.RunnerScaleSet.Id, session.MessageQueueAccessToken, requestIDs)
 | |
| 		require.Error(t, err)
 | |
| 		assert.Nil(t, got)
 | |
| 		var expectedErr *actions.MessageQueueTokenExpiredError
 | |
| 		assert.True(t, errors.As(err, &expectedErr))
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestGetAcquirableJobs(t *testing.T) {
 | |
| 	auth := &actions.ActionsAuth{
 | |
| 		Token: "token",
 | |
| 	}
 | |
| 
 | |
| 	t.Run("Acquire Job", func(t *testing.T) {
 | |
| 		want := &actions.AcquirableJobList{}
 | |
| 		response := []byte(`{"count": 0}`)
 | |
| 
 | |
| 		runnerScaleSet := &actions.RunnerScaleSet{Id: 1}
 | |
| 
 | |
| 		server := newActionsServer(t, http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) {
 | |
| 			w.Write(response)
 | |
| 		}))
 | |
| 
 | |
| 		client, err := actions.NewClient(server.configURLForOrg("my-org"), auth)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		got, err := client.GetAcquirableJobs(context.Background(), runnerScaleSet.Id)
 | |
| 		require.NoError(t, err)
 | |
| 		assert.Equal(t, want, got)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Default retries on server error", func(t *testing.T) {
 | |
| 		runnerScaleSet := &actions.RunnerScaleSet{Id: 1}
 | |
| 
 | |
| 		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(1*time.Millisecond),
 | |
| 		)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		_, err = client.GetAcquirableJobs(context.Background(), runnerScaleSet.Id)
 | |
| 		require.Error(t, err)
 | |
| 		assert.Equalf(t, actualRetry, expectedRetry, "A retry was expected after the first request but got: %v", actualRetry)
 | |
| 	})
 | |
| }
 |