summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xMakefile2
-rw-r--r--plugins/websockets/storage/storage.go90
-rw-r--r--plugins/websockets/storage/storage_test.go299
3 files changed, 0 insertions, 391 deletions
diff --git a/Makefile b/Makefile
index 32f3839c..9cd0531d 100755
--- a/Makefile
+++ b/Makefile
@@ -15,7 +15,6 @@ test_coverage:
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/worker_stack.out -covermode=atomic ./pkg/worker_watcher
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/bst.out -covermode=atomic ./pkg/bst
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/http.out -covermode=atomic ./tests/plugins/http
- go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/storage-ws.out -covermode=atomic ./plugins/websockets/storage
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/http_config.out -covermode=atomic ./plugins/http/config
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/informer.out -covermode=atomic ./tests/plugins/informer
go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/reload.out -covermode=atomic ./tests/plugins/reload
@@ -44,7 +43,6 @@ test: ## Run application tests
go test -v -race -tags=debug ./pkg/worker_watcher
go test -v -race -tags=debug ./pkg/bst
go test -v -race -tags=debug ./tests/plugins/http
- go test -v -race -tags=debug ./plugins/websockets/storage
go test -v -race -tags=debug ./plugins/http/config
go test -v -race -tags=debug ./tests/plugins/informer
go test -v -race -tags=debug ./tests/plugins/reload
diff --git a/plugins/websockets/storage/storage.go b/plugins/websockets/storage/storage.go
deleted file mode 100644
index 43834658..00000000
--- a/plugins/websockets/storage/storage.go
+++ /dev/null
@@ -1,90 +0,0 @@
-package storage
-
-import (
- "sync"
-
- "github.com/spiral/roadrunner/v2/pkg/bst"
-)
-
-type Storage struct {
- sync.RWMutex
- BST bst.Storage
-}
-
-func NewStorage() *Storage {
- return &Storage{
- BST: bst.NewBST(),
- }
-}
-
-func (s *Storage) InsertMany(connID string, topics []string) {
- s.Lock()
- defer s.Unlock()
-
- for i := 0; i < len(topics); i++ {
- s.BST.Insert(connID, topics[i])
- }
-}
-
-func (s *Storage) Insert(connID string, topic string) {
- s.Lock()
- defer s.Unlock()
-
- s.BST.Insert(connID, topic)
-}
-
-func (s *Storage) RemoveMany(connID string, topics []string) {
- s.Lock()
- defer s.Unlock()
-
- for i := 0; i < len(topics); i++ {
- s.BST.Remove(connID, topics[i])
- }
-}
-
-func (s *Storage) Remove(connID string, topic string) {
- s.Lock()
- defer s.Unlock()
-
- s.BST.Remove(connID, topic)
-}
-
-// GetByPtrTS Thread safe get
-func (s *Storage) GetByPtrTS(topics []string, res map[string]struct{}) {
- s.Lock()
- defer s.Unlock()
-
- for i := 0; i < len(topics); i++ {
- d := s.BST.Get(topics[i])
- if len(d) > 0 {
- for ii := range d {
- res[ii] = struct{}{}
- }
- }
- }
-}
-func (s *Storage) GetOneByPtr(topic string, res map[string]struct{}) {
- s.RLock()
- defer s.RUnlock()
-
- d := s.BST.Get(topic)
- if len(d) > 0 {
- for ii := range d {
- res[ii] = struct{}{}
- }
- }
-}
-
-func (s *Storage) GetByPtr(topics []string, res map[string]struct{}) {
- s.RLock()
- defer s.RUnlock()
-
- for i := 0; i < len(topics); i++ {
- d := s.BST.Get(topics[i])
- if len(d) > 0 {
- for ii := range d {
- res[ii] = struct{}{}
- }
- }
- }
-}
diff --git a/plugins/websockets/storage/storage_test.go b/plugins/websockets/storage/storage_test.go
deleted file mode 100644
index 4072992a..00000000
--- a/plugins/websockets/storage/storage_test.go
+++ /dev/null
@@ -1,299 +0,0 @@
-package storage
-
-import (
- "math/rand"
- "testing"
- "time"
-
- "github.com/google/uuid"
- "github.com/stretchr/testify/assert"
-)
-
-const predifined = "chat-1-2"
-
-func TestNewBST(t *testing.T) {
- // create a new bst
- g := NewStorage()
-
- for i := 0; i < 100; i++ {
- g.InsertMany(uuid.NewString(), []string{"comments"})
- }
-
- for i := 0; i < 100; i++ {
- g.InsertMany(uuid.NewString(), []string{"comments2"})
- }
-
- for i := 0; i < 100; i++ {
- g.InsertMany(uuid.NewString(), []string{"comments3"})
- }
-
- res := make(map[string]struct{}, 100)
- assert.Len(t, res, 0)
-
- // should be 100
- g.GetByPtr([]string{"comments"}, res)
- assert.Len(t, res, 100)
-
- res = make(map[string]struct{}, 100)
- assert.Len(t, res, 0)
-
- // should be 100
- g.GetByPtr([]string{"comments2"}, res)
- assert.Len(t, res, 100)
-
- res = make(map[string]struct{}, 100)
- assert.Len(t, res, 0)
-
- // should be 100
- g.GetByPtr([]string{"comments3"}, res)
- assert.Len(t, res, 100)
-}
-
-func BenchmarkGraph(b *testing.B) {
- g := NewStorage()
-
- for i := 0; i < 1000; i++ {
- uid := uuid.New().String()
- g.InsertMany(uuid.NewString(), []string{uid})
- }
-
- g.Insert(uuid.NewString(), predifined)
-
- b.ResetTimer()
- b.ReportAllocs()
-
- res := make(map[string]struct{})
-
- for i := 0; i < b.N; i++ {
- g.GetByPtr([]string{predifined}, res)
-
- for i := range res {
- delete(res, i)
- }
- }
-}
-
-func BenchmarkBigSearch(b *testing.B) {
- g1 := NewStorage()
-
- predefinedSlice := make([]string, 0, 1000)
- for i := 0; i < 1000; i++ {
- predefinedSlice = append(predefinedSlice, uuid.NewString())
- }
- if predefinedSlice == nil {
- b.FailNow()
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), uuid.NewString())
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), predefinedSlice[i])
- }
-
- b.ResetTimer()
- b.ReportAllocs()
-
- res := make(map[string]struct{}, 333)
-
- for i := 0; i < b.N; i++ {
- g1.GetByPtr(predefinedSlice, res)
-
- for i := range res {
- delete(res, i)
- }
- }
-}
-
-func BenchmarkBigSearchWithRemoves(b *testing.B) {
- g1 := NewStorage()
-
- predefinedSlice := make([]string, 0, 1000)
- for i := 0; i < 1000; i++ {
- predefinedSlice = append(predefinedSlice, uuid.NewString())
- }
- if predefinedSlice == nil {
- b.FailNow()
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), uuid.NewString())
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), predefinedSlice[i])
- }
-
- b.ResetTimer()
- b.ReportAllocs()
-
- go func() {
- tt := time.NewTicker(time.Microsecond)
-
- res := make(map[string]struct{}, 1000)
- for {
- select {
- case <-tt.C:
- num := rand.Intn(1000) //nolint:gosec
- g1.GetByPtr(predefinedSlice, res)
- for k := range res {
- g1.Remove(k, predefinedSlice[num])
- }
- }
- }
- }()
-
- res := make(map[string]struct{}, 100)
-
- for i := 0; i < b.N; i++ {
- g1.GetByPtr(predefinedSlice, res)
-
- for i := range res {
- delete(res, i)
- }
- }
-}
-
-func TestBigSearchWithRemoves(t *testing.T) {
- g1 := NewStorage()
-
- predefinedSlice := make([]string, 0, 1000)
- for i := 0; i < 1000; i++ {
- predefinedSlice = append(predefinedSlice, uuid.NewString())
- }
- if predefinedSlice == nil {
- t.FailNow()
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), uuid.NewString())
- }
-
- for i := 0; i < 1000; i++ {
- g1.Insert(uuid.NewString(), predefinedSlice[i])
- }
-
- stopCh := make(chan struct{})
-
- go func() {
- tt := time.NewTicker(time.Microsecond)
-
- res := make(map[string]struct{}, 1000)
- for {
- select {
- case <-tt.C:
- num := rand.Intn(1000) //nolint:gosec
- g1.GetByPtr(predefinedSlice, res)
- for k := range res {
- g1.Remove(k, predefinedSlice[num])
- }
-
- case <-stopCh:
- tt.Stop()
- return
- }
- }
- }()
-
- res := make(map[string]struct{}, 100)
-
- for i := 0; i < 1000; i++ {
- g1.GetByPtr(predefinedSlice, res)
-
- for i := range res {
- delete(res, i)
- }
- }
-
- stopCh <- struct{}{}
-}
-
-func TestGraph(t *testing.T) {
- g := NewStorage()
-
- for i := 0; i < 1000; i++ {
- uid := uuid.New().String()
- g.Insert(uuid.NewString(), uid)
- }
-
- g.Insert(uuid.NewString(), predifined)
-
- res := make(map[string]struct{})
-
- g.GetByPtr([]string{predifined}, res)
- assert.NotEmpty(t, res)
- assert.Len(t, res, 1)
-}
-
-func TestTreeConcurrentContains(t *testing.T) {
- g := NewStorage()
-
- key1 := uuid.NewString()
- key2 := uuid.NewString()
- key3 := uuid.NewString()
- key4 := uuid.NewString()
- key5 := uuid.NewString()
-
- g.Insert(key1, predifined)
- g.Insert(key2, predifined)
- g.Insert(key3, predifined)
- g.Insert(key4, predifined)
- g.Insert(key5, predifined)
-
- res := make(map[string]struct{}, 100)
-
- for i := 0; i < 100; i++ {
- go func() {
- g.GetByPtrTS([]string{predifined}, res)
- }()
-
- go func() {
- g.GetByPtrTS([]string{predifined}, res)
- }()
-
- go func() {
- g.GetByPtrTS([]string{predifined}, res)
- }()
-
- go func() {
- g.GetByPtrTS([]string{predifined}, res)
- }()
- }
-
- time.Sleep(time.Second * 5)
-
- res2 := make(map[string]struct{}, 5)
-
- g.GetByPtr([]string{predifined}, res2)
- assert.NotEmpty(t, res2)
- assert.Len(t, res2, 5)
-}
-
-func TestGraphRemove(t *testing.T) {
- g := NewStorage()
-
- key1 := uuid.NewString()
- key2 := uuid.NewString()
- key3 := uuid.NewString()
- key4 := uuid.NewString()
- key5 := uuid.NewString()
-
- g.Insert(key1, predifined)
- g.Insert(key2, predifined)
- g.Insert(key3, predifined)
- g.Insert(key4, predifined)
- g.Insert(key5, predifined)
-
- res := make(map[string]struct{}, 5)
- g.GetByPtr([]string{predifined}, res)
- assert.NotEmpty(t, res)
- assert.Len(t, res, 5)
-
- g.Remove(key1, predifined)
-
- res2 := make(map[string]struct{}, 4)
- g.GetByPtr([]string{predifined}, res2)
- assert.NotEmpty(t, res2)
- assert.Len(t, res2, 4)
-}