This repository is organized as follows:
Fork this repo and clone your fork. (GitHub docs)
GITHUB_USERNAME="YOUR-GITHUB-USERNAME" \ git clone https://github.com/${GITHUB_USERNAME}/hamilton.git cd ./hamilton git remote add upstream https://github.com/dagworks-inc/hamilton.git
Install the project's dependencies in your preferred method for managing python dependencies. For example, run the following to use venv.
python -m venv ./venv . ./venv/bin/activate pip install \ -r ./requirements.txt \ -r ./requirements-dev.txt \ -r ./requirements-test.txt
Set up pre-commit, which will run some lightweight formatting and linting tasks on every commit.
pre-commit install
Make sure your local copy of the main branch is up to date with the official hamilton repo.
git checkout main git pull upstream main # and might as well update your fork too! git push origin main
Create a new branch.
git checkout -b feat/some-feature
Make changes, commit them, and push them to your fork.
git push origin HEAD
Test your changes locally with pre-commit...
pre-commit run --all-files
...and by following the steps in “How to run unit tests”.
Navigate to https://github.com/dagworks-inc/hamilton/pulls and open a pull request.
You need to have installed the requirements-test.txt dependencies into the environment you're running for this to work. You can run tests two ways:
.circleci/config.yml which also shows commands to run tests from the command line.The most reliable way to run hamilton's unit tests is to simulate its continuous integration (CI) environment in docker.
hamilton's CI logic is defined in shell scripts, whose behavior changes based on environment variable TASK.
The following values for TASK are recognized:
async = unit tests using the async driverdask = unit tests using the dask adapterintegrations = tests on integrations with other frameworkspre-commit = static analysis (i.e. linting)pyspark = unit tests using the spark adapterray = unit tests using the ray adaptertests = core unit tests with minimal requirementsChoose a Python version and task.
PYTHON_VERSION='3.8' TASK=tests
Then run the tests for that combination in a container.
docker run \ --rm \ --entrypoint="" \ -v "$(pwd)":/opt/testing \ --workdir /opt/testing \ --env TASK=${TASK} \ -it circleci/python:${PYTHON_VERSION} \ /bin/bash -c '.ci/setup.sh && .ci/test.sh'
You can debug and execute unit tests in pycharm easily. To set it up, you just hit Edit configurations and then add New > Python Tests > pytest. You then want to specify the tests/ folder under Script path, and ensure the python environment executing it is the appropriate one with all the dependencies installed. If you add -v to the additional arguments part, you'll then get verbose diffs if any tests fail.
You need to install the circleci command line tooling for this to work. See https://circleci.com/docs/local-cli/ for details. Once you have installed it you just need to run circleci local execute from the root directory and it'll run the entire suite of tests that are setup to run each time you push a commit to a branch in github.
These are the steps to push to pypi. This is taken from the python packaging tutorial.
Have an account & be granted the ability to push to sf-hamilton on testpypi & real pypi.
Setup API tokens and add them to your ~/.pypirc.
Run python3 -m pip install --upgrade build.
Run python3 -m pip install --upgrade twine
Run python3 -m build to build Hamilton. It should create things in dist/*.
Push to test pypi - python3 -m twine upload --repository testpypi dist/*.
Note: you cannot push the same version twice to test or real pypi. So it‘s useful to append -rcX to the version. Once you’re happy, you can remove that; just remember to not check that in.
Validate you can install from testpypi - follow the URL output.
If you can, then push to real pypi. python3 -m twine upload dist/*
Double check you can download and install what you just pushed in a fresh environment. A good thing to test is to run the hello world example.
Now that you've pushed to pypi, announce your release! We plan to automate this, but for now...
sf-hamilton-{version_string}. See 1.2.0 for an example.These are the steps to push to Anaconda after you have built and pushed to PyPi successfully.
conda config --set auto_activate_base False to not set conda to be active by default.build_conda.sh that is a bash script that encapsulates the steps. For reference it roughly follows this documentation. Run it with bash build_conda.sh. It should “just work”.