Documentation ¶
Overview ¶
Package rivertest contains shared testing utilities for tests throughout the rest of the project.
Index ¶
- func BaseServiceArchetype(tb testing.TB) *baseservice.Archetype
- func DatabaseConfig(databaseName string) *pgxpool.Config
- func DiscardContinuously[T any](drainChan <-chan T) func()
- func DrainContinuously[T any](drainChan <-chan T) func() []T
- func Logger(tb testing.TB) *slog.Logger
- func LoggerWarn(tb testing.TB) *slog.Logger
- func StubTime(archetype *baseservice.Archetype, t time.Time) time.Time
- func TestDB(ctx context.Context, tb testing.TB) *pgxpool.Pool
- func TestTx(ctx context.Context, tb testing.TB) pgx.Tx
- func WaitOrTimeout[T any](t *testing.T, waitChan <-chan T) T
- func WrapTestMain(m *testing.M)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func BaseServiceArchetype ¶
func BaseServiceArchetype(tb testing.TB) *baseservice.Archetype
BaseServiceArchetype returns a new base service suitable for use in tests. Returns a new instance so that it's not possible to accidentally taint a shared object.
func DatabaseConfig ¶
func DiscardContinuously ¶
func DiscardContinuously[T any](drainChan <-chan T) func()
DiscardContinuously drains continuously out of the given channel and discards anything that comes out of it. Returns a stop function that should be invoked to stop draining. Stop must be invoked before tests finish to stop an internal goroutine.
func DrainContinuously ¶
func DrainContinuously[T any](drainChan <-chan T) func() []T
DrainContinuously drains continuously out of the given channel and accumulates items that are received from it. Returns a get function that can be called to retrieve the current set of received items, and which will also cause the function to shut down and stop draining. This function must be invoked before tests finish to stop an internal goroutine. It's safe to call it multiple times.
func LoggerWarn ¶
Logger returns a logger suitable for use in tests which outputs only at warn or above. Useful in tests where particularly noisy log output is expected.
func StubTime ¶
StubTime is a shortcut for stubbing time for a the given archetype at the given time. It returns the time given as argument for convenience.
func TestDB ¶
TestDB acquires a dedicated test database for the duration of the test. If an error occurs, the test fails. The test database will be automatically returned to the pool at the end of the test and the pgxpool will be closed.
func TestTx ¶
TestTx starts a test transaction that's rolled back automatically as the test case is cleaning itself up. This can be used as a lighter weight alternative to `testdb.Manager` in components where it's not necessary to have many connections open simultaneously.
func WaitOrTimeout ¶
WaitOrTimeout tries to wait on the given channel for a value to come through, and returns it if one does, but times out after a reasonable amount of time. Useful to guarantee that test cases don't hang forever, even in the event of something wrong.
func WrapTestMain ¶
WrapTestMain performs some common setup and teardown that should be shared amongst all packages. e.g. Configures a manager for test databases on setup, and checks for no goroutine leaks on teardown.
Types ¶
This section is empty.