Bug#1078944: diffoscope fails to build from source and fails to run in debian sid/unstable (#389)

Chris Lamb chris at reproducible-builds.org
Sun Aug 18 18:38:47 BST 2024


Fay Stegerman wrote:

> Am I missing something here?  Because diffoscope 274 is already in trixie.  And
> the issue isn't a result of a change to diffoscope itself but a result of
> python3-cryptography […]

That is essentially my reading of the situation. Here's what I just
committed which also refs 

  commit c1aa6259cd1954182a02ede393c3540dcda33a11
  Author: Chris Lamb <lamby at debian.org>
  Date:   Sun Aug 18 18:22:31 2024 +0100
  
      Also catch RuntimeError when importing PyPDF so that PyPDF or,
      crucially, its transitive dependencies do not cause diffoscope
      to traceback at runtime and build time. (Closes:
      Debian:#1078944, reproducible-builds/diffoscope#389)
      
      The root or even primary cause of this bug is not in diffoscope itself; rather,
      the cause is to be found between src:python3-cryptography and src:openssl — see
      bugs #1078747 and #965041 for more details.
      
      However, diffoscope should (and easily can…) be mindful that importing external
      libraries could result in exceptions other than ImportError when we have reason
      to believe that they might do so.
      
      We already do so in fsimage.py for a complicated library (guestfs), so I think
      it's not at all unreasonable to catch it here, too.
      
      Alas I can't seem to reproduce this on my local machine or in a clean sid
      chroot, so I am uploading the following patch after simply having a hard stare
      at the code… albeit on a warm Sunday afternoon.

  diff --git a/diffoscope/comparators/pdf.py b/diffoscope/comparators/pdf.py
  index 7584ae0c..30a6f803 100644
  --- a/diffoscope/comparators/pdf.py
  +++ b/diffoscope/comparators/pdf.py
  @@ -72,7 +72,7 @@ try:
               # PyPDF 1.x
               from PyPDF2.utils import PdfReadError
   
  -except ImportError:  # noqa
  +except (ImportError, RuntimeError):  # noqa
       python_module_missing("pypdf")
       pypdf = None
   
  diff --git a/tests/comparators/test_pdf.py b/tests/comparators/test_pdf.py
  index 25423a5d..738bf95e 100644
  --- a/tests/comparators/test_pdf.py
  +++ b/tests/comparators/test_pdf.py
  @@ -42,7 +42,7 @@ def skip_unless_pypdf3():
       def fn():
           try:
               import pypdf
  -        except ImportError:
  +        except (ImportError, RuntimeError):
               return True
   
           return not pypdf.__version__.startswith("3.")


Regards,

-- 
      o
    ⬋   ⬊      Chris Lamb
   o     o     reproducible-builds.org 💠
    ⬊   ⬋
      o



More information about the Reproducible-builds mailing list