Skip to content

Commit

Permalink
Fix parsing AcquireJob MessageQueueTokenExpiredError (#2837)
Browse files Browse the repository at this point in the history
  • Loading branch information
nikola-jokic authored Aug 25, 2023
1 parent 215b245 commit 52fc819
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 1 deletion.
13 changes: 12 additions & 1 deletion github/actions/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -634,7 +634,18 @@ func (c *Client) AcquireJobs(ctx context.Context, runnerScaleSetId int, messageQ
}

if resp.StatusCode != http.StatusOK {
return nil, ParseActionsErrorFromResponse(resp)
if resp.StatusCode != http.StatusUnauthorized {
return nil, ParseActionsErrorFromResponse(resp)
}

defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
body = trimByteOrderMark(body)
if err != nil {
return nil, err
}

return nil, &MessageQueueTokenExpiredError{msg: string(body)}
}

var acquiredJobs *Int64List
Expand Down
34 changes: 34 additions & 0 deletions github/actions/client_job_acquisition_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package actions_test

import (
"context"
"errors"
"net/http"
"strings"
"testing"
Expand Down Expand Up @@ -84,6 +85,39 @@ func TestAcquireJobs(t *testing.T) {
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) {
Expand Down

0 comments on commit 52fc819

Please sign in to comment.