Files
capa/tests/test_unpack.py
William Ballenthin e523c6cb50 init unpack module
2020-08-25 12:43:40 -06:00

47 lines
1.6 KiB
Python

# Copyright (C) 2020 FireEye, Inc. All Rights Reserved.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at: [package root]/LICENSE.txt
# Unless required by applicable law or agreed to in writing, software distributed under the License
# is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and limitations under the License.
import sys
import textwrap
import pytest
from fixtures import *
import capa.unpack
@pytest.mark.xfail(sys.version_info <= (3, 0), reason="auto-unpack only works on py3")
def test_aspack_is_packed(aspack_extractor):
path = aspack_extractor.path
with open(path, "rb") as f:
buf = f.read()
assert capa.unpack.is_packed(buf) is True
@pytest.mark.xfail(sys.version_info <= (3, 0), reason="auto-unpack only works on py3")
def test_aspack_detect(aspack_extractor):
path = aspack_extractor.path
with open(path, "rb") as f:
buf = f.read()
assert capa.unpack.detect_packer(buf) == capa.unpack.ASPACK
@pytest.mark.xfail(sys.version_info <= (3, 0), reason="auto-unpack only works on py3")
def test_aspack_unpack(aspack_extractor):
path = aspack_extractor.path
with open(path, "rb") as f:
buf = f.read()
unpacked = capa.unpack.unpack_pe(buf)
assert b"This program cannot be run in DOS mode" in unpacked
assert b"cmd.exe" in unpacked