Add POC + regression test.
Note that we override here the method check_no_ASAN_UBSAN_errors to also analyze the last two lines of got_stderr.v0.27.3
parent
67a5a74115
commit
8eca055058
Binary file not shown.
@ -0,0 +1,31 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
import system_tests
|
||||
import os.path
|
||||
|
||||
class TestFirstPoC(metaclass=system_tests.CaseMeta):
|
||||
"""
|
||||
Regression test for the bug described in:
|
||||
https://github.com/Exiv2/exiv2/issues/283
|
||||
"""
|
||||
url = "https://github.com/Exiv2/exiv2/issues/283"
|
||||
|
||||
def check_no_ASAN_UBSAN_errors(self, i, command, got_stderr, expected_stderr):
|
||||
""" Override of system_tests.check_no_ASAN_UBSAN_errors for this particular test case.
|
||||
|
||||
Here we want to also check that the two last lines of got_stderr have the expected_stderr
|
||||
"""
|
||||
|
||||
system_tests.check_no_ASAN_UBSAN_errors(self, i, command, got_stderr, expected_stderr)
|
||||
self.assertListEqual(expected_stderr.splitlines(), got_stderr.splitlines()[-2:])
|
||||
|
||||
filename = os.path.join("$data_path", "pocIssue283.jpg")
|
||||
commands = ["$exiv2 $filename"]
|
||||
stdout = [""]
|
||||
stderr = [
|
||||
"""$exiv2_exception_message """ + filename + """:
|
||||
$kerCorruptedMetadata
|
||||
"""]
|
||||
compare_stderr = check_no_ASAN_UBSAN_errors
|
||||
retval = [1]
|
||||
|
Loading…
Reference in New Issue