mirror of
https://github.com/matrix-org/dendrite.git
synced 2026-01-20 12:33:09 -06:00
Add tests for pinecone monolith
This commit is contained in:
parent
59a5dd2bfa
commit
a91e33037c
|
|
@ -459,7 +459,6 @@ func (m *DendriteMonolith) Start() {
|
||||||
|
|
||||||
go func(ch <-chan pineconeEvents.Event) {
|
go func(ch <-chan pineconeEvents.Event) {
|
||||||
eLog := logrus.WithField("pinecone", "events")
|
eLog := logrus.WithField("pinecone", "events")
|
||||||
relayServerSyncRunning := atomic.NewBool(false)
|
|
||||||
stopRelayServerSync := make(chan bool)
|
stopRelayServerSync := make(chan bool)
|
||||||
|
|
||||||
relayRetriever := RelayServerRetriever{
|
relayRetriever := RelayServerRetriever{
|
||||||
|
|
@ -468,17 +467,18 @@ func (m *DendriteMonolith) Start() {
|
||||||
FederationAPI: m.federationAPI,
|
FederationAPI: m.federationAPI,
|
||||||
RelayServersQueried: make(map[gomatrixserverlib.ServerName]bool),
|
RelayServersQueried: make(map[gomatrixserverlib.ServerName]bool),
|
||||||
RelayAPI: monolith.RelayAPI,
|
RelayAPI: monolith.RelayAPI,
|
||||||
|
running: *atomic.NewBool(false),
|
||||||
}
|
}
|
||||||
relayRetriever.InitializeRelayServers(eLog)
|
relayRetriever.InitializeRelayServers(eLog)
|
||||||
|
|
||||||
for event := range ch {
|
for event := range ch {
|
||||||
switch e := event.(type) {
|
switch e := event.(type) {
|
||||||
case pineconeEvents.PeerAdded:
|
case pineconeEvents.PeerAdded:
|
||||||
if !relayServerSyncRunning.Load() {
|
if !relayRetriever.running.Load() {
|
||||||
go relayRetriever.syncRelayServers(stopRelayServerSync, *relayServerSyncRunning)
|
go relayRetriever.SyncRelayServers(stopRelayServerSync)
|
||||||
}
|
}
|
||||||
case pineconeEvents.PeerRemoved:
|
case pineconeEvents.PeerRemoved:
|
||||||
if relayServerSyncRunning.Load() && m.PineconeRouter.PeerCount(-1) == 0 {
|
if relayRetriever.running.Load() && m.PineconeRouter.PeerCount(-1) == 0 {
|
||||||
stopRelayServerSync <- true
|
stopRelayServerSync <- true
|
||||||
}
|
}
|
||||||
case pineconeEvents.TreeParentUpdate:
|
case pineconeEvents.TreeParentUpdate:
|
||||||
|
|
@ -515,9 +515,10 @@ func (m *DendriteMonolith) Stop() {
|
||||||
type RelayServerRetriever struct {
|
type RelayServerRetriever struct {
|
||||||
Context context.Context
|
Context context.Context
|
||||||
ServerName gomatrixserverlib.ServerName
|
ServerName gomatrixserverlib.ServerName
|
||||||
FederationAPI api.FederationInternalAPI
|
|
||||||
RelayServersQueried map[gomatrixserverlib.ServerName]bool
|
RelayServersQueried map[gomatrixserverlib.ServerName]bool
|
||||||
|
FederationAPI api.FederationInternalAPI
|
||||||
RelayAPI relayServerAPI.RelayInternalAPI
|
RelayAPI relayServerAPI.RelayInternalAPI
|
||||||
|
running atomic.Bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *RelayServerRetriever) InitializeRelayServers(eLog *logrus.Entry) {
|
func (m *RelayServerRetriever) InitializeRelayServers(eLog *logrus.Entry) {
|
||||||
|
|
@ -534,8 +535,8 @@ func (m *RelayServerRetriever) InitializeRelayServers(eLog *logrus.Entry) {
|
||||||
eLog.Infof("Registered relay servers: %v", response.RelayServers)
|
eLog.Infof("Registered relay servers: %v", response.RelayServers)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *RelayServerRetriever) syncRelayServers(stop <-chan bool, running atomic.Bool) {
|
func (m *RelayServerRetriever) SyncRelayServers(stop <-chan bool) {
|
||||||
defer running.Store(false)
|
defer m.running.Store(false)
|
||||||
|
|
||||||
t := time.NewTimer(relayServerRetryInterval)
|
t := time.NewTimer(relayServerRetryInterval)
|
||||||
for {
|
for {
|
||||||
|
|
|
||||||
188
build/gobind-pinecone/monolith_test.go
Normal file
188
build/gobind-pinecone/monolith_test.go
Normal file
|
|
@ -0,0 +1,188 @@
|
||||||
|
// Copyright 2022 The Matrix.org Foundation C.I.C.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package gobind
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"net"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/matrix-org/dendrite/federationapi/api"
|
||||||
|
relayServerAPI "github.com/matrix-org/dendrite/relayapi/api"
|
||||||
|
"github.com/matrix-org/gomatrixserverlib"
|
||||||
|
"github.com/sirupsen/logrus"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
"gotest.tools/v3/poll"
|
||||||
|
)
|
||||||
|
|
||||||
|
var TestBuf = []byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
|
||||||
|
|
||||||
|
type TestNetConn struct {
|
||||||
|
net.Conn
|
||||||
|
shouldFail bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *TestNetConn) Read(b []byte) (int, error) {
|
||||||
|
if t.shouldFail {
|
||||||
|
return 0, fmt.Errorf("Failed")
|
||||||
|
} else {
|
||||||
|
n := copy(b, TestBuf)
|
||||||
|
return n, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *TestNetConn) Write(b []byte) (int, error) {
|
||||||
|
if t.shouldFail {
|
||||||
|
return 0, fmt.Errorf("Failed")
|
||||||
|
} else {
|
||||||
|
return len(b), nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *TestNetConn) Close() error {
|
||||||
|
if t.shouldFail {
|
||||||
|
return fmt.Errorf("Failed")
|
||||||
|
} else {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitStoresPort(t *testing.T) {
|
||||||
|
conduit := Conduit{port: 7}
|
||||||
|
assert.Equal(t, 7, conduit.Port())
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitRead(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
b := make([]byte, len(TestBuf))
|
||||||
|
bytes, err := conduit.Read(b)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, len(TestBuf), bytes)
|
||||||
|
assert.Equal(t, TestBuf, b)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitReadCopy(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
result, err := conduit.ReadCopy()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, TestBuf, result)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitWrite(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
bytes, err := conduit.Write(TestBuf)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, len(TestBuf), bytes)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitClose(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
err := conduit.Close()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.True(t, conduit.closed.Load())
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitReadClosed(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
err := conduit.Close()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
b := make([]byte, len(TestBuf))
|
||||||
|
_, err = conduit.Read(b)
|
||||||
|
assert.Error(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitReadCopyClosed(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
err := conduit.Close()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, err = conduit.ReadCopy()
|
||||||
|
assert.Error(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitWriteClosed(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{}}
|
||||||
|
err := conduit.Close()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, err = conduit.Write(TestBuf)
|
||||||
|
assert.Error(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConduitReadCopyFails(t *testing.T) {
|
||||||
|
conduit := Conduit{conn: &TestNetConn{shouldFail: true}}
|
||||||
|
_, err := conduit.ReadCopy()
|
||||||
|
assert.Error(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var testRelayServers = []gomatrixserverlib.ServerName{"relay1", "relay2"}
|
||||||
|
|
||||||
|
type FakeFedAPI struct {
|
||||||
|
api.FederationInternalAPI
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FakeFedAPI) QueryRelayServers(ctx context.Context, req *api.QueryRelayServersRequest, res *api.QueryRelayServersResponse) error {
|
||||||
|
res.RelayServers = testRelayServers
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type FakeRelayAPI struct {
|
||||||
|
relayServerAPI.RelayInternalAPI
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *FakeRelayAPI) PerformRelayServerSync(ctx context.Context, req *relayServerAPI.PerformRelayServerSyncRequest, res *relayServerAPI.PerformRelayServerSyncResponse) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRelayRetrieverInitialization(t *testing.T) {
|
||||||
|
retriever := RelayServerRetriever{
|
||||||
|
Context: context.Background(),
|
||||||
|
ServerName: "server",
|
||||||
|
RelayServersQueried: make(map[gomatrixserverlib.ServerName]bool),
|
||||||
|
FederationAPI: &FakeFedAPI{},
|
||||||
|
RelayAPI: &FakeRelayAPI{},
|
||||||
|
}
|
||||||
|
|
||||||
|
retriever.InitializeRelayServers(logrus.WithField("test", "relay"))
|
||||||
|
assert.Equal(t, 2, len(retriever.RelayServersQueried))
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRelayRetrieverSync(t *testing.T) {
|
||||||
|
retriever := RelayServerRetriever{
|
||||||
|
Context: context.Background(),
|
||||||
|
ServerName: "server",
|
||||||
|
RelayServersQueried: make(map[gomatrixserverlib.ServerName]bool),
|
||||||
|
FederationAPI: &FakeFedAPI{},
|
||||||
|
RelayAPI: &FakeRelayAPI{},
|
||||||
|
}
|
||||||
|
|
||||||
|
retriever.InitializeRelayServers(logrus.WithField("test", "relay"))
|
||||||
|
assert.Equal(t, 2, len(retriever.RelayServersQueried))
|
||||||
|
|
||||||
|
stopRelayServerSync := make(chan bool)
|
||||||
|
go retriever.SyncRelayServers(stopRelayServerSync)
|
||||||
|
|
||||||
|
check := func(log poll.LogT) poll.Result {
|
||||||
|
for _, queried := range retriever.RelayServersQueried {
|
||||||
|
if !queried {
|
||||||
|
return poll.Continue("waiting for all servers to be queried")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stopRelayServerSync <- true
|
||||||
|
return poll.Success()
|
||||||
|
}
|
||||||
|
poll.WaitOn(t, check, poll.WithTimeout(5*time.Second), poll.WithDelay(100*time.Millisecond))
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue