我想运行一个小的Postgresql数据库,在内存中运行,对于我写的每个单元测试。例如:
@Before void setUp() { String port = runPostgresOnRandomPort(); connectTo("postgres://localhost:"+port+"/in_memory_db"); // ... }
理想情况下,我将有一个postgres可执行文件检入版本控制,单元测试将使用。
类似于Hsql,但是对于postgres。我怎样才能做到这一点?
我能得到这样的Postgres版本吗?我如何指示它不使用磁盘?
这是不可能与Postgres。它不提供像HsqlDB或MysqL这样的进程内/内存引擎。
如果你想创建一个自包含的环境,你可以把Postgres二进制SVN(但它不仅仅是一个可执行文件)。
您需要运行initdb来设置测试数据库,然后才能对此进行任何操作。这可以从批处理文件或通过使用Runtime.exec()。但是请注意,initdb不是快速的。你绝对不想为每个测试运行它。你可能会逃避在你的测试套件之前运行这个。
原文地址:https://www.jb51.cc/postgresql/193660.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。