Blame tests/bugfixes/github/test_CVE_2018_11531.py
|
Packit Service |
21b5d1 |
# -*- coding: utf-8 -*-
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
from system_tests import CaseMeta, path, check_no_ASAN_UBSAN_errors
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
class TestCvePoC(metaclass=CaseMeta):
|
|
Packit Service |
21b5d1 |
"""
|
|
Packit Service |
21b5d1 |
Regression test for the bug described in:
|
|
Packit Service |
21b5d1 |
https://github.com/Exiv2/exiv2/issues/283
|
|
Packit Service |
21b5d1 |
"""
|
|
Packit Service |
21b5d1 |
url = "https://github.com/Exiv2/exiv2/issues/283"
|
|
Packit Service |
21b5d1 |
cve_url = "https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2018-11531"
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
def check_no_ASAN_UBSAN_errors(self, i, command, got_stderr, expected_stderr):
|
|
Packit Service |
21b5d1 |
""" Override of system_tests.check_no_ASAN_UBSAN_errors for this particular test case.
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
Here we want to also check that the two last lines of got_stderr have the expected_stderr
|
|
Packit Service |
21b5d1 |
"""
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
check_no_ASAN_UBSAN_errors(self, i, command, got_stderr, expected_stderr)
|
|
Packit Service |
21b5d1 |
self.assertListEqual(expected_stderr.splitlines(), got_stderr.splitlines()[-2:])
|
|
Packit Service |
21b5d1 |
|
|
Packit Service |
21b5d1 |
filename = path("$data_path/pocIssue283.jpg")
|
|
Packit Service |
21b5d1 |
commands = ["$exiv2 $filename"]
|
|
Packit Service |
21b5d1 |
stdout = [""]
|
|
Packit Service |
21b5d1 |
stderr = [
|
|
Packit Service |
21b5d1 |
"""$exiv2_exception_message $filename:
|
|
Packit Service |
21b5d1 |
$kerCorruptedMetadata
|
|
Packit Service |
21b5d1 |
"""]
|
|
Packit Service |
21b5d1 |
compare_stderr = check_no_ASAN_UBSAN_errors
|
|
Packit Service |
21b5d1 |
retval = [1]
|