testutil

package
v0.6.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 3, 2026 License: MIT Imports: 27 Imported by: 0

Documentation

Overview

Package testutil provides shared test utilities for Melange integration tests.

Package testutil provides shared test utilities for Melange integration tests.

Package testutil provides shared test utilities for Melange integration tests.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Checker

func Checker(db *sql.DB) *melange.Checker

Checker returns a new Checker connected to the given database.

func DB

func DB(tb testing.TB) *sql.DB

DB returns a fully migrated database connection for testing. Each call creates a new isolated database copied from the template. The database is automatically cleaned up when the test completes. Works with both *testing.T and *testing.B.

If DATABASE_URL environment variable is set, connects to remote database instead.

func DomainTablesSQL

func DomainTablesSQL() string

DomainTablesSQL returns the embedded SQL for creating domain tables.

func EmptyDB

func EmptyDB(tb testing.TB) *sql.DB

EmptyDB returns an empty database connection for testing. Each call creates a new isolated empty database. The database is automatically cleaned up when the test completes. Works with both *testing.T and *testing.B.

func SchemaFGA

func SchemaFGA() string

SchemaFGA returns the embedded FGA schema used for tests.

func TuplesViewSQL

func TuplesViewSQL() string

TuplesViewSQL returns the embedded SQL for creating the tuples view.

Types

type BulkFixtures added in v0.6.0

type BulkFixtures struct {
	// contains filtered or unexported fields
}

BulkFixtures provides factory functions for creating test data using PostgreSQL COPY FROM. This is 10-100x faster than batch INSERTs for large datasets.

func NewBulkFixtures added in v0.6.0

func NewBulkFixtures(ctx context.Context, db *sql.DB) *BulkFixtures

NewBulkFixtures creates a new BulkFixtures instance for bulk data loading via COPY FROM.

func (*BulkFixtures) AddOrganizationMembers added in v0.6.0

func (bf *BulkFixtures) AddOrganizationMembers(orgID int64, userIDs []int64, role string) error

AddOrganizationMembers adds users to an organization with the specified role using COPY FROM.

func (*BulkFixtures) CreateOrganizations added in v0.6.0

func (bf *BulkFixtures) CreateOrganizations(n int) ([]int64, error)

CreateOrganizations creates n organizations using COPY FROM. Falls back to batch INSERT if COPY fails.

func (*BulkFixtures) CreatePullRequests added in v0.6.0

func (bf *BulkFixtures) CreatePullRequests(repoID int64, authorIDs []int64, n int) ([]int64, error)

CreatePullRequests creates pull requests in the given repository using COPY FROM. Cycles through authorIDs for each PR.

func (*BulkFixtures) CreateRepositories added in v0.6.0

func (bf *BulkFixtures) CreateRepositories(orgID int64, n int) ([]int64, error)

CreateRepositories creates n repositories under an organization using COPY FROM.

func (*BulkFixtures) CreateUsers added in v0.6.0

func (bf *BulkFixtures) CreateUsers(n int) ([]int64, error)

CreateUsers creates n users using COPY FROM for bulk loading. Falls back to batch INSERT if COPY fails.

func (*BulkFixtures) TupleCount added in v0.6.0

func (bf *BulkFixtures) TupleCount() (int, error)

TupleCount returns the current count of tuples in the melange_tuples view.

type DatabaseConfig added in v0.6.0

type DatabaseConfig struct {
	URL            string
	MaxConnections int
	EnablePooling  bool
}

DatabaseConfig holds configuration for connecting to a database.

func GetDatabaseConfig added in v0.6.0

func GetDatabaseConfig() DatabaseConfig

GetDatabaseConfig reads database configuration from environment variables. If DATABASE_URL is set, it returns configuration for a remote database. Otherwise, returns an empty config which signals to use testcontainers.

type Fixtures

type Fixtures struct {
	// contains filtered or unexported fields
}

Fixtures provides factory functions for creating test data in bulk. All functions use batch inserts for efficiency at scale.

func NewFixtures

func NewFixtures(ctx context.Context, db *sql.DB) *Fixtures

NewFixtures creates a new Fixtures instance for bulk data insertion.

func (*Fixtures) AddOrganizationMembers

func (f *Fixtures) AddOrganizationMembers(orgID int64, userIDs []int64, role string) error

AddOrganizationMembers adds users to an organization with the specified role. role must be one of: owner, admin, member, billing_manager

func (*Fixtures) AddRepositoryCollaborators

func (f *Fixtures) AddRepositoryCollaborators(repoID int64, userIDs []int64, role string) error

AddRepositoryCollaborators adds users as collaborators to a repository. role must be one of: owner, admin, maintainer, writer, reader

func (*Fixtures) AddTeamMembers

func (f *Fixtures) AddTeamMembers(teamID int64, userIDs []int64, role string) error

AddTeamMembers adds users to a team with the specified role. role must be one of: maintainer, member

func (*Fixtures) CreateIssues

func (f *Fixtures) CreateIssues(repoID int64, authorIDs []int64, n int) ([]int64, error)

CreateIssues creates issues in the given repository. Cycles through authorIDs for each issue.

func (*Fixtures) CreateOrganization

func (f *Fixtures) CreateOrganization(name string) (int64, error)

CreateOrganization creates a single organization and returns its ID.

func (*Fixtures) CreateOrganizations

func (f *Fixtures) CreateOrganizations(n int) ([]int64, error)

CreateOrganizations creates n organizations and returns their IDs.

func (*Fixtures) CreatePullRequests

func (f *Fixtures) CreatePullRequests(repoID int64, authorIDs []int64, n int) ([]int64, error)

CreatePullRequests creates pull requests in the given repository. Cycles through authorIDs for each PR.

func (*Fixtures) CreateRepositories

func (f *Fixtures) CreateRepositories(orgID int64, n int) ([]int64, error)

CreateRepositories creates n repositories under an organization and returns their IDs.

func (*Fixtures) CreateTeams

func (f *Fixtures) CreateTeams(orgID int64, n int) ([]int64, error)

CreateTeams creates n teams in an organization and returns their IDs.

func (*Fixtures) CreateUsers

func (f *Fixtures) CreateUsers(n int) ([]int64, error)

CreateUsers creates n users and returns their IDs.

func (*Fixtures) TupleCount

func (f *Fixtures) TupleCount() (int, error)

TupleCount returns the current count of tuples in the melange_tuples view.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL