2022-08-01 10:33:18 -04:00
|
|
|
package peerstream
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/consul/proto/pbpeering"
|
|
|
|
"github.com/hashicorp/consul/proto/pbpeerstream"
|
|
|
|
"github.com/hashicorp/consul/sdk/testutil"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestServer_ExchangeSecret(t *testing.T) {
|
|
|
|
srv, store := newTestServer(t, nil)
|
|
|
|
_ = writePeeringToBeDialed(t, store, 1, "my-peer")
|
|
|
|
|
|
|
|
testutil.RunStep(t, "unknown establishment secret is rejected", func(t *testing.T) {
|
|
|
|
resp, err := srv.ExchangeSecret(context.Background(), &pbpeerstream.ExchangeSecretRequest{
|
|
|
|
PeerID: testPeerID,
|
|
|
|
EstablishmentSecret: "bad",
|
|
|
|
})
|
|
|
|
testutil.RequireErrorContains(t, err, `rpc error: code = PermissionDenied desc = invalid peering establishment secret`)
|
|
|
|
require.Nil(t, resp)
|
|
|
|
})
|
|
|
|
|
|
|
|
var secret string
|
|
|
|
testutil.RunStep(t, "known establishment secret is accepted", func(t *testing.T) {
|
2022-08-02 16:20:07 -06:00
|
|
|
// First write the establishment secret so that it can be exchanged
|
2022-08-08 01:41:00 -06:00
|
|
|
require.NoError(t, store.PeeringSecretsWrite(1, &pbpeering.SecretsWriteRequest{
|
|
|
|
PeerID: testPeerID,
|
|
|
|
Request: &pbpeering.SecretsWriteRequest_GenerateToken{
|
|
|
|
GenerateToken: &pbpeering.SecretsWriteRequest_GenerateTokenRequest{
|
|
|
|
EstablishmentSecret: testEstablishmentSecretID,
|
|
|
|
},
|
2022-08-01 10:33:18 -04:00
|
|
|
},
|
|
|
|
}))
|
2022-08-02 16:20:07 -06:00
|
|
|
|
|
|
|
// Exchange the now-valid establishment secret for a stream secret
|
2022-08-01 10:33:18 -04:00
|
|
|
resp, err := srv.ExchangeSecret(context.Background(), &pbpeerstream.ExchangeSecretRequest{
|
|
|
|
PeerID: testPeerID,
|
|
|
|
EstablishmentSecret: testEstablishmentSecretID,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEmpty(t, resp.StreamSecret)
|
|
|
|
|
|
|
|
secret = resp.StreamSecret
|
|
|
|
})
|
|
|
|
|
|
|
|
testutil.RunStep(t, "pending secret is persisted to server", func(t *testing.T) {
|
|
|
|
s, err := store.PeeringSecretsRead(nil, testPeerID)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
require.Equal(t, secret, s.GetStream().GetPendingSecretID())
|
|
|
|
})
|
|
|
|
}
|