在Heroku上测试Postgre数据库

时间:2018-06-12 11:22:28

标签: javascript node.js postgresql heroku mocha

我目前正在Heroku上使用Swagger构建API,我想尝试端点是否在Postgre数据库中创建正确的条目。但是,一旦我尝试在我的测试环境中连接到Heroku的Postgre,连接就会被拒绝。我认为这是因为在连续集成环境中,heroku创建了一个沙箱,并且不接受与真实dbs的连接。

我尝试按照此处的建议创建备份数据库:https://devcenter.heroku.com/articles/heroku-postgres-backups 但我找不到要访问的信息!

任何帮助表示赞赏!

谢谢。

这是我的代码测试:

'use strict';

var should = require('should');
var request = require('supertest');
var assert = require('assert');
var server = require('../../../app');

var pg = require('pg');
var knex = require('knex')({
  client: 'postgresql',
  connection: process.env.DATABASE_URL

});

describe('controllers', function () {
  describe('testing cenas', function () {
     it('test1', function (done) {

      request(server)
        .get('/hello')
        .set('Accept', 'application/json')
        .expect('Content-Type', /json/)
        .expect(200)
        .end(function (err, res) {

          assert.equal(res.body, 'Hello,Hugo Pereira!');
          done();
        });
    });


  });
});

它出错了:

Unhandled rejection Error: Unable to acquire a connection
    at Client_PG.acquireConnection (/app/node_modules/knex/lib/client.js:332:40)
    at Runner.ensureConnection (/app/node_modules/knex/lib/runner.js:233:24)
    at Runner.run (/app/node_modules/knex/lib/runner.js:47:42)
    at Builder.Target.then (/app/node_modules/knex/lib/interface.js:39:43)
    at testPg (/app/api/controllers/hello_world.js:27:44)
    at swaggerRouter (/app/node_modules/swagger-tools/middleware/swagger-router.js:407:20)
    at swagger_router (/app/node_modules/swagger-node-runner/fittings/swagger_router.js:31:5)
    at Runner.<anonymous> (/app/node_modules/bagpipes/lib/bagpipes.js:171:7)
    at bound (domain.js:301:14)
    at Runner.runBound (domain.js:314:12)
    at Runner.pipeline (/app/node_modules/pipeworks/pipeworks.js:72:17)
    at Runner.flow (/app/node_modules/pipeworks/pipeworks.js:223:19)
    at Pipeworks.flow (/app/node_modules/pipeworks/pipeworks.js:135:17)
    at Pipeworks.siphon (/app/node_modules/pipeworks/pipeworks.js:186:19)
    at Runner.<anonymous> (/app/node_modules/bagpipes/lib/bagpipes.js:98:22)
    at bound (domain.js:301:14)
  0 passing (2s)

3 个答案:

答案 0 :(得分:0)

heroku pg:psql命令应该连接到您的数据库。您还可以传递参数以连接到备用/备份数据库。

答案 1 :(得分:0)

如果您使用的是heroku postgres网址,那么外部访问需要的一件事就是附加到网址的查询字符串?ssl=true

e.g。

"DATABASE_URL" : "postgres://user:pass@ec2-54-235-206-118.compute-1.amazonaws.com:5432/dbid?ssl=true"

答案 2 :(得分:0)

我设法使用heroku In-dyno数据库(https://devcenter.heroku.com/articles/heroku-ci-in-dyno-databases)解决了这个问题。一旦获得数据库,我就进入我的开发环境中的一个端点,该端点使我自己得到了真实数据库模式的转储文件。在测试环境中,我导入该文件,瞧,我拥有测试环境所需的所有架构和表。