browser/devtools/netmonitor/test/sjs_status-codes-test-server.sjs
author Sami Jaktholm <sjakthol@outlook.com>
Mon, 30 Jun 2014 03:09:00 -0400
changeset 199635 5870de152e7151d387c7ee1d5dec6896cf42a47a
parent 149416 70d096ed10f70a8f0133fd82b8f2f279f8e490bd
child 208178 00f079c876f68f618c0d79d3448c4c59430f9368
permissions -rw-r--r--
Bug 872379 - Netmonitor tests SJS: Store a reference to the response timer to avoid garbage collection before the timer fires. Otherwise netmonitor tests timeout waiting for missing responses. r=vp, a=test-only

/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

const { classes: Cc, interfaces: Ci } = Components;

function handleRequest(request, response) {
  response.processAsync();

  let params = request.queryString.split("&");
  let status = params.filter((s) => s.contains("sts="))[0].split("=")[1];

  let timer = Cc["@mozilla.org/timer;1"].createInstance(Ci.nsITimer);
  timer.initWithCallback(() => {
    // to avoid garbage collection
    timer = null;
    switch (status) {
      case "100":
        response.setStatusLine(request.httpVersion, 101, "Switching Protocols");
        break;
      case "200":
        response.setStatusLine(request.httpVersion, 202, "Created");
        break;
      case "300":
        response.setStatusLine(request.httpVersion, 303, "See Other");
        break;
      case "400":
        response.setStatusLine(request.httpVersion, 404, "Not Found");
        break;
      case "500":
        response.setStatusLine(request.httpVersion, 501, "Not Implemented");
        break;
    }
    response.setHeader("Content-Type", "text/plain; charset=utf-8", false);
    response.write("Hello status code " + status + "!");
    response.finish();
  }, 10, Ci.nsITimer.TYPE_ONE_SHOT); // Make sure this request takes a few ms.
}