Заблокировал это метод в чай - PullRequest
0 голосов
/ 10 декабря 2018

У меня есть файл js, который предоставляет некоторые операции с БД.Этот файл работает только с обещаниями, которые могут быть связаны.Чтобы протестировать этот класс, я работаю с асинхронной функцией.

Проблема в том, что всякий раз, когда я работаю с обещаниями внутри моей тестовой функции, функция it блокируется для каждого другого теста позже.

Вот два примера:

'use strict'

const exec = require('child_process').exec
const path = require('path')
const request = require('request')
const expect = require('chai').expect
const createTableStatements = require('../data')

test()

async function test () {
  await testGetUser()
  console.log('1')
  await testGetFaculties()
}

function testGetUser () {
  return new Promise((resolve1) => {
    describe('test get user', function () {
      const db = require('../dbInterface')
      it('test get user should be complete', function () {
        db.dbFunctions.dropAll()
          .then(onResolve => {
              return db.dbFunctions.createTable(createTableStatements.createTableStatements.user)
            }
          )
          .then(() => {
            console.log('success create user table')
            return db.dbFunctions.addUser('1', 'firstName', 'lastName', 'email')
          })
          .then(resolve => {
            return db.dbFunctions.getUser('email', undefined)
          })
          .then(result => {
            expect(result.toString().includes('dummy')).to.equal(false)
          })
          .then(resolve => {
            return db.dbFunctions.dropAll()
          })
          .then(resolve => {
            console.log('resolve')
            resolve1()
          })
          .catch(err => console.log(err))
      })
    })
  })
}


function testGetFaculties () {
  return new Promise(resolve => {
    describe('test get faculties', function () {

      let db
      before(function () {
        db = require('../dbInterface')
      })
      console.log('displayed')
      it('should work', function () {
        console.log('locked')
        expect(db.dbFunctions.getFaculties('hsa')).to.be.an('array').that.does.include('Science')
        resolve()
      })
    })
  })
}

И это вывод

resolve
1
displayed

Как видите, console.log('locked') не обрабатывается.Что я понял до сих пор, так это то, что эта проблема возникает только при вызове expect в функции then.Но это необходимо для моих тестов.

Функция test () должна содержать гораздо больше тестов, только для этого вопроса я сократил ее.

И для пояснения: если я только тестирую методы типаtestGetFaculties (), которая не содержит другой цепочки обещаний внутри, работает так, как должна.

Есть идеи, почему это так?

1 Ответ

0 голосов
/ 10 декабря 2018

Скорее всего, console.log( 'locked' ); ничего не делает, потому что ваш предыдущий контрольный пример не был завершен вообще.

Запись describe, it, before внутри Обещания и содержащая невозвращенные Обещания - это то, что вы не должны делать.

Гораздо лучший тестовый пример будет выглядеть так:

'use strict'

const exec = require('child_process').exec
const path = require('path')
const request = require('request')
const expect = require('chai').expect
const createTableStatements = require('../data')

// You use this in both test cases anyway
const db = require('../dbInterface');

describe('test get user', function () {

    it('test get user should be complete', function () {          
        return db
     // ^ returning promise will make sure that the test ends when the promise ends.
            .dbFunctions
            .dropAll()
            .then(onResolve => { ... } )
            ...
      )
    } );

} );

describe('test get faculties', function () {

    it('should work', function () {
        return db
     // ^ returning promise will make sure that the test ends when the promise ends.
           .dbFunctions
           .getFaculties('hsa')
           .then( value => {
               // ^ You actually need to test the value of the resolve promise
               expect( value ).to.be.an('array').that.does.include('Science');
           } )
    } );

} ); 
...