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]