{"id":30240414,"url":"https://github.com/hypothesis/tox-envfile","last_synced_at":"2025-08-15T04:38:37.519Z","repository":{"id":43422160,"uuid":"212414817","full_name":"hypothesis/tox-envfile","owner":"hypothesis","description":"A tox plugin that loads envvars from env files into your tox envs","archived":false,"fork":false,"pushed_at":"2025-06-13T14:54:07.000Z","size":54,"stargazers_count":8,"open_issues_count":0,"forks_count":0,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-07-14T09:00:19.536Z","etag":null,"topics":["tox","tox-plugin"],"latest_commit_sha":null,"homepage":"","language":"Makefile","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-2-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/hypothesis.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2019-10-02T18:36:40.000Z","updated_at":"2025-07-01T19:10:52.000Z","dependencies_parsed_at":"2023-02-13T20:55:20.655Z","dependency_job_id":"724b1447-4b9e-4a3f-b656-192f4681ba4a","html_url":"https://github.com/hypothesis/tox-envfile","commit_stats":{"total_commits":24,"total_committers":4,"mean_commits":6.0,"dds":"0.16666666666666663","last_synced_commit":"6e0b1a14f1b7de56b19801a56c8d9388cd5ae1c3"},"previous_names":[],"tags_count":6,"template":false,"template_full_name":null,"purl":"pkg:github/hypothesis/tox-envfile","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hypothesis%2Ftox-envfile","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hypothesis%2Ftox-envfile/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hypothesis%2Ftox-envfile/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hypothesis%2Ftox-envfile/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/hypothesis","download_url":"https://codeload.github.com/hypothesis/tox-envfile/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hypothesis%2Ftox-envfile/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":270524432,"owners_count":24600195,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-08-15T02:00:12.559Z","response_time":110,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["tox","tox-plugin"],"created_at":"2025-08-15T04:38:27.329Z","updated_at":"2025-08-15T04:38:37.506Z","avatar_url":"https://github.com/hypothesis.png","language":"Makefile","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003ca href=\"https://github.com/hypothesis/tox-envfile/actions/workflows/ci.yml?query=branch%3Amain\"\u003e\u003cimg src=\"https://img.shields.io/github/actions/workflow/status/hypothesis/tox-envfile/ci.yml?branch=main\"\u003e\u003c/a\u003e\n\u003ca href=\"https://pypi.org/project/tox-envfile\"\u003e\u003cimg src=\"https://img.shields.io/pypi/v/tox-envfile\"\u003e\u003c/a\u003e\n\u003ca\u003e\u003cimg src=\"https://img.shields.io/badge/python-3.12 | 3.11 | 3.10 | 3.9-success\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/hypothesis/tox-envfile/blob/main/LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/badge/license-BSD--2--Clause-success\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/hypothesis/cookiecutters/tree/main/pypackage\"\u003e\u003cimg src=\"https://img.shields.io/badge/cookiecutter-pypackage-success\"\u003e\u003c/a\u003e\n\u003ca href=\"https://black.readthedocs.io/en/stable/\"\u003e\u003cimg src=\"https://img.shields.io/badge/code%20style-black-000000\"\u003e\u003c/a\u003e\n\n# tox-envfile\n\nLoad env files in your tox envs.\n\ntox-envfile reads environment variables from a file named `.devdata.env` in the\nsame directory as your `tox.ini` file and adds them to the environment that tox\nruns your commands in.\n\nThis is a pretty dumb plugin for now: all of the environment variables in\n`.devdata.env` will be loaded into the environment for every tox env that you\nrun, unconditionally. Any existing envvars with conflicting names will be\noverwritten. Only a single environment file is supported and it must be named\n`.devdata.env`.\n\nenv File Format\n---------------\n\n[python-dotenv](https://saurabh-kumar.com/python-dotenv/) is used for the env file parsing.\n\nThe `.devdata.env` file should be an env file with contents that look like\nthis:\n\n```shell\n# a comment that will be ignored.\nREDIS_ADDRESS=localhost:6379\nMEANING_OF_LIFE=42\nMULTILINE_VAR=\"hello\\nworld\"\n```\n\nOr like this:\n\n```shell\nexport S3_BUCKET=YOURS3BUCKET\nexport SECRET_KEY=YOURSECRETKEYGOESHERE\n```\n\nPOSIX variable expansion works, using variables from the environment or from\nearlier lines in the env file:\n\n```shell\nCONFIG_PATH=${HOME}/.config/foo\nDOMAIN=example.org\nEMAIL=admin@${DOMAIN}\n```\n\n## Setting up Your tox-envfile Development Environment\n\nFirst you'll need to install:\n\n* [Git](https://git-scm.com/).\n  On Ubuntu: `sudo apt install git`, on macOS: `brew install git`.\n* [GNU Make](https://www.gnu.org/software/make/).\n  This is probably already installed, run `make --version` to check.\n* [pyenv](https://github.com/pyenv/pyenv).\n  Follow the instructions in pyenv's README to install it.\n  The **Homebrew** method works best on macOS.\n  The **Basic GitHub Checkout** method works best on Ubuntu.\n  You _don't_ need to set up pyenv's shell integration (\"shims\"), you can\n  [use pyenv without shims](https://github.com/pyenv/pyenv#using-pyenv-without-shims).\n\nThen to set up your development environment:\n\n```terminal\ngit clone https://github.com/hypothesis/tox-envfile.git\ncd tox-envfile\nmake help\n```\n\n## Releasing a New Version of the Project\n\n1. First, to get PyPI publishing working you need to go to:\n   \u003chttps://github.com/organizations/hypothesis/settings/secrets/actions/PYPI_TOKEN\u003e\n   and add tox-envfile to the `PYPI_TOKEN` secret's selected\n   repositories.\n\n2. Now that the tox-envfile project has access to the `PYPI_TOKEN` secret\n   you can release a new version by just [creating a new GitHub release](https://docs.github.com/en/repositories/releasing-projects-on-github/managing-releases-in-a-repository).\n   Publishing a new GitHub release will automatically trigger\n   [a GitHub Actions workflow](.github/workflows/pypi.yml)\n   that will build the new version of your Python package and upload it to\n   \u003chttps://pypi.org/project/tox-envfile\u003e.\n\n## Changing the Project's Python Versions\n\nTo change what versions of Python the project uses:\n\n1. Change the Python versions in the\n   [cookiecutter.json](.cookiecutter/cookiecutter.json) file. For example:\n\n   ```json\n   \"python_versions\": \"3.10.4, 3.9.12\",\n   ```\n\n2. Re-run the cookiecutter template:\n\n   ```terminal\n   make template\n   ```\n\n3. Commit everything to git and send a pull request\n\n## Changing the Project's Python Dependencies\n\nTo change the production dependencies in the `setup.cfg` file:\n\n1. Change the dependencies in the [`.cookiecutter/includes/setuptools/install_requires`](.cookiecutter/includes/setuptools/install_requires) file.\n   If this file doesn't exist yet create it and add some dependencies to it.\n   For example:\n\n   ```\n   pyramid\n   sqlalchemy\n   celery\n   ```\n\n2. Re-run the cookiecutter template:\n\n   ```terminal\n   make template\n   ```\n\n3. Commit everything to git and send a pull request\n\nTo change the project's formatting, linting and test dependencies:\n\n1. Change the dependencies in the [`.cookiecutter/includes/tox/deps`](.cookiecutter/includes/tox/deps) file.\n   If this file doesn't exist yet create it and add some dependencies to it.\n   Use tox's [factor-conditional settings](https://tox.wiki/en/latest/config.html#factors-and-factor-conditional-settings)\n   to limit which environment(s) each dependency is used in.\n   For example:\n\n   ```\n   lint: flake8,\n   format: autopep8,\n   lint,tests: pytest-faker,\n   ```\n\n2. Re-run the cookiecutter template:\n\n   ```terminal\n   make template\n   ```\n\n3. Commit everything to git and send a pull request\n\nTesting Manually\n----------------\n\nTo test it manually you can install your local development copy of\n`tox-envfile` into the local development environment of another tox-using\nproject such as\n[cookiecutter-pypackage-test](https://github.com/hypothesis/cookiecutter-pypackage-test):\n\n1. Install a local development copy of `cookiecutter-pypackage-test` in a temporary directory:\n\n   ```terminal\n   git clone https://github.com/hypothesis/cookiecutter-pypackage-test.git /tmp/cookiecutter-pypackage-test\n   ```\n\n2. Run `cookiecutter-pypackage-test`'s `make sure` command to make sure that\n   everything is working and to trigger tox to create its `.tox/.tox`\n   venv:\n\n   ```terminal\n   make --directory \"/tmp/cookiecutter-pypackage-test\" sure\n   ```\n\n3. Uninstall the production copy of `tox-envfile` from `cookiecutter-pypackage-test`'s `.tox/.tox` venv:\n\n   ```terminal\n   /tmp/cookiecutter-pypackage-test/.tox/.tox/bin/pip uninstall tox-envfile\n   ```\n\n4. Install your local development copy of `tox-envfile` into `cookiecutter-pypackage-test`'s `.tox/.tox` venv:\n\n   ```terminal\n   /tmp/cookiecutter-pypackage-test/.tox/.tox/bin/pip install -e .\n   ```\n\n5. Now `cookiecutter-pypackage-test` commands will use your local development copy of `tox-envfile`:\n\n   ```terminal\n   make --directory \"/tmp/cookiecutter-pypackage-test\" test\n   ```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhypothesis%2Ftox-envfile","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fhypothesis%2Ftox-envfile","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhypothesis%2Ftox-envfile/lists"}