summaryrefslogtreecommitdiff
path: root/tests/format/elf/overlapping_areas.py
blob: 5e3ba07d62477328a051792381e95e321a822d9c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/usr/bin/python
# -*- coding: utf-8 -*-


# Il arrive que les segments englobent partiellement des sections.
#
# Cela peut être problématique si une section contient une chaîne de taille
# n qui se retrouve à cheval sur deux zones (la section des chaînes découpée
# en deux par exemple).
#
# Au moment d'associer l'instruction chargée à la zone de départ, cette
# dernière n'est pas assez grande car elle ne représente pas la section
# en entier.


from chrysacase import ChrysalideTestCase
from pychrysalide.analysis import LoadedBinary
from pychrysalide.analysis.contents import FileContent
from pychrysalide.format.elf import ElfFormat
from threading import Event
import os
import sys


class TestOverlappingAreas(ChrysalideTestCase):
    """TestCase for BSS segment overlapping string section."""

    @classmethod
    def setUpClass(cls):

        super(TestOverlappingAreas, cls).setUpClass()

        cls.log('Compile binary "overlapping_areas" if needed...')

        fullname = sys.modules[cls.__module__].__file__
        dirpath = os.path.dirname(fullname)

        os.system('make -C %s overlapping_areas > /dev/null 2>&1' % dirpath)


    @classmethod
    def tearDownClass(cls):

        super(TestOverlappingAreas, cls).tearDownClass()

        cls.log('Delete built binaries...')

        fullname = sys.modules[cls.__module__].__file__
        dirpath = os.path.dirname(fullname)

        os.system('make -C %s clean > /dev/null 2>&1' % dirpath)


    def testOOBSectionName(self):
        """Avoid crashing because of overlapping binary areas."""

        fullname = sys.modules[self.__class__.__module__].__file__
        filename = os.path.basename(fullname)

        baselen = len(fullname) - len(filename)

        cnt = FileContent(fullname[:baselen] + 'overlapping_areas')
        self.assertIsNotNone(cnt)

        fmt = ElfFormat(cnt)
        self.assertIsInstance(fmt, ElfFormat)

        binary = LoadedBinary(fmt)

        binary.analyze_and_wait()