Ejemplo n.º 1
0
    def runTest(self):
        def _check(spa):
            ret = spa.start("aa")

            self.assertEqual(ret, ApplicationStatus.OK)

            self.assertEqual(spa.stdout[0], "Stdout test1")
            self.assertEqual(spa.stdout[1], "Stdout test2")

            self.assertEqual(spa.stderr[0], "Stderr test1")
            self.assertEqual(spa.stderr[1], "Stderr test2")

            ret = spa.start("aaa")
            self.assertEqual(ret, ApplicationStatus.ERROR)

            # Check that stdout/err is reset
            self.assertEqual(len(spa.stdout), 2)
            self.assertEqual(len(spa.stderr), 2)

            # Check that the test log is reset
            self.assertEqual(len(spa.testLog), 1)

            ret = spa.start("aaaa")
            self.assertEqual(ret, ApplicationStatus.CRASHED)

        # Check with stdin as source
        _check(SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "none"]))

        # Now use a temporary file instead
        (_, inputFile) = tempfile.mkstemp()
        _check(SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "none", inputFile], inputFile=inputFile))
        os.remove(inputFile)
Ejemplo n.º 2
0
def test_PersistentApplicationTestPerf(tmp_path):
    def _check(spa):
        try:
            spa.start()

            oldPid = spa.process.pid
            startTime = time.time()

            for i in range(1, 10000):
                spa.runTest("aaa\naaaa")

            stopTime = time.time()
            print("%s execs per second" % (float(10000) / float(stopTime - startTime)))
            newPid = spa.process.pid

            # Make sure we are still in the same process
            assert oldPid == newPid

        finally:
            spa.stop()
    # Check with spfp and stdin as source
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "spfp"],
                                       persistentMode=PersistentMode.SPFP, processingTimeout=3))

    # Check with sigstop and temporary file as source
    inputFile = tmp_path / "input.tmp"
    inputFile.touch()
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "sigstop",
                                                        str(inputFile)],
                                       persistentMode=PersistentMode.SIGSTOP, processingTimeout=3,
                                       inputFile=str(inputFile)))
Ejemplo n.º 3
0
    def runTest(self):
        def _check(spa):
            spa.start()

            oldPid = spa.process.pid
            startTime = time.time()

            for i in range(1, 10000):
                spa.runTest("aaa\naaaa")

            stopTime = time.time()
            print("%s execs per second" % (float(10000) / float(stopTime - startTime)))
            newPid = spa.process.pid

            # Make sure we are still in the same process
            self.assertEqual(oldPid, newPid)

            spa.stop()
        # Check with spfp and stdin as source
        _check(SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "spfp"],
                                           persistentMode=PersistentMode.SPFP, processingTimeout=3))

        # Check with sigstop and temporary file as source
        (_, inputFile) = tempfile.mkstemp()
        _check(SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "sigstop", inputFile],
                                           persistentMode=PersistentMode.SIGSTOP, processingTimeout=3, inputFile=inputFile))
        os.remove(inputFile)
Ejemplo n.º 4
0
    def runTest(self):
        (_, inputFile) = tempfile.mkstemp()
        spa = SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "faulty_sigstop", inputFile],
                                           persistentMode=PersistentMode.SIGSTOP, inputFile=inputFile)

        # Should not throw, instead it should be a no-op
        spa.stop()
        os.remove(inputFile)
Ejemplo n.º 5
0
    def runTest(self):
        (_, inputFile) = tempfile.mkstemp()
        spa = SimplePersistentApplication("python", [os.path.join(TEST_PATH, "test_shell.py"), "faulty_sigstop", inputFile],
                                           persistentMode=PersistentMode.SIGSTOP, inputFile=inputFile)

        with self.assertRaises(RuntimeError):
            spa.start()

        os.remove(inputFile)
Ejemplo n.º 6
0
def test_PersistentApplicationTestStopWithoutStart(tmp_path):
    inputFile = tmp_path / "input.tmp"
    inputFile.touch()
    spa = SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "faulty_sigstop",
                                                       str(inputFile)],
                                      persistentMode=PersistentMode.SIGSTOP, inputFile=str(inputFile))

    # Should not throw, instead it should be a no-op
    spa.stop()
Ejemplo n.º 7
0
def test_PersistentApplicationTestFaultySigstop(tmp_path):
    inputFile = tmp_path / "input.tmp"
    inputFile.touch()
    spa = SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "faulty_sigstop",
                                                       str(inputFile)],
                                      persistentMode=PersistentMode.SIGSTOP, inputFile=str(inputFile))

    with pytest.raises(RuntimeError):
        spa.start()
Ejemplo n.º 8
0
    def runTest(self):
        def _check(spa):
            ret = spa.start()

            # Start shouldn't return anything in persistent mode
            self.assertEqual(ret, None)

            ret = spa.runTest("aaa\naaaa")

            self.assertEqual(ret, ApplicationStatus.OK)

            self.assertEqual(spa.stdout[2], "aaa")
            self.assertEqual(spa.stdout[3], "aaaa")

            ret = spa.runTest("aa\naaa")

            self.assertEqual(ret, ApplicationStatus.OK)

            ret = spa.runTest("aaa\naaaa")
            print(spa.stdout)
            print(spa.stderr)
            self.assertEqual(ret, ApplicationStatus.CRASHED)

            self.assertEqual(len(spa.testLog), 3)

            oldPid = spa.process.pid

            spa.stop()
            spa.start()

            newPid = spa.process.pid

            self.assertNotEqual(oldPid, newPid)

            ret = spa.runTest("aaaaa")

            self.assertEqual(ret, ApplicationStatus.TIMEDOUT)
            self.assertEqual(len(spa.testLog), 1)

        # Check with spfp and stdin as source
        _check(
            SimplePersistentApplication(
                "python", [os.path.join(TEST_PATH, "test_shell.py"), "spfp"],
                persistentMode=PersistentMode.SPFP,
                processingTimeout=2))

        # Check with sigstop and temporary file as source
        (_, inputFile) = tempfile.mkstemp()
        _check(
            SimplePersistentApplication("python", [
                os.path.join(TEST_PATH, "test_shell.py"), "sigstop", inputFile
            ],
                                        persistentMode=PersistentMode.SIGSTOP,
                                        processingTimeout=2,
                                        inputFile=inputFile))
        os.remove(inputFile)
Ejemplo n.º 9
0
def test_PersistentApplicationTestOtherModes(tmp_path):
    def _check(spa):
        try:
            ret = spa.start()

            # Start shouldn't return anything in persistent mode
            assert ret is None

            ret = spa.runTest("aaa\naaaa")

            assert ret == ApplicationStatus.OK

            assert spa.stdout[2] == "aaa"
            assert spa.stdout[3] == "aaaa"

            ret = spa.runTest("aa\naaa")

            assert ret == ApplicationStatus.OK

            ret = spa.runTest("aaa\naaaa")
            print(spa.stdout)
            print(spa.stderr)
            assert ret == ApplicationStatus.CRASHED

            assert len(spa.testLog) == 3

            oldPid = spa.process.pid

            spa.stop()
            spa.start()

            newPid = spa.process.pid

            assert oldPid != newPid

            ret = spa.runTest("aaaaa")

            assert ret == ApplicationStatus.TIMEDOUT
            assert len(spa.testLog) == 1
        finally:
            spa.stop()

    # Check with spfp and stdin as source
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "spfp"],
                                       persistentMode=PersistentMode.SPFP, processingTimeout=2))

    # Check with sigstop and temporary file as source
    inputFile = tmp_path / "input.tmp"
    inputFile.touch()
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "sigstop",
                                                        str(inputFile)],
                                       persistentMode=PersistentMode.SIGSTOP, processingTimeout=2,
                                       inputFile=str(inputFile)))
Ejemplo n.º 10
0
def test_PersistentApplicationTestModeNone(tmp_path):
    def _check(spa):
        try:
            ret = spa.start("aa")

            assert ret == ApplicationStatus.OK

            assert spa.stdout[0] == "Stdout test1"
            assert spa.stdout[1] == "Stdout test2"

            assert spa.stderr[0] == "Stderr test1"
            assert spa.stderr[1] == "Stderr test2"

            ret = spa.start("aaa")
            assert ret == ApplicationStatus.ERROR

            # Check that stdout/err is reset
            assert len(spa.stdout) == 2
            assert len(spa.stderr) == 2

            # Check that the test log is reset
            assert len(spa.testLog) == 1

            ret = spa.start("aaaa")
            assert ret == ApplicationStatus.CRASHED
        finally:
            spa.stop()

    # Check with stdin as source
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "none"]))

    # Now use a temporary file instead
    inputFile = tmp_path / "input.tmp"
    inputFile.touch()
    _check(SimplePersistentApplication(sys.executable, [os.path.join(TEST_PATH, "test_shell.py"), "none",
                                                        str(inputFile)],
                                       inputFile=str(inputFile)))