2020-04-10 03:07:53 +03:00
|
|
|
package eventsubscribers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"testing"
|
2020-04-10 15:19:00 +03:00
|
|
|
"time"
|
2020-04-10 03:07:53 +03:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/elyby/chrly/api/mojang"
|
2020-04-19 02:31:09 +03:00
|
|
|
"github.com/elyby/chrly/dispatcher"
|
2020-04-10 03:07:53 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMojangBatchUuidsProviderChecker(t *testing.T) {
|
|
|
|
t.Run("empty state", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderResponseChecker(d, time.Millisecond)
|
2020-04-10 03:07:53 +03:00
|
|
|
assert.Nil(t, checker(context.Background()))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("when no error occurred", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderResponseChecker(d, time.Millisecond)
|
|
|
|
d.Emit("mojang_textures:batch_uuids_provider:result", []string{"username"}, []*mojang.ProfileInfo{}, nil)
|
2020-04-10 03:07:53 +03:00
|
|
|
assert.Nil(t, checker(context.Background()))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("when error occurred", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderResponseChecker(d, time.Millisecond)
|
2020-04-10 03:07:53 +03:00
|
|
|
err := errors.New("some error occurred")
|
2020-04-19 02:31:09 +03:00
|
|
|
d.Emit("mojang_textures:batch_uuids_provider:result", []string{"username"}, nil, err)
|
2020-04-10 03:07:53 +03:00
|
|
|
assert.Equal(t, err, checker(context.Background()))
|
|
|
|
})
|
2020-04-10 15:19:00 +03:00
|
|
|
|
|
|
|
t.Run("should reset value after passed duration", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderResponseChecker(d, 20*time.Millisecond)
|
2020-04-10 15:19:00 +03:00
|
|
|
err := errors.New("some error occurred")
|
2020-04-19 02:31:09 +03:00
|
|
|
d.Emit("mojang_textures:batch_uuids_provider:result", []string{"username"}, nil, err)
|
2020-04-10 15:19:00 +03:00
|
|
|
assert.Equal(t, err, checker(context.Background()))
|
|
|
|
time.Sleep(40 * time.Millisecond)
|
|
|
|
assert.Nil(t, checker(context.Background()))
|
|
|
|
})
|
2020-04-10 03:07:53 +03:00
|
|
|
}
|
2020-04-10 15:39:48 +03:00
|
|
|
|
|
|
|
func TestMojangBatchUuidsProviderQueueLengthChecker(t *testing.T) {
|
|
|
|
t.Run("empty state", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderQueueLengthChecker(d, 10)
|
2020-04-10 15:39:48 +03:00
|
|
|
assert.Nil(t, checker(context.Background()))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("less than allowed limit", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderQueueLengthChecker(d, 10)
|
|
|
|
d.Emit("mojang_textures:batch_uuids_provider:round", []string{"username"}, 9)
|
2020-04-10 15:39:48 +03:00
|
|
|
assert.Nil(t, checker(context.Background()))
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("greater than allowed limit", func(t *testing.T) {
|
2020-04-19 02:31:09 +03:00
|
|
|
d := dispatcher.New()
|
|
|
|
checker := MojangBatchUuidsProviderQueueLengthChecker(d, 10)
|
|
|
|
d.Emit("mojang_textures:batch_uuids_provider:round", []string{"username"}, 10)
|
2020-04-10 15:39:48 +03:00
|
|
|
checkResult := checker(context.Background())
|
|
|
|
if assert.Error(t, checkResult) {
|
|
|
|
assert.Equal(t, "the maximum number of tasks in the queue has been exceeded", checkResult.Error())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|