guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

25/65: gnu: Add python-devpi-client.


From: guix-commits
Subject: 25/65: gnu: Add python-devpi-client.
Date: Fri, 20 Dec 2024 16:41:40 -0500 (EST)

rekado pushed a commit to branch python-team
in repository guix.

commit 6f3c284145d0a3838d23aec7b734e92111305c41
Author: Ricardo Wurmus <rekado@elephly.net>
AuthorDate: Mon Dec 16 21:05:50 2024 +0100

    gnu: Add python-devpi-client.
    
    * gnu/packages/python-web.scm (python-devpi-client): New variable.
    
    Change-Id: I29e0e3b573111d39b93d595cb7a49c588f5ac99a
---
 gnu/packages/python-web.scm | 57 +++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 57 insertions(+)

diff --git a/gnu/packages/python-web.scm b/gnu/packages/python-web.scm
index 2d3449ef1c..15fa2e04c8 100644
--- a/gnu/packages/python-web.scm
+++ b/gnu/packages/python-web.scm
@@ -168,6 +168,63 @@
 devpi-client and others.")
     (license license:expat)))
 
+(define-public python-devpi-client
+  (package
+    (name "python-devpi-client")
+    (version "7.2.0")
+    (source
+     (origin
+       (method url-fetch)
+       (uri (pypi-uri "devpi-client" version))
+       (sha256
+        (base32 "0ywx4ql8lsypb17n2miq39bmkrp232sdk8g6pskqp1y3b223chy1"))))
+    (build-system pyproject-build-system)
+    (arguments
+     (list
+      #:test-flags
+      ;; This wants to use pip install
+      '(list "--ignore=testing/test_upload.py"
+             ;; These complain about finding distutils.  It's not my fault,
+             ;; mate, setuptools is right there, but you won't pick it!
+             "--ignore=testing/test_list_remove.py"
+             "--ignore=testing/test_main.py"
+             "--ignore=testing/test_install.py"
+             "--ignore=testing/test_functional.py"
+             "--ignore=testing/test_test.py")
+      #:phases
+      '(modify-phases %standard-phases
+         (add-after 'unpack 'patch-tests
+           (lambda _
+             ;; Do not replace the directory name of the store item.
+             (substitute* "testing/conftest.py"
+               (("\"devpi-server\", \"devpi-init\"")
+                "\"/bin/devpi-server\", \"/bin/devpi-init\""))))
+         (add-before 'check 'set-HOME
+           ;; Some tests need this
+           (lambda _ (setenv "HOME" "/tmp"))))))
+    (propagated-inputs (list python-pypa-build
+                             python-check-manifest
+                             python-colorama
+                             python-devpi-common
+                             python-iniconfig
+                             python-pkginfo
+                             python-platformdirs
+                             python-pluggy
+                             python-pypitoken
+                             python-tomli))
+    (native-inputs
+     (list python-devpi-server
+           python-pytest
+           python-setuptools
+           python-virtualenv))
+    (home-page "https://github.com/devpi/devpi";)
+    (synopsis "Devpi upload/install/... commands for Python developers")
+    (description
+     "The devpi command line tool is typically used in conjunction with
+devpi-server.  It allows to upload, test and install packages from devpi
+indexes.")
+    (license license:expat)))
+
 (define-public python-devpi-server
   (package
     (name "python-devpi-server")



reply via email to

[Prev in Thread] Current Thread [Next in Thread]