summaryrefslogtreecommitdiffstats
path: root/testing/mozbase/mozrunner/tests/test_interactive.py
blob: fe83bf80ee2bb553c2e5797ae7e9c9cdd9d6529d (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
#!/usr/bin/env python

import threading
from time import sleep

import mozrunnertest


class RunnerThread(threading.Thread):

    def __init__(self, runner, timeout=10):
        threading.Thread.__init__(self)
        self.runner = runner
        self.timeout = timeout

    def run(self):
        sleep(self.timeout)
        self.runner.stop()


class MozrunnerInteractiveTestCase(mozrunnertest.MozrunnerTestCase):

    def test_run_interactive(self):
        """Bug 965183: Run process in interactive mode and call wait()"""
        pid = self.runner.start(interactive=True)
        self.pids.append(pid)

        thread = RunnerThread(self.runner, 5)
        self.threads.append(thread)
        thread.start()

        # This is a blocking call. So the process should be killed by the thread
        self.runner.wait()
        thread.join()
        self.assertFalse(self.runner.is_running())

    def test_stop_interactive(self):
        """Bug 965183: Explicitely stop process in interactive mode"""
        pid = self.runner.start(interactive=True)
        self.pids.append(pid)

        self.runner.stop()

    def test_wait_after_process_finished(self):
        """Wait after the process has been stopped should not raise an error"""
        self.runner.start(interactive=True)
        sleep(5)
        self.runner.process_handler.kill()

        returncode = self.runner.wait(1)

        self.assertNotIn(returncode, [None, 0])
        self.assertIsNotNone(self.runner.process_handler)