我正在try 为我的Postgres数据库编写集成测试.为此,我在Go中使用了测试容器.我已经在我的实际数据库中使用了TERN迁移,并将迁移放在Migrations文件夹中.问题是我的一些迁移使用.tern.conf文件中的属性,因为这些值可能会因环境而异.我为local创建了一个与local.tern.conf类似的配置文件,并try 设置全局变量.但由于某些原因,当我运行迁移时,没有 Select 这些值.下面是一个例子--

func SetupTestDatabase() *TestDatabase {
    // Set the TERN_CONFIG environment variable to the path of your local.tern.conf file
    if err := os.Setenv("TERN_CONFIG", "../local.tern.conf"); err != nil {
        // Handle error if setting the environment variable fails
        zap.S().Fatal("failed to set TERN_CONFIG", err)
    }

    // setup db container
    ctx, cancel := context.WithTimeout(context.Background(), time.Second*60)
    defer cancel()

    container, dbInstance, dbAddr, err := createContainer(ctx)
    if err != nil {
        zap.S().Fatal("failed to setup test", err)
    }

    conn, _ := dbInstance.Acquire(ctx)
    m, err := migrate.NewMigrator(ctx, conn.Conn(), "schema_version_table")
    if err != nil {
        zap.S().Fatal("failed to setup migrator", err)
    }

    if err := m.LoadMigrations("../migrations"); err != nil {
        zap.S().Fatal("failed to load migrations", err)
        return nil
    }

    if len(m.Migrations) == 0 {
        zap.S().Fatal("no migrations found")
        return nil
    }

    if err := m.Migrate(ctx); err != nil {
        zap.S().Fatal("failed to migrate", err)
        return nil
    }

    return &TestDatabase{
        container:  container,
        DbInstance: dbInstance,
        DbAddress:  dbAddr,
    }
}

这是我迁徙的一部分-

....
CREATE TABLE {{.version_table}} (
    version integer NOT NULL
);

alter table {{.version_table}}
    owner to {{.master_user}};
.....

这里是本地.tern.conf-

[database]
 host = <host>
 port = 5432
 database = <db name>
 version_table = schema_version_table

[data]
 master_user = <user>

推荐答案

我猜配置文件一定是针对由testtainers-go提供的随机端口,而不是针对postgres的默认5432端口.您可能需要动态生成该文件,从测试容器获取主机和随机端口-使用容器的HostMappedPort方法.请参阅https://golang.testcontainers.org/features/networking/#getting-the-container-host

ip, _ := nginxC.Host(ctx)
port, _ := nginxC.MappedPort(ctx, "80")
_, _ = http.Get(fmt.Sprintf("http://%s:%s", ip, port.Port()))

你能试一试吗?

另一种 Select 是使用"TestContainers Desktop",它允许为给定的服务(Postgres)定义端口,以透明的方式将对该端口的任何请求代理到随机请求.请参阅https://knowledge.testcontainers.cloud/fixed-ports

现在,您可以配置TestContainers桌面应用程序,将这些随机端口也代理到您机器上的固定端口,以调试TestContainers服务.要这样做,只需点击"服务"子菜单中的"打开配置位置"即可.然后,您可以克隆样例配置文件并将其重命名为my-service.toml,其中"my-service"是您的服务的实际名称,最后 Select 一个应该始终可用于调试服务的固定端口.保存文件后,会自动检测并重新加载该文件.

Postgresql相关问答推荐

如何在gorm中创建一个可读但不可写的字段

Postgres SQL执行加入

PostgreSQL:函数结果表内冲突(...)上的";中的字段名称

PostgreSQL:重新创建主键值以匹配记录计数

在插入时创建一个触发器,在PostgreSQL中的另一个表上创建另一个触发器

在Postgres游标中从一行变量中减go 另一行变量

PostGresql :正则表达式 Select 其中只有一个正斜杠的行

在特定距离内创建点的唯一索引

EF Core添加迁移目标postgreeSQL返回无法加载类型'Microsoft.EntityFrameworkCore.Storage.IRelationalValueBufferFactoryFactory

将数组插入 Postgresql 数据库

PG::TRDeadlockDetected:ERROR: deadlock detected

我如何在docker中备份数据库

如何防止用户看到其他数据库和其他数据库中的表?

Sidekiq - 无法在 5.000 秒内获得数据库连接

避免 created_at 和 updated_at 由 sequelize 自动生成

将主键更改为自动递增

Postgres 类似于 SQL Server 中的 CROSS APPLY

如何将主键添加到视图?

Hibernate 启动很慢

如何缩小 pg_toast 表?