chore(poll): return NotModifiedTimeoutErr on 304
This commit is contained in:
parent
35a3c1c23a
commit
bdf9298496
4 changed files with 65 additions and 1 deletions
|
@ -22,6 +22,7 @@ const CausalityTokenHeader = "X-Garage-Causality-Token"
|
||||||
var TombstoneItemErr = errors.New("item is a tombstone")
|
var TombstoneItemErr = errors.New("item is a tombstone")
|
||||||
var NoSuchItemErr = errors.New("item does not exist")
|
var NoSuchItemErr = errors.New("item does not exist")
|
||||||
var ConcurrentItemsErr = errors.New("item has multiple concurrent values")
|
var ConcurrentItemsErr = errors.New("item has multiple concurrent values")
|
||||||
|
var NotModifiedTimeoutErr = errors.New("not modified within timeout")
|
||||||
|
|
||||||
var awsSigner = v4.NewSigner()
|
var awsSigner = v4.NewSigner()
|
||||||
|
|
||||||
|
@ -300,6 +301,8 @@ func (c *Client) readItemSingle(ctx context.Context, b Bucket, pk string, sk str
|
||||||
return nil, "", NoSuchItemErr
|
return nil, "", NoSuchItemErr
|
||||||
case http.StatusConflict:
|
case http.StatusConflict:
|
||||||
return nil, ct, ConcurrentItemsErr
|
return nil, ct, ConcurrentItemsErr
|
||||||
|
case http.StatusNotModified:
|
||||||
|
return nil, "", NotModifiedTimeoutErr
|
||||||
default:
|
default:
|
||||||
return nil, "", fmt.Errorf("http status code %d", resp.StatusCode)
|
return nil, "", fmt.Errorf("http status code %d", resp.StatusCode)
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,12 @@ func (c *Client) PollRange(ctx context.Context, b Bucket, pk string, q PollRange
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if resp.StatusCode != http.StatusOK {
|
switch resp.StatusCode {
|
||||||
|
case http.StatusOK:
|
||||||
|
break
|
||||||
|
case http.StatusNotModified:
|
||||||
|
return nil, NotModifiedTimeoutErr
|
||||||
|
default:
|
||||||
return nil, fmt.Errorf("http status code %d: %s", resp.StatusCode, body)
|
return nil, fmt.Errorf("http status code %d: %s", resp.StatusCode, body)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -80,3 +80,38 @@ func TestClient_PollRange(t *testing.T) {
|
||||||
require.Equal(t, "hello3", string(result.Items[0].Values[0]))
|
require.Equal(t, "hello3", string(result.Items[0].Values[0]))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestClient_PollRange_Timeout(t *testing.T) {
|
||||||
|
if testing.Short() {
|
||||||
|
t.Skip("Skipping in short mode: 1 sec minimum to trigger timeout")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
f, ctx := newFixture(t)
|
||||||
|
|
||||||
|
pk := randomPk()
|
||||||
|
sk := randomSk()
|
||||||
|
|
||||||
|
for i := range 5 {
|
||||||
|
err := f.cli.InsertItem(ctx, f.bucket, pk, sk+"-"+strconv.Itoa(i), "", []byte("hello1"))
|
||||||
|
require.NoError(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// first read should complete immediately
|
||||||
|
q := k2v.PollRangeQuery{
|
||||||
|
Start: sk,
|
||||||
|
}
|
||||||
|
result, err := f.cli.PollRange(ctx, f.bucket, pk, q, 5*time.Second)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.NotEmpty(t, result.SeenMarker)
|
||||||
|
require.Len(t, result.Items, 5)
|
||||||
|
for i := range result.Items {
|
||||||
|
require.Len(t, result.Items[i].Values, 1)
|
||||||
|
require.Equal(t, "hello1", string(result.Items[i].Values[0]))
|
||||||
|
}
|
||||||
|
|
||||||
|
q.SeenMarker = result.SeenMarker
|
||||||
|
result, err = f.cli.PollRange(ctx, f.bucket, pk, q, 1*time.Second)
|
||||||
|
require.ErrorIs(t, err, k2v.NotModifiedTimeoutErr)
|
||||||
|
}
|
||||||
|
|
|
@ -46,3 +46,24 @@ func TestClient_PollItem(t *testing.T) {
|
||||||
require.NotEmpty(t, ct)
|
require.NotEmpty(t, ct)
|
||||||
require.NoError(t, <-updateErrCh)
|
require.NoError(t, <-updateErrCh)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestClient_PollItem_Timeout(t *testing.T) {
|
||||||
|
if testing.Short() {
|
||||||
|
t.Skip("Skipping in short mode: 1 sec minimum to trigger timeout")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
f, ctx := newFixture(t)
|
||||||
|
|
||||||
|
pk := randomPk()
|
||||||
|
sk := randomSk()
|
||||||
|
|
||||||
|
err := f.cli.InsertItem(ctx, f.bucket, pk, sk, "", []byte("hello1"))
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
_, ct, err := f.cli.ReadItemSingle(ctx, f.bucket, pk, sk)
|
||||||
|
item, ct, err := f.cli.PollItem(ctx, f.bucket, pk, sk, ct, 1*time.Second)
|
||||||
|
require.ErrorIs(t, err, k2v.NotModifiedTimeoutErr)
|
||||||
|
require.Empty(t, item)
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue