文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

在带有 postgres 的 go test 容器中使用 tern 迁移

2024-02-06 12:38

关注

问题内容

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

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}};
.....

这是 local.tern.conf-

[database]
 host = 
 port = 5432
 database = 
 version_table = schema_version_table

[data]
 master_user = 


正确答案


我猜配置文件必须针对 testcontainers-go 提供的随机端口,而不是 Postgres 的默认 5432 端口。您可能需要使用容器的 HostMappedPort 方法动态生成该文件,从 testcontainers-go 获取主机和随机端口。请参阅 https://golang.testcontainers.org/features/networking /#获取容器主机

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

你能尝试一下吗?

另一种选择是使用“Testcontainers Desktop”,它允许定义给定服务(postgres)的端口,以透明的方式将对该端口的任何请求代理到随机端口。请参阅https://www.php.cn/link/9a4d6e8685bd057e4f68930bd7c8ecc0

以上就是在带有 postgres 的 go test 容器中使用 tern 迁移的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯