summaryrefslogtreecommitdiff
path: root/test/simple/test-http-client-race-2.js
blob: 97df9ef547a60a0939460c51f7daec1ae430581a (plain)
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
87
88
89
90
91
92
93
94
95
96
97
98
var common = require('../common');
var assert = require('assert');
var http = require('http');
var url = require("url");

//
// Slight variation on test-http-client-race to test for another race
// condition involving the parsers FreeList used internally by http.Client.
//

var body1_s = "1111111111111111";
var body2_s = "22222";
var body3_s = "3333333333333333333";

var server = http.createServer(function (req, res) {
  var pathname = url.parse(req.url).pathname;

  var body;
  switch (pathname) {
    case "/1": body = body1_s; break;
    case "/2": body = body2_s; break;
    default: body = body3_s;
  };

  res.writeHead(200, { "Content-Type": "text/plain"
                     , "Content-Length": body.length
                     });
  res.end(body);
});
server.listen(common.PORT);

var body1 = "";
var body2 = "";
var body3 = "";

server.addListener("listening", function() {
  var client = http.createClient(common.PORT);

  //
  // Client #1 is assigned Parser #1
  //
  var req1 = client.request("/1")
  req1.end();
  req1.addListener('response', function (res1) {
    res1.setEncoding("utf8");

    res1.addListener('data', function (chunk) {
      body1 += chunk;
    });

    res1.addListener('end', function () {
      //
      // Delay execution a little to allow the "close" event to be processed
      // (required to trigger this bug!)
      //
      setTimeout(function () {
        //
        // The bug would introduce itself here: Client #2 would be allocated the
        // parser that previously belonged to Client #1. But we're not finished
        // with Client #1 yet!
        //
        var client2 = http.createClient(common.PORT);

        //
        // At this point, the bug would manifest itself and crash because the
        // internal state of the parser was no longer valid for use by Client #1.
        //
        var req2 = client.request("/2");
        req2.end();
        req2.addListener('response', function (res2) {
          res2.setEncoding("utf8");
          res2.addListener('data', function (chunk) { body2 += chunk; });
          res2.addListener('end', function () {

            //
            // Just to be really sure we've covered all our bases, execute a
            // request using client2.
            //
            var req3 = client2.request("/3");
            req3.end();
            req3.addListener('response', function (res3) {
              res3.setEncoding("utf8");
              res3.addListener('data', function (chunk) { body3 += chunk });
              res3.addListener('end', function() { server.close(); });
            });
          });
        });
      }, 500);
    });
  });
});

process.addListener("exit", function () {
  assert.equal(body1_s, body1);
  assert.equal(body2_s, body2);
  assert.equal(body3_s, body3);
});