now wating correctly for mongo by checking logMessage

This commit is contained in:
2016-09-12 14:45:08 +02:00
parent ee3c3580d3
commit 50a6a1a690
2 changed files with 37 additions and 16 deletions

View File

@@ -1,36 +1,46 @@
import 'typings-test'
import * as shelljs from 'shelljs'
import * as should from 'should'
import * as smartdata from '../dist/index'
// the tested module
import * as smartdata from '../dist/index'
let mongoChildProcess
let testDbConnection: smartdata.DbConnection
let testDbCollection: smartdata.DbCollection<any>
describe('mongodb',function(){
it('should start mongodb',function(done){
describe('mongodb', function () {
it('should start mongodb', function (done) {
this.timeout(10000)
mongoChildProcess = shelljs.exec('mongod --dbpath=./test/data --port 27017',{async: true})
setTimeout(() => { done() }, 5000) // give mongodb it some time to complete startup
mongoChildProcess = shelljs.exec('mongod --dbpath=./test/data --port 27017', { async: true, silent: true })
let doneCalled = false
mongoChildProcess.stdout.on('data', function(data) {
console.log(data)
if (!doneCalled){
if (/waiting for connections on port 27017/.test(data)) {
doneCalled = true
done()
}
}
})
})
})
describe('smartdata',function(){
it('should establish a connection to mongodb',function(done){
describe('smartdata', function () {
it('should establish a connection to mongodb', function (done) {
testDbConnection = new smartdata.DbConnection('mongodb://localhost:27017/smartdata')
testDbConnection.connect().then(() => { done() })
})
it('should create a collection',function(){
testDbCollection = new smartdata.DbCollection('something',testDbConnection)
it('should create a collection', function () {
testDbCollection = new smartdata.DbCollection('something', testDbConnection)
})
it('should close the db Connection',function(){
it('should close the db Connection', function () {
testDbConnection.close()
})
})
describe('mongodb',function(){
it('should kill mongodb',function(){
describe('mongodb', function () {
it('should kill mongodb', function () {
this.timeout(10000)
shelljs.exec('mongod --dbpath=./test/data --shutdown')
mongoChildProcess.kill('SIGTERM')