2021-01-28 16:16:05 +01:00
|
|
|
package aggregator
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/traefik/traefik/v2/pkg/config/dynamic"
|
|
|
|
"github.com/traefik/traefik/v2/pkg/provider"
|
|
|
|
"github.com/traefik/traefik/v2/pkg/safe"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestProviderAggregator_Provide(t *testing.T) {
|
|
|
|
aggregator := ProviderAggregator{
|
|
|
|
internalProvider: &providerMock{"internal"},
|
|
|
|
fileProvider: &providerMock{"file"},
|
|
|
|
providers: []provider.Provider{
|
|
|
|
&providerMock{"salad"},
|
|
|
|
&providerMock{"tomato"},
|
|
|
|
&providerMock{"onion"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
cfgCh := make(chan dynamic.Message)
|
|
|
|
errCh := make(chan error)
|
|
|
|
pool := safe.NewPool(context.Background())
|
|
|
|
|
|
|
|
t.Cleanup(pool.Stop)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
errCh <- aggregator.Provide(cfgCh, pool)
|
|
|
|
}()
|
|
|
|
|
2021-02-25 17:20:04 +01:00
|
|
|
// Make sure the file provider is always called first.
|
2021-02-01 12:36:03 +01:00
|
|
|
requireReceivedMessageFromProviders(t, cfgCh, []string{"file"})
|
2021-01-28 16:16:05 +01:00
|
|
|
|
|
|
|
// Check if all providers have been called, the order doesn't matter.
|
2021-02-25 17:20:04 +01:00
|
|
|
requireReceivedMessageFromProviders(t, cfgCh, []string{"salad", "tomato", "onion", "internal"})
|
2021-01-28 16:16:05 +01:00
|
|
|
|
|
|
|
require.NoError(t, <-errCh)
|
|
|
|
}
|
|
|
|
|
|
|
|
// requireReceivedMessageFromProviders makes sure the given providers have emitted a message on the given message channel.
|
|
|
|
// Providers order is not enforced.
|
|
|
|
func requireReceivedMessageFromProviders(t *testing.T, cfgCh <-chan dynamic.Message, names []string) {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
var msg dynamic.Message
|
|
|
|
var receivedMessagesFrom []string
|
|
|
|
|
|
|
|
for range names {
|
|
|
|
select {
|
2021-03-08 09:58:04 +01:00
|
|
|
case <-time.After(100 * time.Millisecond):
|
|
|
|
require.Fail(t, "Timeout while waiting for configuration.")
|
2021-01-28 16:16:05 +01:00
|
|
|
case msg = <-cfgCh:
|
|
|
|
receivedMessagesFrom = append(receivedMessagesFrom, msg.ProviderName)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
require.ElementsMatch(t, names, receivedMessagesFrom)
|
|
|
|
}
|
|
|
|
|
|
|
|
type providerMock struct {
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *providerMock) Init() error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *providerMock) Provide(configurationChan chan<- dynamic.Message, pool *safe.Pool) error {
|
|
|
|
configurationChan <- dynamic.Message{
|
|
|
|
ProviderName: p.Name,
|
|
|
|
Configuration: &dynamic.Configuration{},
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|