opentelemetry-collector/extension/zpagesextension/zpagesextension_test.go

155 lines
4.3 KiB
Go

// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
package zpagesextension
import (
"context"
"net"
"net/http"
"runtime"
"testing"
"github.com/stretchr/testify/require"
sdktrace "go.opentelemetry.io/otel/sdk/trace"
"go.opentelemetry.io/otel/trace"
"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/component/componenttest"
"go.opentelemetry.io/collector/config/configauth"
"go.opentelemetry.io/collector/config/confighttp"
"go.opentelemetry.io/collector/internal/testutil"
)
type zpagesHost struct {
component.Host
}
func newZPagesHost() *zpagesHost {
return &zpagesHost{Host: componenttest.NewNopHost()}
}
func (*zpagesHost) RegisterZPages(*http.ServeMux, string) {}
var (
_ registerableTracerProvider = (*registerableProvider)(nil)
_ registerableTracerProvider = sdktrace.NewTracerProvider()
)
type registerableProvider struct {
trace.TracerProvider
}
func (*registerableProvider) RegisterSpanProcessor(sdktrace.SpanProcessor) {}
func (*registerableProvider) UnregisterSpanProcessor(sdktrace.SpanProcessor) {}
func newZpagesTelemetrySettings() component.TelemetrySettings {
set := componenttest.NewNopTelemetrySettings()
set.TracerProvider = &registerableProvider{set.TracerProvider}
return set
}
func TestZPagesExtensionUsage(t *testing.T) {
cfg := &Config{
confighttp.ServerConfig{
Endpoint: testutil.GetAvailableLocalAddress(t),
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.NotNil(t, zpagesExt)
require.NoError(t, zpagesExt.Start(context.Background(), newZPagesHost()))
t.Cleanup(func() { require.NoError(t, zpagesExt.Shutdown(context.Background())) })
// Give a chance for the server goroutine to run.
runtime.Gosched()
_, zpagesPort, err := net.SplitHostPort(cfg.ServerConfig.Endpoint)
require.NoError(t, err)
client := &http.Client{}
resp, err := client.Get("http://localhost:" + zpagesPort + "/debug/tracez")
require.NoError(t, err)
defer resp.Body.Close()
require.Equal(t, http.StatusOK, resp.StatusCode)
}
func TestZPagesExtensionBadAuthExtension(t *testing.T) {
cfg := &Config{
confighttp.ServerConfig{
Endpoint: "localhost:0",
Auth: &confighttp.AuthConfig{
Authentication: configauth.Authentication{
AuthenticatorID: component.MustNewIDWithName("foo", "bar"),
},
},
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.EqualError(t, zpagesExt.Start(context.Background(), componenttest.NewNopHost()), `failed to resolve authenticator "foo/bar": authenticator not found`)
}
func TestZPagesExtensionPortAlreadyInUse(t *testing.T) {
endpoint := testutil.GetAvailableLocalAddress(t)
ln, err := net.Listen("tcp", endpoint)
require.NoError(t, err)
defer ln.Close()
cfg := &Config{
confighttp.ServerConfig{
Endpoint: endpoint,
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.NotNil(t, zpagesExt)
require.Error(t, zpagesExt.Start(context.Background(), componenttest.NewNopHost()))
}
func TestZPagesMultipleStarts(t *testing.T) {
cfg := &Config{
confighttp.ServerConfig{
Endpoint: testutil.GetAvailableLocalAddress(t),
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.NotNil(t, zpagesExt)
require.NoError(t, zpagesExt.Start(context.Background(), componenttest.NewNopHost()))
t.Cleanup(func() { require.NoError(t, zpagesExt.Shutdown(context.Background())) })
// Try to start it again, it will fail since it is on the same endpoint.
require.Error(t, zpagesExt.Start(context.Background(), componenttest.NewNopHost()))
}
func TestZPagesMultipleShutdowns(t *testing.T) {
cfg := &Config{
confighttp.ServerConfig{
Endpoint: testutil.GetAvailableLocalAddress(t),
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.NotNil(t, zpagesExt)
require.NoError(t, zpagesExt.Start(context.Background(), componenttest.NewNopHost()))
require.NoError(t, zpagesExt.Shutdown(context.Background()))
require.NoError(t, zpagesExt.Shutdown(context.Background()))
}
func TestZPagesShutdownWithoutStart(t *testing.T) {
cfg := &Config{
confighttp.ServerConfig{
Endpoint: testutil.GetAvailableLocalAddress(t),
},
}
zpagesExt := newServer(cfg, newZpagesTelemetrySettings())
require.NotNil(t, zpagesExt)
require.NoError(t, zpagesExt.Shutdown(context.Background()))
}