summaryrefslogtreecommitdiffstats
path: root/toolkit/components/backgroundtasks/tests/xpcshell/test_backgroundtask_no_output.js
blob: 59712c6ce1c7cec7742490ef4492e2695c65ff18 (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
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*-
 * vim: sw=4 ts=4 sts=4 et
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

// Run a background task which itself waits for a launched background task,
// which itself waits for a launched background task, etc.  Verify no output is
// produced.
add_task(async function test_backgroundtask_no_output() {
  let sentinel = Services.uuid.generateUUID().toString();
  sentinel = sentinel.substring(1, sentinel.length - 1);

  let count = 2;
  let outputLines = [];
  let exitCode = await do_backgroundtask("no_output", {
    extraArgs: [sentinel, count.toString()],
    // This is a misnomer: stdout is redirected to stderr, so this is _any_
    // output line.
    onStdoutLine: line => outputLines.push(line),
  });
  Assert.equal(0, exitCode);

  Assert.deepEqual([], outputLines);
});

// Run a background task which itself waits for a launched background task,
// which itself waits for a launched background task, etc.  Since we ignore the
// no output restriction, verify that output is produced.
add_task(async function test_backgroundtask_ignore_no_output() {
  let sentinel = Services.uuid.generateUUID().toString();
  sentinel = sentinel.substring(1, sentinel.length - 1);

  let count = 2;
  let outputLines = [];
  let exitCode = await do_backgroundtask("no_output", {
    extraArgs: [sentinel, count.toString()],
    extraEnv: { MOZ_BACKGROUNDTASKS_IGNORE_NO_OUTPUT: "1" },
    // This is a misnomer: stdout is redirected to stderr, so this is _any_
    // output line.
    onStdoutLine: line => {
      if (line.includes(sentinel)) {
        outputLines.push(line);
      }
    },
  });
  Assert.equal(0, exitCode);

  Assert.equal(count, outputLines.length);
});