Message ID | 20250106124414.7861f9b8@ens-lyon.fr |
---|---|
State | New |
Headers |
Return-Path: <guix-patches-bounces+patchwork=mira.cbaines.net@gnu.org> X-Original-To: patchwork@mira.cbaines.net Delivered-To: patchwork@mira.cbaines.net Received: by mira.cbaines.net (Postfix, from userid 113) id 3627F27BBE9; Mon, 6 Jan 2025 11:45:39 +0000 (GMT) X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on mira.cbaines.net X-Spam-Level: X-Spam-Status: No, score=-7.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,MAILING_LIST_MULTI,RCVD_IN_DNSWL_BLOCKED, RCVD_IN_VALIDITY_CERTIFIED,RCVD_IN_VALIDITY_RPBL,RCVD_IN_VALIDITY_SAFE, SPF_HELO_PASS,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.6 Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mira.cbaines.net (Postfix) with ESMTPS id 3FFCA27BBE2 for <patchwork@mira.cbaines.net>; Mon, 6 Jan 2025 11:45:34 +0000 (GMT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from <guix-patches-bounces@gnu.org>) id 1tUlXk-0002Yz-88; Mon, 06 Jan 2025 06:45:12 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from <Debian-debbugs@debbugs.gnu.org>) id 1tUlXc-0002Wa-Bb for guix-patches@gnu.org; Mon, 06 Jan 2025 06:45:05 -0500 Received: from debbugs.gnu.org ([2001:470:142:5::43]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from <Debian-debbugs@debbugs.gnu.org>) id 1tUlXb-00056X-UW for guix-patches@gnu.org; Mon, 06 Jan 2025 06:45:04 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=debbugs.gnu.org; s=debbugs-gnu-org; h=MIME-Version:From:Date:To:Subject; bh=ExVF8rqxMWcTIVQAKIGSYMQzB7e0Vx33Mb/ps2znjsU=; b=hHJlZWYAQEn79YP3LZFu7/ryim8qWdG+Ysld9TYCeeIrARWKNINETKxp2kirCi4+1jQ+phxM0ZZHLOsIWssQyq46isvnKGU6jt4ugtc5uAmICc9Nwcn5qxWgF3hqMaZENL6tQIWAAuHVgCs/uVlPM6Y8rTdM641S88Z6n+5XMCbqseCiiyrlW6t5pOcUezbs3Y0Vo4l7EpTjWPWcSfVSDLNOP4j9kRg5gDD/cJseJDu7M/JaWpDwQM9IOCr7P4MWvLOR9+wLen6SlyfaFLLG0iFKP491HrF/OSE+Fs5B/t37G3h5EnOQc6VYqtwkuVHVedUTLgVolEs3AzlX3geLHg==; Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from <Debian-debbugs@debbugs.gnu.org>) id 1tUlXa-0007At-P4 for guix-patches@gnu.org; Mon, 06 Jan 2025 06:45:02 -0500 X-Loop: help-debbugs@gnu.org Subject: [bug#75400] [PATCH] Fixing python-spacy Resent-From: Alice BRENON <alice.brenon@ens-lyon.fr> Original-Sender: "Debbugs-submit" <debbugs-submit-bounces@debbugs.gnu.org> Resent-CC: guix-patches@gnu.org Resent-Date: Mon, 06 Jan 2025 11:45:02 +0000 Resent-Message-ID: <handler.75400.B.173616387527512@debbugs.gnu.org> Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: report 75400 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: 75400@debbugs.gnu.org X-Debbugs-Original-To: guix-patches@gnu.org Received: via spool by submit@debbugs.gnu.org id=B.173616387527512 (code B ref -1); Mon, 06 Jan 2025 11:45:02 +0000 Received: (at submit) by debbugs.gnu.org; 6 Jan 2025 11:44:35 +0000 Received: from localhost ([127.0.0.1]:37014 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from <debbugs-submit-bounces@debbugs.gnu.org>) id 1tUlX8-00079f-Ow for submit@debbugs.gnu.org; Mon, 06 Jan 2025 06:44:35 -0500 Received: from lists.gnu.org ([2001:470:142::17]:41182) by debbugs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.84_2) (envelope-from <alice.brenon@ens-lyon.fr>) id 1tUlX5-00079G-AP for submit@debbugs.gnu.org; Mon, 06 Jan 2025 06:44:33 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from <alice.brenon@ens-lyon.fr>) id 1tUlWy-0002Rq-Jv for guix-patches@gnu.org; Mon, 06 Jan 2025 06:44:24 -0500 Received: from lxc-smtp2.ens-lyon.fr ([140.77.167.81]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from <alice.brenon@ens-lyon.fr>) id 1tUlWv-00054H-Jq for guix-patches@gnu.org; Mon, 06 Jan 2025 06:44:24 -0500 Received: from localhost (localhost [127.0.0.1]) by lxc-smtp2.ens-lyon.fr (Postfix) with ESMTP id B98C1145753 for <guix-patches@gnu.org>; Mon, 6 Jan 2025 12:44:15 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=ens-lyon.fr; s=2024; t=1736163855; bh=xiH7Or9P6TmV/BrfpZjd9jWbpdUE4ifwaUDp03NiWV0=; h=Date:From:To:Subject:From; b=p78L9txsGxDuSC9p5d86F/oeiSYM6UyydRYEF4K75NY/cibAAza6WWi+aK0I/Kgoe sv7yEZgfZVxn2LVsxc1av8uR+Gi7Oh78Y1GzTCBrcUGlEGYx5hj5t0GvXZrQ4vUp8p e+fQHQ+U3hySmJ2VliUQqJAr4fhh5Y3TmI3LA/xIRNmW8g353BUM6+LrBzUMc9hRGX UeExDjajQzr+8mttqiXTb1xRPu0C29eUlj/swWUrhyOsSOuoadYw5GxXADBXdzuHn3 5MEUGsQUgzq/y8VrLrEzRL2TcyUYKSqKGmeUZa/44TRBeySV9LHvxxetIZJG3OeX6D 6wlo9axm3930Q== X-Virus-Scanned: by amavisd-new-2.11.0 (20160426) (Debian) at ens-lyon.fr Received: from lxc-smtp2.ens-lyon.fr ([127.0.0.1]) by localhost (lxc-smtp2.ens-lyon.fr [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id YPpBw6uIOmi2 for <guix-patches@gnu.org>; Mon, 6 Jan 2025 12:44:15 +0100 (CET) Received: from localhost (dhcp-67-68.ixxi.ens-lyon.fr [140.77.67.68]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by lxc-smtp2.ens-lyon.fr (Postfix) with ESMTPSA id A1ECC140388 for <guix-patches@gnu.org>; Mon, 6 Jan 2025 12:44:14 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=ens-lyon.fr; s=2024; t=1736163855; bh=xiH7Or9P6TmV/BrfpZjd9jWbpdUE4ifwaUDp03NiWV0=; h=Date:From:To:Subject:From; b=p78L9txsGxDuSC9p5d86F/oeiSYM6UyydRYEF4K75NY/cibAAza6WWi+aK0I/Kgoe sv7yEZgfZVxn2LVsxc1av8uR+Gi7Oh78Y1GzTCBrcUGlEGYx5hj5t0GvXZrQ4vUp8p e+fQHQ+U3hySmJ2VliUQqJAr4fhh5Y3TmI3LA/xIRNmW8g353BUM6+LrBzUMc9hRGX UeExDjajQzr+8mttqiXTb1xRPu0C29eUlj/swWUrhyOsSOuoadYw5GxXADBXdzuHn3 5MEUGsQUgzq/y8VrLrEzRL2TcyUYKSqKGmeUZa/44TRBeySV9LHvxxetIZJG3OeX6D 6wlo9axm3930Q== Date: Mon, 6 Jan 2025 12:44:14 +0100 From: Alice BRENON <alice.brenon@ens-lyon.fr> Message-ID: <20250106124414.7861f9b8@ens-lyon.fr> X-Mailer: Claws Mail 4.3.0 (GTK 3.24.41; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="MP_/WIle2chhq6j4hF1jjIUpwVM" Received-SPF: pass client-ip=140.77.167.81; envelope-from=alice.brenon@ens-lyon.fr; helo=lxc-smtp2.ens-lyon.fr X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H2=-0.001, RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list X-BeenThere: guix-patches@gnu.org List-Id: <guix-patches.gnu.org> List-Unsubscribe: <https://lists.gnu.org/mailman/options/guix-patches>, <mailto:guix-patches-request@gnu.org?subject=unsubscribe> List-Archive: <https://lists.gnu.org/archive/html/guix-patches> List-Post: <mailto:guix-patches@gnu.org> List-Help: <mailto:guix-patches-request@gnu.org?subject=help> List-Subscribe: <https://lists.gnu.org/mailman/listinfo/guix-patches>, <mailto:guix-patches-request@gnu.org?subject=subscribe> Errors-To: guix-patches-bounces+patchwork=mira.cbaines.net@gnu.org Sender: guix-patches-bounces+patchwork=mira.cbaines.net@gnu.org X-getmail-retrieved-from-mailbox: Patches |
Series |
[bug#75400] Fixing python-spacy
|
|
Commit Message
Alice BRENON
Jan. 6, 2025, 11:44 a.m. UTC
Hi all, The package `python-spacy` seems to have been broken at least partially by the recent changes in python tooling. The attached patch is a very short first step into fixing it. This message doesn't hope to get it accepted but is rather meant to open the discussion on the topic. - the first issue is naturally the new required dependencies in `native-inputs` mentioned in bdde278dc9c565d8e9d11427c3a670ba86808af5 an visible in many python packages commit these past weeks. Surprisingly, I managed to compile `python-spacy` by adding only `python-wheel`, without `python-setuptools`. What makes both required? Are we sure that both were required in each and every python package recently modified? - the second issue which I can't link with the changes in our tooling is caused by two packages which tests have broken: `python-aws-xray-sdk` and `python-jose`. First one seems to have a problem in sqlalchemy version (it seems to be using too recent a syntax; which is weird considering the fact that it uses version 2 and that it used to work — `python-aws-xray-sdk` hasn't been modified since cec543e7 on april the 27th 2023!). Second one now has trouble checking several certificates for mere formatting reasons (expected and actual PEMs are almost the same, only newlines are different; fixing the code of the test itself, another one breaks somewhere else. It seems that these source codes aren't sturdy enough and don't work at all in the package environment guix provides. - these packages are dependencies of `python-moto`. Removing them from the dependencies, many tests break as expected for lack of these modules, but disabling them isn't enough: I played a game of whack-a-mole yesterday trying to get the tests to pass. Strangely, whereas testing with hypothesis runs all the tests and then reports all that have failed, fixing the one reported and running the tests again doesn't help: new tests break in different files that were apparently fine before… I had three iterations of this process, each one consuming half and hour on my machine. As far as I am concerned, these tests are unreliable and don't bring any additional confidence to the package. I have disabled them to test the fix for `python-spacy` and have been able to compile it and use the package. Appart from that, everything looks ok. `python-moto` appears as a dependency of `python-smart-open` which itself is both a direct dependency of `python-spacy` and a dependency of `python-pathy` which is also a dependency of `python-spacy`. python-smart-open -> python-moto python-pathy -> python-smart-open python-spacy -> python-smart-open, python-pathy I understand that disabling the tests on a package entirely isn't a very sound practice for a distribution so I doubt this is an acceptable fix. As I understand the situation the next steps will be to sort things between `python-aws-xray-sdk` and `python-sqlalchemy` and to understand why the tests in `python-jose` have suddenly broken so bad. Best, Alice
Comments
Hello Alice, Alice BRENON <alice.brenon@ens-lyon.fr> skribis: >>From 9a349ac01cec33fc1e49ba7f80ae18ef5cfdf922 Mon Sep 17 00:00:00 2001 > Message-ID: <9a349ac01cec33fc1e49ba7f80ae18ef5cfdf922.1736155491.git.alice.brenon@ens-lyon.fr> > From: Alice BRENON <alice.brenon@ens-lyon.fr> > Date: Sat, 4 Jan 2025 23:01:50 +0100 > Subject: [PATCH] gnu: python-spacy: Fix build. > > * gnu/packages/machine-learning.scm (python-spacy): Fix build. > [native-inputs]: Add python-wheel > > Change-Id: I6550f6dc0cb1fb88fc733f6471f1831c4ba95977 Applied. Thanks for the debugging session and thorough analysis. Cc’ing the Python team for feedback on your other comments: https://issues.guix.gnu.org/75400 Ludo’.
Hi Alice, via: > Cc’ing the Python team for feedback on your other comments: > > https://issues.guix.gnu.org/75400 > - the first issue is naturally the new required dependencies in `native-inputs` > mentioned in bdde278dc9c565d8e9d11427c3a670ba86808af5 an visible in many > python packages commit these past weeks. Surprisingly, I managed to compile > `python-spacy` by adding only `python-wheel`, without `python-setuptools`. > What makes both required? Are we sure that both were required in each and > every python package recently modified? in short: yes. I can’t tell for sure for this exact case because the output of `guix graph` is too big for `xdot` to handle, but it’s likely python-setuptools is implicitly propagated through some dependency (perhaps a bug like https://issues.guix.gnu.org/25235) to python-spacy and thus it looks like it’s “not required”. Lars
Hi Lars! Thanks for the great insight. Yeah, I tried generating that graph when I started the investigation because at first I couldn't understand where the crashing version of `python-moto` was still being used… ^^' I got a PNG over 25Mo. I ended up browsing the dot graph in text directly. Ok, so I think I'll make another patch to add setuptools (can I send the patch to this closed issue or will I need to open a new one?). Any opinion on all the broken tests, anyone? Alice Le Tue, 7 Jan 2025 15:18:32 +0100, Lars-Dominik Braun <lars@6xq.net> a écrit : > Hi Alice, > > via: > > > Cc’ing the Python team for feedback on your other comments: > > > > https://issues.guix.gnu.org/75400 > > > - the first issue is naturally the new required dependencies in > > `native-inputs` mentioned in > > bdde278dc9c565d8e9d11427c3a670ba86808af5 an visible in many python > > packages commit these past weeks. Surprisingly, I managed to > > compile `python-spacy` by adding only `python-wheel`, without > > `python-setuptools`. What makes both required? Are we sure that > > both were required in each and every python package recently > > modified? > > in short: yes. I can’t tell for sure for this exact case because > the output of `guix graph` is too big for `xdot` to handle, but it’s > likely python-setuptools is implicitly propagated through some > dependency (perhaps a bug > like https://issues.guix.gnu.org/25235) to python-spacy and thus it looks like it’s “not required”. > > Lars >
Alice BRENON <alice.brenon@ens-lyon.fr> skribis: > Thanks for the great insight. Yeah, I tried generating that graph when I started > the investigation because at first I couldn't understand where the crashing > version of `python-moto` was still being used… ^^' I got a PNG over 25Mo. Note that you use, say, ‘guix graph -M3’ to cut the graph at distance 3. Or you can use things like ‘guix graph --path python-spacy python-moto’. Ludo’.
> Note that you use, say, ‘guix graph -M3’ to cut the graph at distance 3.
Hi, should the CLI documentation for guix graph mention that graphviz is the default backend?
For example, when calling `guix graph --list-backends`?
all best,
jgart
From 9a349ac01cec33fc1e49ba7f80ae18ef5cfdf922 Mon Sep 17 00:00:00 2001 Message-ID: <9a349ac01cec33fc1e49ba7f80ae18ef5cfdf922.1736155491.git.alice.brenon@ens-lyon.fr> From: Alice BRENON <alice.brenon@ens-lyon.fr> Date: Sat, 4 Jan 2025 23:01:50 +0100 Subject: [PATCH] gnu: python-spacy: Fix build. * gnu/packages/machine-learning.scm (python-spacy): Fix build. [native-inputs]: Add python-wheel Change-Id: I6550f6dc0cb1fb88fc733f6471f1831c4ba95977 --- gnu/packages/machine-learning.scm | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gnu/packages/machine-learning.scm b/gnu/packages/machine-learning.scm index c7d336b8b3..1617ef917e 100644 --- a/gnu/packages/machine-learning.scm +++ b/gnu/packages/machine-learning.scm @@ -1282,7 +1282,7 @@ (define-public python-spacy python-typing-extensions python-wasabi)) (native-inputs - (list python-cython python-pytest python-mock)) + (list python-cython python-pytest python-mock python-wheel)) (home-page "https://spacy.io") (synopsis "Natural Language Processing (NLP) in Python") (description base-commit: 7a7c01b393ecb20dff142b9ea9bf8317e994bef2 -- 2.47.1