Developer Installation
This guide will walk you through setting up a development environment for
astrodata
. If you are a user looking to install astrodata
for personal use,
either as a developer or as a user, and are just looking to install the package
as a dependency, see the Quick Start.
Developer Documentation Overview
This page specifically helps with setting up a development environment and running the unit tests.
Developer environment setup
This guide will walk you through setting up a development environment for
astrodata
. If you are a user looking to install astrodata
for personal use,
and are just looking to install the package as a dependency, see the
Quick Start.
Note
This guide assumes you are familiar with the basics of Python development, including virtual environments, package management, and testing. It focuses on setting up your development environment, not why or how these things work.
Warning
This guide only applies to development on UNIX-like systems, like linux distributions and macOS. If you’re developing on Windows, you may need to adapt some of the commands and instructions to work with your system.
Requirements
To install astrodata
, you will need the following:
Python 3.10, 3.11, or 3.12
Poetry in some flavor
poetry-plugin-export
, installed into the same environment as PoetryNox (optional, see note below)
Please see the Poetry and nox documentation for installation instructions. Note that it is not recommended to install Poetry with pip, especially in your working directory for the project. There are several solutions to this in their documentation.
We recommend using pipx to install Poetry and nox, as it will install them in isolated environments and make them easier to manage. If you’re using pipx, you only need to copy/paste the following lines to ensure you have everything installed properly:
pipx install poetry
poetry self add poetry-plugin-export
pipx install nox
Note
If you’d prefer not to install nox, you can invoke it using Poetry:
poetry run nox [...arguments...]
Instructions
Clone the repository
First, clone the repository from GitHub. Using the command line:
git clone git@github.com:GeminiDRSoftware/astrodata.git
Or use your preferred method for cloning a repository.
Install the dependencies
cd
into the repository directory:
cd astrodata
If you are not already inside a virtual environment of some flavor, such as a
conda
or venv
environment, you can have nox
create one for you:
nox -s devshell # Creates a virtual environment
nox -s devconda # Creates a conda environment
Note
We recommend using the devshell
session, as venv
environments are
more flexible and allow for more pythonic automation in the development
process. The devconda
session is provided for users who prefer to use
conda environments, but it’s not as flexible as the devshell
session and
may require manual tweaking.
Warning
Both of these sessions will create a new environment, either located at
.astrodata_venv
or in the astrodata
conda environment. It will
remove any environments found there (for consistency when resetting the
environment).
Otherwise, to install the dependencies in the current environment–or one you’ve set up and activate yourself–navigate to the root of the repository and run:
poetry install
This will install all the dependencies needed to run astrodata
within your
virtual environment, including all test, development, and documentation
dependencies. This installs astrodata
in a way that’s equivalent to
installing with
pip in editable mode <editable_pip>.
Note
You can install specific dependency groups by running poetry install
--only
. For example, to install the main
and test
dependencies:
poetry install --only main,test
The groups must be separated by commas, and the groups are defined in the
pyproject.toml
file.
Unless you are working on the documentation or testing specifically, you will likely never need to isolate dependencies in this way. This is primarily used for optimizing CI/CD workflows.
Run the tests
astrodata
uses nox for running tests. To run the tests, simply run:
nox
This will run all linting checks and unit tests for any supported Python distributions it can find, reporting on the coverage at the end of the run.
You can see the available sessions by running:
nox -l
This will output information about available session to run. To select a
specific session, use the -s
flag. For example, to run the unit tests on a
Python 3.10 build of astrodata
:
nox -s "build_tests-3.10(unit)""
Or, to run the normal unit tests and not the linter:
nox -s "unit_tests"
All tests will be run in isolated environments based on specifications in the
noxfile.py
file in the main project directory. Those environments, by
default, are re-created each time you run the tests. To avoid that, you can
pass the --reuse-existing-virtualenvs
/-r
flag to nox, which will
reuse any existing virtual environments it finds. If the environment isn’t
found, it will be made.
Other development commands
Development without a Virtual Environment
If you don’t need a virtual environment, you can use the poetry run
command
to run commands in the environment without activating it. For example, to run
the tests without activating the environment, you can run:
poetry run nox
Copy/Paste to create and enter a developer environment
This is for convenience to copy/paste the above commands required to create and enter a developer shell.
# Start in the directory you'd like to keep astrodata in.
git clone git@github.com:GeminiDRSoftware/astrodata.git
cd astrodata
nox -s devshell
source .astrodata_venv/bin/activate