schangxiang@126.com
2025-06-13 f10d68fe7b934ba7ad8e8393f36f20878ed8155d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
  assert that data is called many times
  assert that end is called eventually
 
  assert that when stream enters pause state,
  on drain is emitted eventually.
*/
 
var es = require('..')
var it = require('it-is').style('colour')
var spec = require('stream-spec')
 
exports['simple stream'] = function (test) {
 
  var stream = es.through()
  var x = spec(stream).basic().pausable()
 
  stream.write(1)
  stream.write(1)
  stream.pause()
  stream.write(1)
  stream.resume()
  stream.write(1)
  stream.end(2) //this will call write()
 
  process.nextTick(function (){
    x.validate()
    test.done()
  }) 
}
 
exports['throw on write when !writable'] = function (test) {
 
  var stream = es.through()
  var x = spec(stream).basic().pausable()
 
  stream.write(1)
  stream.write(1)
  stream.end(2) //this will call write()
  stream.write(1) //this will be throwing..., but the spec will catch it.
 
  process.nextTick(function () {
    x.validate()
    test.done()
  })
  
}
 
exports['end fast'] = function (test) {
 
  var stream = es.through()
  var x = spec(stream).basic().pausable()
 
  stream.end() //this will call write()
 
  process.nextTick(function () {
    x.validate()
    test.done()
  })
  
}
 
 
/*
  okay, that was easy enough, whats next?
 
  say, after you call paused(), write should return false
  until resume is called.
 
  simple way to implement this:
    write must return !paused
  after pause() paused = true
  after resume() paused = false
 
  on resume, if !paused drain is emitted again.
  after drain, !paused
 
  there are lots of subtle ordering bugs in streams.
 
  example, set !paused before emitting drain.
 
  the stream api is stateful. 
*/
 
 
require('./helper')(module)