2023-03-28 19:39:22 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 19:39:22 +01:00
|
|
|
|
2022-07-12 11:34:14 +01:00
|
|
|
package proxycfgglue
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
|
|
|
"github.com/hashicorp/consul/agent/proxycfg"
|
|
|
|
)
|
|
|
|
|
2022-07-22 11:52:05 +01:00
|
|
|
func indexGenerator() func() uint64 {
|
|
|
|
var idx uint64
|
|
|
|
return func() uint64 {
|
|
|
|
idx++
|
|
|
|
return idx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-12 11:34:14 +01:00
|
|
|
func getEventResult[ResultType any](t *testing.T, eventCh <-chan proxycfg.UpdateEvent) ResultType {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
select {
|
|
|
|
case event := <-eventCh:
|
|
|
|
require.NoError(t, event.Err, "event should not have an error")
|
|
|
|
result, ok := event.Result.(ResultType)
|
|
|
|
require.Truef(t, ok, "unexpected result type: %T", event.Result)
|
|
|
|
return result
|
|
|
|
case <-time.After(100 * time.Millisecond):
|
|
|
|
t.Fatal("timeout waiting for event")
|
|
|
|
}
|
|
|
|
|
|
|
|
panic("this should never be reached")
|
|
|
|
}
|
|
|
|
|
|
|
|
func expectNoEvent(t *testing.T, eventCh <-chan proxycfg.UpdateEvent) {
|
|
|
|
select {
|
|
|
|
case <-eventCh:
|
|
|
|
t.Fatal("expected no event")
|
|
|
|
case <-time.After(100 * time.Millisecond):
|
|
|
|
}
|
|
|
|
}
|
2022-07-12 11:41:29 +01:00
|
|
|
|
|
|
|
func getEventError(t *testing.T, eventCh <-chan proxycfg.UpdateEvent) error {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
select {
|
|
|
|
case event := <-eventCh:
|
|
|
|
require.Error(t, event.Err)
|
|
|
|
return event.Err
|
|
|
|
case <-time.After(100 * time.Millisecond):
|
|
|
|
t.Fatal("timeout waiting for event")
|
|
|
|
}
|
|
|
|
|
|
|
|
panic("this should never be reached")
|
|
|
|
}
|