Skip to content

Commit

Permalink
Merge pull request NixOS#307337 from SuperSandro2000/diffoscope-tlsh
Browse files Browse the repository at this point in the history
diffoscope: disable radare2 to fix tests
  • Loading branch information
eclairevoyant authored Apr 30, 2024
2 parents 5610faa + 02e439f commit 3e67815
Showing 1 changed file with 27 additions and 6 deletions.
33 changes: 27 additions & 6 deletions pkgs/tools/misc/diffoscope/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,6 @@
, python3
, qemu
, R
, radare2
, sng
, sqlite
, squashfsTools
Expand All @@ -76,8 +75,26 @@
, writeScript
}:

let
python = python3.override {
packageOverrides = final: prev: {
# version 4 or newer would log the followng error but tests currently don't fail because radare2 is disabled
# ValueError: argument TNULL is not a TLSH hex string
tlsh = prev.tlsh.overridePythonAttrs ({ src, ... }: let
version = "3.19.1";
in {
inherit version;
src = src.override {
rev = version;
hash = "sha256-ZYEjT/yShfA4+zpbGOtaFOx1nSSOWPtMvskPhHv3c9U=";
};
});
};
};
in

# Note: when upgrading this package, please run the list-missing-tools.sh script as described below!
python3.pkgs.buildPythonApplication rec {
python.pkgs.buildPythonApplication rec {
pname = "diffoscope";
version = "265";

Expand Down Expand Up @@ -124,6 +141,11 @@ python3.pkgs.buildPythonApplication rec {
# docx2txt <- makes tests broken:
# > FAILED tests/comparators/test_docx.py::test_diff - IndexError: list index out of range
# > FAILED tests/comparators/test_docx.py::test_compare_non_existing - AssertionError
# radare2
# > FAILED tests/comparators/test_elf_decompiler.py::test_ghidra_diff - IndexError: list index out of range
# > FAILED tests/comparators/test_elf_decompiler.py::test_radare2_diff - AssertionError
# > FAILED tests/comparators/test_macho_decompiler.py::test_ghidra_diff - assert 0 == 1
# > FAILED tests/comparators/test_macho_decompiler.py::test_radare2_diff - AssertionError
#
# We filter automatically all packages for the host platform (some dependencies are not supported on Darwin, aarch64, etc.).
pythonPath = lib.filter (lib.meta.availableOn stdenv.hostPlatform) ([
Expand Down Expand Up @@ -160,7 +182,7 @@ python3.pkgs.buildPythonApplication rec {
zip
zstd
]
++ (with python3.pkgs; [
++ (with python.pkgs; [
argcomplete
debian
defusedxml
Expand Down Expand Up @@ -203,13 +225,12 @@ python3.pkgs.buildPythonApplication rec {
procyon
qemu
R
radare2
tcpdump
ubootTools
wabt
xmlbeans
]
++ (with python3.pkgs; [
++ (with python.pkgs; [
androguard
binwalk
guestfs
Expand All @@ -224,7 +245,7 @@ python3.pkgs.buildPythonApplication rec {
++ lib.optionals (stdenv.hostPlatform.system != "aarch64-darwin") [ gnumeric ]
));

nativeCheckInputs = with python3.pkgs; [
nativeCheckInputs = with python.pkgs; [
pytestCheckHook
] ++ pythonPath;

Expand Down

0 comments on commit 3e67815

Please sign in to comment.