mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 21:09:03 +02:00
oeqa/selftest: add test case for oeqa.utils.subprocesstweak
This class has a monkey-patched CalledProcessError instance that extends the __str__ method. Add a test case to ensure that it behaves as expected. (From OE-Core rev: 3c0e7b537eac62fced196e82ede781d88e593a69) Signed-off-by: Ross Burton <ross.burton@arm.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
dfaff44d8a
commit
ef6748323f
|
@ -9,11 +9,11 @@ from oeqa.utils.commands import get_bb_var, get_bb_vars, bitbake, runCmd
|
||||||
import oe.path
|
import oe.path
|
||||||
import os
|
import os
|
||||||
|
|
||||||
class LibOE(OESelftestTestCase):
|
class CopyTreeTests(OESelftestTestCase):
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
super(LibOE, cls).setUpClass()
|
super().setUpClass()
|
||||||
cls.tmp_dir = get_bb_var('TMPDIR')
|
cls.tmp_dir = get_bb_var('TMPDIR')
|
||||||
|
|
||||||
def test_copy_tree_special(self):
|
def test_copy_tree_special(self):
|
||||||
|
@ -102,3 +102,36 @@ class LibOE(OESelftestTestCase):
|
||||||
self.assertEqual(dstcnt, len(testfiles), "Number of files in dst (%s) differs from number of files in src(%s)." % (dstcnt, srccnt))
|
self.assertEqual(dstcnt, len(testfiles), "Number of files in dst (%s) differs from number of files in src(%s)." % (dstcnt, srccnt))
|
||||||
|
|
||||||
oe.path.remove(testloc)
|
oe.path.remove(testloc)
|
||||||
|
|
||||||
|
class SubprocessTests(OESelftestTestCase):
|
||||||
|
|
||||||
|
def test_subprocess_tweak(self):
|
||||||
|
"""
|
||||||
|
Test that the string representation of
|
||||||
|
oeqa.utils.subprocesstweak.OETestCalledProcessError includes stdout and
|
||||||
|
stderr, as expected.
|
||||||
|
"""
|
||||||
|
script = """
|
||||||
|
#! /bin/sh
|
||||||
|
echo Ivn fgqbhg | tr '[a-zA-Z]' '[n-za-mN-ZA-M]'
|
||||||
|
echo Ivn fgqree | tr '[a-zA-Z]' '[n-za-mN-ZA-M]' >&2
|
||||||
|
exit 42
|
||||||
|
"""
|
||||||
|
|
||||||
|
import subprocess
|
||||||
|
import unittest.mock
|
||||||
|
from oeqa.utils.subprocesstweak import OETestCalledProcessError
|
||||||
|
|
||||||
|
with self.assertRaises(OETestCalledProcessError) as cm:
|
||||||
|
with unittest.mock.patch("subprocess.CalledProcessError", OETestCalledProcessError):
|
||||||
|
subprocess.run(["bash", "-"], input=script, text=True, capture_output=True, check=True)
|
||||||
|
|
||||||
|
e = cm.exception
|
||||||
|
self.assertEqual(e.returncode, 42)
|
||||||
|
self.assertEqual("Via stdout\n", e.stdout)
|
||||||
|
self.assertEqual("Via stderr\n", e.stderr)
|
||||||
|
|
||||||
|
string = str(e)
|
||||||
|
self.assertIn("exit status 42", string)
|
||||||
|
self.assertIn("Standard Output: Via stdout", string)
|
||||||
|
self.assertIn("Standard Error: Via stderr", string)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user