测试可读流(在jest中),具有推送值的延迟

时间:2018-02-13 13:00:39

标签: node.js testing stream jest

我试图创建一个可读流,其中数据以突发间隔的方式到达 数据包(如网络读取)。

我在开玩笑时遇到了麻烦。我在下面编写了2个测试。这两个测试中的第一个是有效的(因为它 产生输出到控制台),但第二个失败 - 也就是说,控制台上没有输出。 我也尝试过使用fakeTimers,但似乎没什么区别。任何指针都会受到赞赏。

测试本身没有依赖关系 - 所以代码应该独立运行

const Readable = require('stream').Readable
function sleep(ms) {return new Promise(resolve => setTimeout(resolve, ms))}
const lines = ['line 1\n', 'line 2\nline 3']
function* getIter() {for (let line of lines) {yield line}}

describe ('Iteration', () => {

  it ('read iter values from stream', () => {
    let rs = new Readable, res, iter = getIter()

    while (res = iter.next()) {
      if (res.done) {
        rs.push(null)
        break
      } else {
        rs.push(res.value)
      }
    }
    rs.pipe(process.stdout)
  })

  it ('read iter values from stream with delay', (done) => {
    var rs = new Readable,
        res,
        iter = getIter()

    while (res = iter.next()) {
      if (res.done) {
        sleep(1).then(() => {
          rs.push(null)
        })
        break
      } else {
        sleep(1).then(() => {
          rs.push(res.value)
        })
      }
    }

    sleep(10).then(() => {
      rs.pipe(process.stdout)
      done()
    })
  })
})

0 个答案:

没有答案