2023-01-23 17:55:12 +00:00
|
|
|
// 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 internal
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/matrix-org/dendrite/internal/sqlutil"
|
|
|
|
"github.com/matrix-org/dendrite/relayapi/storage/shared"
|
|
|
|
"github.com/matrix-org/dendrite/test"
|
|
|
|
"github.com/matrix-org/gomatrixserverlib"
|
2023-04-06 09:55:01 +01:00
|
|
|
"github.com/matrix-org/gomatrixserverlib/fclient"
|
2023-04-19 15:50:33 +01:00
|
|
|
"github.com/matrix-org/gomatrixserverlib/spec"
|
2023-01-23 17:55:12 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
type testFedClient struct {
|
2023-04-24 17:23:25 +01:00
|
|
|
fclient.FederationClient
|
2023-01-23 17:55:12 +00:00
|
|
|
shouldFail bool
|
|
|
|
queryCount uint
|
|
|
|
queueDepth uint
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *testFedClient) P2PGetTransactionFromRelay(
|
|
|
|
ctx context.Context,
|
2023-04-19 15:50:33 +01:00
|
|
|
u spec.UserID,
|
2023-04-06 09:55:01 +01:00
|
|
|
prev fclient.RelayEntry,
|
2023-04-19 15:50:33 +01:00
|
|
|
relayServer spec.ServerName,
|
2023-04-06 09:55:01 +01:00
|
|
|
) (res fclient.RespGetRelayTransaction, err error) {
|
2023-01-23 17:55:12 +00:00
|
|
|
f.queryCount++
|
|
|
|
if f.shouldFail {
|
|
|
|
return res, fmt.Errorf("Error")
|
|
|
|
}
|
|
|
|
|
2023-04-06 09:55:01 +01:00
|
|
|
res = fclient.RespGetRelayTransaction{
|
2023-01-31 19:31:57 +00:00
|
|
|
Transaction: gomatrixserverlib.Transaction{},
|
|
|
|
EntryID: 0,
|
2023-01-23 17:55:12 +00:00
|
|
|
}
|
|
|
|
if f.queueDepth > 0 {
|
|
|
|
res.EntriesQueued = true
|
|
|
|
} else {
|
|
|
|
res.EntriesQueued = false
|
|
|
|
}
|
|
|
|
f.queueDepth -= 1
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPerformRelayServerSync(t *testing.T) {
|
|
|
|
testDB := test.NewInMemoryRelayDatabase()
|
|
|
|
db := shared.Database{
|
|
|
|
Writer: sqlutil.NewDummyWriter(),
|
|
|
|
RelayQueue: testDB,
|
|
|
|
RelayQueueJSON: testDB,
|
|
|
|
}
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
userID, err := spec.NewUserID("@local:domain", false)
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.Nil(t, err, "Invalid userID")
|
|
|
|
|
|
|
|
fedClient := &testFedClient{}
|
|
|
|
relayAPI := NewRelayInternalAPI(
|
2023-01-29 19:26:16 +00:00
|
|
|
&db, fedClient, nil, nil, nil, false, "", true,
|
2023-01-23 17:55:12 +00:00
|
|
|
)
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
err = relayAPI.PerformRelayServerSync(context.Background(), *userID, spec.ServerName("relay"))
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPerformRelayServerSyncFedError(t *testing.T) {
|
|
|
|
testDB := test.NewInMemoryRelayDatabase()
|
|
|
|
db := shared.Database{
|
|
|
|
Writer: sqlutil.NewDummyWriter(),
|
|
|
|
RelayQueue: testDB,
|
|
|
|
RelayQueueJSON: testDB,
|
|
|
|
}
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
userID, err := spec.NewUserID("@local:domain", false)
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.Nil(t, err, "Invalid userID")
|
|
|
|
|
|
|
|
fedClient := &testFedClient{shouldFail: true}
|
|
|
|
relayAPI := NewRelayInternalAPI(
|
2023-01-29 19:26:16 +00:00
|
|
|
&db, fedClient, nil, nil, nil, false, "", true,
|
2023-01-23 17:55:12 +00:00
|
|
|
)
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
err = relayAPI.PerformRelayServerSync(context.Background(), *userID, spec.ServerName("relay"))
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.Error(t, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPerformRelayServerSyncRunsUntilQueueEmpty(t *testing.T) {
|
|
|
|
testDB := test.NewInMemoryRelayDatabase()
|
|
|
|
db := shared.Database{
|
|
|
|
Writer: sqlutil.NewDummyWriter(),
|
|
|
|
RelayQueue: testDB,
|
|
|
|
RelayQueueJSON: testDB,
|
|
|
|
}
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
userID, err := spec.NewUserID("@local:domain", false)
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.Nil(t, err, "Invalid userID")
|
|
|
|
|
|
|
|
fedClient := &testFedClient{queueDepth: 2}
|
|
|
|
relayAPI := NewRelayInternalAPI(
|
2023-01-29 19:26:16 +00:00
|
|
|
&db, fedClient, nil, nil, nil, false, "", true,
|
2023-01-23 17:55:12 +00:00
|
|
|
)
|
|
|
|
|
2023-04-19 15:50:33 +01:00
|
|
|
err = relayAPI.PerformRelayServerSync(context.Background(), *userID, spec.ServerName("relay"))
|
2023-01-23 17:55:12 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, uint(3), fedClient.queryCount)
|
|
|
|
}
|