fix: dlls test issue #5

This commit is contained in:
Dobin Rutishauser
2025-06-08 19:03:57 +02:00
parent a9663d81a7
commit 015ec55975
3 changed files with 30 additions and 25 deletions
+1
View File
@@ -10,6 +10,7 @@ VerifyFilename: FilePath = FilePath("C:\\Temp\\a")
# Directory structure # Directory structure
PATH_EXES = "data/binary/exes/" PATH_EXES = "data/binary/exes/"
PATH_EXES_MORE = "data/binary/exes_more/" PATH_EXES_MORE = "data/binary/exes_more/"
PATH_DLLS = "data/binary/dlls/"
PATH_SHELLCODES = "data/binary/shellcodes/" PATH_SHELLCODES = "data/binary/shellcodes/"
PATH_CARRIER = "data/source/carrier/" PATH_CARRIER = "data/source/carrier/"
PATH_PAYLOAD = "data/source/payload/" PATH_PAYLOAD = "data/source/payload/"
+2 -2
View File
@@ -24,8 +24,8 @@ class DerBackdoorerTest(unittest.TestCase):
def test_function_backdoorer_dll(self): def test_function_backdoorer_dll(self):
superpe = SuperPe(PATH_EXES + "libbz2-1.dll") superpe = SuperPe(PATH_DLLS + "TestDLL.dll")
function_backdoorer = FunctionBackdoorer(superpe) function_backdoorer = FunctionBackdoorer(superpe)
addr = function_backdoorer.find_suitable_instruction_addr(superpe.get_entrypoint()) addr = function_backdoorer.find_suitable_instruction_addr(superpe.get_entrypoint())
self.assertEqual(addr, 0x135D) self.assertEqual(addr, 0x13CA)
+27 -23
View File
@@ -69,64 +69,68 @@ class SuperPeTest(unittest.TestCase):
def test_dll(self): def test_dll(self):
dll_filepath = PATH_EXES + "libbz2-1.dll" dll_filepath = PATH_DLLS + "TestDLL.dll"
superpe = SuperPe(dll_filepath) superpe = SuperPe(dll_filepath)
# Properties # Properties
self.assertTrue(superpe.is_dll()) self.assertTrue(superpe.is_dll())
self.assertTrue(superpe.is_64()) self.assertTrue(superpe.is_64())
self.assertFalse(superpe.is_dotnet()) self.assertFalse(superpe.is_dotnet())
self.assertEqual(superpe.get_entrypoint(), 0x1350) self.assertEqual(superpe.get_entrypoint(), 0x13B0)
self.assertIsNone(superpe.get_rwx_section()) self.assertIsNone(superpe.get_rwx_section())
self.assertEqual(superpe.get_image_base(), 0x1F13C0000) self.assertEqual(superpe.get_image_base(), 0x180000000)
self.assertEqual(superpe.is_dynamic_base(), True) self.assertEqual(superpe.is_dynamic_base(), True)
# Text Section 1 (pefile SectionStructure) # Text Section 1 (pefile SectionStructure)
code_sect: pefile.SectionStructure = superpe.get_code_section() code_sect: pefile.SectionStructure = superpe.get_code_section()
self.assertEqual(code_sect.Name.decode(), ".text\x00\x00\x00") self.assertEqual(code_sect.Name.decode(), ".text\x00\x00\x00")
self.assertEqual(code_sect.VirtualAddress, 0x1000) self.assertEqual(code_sect.VirtualAddress, 0x1000)
self.assertEqual(code_sect.Misc_VirtualSize, 0x12D08) self.assertEqual(code_sect.Misc_VirtualSize, 3912)
# Text Section 2 (PeSection) # Text Section 2 (PeSection)
code_pesect: PeSection = superpe.get_section_by_name(".text") code_pesect: PeSection = superpe.get_section_by_name(".text")
self.assertIsNotNone(code_pesect) self.assertIsNotNone(code_pesect)
self.assertEqual(code_pesect.name, ".text") self.assertEqual(code_pesect.name, ".text")
self.assertEqual(code_pesect.virt_addr, 0x1000) self.assertEqual(code_pesect.virt_addr, 0x1000)
self.assertEqual(code_pesect.virt_size, 0x12D08) self.assertEqual(code_pesect.virt_size, 3912)
# Relocations # Relocations
base_relocs: List[PeRelocEntry] = superpe.get_base_relocs() base_relocs: List[PeRelocEntry] = superpe.get_base_relocs()
self.assertEqual(len(base_relocs), 54) self.assertEqual(len(base_relocs), 17)
base_reloc = base_relocs[0] base_reloc = base_relocs[0]
self.assertEqual(base_reloc.rva, 0x13CE8) self.assertEqual(base_reloc.rva, 0x20F8)
self.assertEqual(base_reloc.base_rva, 0x13000) self.assertEqual(base_reloc.base_rva, 0x2000)
self.assertEqual(base_reloc.offset, 0xCE8) self.assertEqual(base_reloc.offset, 0xF8)
# IAT # IAT
iat_entries: Dict[str, List[IatEntry]] = superpe.get_iat_entries() iat_entries: Dict[str, List[IatEntry]] = superpe.get_iat_entries()
self.assertEqual(len(iat_entries), 2) self.assertEqual(len(iat_entries), 4)
self.assertTrue("kernel32.dll" in iat_entries) self.assertTrue("kernel32.dll" in iat_entries)
self.assertTrue("msvcrt.dll" in iat_entries) self.assertTrue("vcruntime140.dll" in iat_entries)
kernel32_entries = iat_entries["kernel32.dll"] kernel32_entries = iat_entries["kernel32.dll"]
self.assertEqual(len(kernel32_entries), 12) self.assertEqual(len(kernel32_entries), 14)
entry = kernel32_entries[0] entry = kernel32_entries[0]
self.assertEqual(entry.dll_name, "kernel32.dll") self.assertEqual(entry.dll_name, "kernel32.dll")
self.assertEqual(entry.func_name, "DeleteCriticalSection") self.assertEqual(entry.func_name, "GetSystemTimeAsFileTime")
self.assertEqual(entry.iat_vaddr, 0x1f13db1c4) self.assertEqual(entry.iat_vaddr, 0x180002000)
self.assertEqual(superpe.get_vaddr_of_iatentry("DeleteCriticalSection"), 0x1F13DB1C4) self.assertIsNone(superpe.get_vaddr_of_iatentry("asdf"))
self.assertEqual(superpe.get_replacement_iat_for( self.assertEqual(superpe.get_vaddr_of_iatentry("RtlCaptureContext"), 0x180002008)
"kernel32.dll", "GetEnvironmentStringsW"), "InitializeCriticalSection")
# bad test, but result is random
self.assertNotEqual(superpe.get_replacement_iat_for(
"kernel32.dll", "GetEnvironmentStringsW"), "GetEnvironmentStringsW")
# Exports # Exports
exports = superpe.get_exports_full() exports = superpe.get_exports_full()
self.assertEqual(len(exports), 35) self.assertEqual(len(exports), 6)
export = exports[0] export = exports[0]
self.assertEqual(export["name"], "BZ2_blockSort") self.assertEqual(export["name"], "test")
self.assertEqual(export["addr"], 0x2FC0) self.assertEqual(export["addr"], 0x1000)
self.assertEqual(export["size"], 416) self.assertEqual(export["size"], 80)
# VRA/Virt to Phys/Raw # VRA/Virt to Phys/Raw
raw = superpe.get_offset_from_rva(0xD690) # BZ2_bzdopen export raw = superpe.get_offset_from_rva(0x1000) # test export
self.assertEqual(raw, 0xCA90) self.assertEqual(raw, 0x400)