2020-02-13 09:12:09 +08:00
|
|
|
// Copyright 2020 Kentaro Hibino. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package asynq
|
|
|
|
|
|
|
|
import (
|
2020-02-16 15:14:30 +08:00
|
|
|
"sync"
|
2020-02-13 09:12:09 +08:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/hibiken/asynq/internal/base"
|
|
|
|
"github.com/hibiken/asynq/internal/rdb"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestSubscriber(t *testing.T) {
|
|
|
|
r := setup(t)
|
|
|
|
rdbClient := rdb.NewRDB(r)
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
registeredID string // ID for which cancel func is registered
|
|
|
|
publishID string // ID to be published
|
|
|
|
wantCalled bool // whether cancel func should be called
|
|
|
|
}{
|
|
|
|
{"abc123", "abc123", true},
|
|
|
|
{"abc456", "abc123", false},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
2020-02-17 06:42:21 +08:00
|
|
|
var mu sync.Mutex
|
2020-02-13 09:12:09 +08:00
|
|
|
called := false
|
|
|
|
fakeCancelFunc := func() {
|
2020-02-17 06:42:21 +08:00
|
|
|
mu.Lock()
|
|
|
|
defer mu.Unlock()
|
2020-02-13 09:12:09 +08:00
|
|
|
called = true
|
|
|
|
}
|
|
|
|
cancelations := base.NewCancelations()
|
|
|
|
cancelations.Add(tc.registeredID, fakeCancelFunc)
|
|
|
|
|
2020-03-09 22:11:16 +08:00
|
|
|
subscriber := newSubscriber(testLogger, rdbClient, cancelations)
|
2020-02-16 15:14:30 +08:00
|
|
|
var wg sync.WaitGroup
|
|
|
|
subscriber.start(&wg)
|
2020-02-13 09:12:09 +08:00
|
|
|
|
2020-04-16 23:58:44 +08:00
|
|
|
// wait for subscriber to establish connection to pubsub channel
|
|
|
|
time.Sleep(time.Second)
|
|
|
|
|
2020-02-13 09:12:09 +08:00
|
|
|
if err := rdbClient.PublishCancelation(tc.publishID); err != nil {
|
|
|
|
subscriber.terminate()
|
|
|
|
t.Fatalf("could not publish cancelation message: %v", err)
|
|
|
|
}
|
|
|
|
|
2020-04-16 23:58:44 +08:00
|
|
|
// wait for redis to publish message
|
2020-02-13 09:12:09 +08:00
|
|
|
time.Sleep(time.Second)
|
|
|
|
|
2020-02-17 06:42:21 +08:00
|
|
|
mu.Lock()
|
2020-02-13 09:12:09 +08:00
|
|
|
if called != tc.wantCalled {
|
|
|
|
if tc.wantCalled {
|
|
|
|
t.Errorf("fakeCancelFunc was not called, want the function to be called")
|
|
|
|
} else {
|
|
|
|
t.Errorf("fakeCancelFunc was called, want the function to not be called")
|
|
|
|
}
|
|
|
|
}
|
2020-02-17 06:42:21 +08:00
|
|
|
mu.Unlock()
|
2020-02-13 09:12:09 +08:00
|
|
|
|
|
|
|
subscriber.terminate()
|
|
|
|
}
|
|
|
|
}
|