Skip to content

Commit

Permalink
GO: Add BZPopMin command
Browse files Browse the repository at this point in the history
Signed-off-by: jbrinkman <[email protected]>
  • Loading branch information
jbrinkman committed Dec 24, 2024
1 parent 23db4bb commit 531a993
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 0 deletions.
9 changes: 9 additions & 0 deletions go/api/base_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -1370,3 +1370,12 @@ func (client *baseClient) ZPopMaxWithCount(key string, count int64) (map[Result[
}
return handleStringDoubleMapResponse(result)
}

func (client *baseClient) BZPopMin(keys []string, timeoutSecs float64) ([]Result[string], error) {
result, err := client.executeCommand(C.BZPopMin, append(keys, utils.FloatToString(timeoutSecs)))
if err != nil {
return nil, err
}

return handleStringArrayOrNullResponse(result)
}
3 changes: 3 additions & 0 deletions go/api/sorted_set_commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -192,4 +192,7 @@ type SortedSetCommands interface {
//
// [valkey.io]: https://valkey.io/commands/zpopmin/
ZPopMaxWithCount(key string, count int64) (map[Result[string]]Result[float64], error)

// [valkey bzpopmin]: https://valkey.io/commands/bzpopmin/
BZPopMin(keys []string, timeoutSecs float64) ([]Result[string], error)
}
41 changes: 41 additions & 0 deletions go/integTest/shared_commands_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3969,6 +3969,47 @@ func (suite *GlideTestSuite) TestZincrBy() {
assert.NotNil(suite.T(), err)
assert.IsType(suite.T(), &api.RequestError{}, err)
})

func (suite *GlideTestSuite) TestBZPopMin() {
suite.runWithDefaultClients(func(client api.BaseClient) {
key1 := "{listKey}-1-" + uuid.NewString()
// key2 := "{listKey}-2-" + uuid.NewString()

// Add elements to key1
zaddResult1, err := client.ZAdd(key1, map[string]float64{"a": 1.0, "b": 1.5})
assert.Nil(suite.T(), err)
assert.Equal(suite.T(), int64(2), zaddResult1.Value())

// Add elements to key2
// zaddResult2, err := client.ZAdd(key2, map[string]float64{"c": 2.0})
// assert.Nil(suite.T(), err)
// assert.Equal(suite.T(), int64(1), zaddResult2.Value())

// // Pop minimum element from key1 and key2
// bzpopminResult1, err := client.BZPopMin([]string{key1, key2}, 500*time.Millisecond)
// assert.NoError(suite.T(), err)
// assert.Equal(suite.T() []interface{}{key1, "a", 1.0}, bzpopminResult1)

// // Attempt to pop from non-existent key3
// bzpopminResult2, err := client.BZPopMin([]string{key3}, 1*time.Second)
// assert.NoError(suite.T() err)
// assert.Nil(suite.T() bzpopminResult2)

// // Pop minimum element from key2
// bzpopminResult3, err := client.BZPopMin([]string{key3, key2}, 500*time.Millisecond)
// assert.NoError(suite.T() err)
// assert.Equal(suite.T() []interface{}{key2, "c", 2.0}, bzpopminResult3)

// // Set key3 to a non-sorted set value
// setResult, err := client.Set(key3, "value")
// assert.NoError(suite.T() err)
// assert.Equal(suite.T() "OK", setResult)

// // Attempt to pop from key3 which is not a sorted set
// _, err = client.BZPopMin([]string{key3}, 500*time.Millisecond)
// assert.Error(suite.T() err)
// assert.IsType(suite.T() RequestException{}, err)
})
}

func (suite *GlideTestSuite) TestZPopMin() {
Expand Down

0 comments on commit 531a993

Please sign in to comment.