mirror of
https://github.com/logos-messaging/go-libp2p-pubsub.git
synced 2026-01-02 12:53:09 +00:00
add ctx to sub.Next for cancellation
This commit is contained in:
parent
539e4b6b45
commit
25b8aad61f
@ -127,7 +127,7 @@ func TestBasicFloodsub(t *testing.T) {
|
||||
psubs[owner].Publish("foobar", msg)
|
||||
|
||||
for _, sub := range msgs {
|
||||
got, err := sub.Next()
|
||||
got, err := sub.Next(ctx)
|
||||
if err != nil {
|
||||
t.Fatal(sub.err)
|
||||
}
|
||||
@ -525,7 +525,7 @@ func TestSubscribeMultipleTimes(t *testing.T) {
|
||||
|
||||
psubs[1].Publish("foo", []byte("bar"))
|
||||
|
||||
msg, err := sub1.Next()
|
||||
msg, err := sub1.Next(ctx)
|
||||
if err != nil {
|
||||
t.Fatalf("unexpected error: %v.", err)
|
||||
}
|
||||
@ -536,7 +536,7 @@ func TestSubscribeMultipleTimes(t *testing.T) {
|
||||
t.Fatalf("data is %s, expected %s.", data, "bar")
|
||||
}
|
||||
|
||||
msg, err = sub2.Next()
|
||||
msg, err = sub2.Next(ctx)
|
||||
if err != nil {
|
||||
t.Fatalf("unexpected error: %v.", err)
|
||||
}
|
||||
|
||||
@ -1,5 +1,9 @@
|
||||
package floodsub
|
||||
|
||||
import (
|
||||
"context"
|
||||
)
|
||||
|
||||
type Subscription struct {
|
||||
topic string
|
||||
ch chan *Message
|
||||
@ -11,14 +15,17 @@ func (sub *Subscription) Topic() string {
|
||||
return sub.topic
|
||||
}
|
||||
|
||||
func (sub *Subscription) Next() (*Message, error) {
|
||||
msg, ok := <-sub.ch
|
||||
func (sub *Subscription) Next(ctx context.Context) (*Message, error) {
|
||||
select {
|
||||
case msg, ok := <-sub.ch:
|
||||
if !ok {
|
||||
return msg, sub.err
|
||||
}
|
||||
|
||||
if !ok {
|
||||
return msg, sub.err
|
||||
return msg, nil
|
||||
case <-ctx.Done():
|
||||
return nil, ctx.Err()
|
||||
}
|
||||
|
||||
return msg, nil
|
||||
}
|
||||
|
||||
func (sub *Subscription) Cancel() {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user