mirror of
https://github.com/pomerium/pomerium.git
synced 2025-04-30 02:46:30 +02:00
* update tracing config definitions * new tracing system * performance improvements * only configure tracing in envoy if it is enabled in pomerium * [tracing] refactor to use custom extension for trace id editing (#5420) refactor to use custom extension for trace id editing * set default tracing sample rate to 1.0 * fix proxy service http middleware * improve some existing auth related traces * test fixes * bump envoyproxy/go-control-plane * code cleanup * test fixes * Fix missing spans for well-known endpoints * import extension apis from pomerium/envoy-custom
40 lines
834 B
Go
40 lines
834 B
Go
package snippets
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/pomerium/pomerium/internal/log"
|
|
"github.com/pomerium/pomerium/internal/testenv"
|
|
)
|
|
|
|
func RunWithDelayedShutdown(ctx context.Context, serve func() error, stop func()) func() error {
|
|
env := testenv.EnvFromContext(ctx)
|
|
|
|
stopping := make(chan struct{})
|
|
serveExited := make(chan error, 1)
|
|
env.OnStateChanged(testenv.Stopping, func() {
|
|
close(stopping)
|
|
})
|
|
cancel := env.OnStateChanged(testenv.Stopped, func() {
|
|
stop()
|
|
if err := <-serveExited; err != nil && !errors.Is(err, http.ErrServerClosed) {
|
|
log.Ctx(ctx).Err(err).Msg("error stopping server")
|
|
}
|
|
})
|
|
go func() {
|
|
serveExited <- serve()
|
|
close(serveExited)
|
|
}()
|
|
|
|
return func() error {
|
|
select {
|
|
case <-stopping:
|
|
return nil
|
|
case err := <-serveExited:
|
|
cancel()
|
|
return err
|
|
}
|
|
}
|
|
}
|