From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mp1 ([2001:41d0:2:bcc0::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by ms0.migadu.com with LMTPS id /RYwFQLnCmFVYQAAgWs5BA (envelope-from ) for ; Wed, 04 Aug 2021 21:14:10 +0200 Received: from aspmx1.migadu.com ([2001:41d0:2:bcc0::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by mp1 with LMTPS id 4NYBEALnCmGPAwAAbx9fmQ (envelope-from ) for ; Wed, 04 Aug 2021 19:14:10 +0000 Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by aspmx1.migadu.com (Postfix) with ESMTPS id CEED413809 for ; Wed, 4 Aug 2021 21:14:09 +0200 (CEST) Received: from localhost ([::1]:55284 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1mBMLA-0000Zt-TJ for larch@yhetil.org; Wed, 04 Aug 2021 15:14:08 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:37002) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1mBML4-0000ZU-2E for guix-patches@gnu.org; Wed, 04 Aug 2021 15:14:02 -0400 Received: from debbugs.gnu.org ([209.51.188.43]:33633) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1mBML3-0000di-Ri for guix-patches@gnu.org; Wed, 04 Aug 2021 15:14:01 -0400 Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1mBML3-0005lG-NV for guix-patches@gnu.org; Wed, 04 Aug 2021 15:14:01 -0400 X-Loop: help-debbugs@gnu.org Subject: [bug#49281] Add dynaconf Resent-From: Sarah Morgensen Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Wed, 04 Aug 2021 19:14:01 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 49281 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: Giacomo Leidi Cc: 49835@debbugs.gnu.org, 49281@debbugs.gnu.org Received: via spool by 49281-submit@debbugs.gnu.org id=B49281.162810442122101 (code B ref 49281); Wed, 04 Aug 2021 19:14:01 +0000 Received: (at 49281) by debbugs.gnu.org; 4 Aug 2021 19:13:41 +0000 Received: from localhost ([127.0.0.1]:45173 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1mBMKY-0005k6-62 for submit@debbugs.gnu.org; Wed, 04 Aug 2021 15:13:41 -0400 Received: from out2.migadu.com ([188.165.223.204]:54055) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1mBMKT-0005js-FZ; Wed, 04 Aug 2021 15:13:28 -0400 X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mgsn.dev; s=key1; t=1628104404; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=LvRs2C9ESZ3opdegv02Zm2caPxcM3YM4mDQSYM0NxVQ=; b=iwKB/eYI7u9RFlpFjhm7Myi8cSJtUN5NeX4pc5GzBOamCxbQrb20cspC45e8yOhTPQCq6E f11xP7PEp8kUtyM7Vv+cd92f2M0+uAJqvhctyarQ758n7dTidfPawzXo6EdVhTP4kIpUFf le7myG+HbUySz2NAb3KAdZz7BZ1g9CY= From: Sarah Morgensen References: <20210802181359.10695-1-goodoldpaul@autistici.org> <20210802181359.10695-7-goodoldpaul@autistici.org> Date: Wed, 04 Aug 2021 12:13:21 -0700 In-Reply-To: <20210802181359.10695-7-goodoldpaul@autistici.org> (Giacomo Leidi's message of "Mon, 2 Aug 2021 20:13:59 +0200") Message-ID: <86czqt2fce.fsf_-_@mgsn.dev> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="=-=-=" X-Migadu-Auth-User: iskarian@mgsn.dev X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list X-BeenThere: guix-patches@gnu.org List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: guix-patches-bounces+larch=yhetil.org@gnu.org Sender: "Guix-patches" X-Migadu-Flow: FLOW_IN ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org; s=key1; t=1628104450; h=from:from:sender:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:resent-cc:resent-from:resent-sender: resent-message-id:in-reply-to:in-reply-to:references:references: list-id:list-help:list-unsubscribe:list-subscribe:list-post: dkim-signature; bh=LvRs2C9ESZ3opdegv02Zm2caPxcM3YM4mDQSYM0NxVQ=; b=LhHHu5DbIxdMWGtUqENl2ta82XvWBEzJ/pQER3uhabsa96YdgWGRf+x77LbzI3WgFDOelC S1ItXx0gpMO9ndBwCbCxq0uzFVijpSXtV2eXxFA+vS+nzMowEuuZzNeZxCRRtYF9GAfru7 MSWMXgnx7zipsvIjFCkWcYIU6MK914weQl9mcGGdaqcLThOF4R3aQdRpk4K3XROrxRVi5M EG8/Tx09mDHuEIFDVx3iKepKoKojxB4tv6l2qXNXQYpFCd3muNi+poDTeNkmf/5kEj+/tO tAEq9L86SG+mVTx5CZZ8a21JRbBvk/bqnRtxV48k1gmJSeFJnlJgEaSnkQ1xLQ== ARC-Seal: i=1; s=key1; d=yhetil.org; t=1628104450; a=rsa-sha256; cv=none; b=Wn6E1L3fwnxquiGVuCAQmOzBB/EX/zEW55h0u3UvcxxbMT2sagAldgflsN9mxRnEGpjd2J 6LWfjNx2lndwM+WSNX4o9RV7+zzvhv3IN8o2UL5m5Mysn0IhTPNMteqP3YQDh8YOvBqt1Z SNwJ9rFoIwcmzg+thsz3tbqG4Voh9d9UbVu/GrpO8u0TGEHFRQ1ZXzxycG9TQ25mAD2vYz 3DiyMockz+gYgcdopMM528bx4okn5lGgWAe4FXrlgbRxhppdSLEm714YXVxz/EHv2L17ge Kay67mPU8EocSMrFfYr2g8TN2f7llFyHccszwKO1sGNG5XiUhhW06aDWEpPHog== ARC-Authentication-Results: i=1; aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=mgsn.dev header.s=key1 header.b="iwKB/eYI"; dmarc=fail reason="SPF not aligned (relaxed)" header.from=mgsn.dev (policy=none); spf=pass (aspmx1.migadu.com: domain of guix-patches-bounces@gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=guix-patches-bounces@gnu.org X-Migadu-Spam-Score: 0.19 Authentication-Results: aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=mgsn.dev header.s=key1 header.b="iwKB/eYI"; dmarc=fail reason="SPF not aligned (relaxed)" header.from=mgsn.dev (policy=none); spf=pass (aspmx1.migadu.com: domain of guix-patches-bounces@gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=guix-patches-bounces@gnu.org X-Migadu-Queue-Id: CEED413809 X-Spam-Score: 0.19 X-Migadu-Scanner: scn1.migadu.com X-TUID: 6AE2Xc381KKl --=-=-= Content-Type: text/plain Hi, Thanks again for your work on packaging this! Giacomo Leidi writes: > * gnu/packages/python-xyz.scm (python-colorama-0.4.1): New variable, > (python-dotenv-0.13.0): New variable, > (dynaconf): New variable. Packages typically get one commit per package (so this would be three commits). > * gnu/packages/patches/dynaconf-Unvendor-dependencies.patch: New file. ^ an extra space slipped in here. > * local.mk (dist_patch_DATA): Register it. > --- > gnu/local.mk | 1 + > .../dynaconf-Unvendor-dependencies.patch | 161 ++++++++++++++++++ > gnu/packages/python-xyz.scm | 95 +++++++++++ > 3 files changed, 257 insertions(+) > create mode 100644 gnu/packages/patches/dynaconf-Unvendor-dependencies.patch > > diff --git a/gnu/local.mk b/gnu/local.mk > index 9e8f2d702d..847137b77c 100644 > --- a/gnu/local.mk > +++ b/gnu/local.mk > @@ -972,6 +972,7 @@ dist_patch_DATA = \ > %D%/packages/patches/dstat-skip-devices-without-io.patch \ > %D%/packages/patches/dune-istl-2.7-fix-non-mpi-tests.patch \ > %D%/packages/patches/dvd+rw-tools-add-include.patch \ > + %D%/packages/patches/dynaconf-Unvendor-dependencies.patch \ > %D%/packages/patches/ecl-16-format-directive-limit.patch \ > %D%/packages/patches/ecl-16-ignore-stderr-write-error.patch \ > %D%/packages/patches/ecl-16-libffi.patch \ > diff --git a/gnu/packages/patches/dynaconf-Unvendor-dependencies.patch b/gnu/packages/patches/dynaconf-Unvendor-dependencies.patch > new file mode 100644 > index 0000000000..10b72d5013 > --- /dev/null > +++ b/gnu/packages/patches/dynaconf-Unvendor-dependencies.patch > @@ -0,0 +1,161 @@ > +From 3558d30d5916ec6a91ce0d9c201ff9a11675d7c3 Mon Sep 17 00:00:00 2001 > +From: Giacomo Leidi > +Date: Mon, 2 Aug 2021 19:29:07 +0200 > +Subject: [PATCH] Use system dependencies. > + > +Box was not unvendored because it appears to be heavily patched. > +--- > + dynaconf/cli.py | 4 ++-- > + dynaconf/default_settings.py | 2 +- > + dynaconf/loaders/env_loader.py | 2 +- > + dynaconf/loaders/toml_loader.py | 2 +- > + dynaconf/loaders/yaml_loader.py | 2 +- > + dynaconf/utils/parse_conf.py | 2 +- > + dynaconf/vendor/box/converters.py | 6 +++--- > + dynaconf/vendor/box/from_file.py | 6 +++--- > + tests/test_cli.py | 2 +- > + 9 files changed, 14 insertions(+), 14 deletions(-) > + > +diff --git a/dynaconf/cli.py b/dynaconf/cli.py > +index 2d45e52..7df767a 100644 > +--- a/dynaconf/cli.py > ++++ b/dynaconf/cli.py > +@@ -20,8 +20,8 @@ from dynaconf.utils.functional import empty > + from dynaconf.utils.parse_conf import parse_conf_data > + from dynaconf.validator import ValidationError > + from dynaconf.validator import Validator > +-from dynaconf.vendor import click > +-from dynaconf.vendor import toml > ++import click > ++import toml > + > + > + CWD = Path.cwd() > +diff --git a/dynaconf/default_settings.py b/dynaconf/default_settings.py > +index 66601b0..9605fc5 100644 > +--- a/dynaconf/default_settings.py > ++++ b/dynaconf/default_settings.py > +@@ -8,7 +8,7 @@ from dynaconf.utils import upperfy > + from dynaconf.utils import warn_deprecations > + from dynaconf.utils.files import find_file > + from dynaconf.utils.parse_conf import parse_conf_data > +-from dynaconf.vendor.dotenv import load_dotenv > ++from dotenv import load_dotenv > + > + > + def try_renamed(key, value, older_key, current_key): > +diff --git a/dynaconf/loaders/env_loader.py b/dynaconf/loaders/env_loader.py > +index e7b13bd..b034c8a 100644 > +--- a/dynaconf/loaders/env_loader.py > ++++ b/dynaconf/loaders/env_loader.py > +@@ -2,7 +2,7 @@ from os import environ > + > + from dynaconf.utils import upperfy > + from dynaconf.utils.parse_conf import parse_conf_data > +-from dynaconf.vendor.dotenv import cli as dotenv_cli > ++from dotenv import cli as dotenv_cli > + > + > + IDENTIFIER = "env" > +diff --git a/dynaconf/loaders/toml_loader.py b/dynaconf/loaders/toml_loader.py > +index 07b973f..d81d675 100644 > +--- a/dynaconf/loaders/toml_loader.py > ++++ b/dynaconf/loaders/toml_loader.py > +@@ -5,7 +5,7 @@ from dynaconf import default_settings > + from dynaconf.constants import TOML_EXTENSIONS > + from dynaconf.loaders.base import BaseLoader > + from dynaconf.utils import object_merge > +-from dynaconf.vendor import toml > ++import toml > + > + > + def load(obj, env=None, silent=True, key=None, filename=None): > +diff --git a/dynaconf/loaders/yaml_loader.py b/dynaconf/loaders/yaml_loader.py > +index 33c6532..3ef419a 100644 > +--- a/dynaconf/loaders/yaml_loader.py > ++++ b/dynaconf/loaders/yaml_loader.py > +@@ -7,7 +7,7 @@ from dynaconf.constants import YAML_EXTENSIONS > + from dynaconf.loaders.base import BaseLoader > + from dynaconf.utils import object_merge > + from dynaconf.utils.parse_conf import try_to_encode > +-from dynaconf.vendor.ruamel import yaml > ++from ruamel import yaml > + > + # Add support for Dynaconf Lazy values to YAML dumper > + yaml.SafeDumper.yaml_representers[ > +diff --git a/dynaconf/utils/parse_conf.py b/dynaconf/utils/parse_conf.py > +index 5fc8234..6509c35 100644 > +--- a/dynaconf/utils/parse_conf.py > ++++ b/dynaconf/utils/parse_conf.py > +@@ -8,7 +8,7 @@ from dynaconf.utils import extract_json_objects > + from dynaconf.utils import multi_replace > + from dynaconf.utils import recursively_evaluate_lazy_format > + from dynaconf.utils.boxing import DynaBox > +-from dynaconf.vendor import toml > ++import toml > + > + try: > + from jinja2 import Environment > +diff --git a/dynaconf/vendor/box/converters.py b/dynaconf/vendor/box/converters.py > +index 93cdcfb..c81877a 100644 > +--- a/dynaconf/vendor/box/converters.py > ++++ b/dynaconf/vendor/box/converters.py > +@@ -7,9 +7,9 @@ _B='utf-8' > + _A=None > + import csv,json,sys,warnings > + from pathlib import Path > +-import dynaconf.vendor.ruamel.yaml as yaml > ++import ruamel.yaml as yaml > + from dynaconf.vendor.box.exceptions import BoxError,BoxWarning > +-from dynaconf.vendor import toml > ++import toml > + BOX_PARAMETERS='default_box','default_box_attr','conversion_box','frozen_box','camel_killer_box','box_safe_prefix','box_duplicates','ordered_box','default_box_none_transform','box_dots','modify_tuples_box','box_intact_types','box_recast' > + def _exists(filename,create=_E): > + A=filename;B=Path(A) > +@@ -75,4 +75,4 @@ def _to_csv(box_list,filename,encoding=_B,errors=_C): > + for G in A:D.writerow(G) > + def _from_csv(filename,encoding=_B,errors=_C): > + A=filename;_exists(A) > +- with open(A,_G,encoding=encoding,errors=errors,newline='')as B:C=csv.DictReader(B);return[A for A in C] > +\ No newline at end of file > ++ with open(A,_G,encoding=encoding,errors=errors,newline='')as B:C=csv.DictReader(B);return[A for A in C] > +diff --git a/dynaconf/vendor/box/from_file.py b/dynaconf/vendor/box/from_file.py > +index daa1137..4a2739d 100644 > +--- a/dynaconf/vendor/box/from_file.py > ++++ b/dynaconf/vendor/box/from_file.py > +@@ -1,8 +1,8 @@ > + from json import JSONDecodeError > + from pathlib import Path > + from typing import Union > +-from dynaconf.vendor.toml import TomlDecodeError > +-from dynaconf.vendor.ruamel.yaml import YAMLError > ++from toml import TomlDecodeError > ++from ruamel.yaml import YAMLError > + from .exceptions import BoxError > + from .box import Box > + from .box_list import BoxList > +@@ -31,4 +31,4 @@ def box_from_file(file,file_type=None,encoding='utf-8',errors='strict'): > + if A.suffix in('.json','.jsn'):return _to_json(B) > + if A.suffix in('.yaml','.yml'):return _to_yaml(B) > + if A.suffix in('.tml','.toml'):return _to_toml(B) > +- raise BoxError(f"Could not determine file type based off extension, please provide file_type") > +\ No newline at end of file > ++ raise BoxError(f"Could not determine file type based off extension, please provide file_type") > +diff --git a/tests/test_cli.py b/tests/test_cli.py > +index 9338851..726b009 100644 > +--- a/tests/test_cli.py > ++++ b/tests/test_cli.py > +@@ -11,7 +11,7 @@ from dynaconf.cli import main > + from dynaconf.cli import read_file_in_root_directory > + from dynaconf.cli import WRITERS > + from dynaconf.utils.files import read_file > +-from dynaconf.vendor.click.testing import CliRunner > ++from click.testing import CliRunner > + > + > + runner = CliRunner() > + > +base-commit: 952e713353356ea701196ac5ad204c72fd097e58 > +-- > +2.32.0 > + > diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm > index b7e20d8358..f4f3b7fb3f 100644 > --- a/gnu/packages/python-xyz.scm > +++ b/gnu/packages/python-xyz.scm > @@ -137,6 +137,7 @@ > #:use-module (gnu packages crypto) > #:use-module (gnu packages databases) > #:use-module (gnu packages dbm) > + #:use-module (gnu packages django) > #:use-module (gnu packages djvu) > #:use-module (gnu packages docker) > #:use-module (gnu packages enchant) > @@ -12473,6 +12474,16 @@ text.") > (home-page "https://pypi.org/project/colorama/") > (license license:bsd-3))) > > +(define-public python-colorama-0.4.1 > + (package (inherit python-colorama) > + (version "0.4.1") > + (source > + (origin > + (method url-fetch) > + (uri (pypi-uri "colorama" version)) > + (sha256 > + (base32 "0ba247bx5pc60hcpbf3rjsqk0whilg241i9qdfnlcwij5qgdgvh5")))))) > + > (define-public python2-colorama > (package-with-python2 python-colorama)) > > @@ -26292,6 +26303,18 @@ Voronoi diagram.") > read key-value pairs from a .env file and set them as environment variables") > (license license:bsd-3))) > > +(define-public python-dotenv-0.13.0 > + (package (inherit python-dotenv) > + (name "python-dotenv") > + (version "0.13.0") > + (source > + (origin > + (method url-fetch) > + (uri (pypi-uri "python-dotenv" version)) > + (sha256 > + (base32 > + "0x5dagmfn31phrbxlwacw3s4w5vibv8fxqc62nqcdvdhjsy0k69v")))))) > + > (define-public python-box > (package > (name "python-box") > @@ -26315,3 +26338,75 @@ read key-value pairs from a .env file and set them as environment variables") > "This package provides the @code{python-box} Python module. > It implements advanced Python dictionaries with dot notation access.") > (license license:expat))) > + > +(define-public dynaconf > + (package > + (name "dynaconf") > + (version "3.1.4") > + (source > + (origin > + (method git-fetch) > + (uri > + (git-reference > + (url "https://github.com/rochacbruno/dynaconf") > + (commit version))) > + (file-name (git-file-name name version)) > + (sha256 > + (base32 > + "0dafd7hb691g6s3yjfvl5gph5md73n6g9j44kjpbnbbilr5pc85g")) > + (patches (search-patches "dynaconf-Unvendor-dependencies.patch")) > + (modules '((guix build utils))) > + (snippet '(begin > + ;; Remove vendored dependencies > + (let ((unvendor '("click" "dotenv" "ruamel" "toml"))) > + (with-directory-excursion "dynaconf/vendor" > + (for-each delete-file-recursively unvendor)) > + (with-directory-excursion "dynaconf/vendor_src" > + (for-each delete-file-recursively unvendor))))))) > + (build-system python-build-system) > + (arguments > + `(#:phases > + (modify-phases %standard-phases > + (replace 'check > + (lambda* (#:key tests? outputs #:allow-other-keys) > + (when tests? > + (setenv "PATH" > + (string-append (assoc-ref outputs "out") "/bin:" > + (getenv "PATH"))) > + ;; These tests depend on hvac and a > + ;; live Vault process. > + (delete-file "tests/test_vault.py") > + (invoke "make" "test_only")) > + #t))))) ^ Nitpick: phases no longer have to end in #t, though it doesn't hurt. > + (propagated-inputs > + `(("python-click" ,python-click) > + ("python-dotenv" ,python-dotenv-0.13.0) > + ("python-ruamel.yaml" ,python-ruamel.yaml) > + ("python-toml" ,python-toml))) > + (native-inputs > + `(("make" ,gnu-make) > + ("python-codecov" ,python-codecov) > + ("python-configobj" ,python-configobj) > + ("python-colorama" ,python-colorama-0.4.1) > + ("python-django" ,python-django) > + ("python-flake8" ,python-flake8) > + ("python-flake8-debugger" ,python-flake8-debugger) > + ("python-flake8-print" ,python-flake8-print) > + ("python-flake8-todo" ,python-flake8-todo) > + ("python-flask" ,python-flask) > + ("python-future" ,python-future) > + ("python-pep8-naming" ,python-pep8-naming) > + ("python-pytest" ,python-pytest-6) > + ("python-pytest-cov" ,python-pytest-cov) > + ("python-pytest-forked" ,python-pytest-forked) > + ("python-pytest-mock" ,python-pytest-mock) > + ("python-pytest-xdist" ,python-pytest-xdist) > + ("python-radon" ,python-radon))) With the test_only target, I think only a few of these are actually required. Also, configobj should probably be a propagated input as dynaconf uses it for ini files. I've attached a patch below. Notably, this seems to make python-flake8-debugger, python-flake8-todo, python-pep8-naming and python-colorama-0.4.1 unneccessary (I think because they are used for code linting, and the test_only target doesn't do linting). WDYT? (Even if they aren't necessary for packaging dynaconf, you're still welcome to send them as separate patches :) > + (home-page > + "https://github.com/rochacbruno/dynaconf") ^ Nitpick: this can go on one line > + (synopsis > + "The dynamic configurator for your Python Project") ^ Likewise > + (description > + "This package provides @code{dynaconf} the dynamic configurator for > +your Python Project.") Even as someone who has used python a lot before, this doesn't tell me anything about what dynaconf actually does or why I might want to install it. (Or, is it even an end-user package?) For examples, take a look at pretty much any package which has more than two lines in its description (like, say, python-seaborn). I know writing a good description can be difficult, but they tend to stick around and read by lots of people, so getting it right the first time is important! > + (license license:expat))) --=-=-= Content-Type: text/x-patch Content-Disposition: inline; filename=python-dynaconf-inputs.patch Content-Description: python-dynaconf-3.1.4-inputs.patch diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm index f4f3b7fb3f..58defd9fcc 100644 --- a/gnu/packages/python-xyz.scm +++ b/gnu/packages/python-xyz.scm @@ -26380,28 +26380,16 @@ It implements advanced Python dictionaries with dot notation access.") #t))))) (propagated-inputs `(("python-click" ,python-click) + ("python-configobj" ,python-configobj) ("python-dotenv" ,python-dotenv-0.13.0) ("python-ruamel.yaml" ,python-ruamel.yaml) ("python-toml" ,python-toml))) (native-inputs - `(("make" ,gnu-make) - ("python-codecov" ,python-codecov) - ("python-configobj" ,python-configobj) - ("python-colorama" ,python-colorama-0.4.1) - ("python-django" ,python-django) - ("python-flake8" ,python-flake8) - ("python-flake8-debugger" ,python-flake8-debugger) - ("python-flake8-print" ,python-flake8-print) - ("python-flake8-todo" ,python-flake8-todo) + `(("python-django" ,python-django) ("python-flask" ,python-flask) - ("python-future" ,python-future) - ("python-pep8-naming" ,python-pep8-naming) ("python-pytest" ,python-pytest-6) ("python-pytest-cov" ,python-pytest-cov) - ("python-pytest-forked" ,python-pytest-forked) - ("python-pytest-mock" ,python-pytest-mock) - ("python-pytest-xdist" ,python-pytest-xdist) - ("python-radon" ,python-radon))) + ("python-pytest-mock" ,python-pytest-mock))) (home-page "https://github.com/rochacbruno/dynaconf") (synopsis --=-=-= Content-Type: text/plain -- Sarah --=-=-=--