Fixes postgres flaky test (#3822)

* Changes expected error code

* nits
This commit is contained in:
Florent Vilmart
2017-05-16 12:06:17 -04:00
committed by Arthur Cinader
parent ab04641ed0
commit 9dbb89a2e4
3 changed files with 21 additions and 11 deletions

View File

@@ -1,7 +1,7 @@
const Parse = require('parse/node').Parse;
const PostgresStorageAdapter = require('../src/Adapters/Storage/Postgres/PostgresStorageAdapter');
const postgresURI = 'postgres://localhost:5432/parse_server_postgres_adapter_test_database';
const Config = require('../src/Config');
//public schema
const databaseOptions1 = {
initOptions: {
@@ -28,33 +28,40 @@ const GameScore = Parse.Object.extend({
className: "GameScore"
});
describe('Postgres database init options', () => {
describe_only_db('postgres')('Postgres database init options', () => {
it('should create server with public schema databaseOptions', (done) => {
const config = new Config('test');
// Close the current DB before continueing
config.database.adapter._pgp.end();
reconfigureServer({
databaseAdapter: new PostgresStorageAdapter({
uri: postgresURI, collectionPrefix: 'test_',
databaseOptions: databaseOptions1
})
}).then(done, fail);
}).then(done, done.fail);
});
it("save new GameScore in public schema", function (done) {
var score = new GameScore({ "score": 1337, "playerName": "Sean Plott", "cheatMode": false });
score.save().then(done, fail);
score.save().then(done, done.fail);
});
it('should fail to create server if schema databaseOptions does not exist', (done) => {
const config = new Config('test');
// Close the current DB before continueing
config.database.adapter._pgp.end();
reconfigureServer({
databaseAdapter: new PostgresStorageAdapter({
uri: postgresURI, collectionPrefix: 'test_',
databaseOptions: databaseOptions2
})
}).then(() => {
done.fail('Should not succeed');
}, error => {
// INVALID_SCHEMA error 3F000
// https://www.postgresql.org/docs/9.5/static/errcodes-appendix.html
expect(error.code).toEqual('3F000');
done();
})
.catch(error => {
expect(error.code).toEqual('42P01');
done();
});
});
});
});

View File

@@ -23,5 +23,5 @@ export function createClient(uri, databaseOptions) {
}
}
return client;
return { client, pgp };
}

View File

@@ -403,6 +403,7 @@ export class PostgresStorageAdapter {
// Private
_collectionPrefix: string;
_client;
_pgp;
constructor({
uri,
@@ -410,7 +411,9 @@ export class PostgresStorageAdapter {
databaseOptions
}) {
this._collectionPrefix = collectionPrefix;
this._client = createClient(uri, databaseOptions);
const { client, pgp } = createClient(uri, databaseOptions);
this._client = client;
this._pgp = pgp;
}
_ensureSchemaCollectionExists(conn) {