Skip to content

Commit

Permalink
Add dev setup docs (#57)
Browse files Browse the repository at this point in the history
  • Loading branch information
ml-evs authored Jan 30, 2024
1 parent eb321c4 commit 21a7492
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 4 deletions.
8 changes: 4 additions & 4 deletions doc/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -65,10 +65,10 @@ build/generate-stamp: $(wildcard source/reference/*.rst)
generate-rst-from-md:
# generate contributing docs
mkdir -p source/dev
pandoc --from=markdown --to=rst --output=source/dev/_index.rst ../CONTRIBUTING.md
echo ".. _devindex:" > source/dev/index.rst
cat source/dev/_index.rst >> source/dev/index.rst
rm source/dev/_index.rst
pandoc --from=markdown --to=rst --output=source/dev/_contributing.rst ../CONTRIBUTING.md
echo ".. _contributing:" > source/dev/contributing.rst
cat source/dev/_contributing.rst >> source/dev/contributing.rst
rm source/dev/_contributing.rst
# generate changelog
pandoc --from=markdown --to=rst --output=source/_changelog.rst ../CHANGELOG.md
echo ".. _changelog:" > source/changelog.rst
Expand Down
37 changes: 37 additions & 0 deletions doc/source/dev/devinstall.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
.. _devinstall:

********************************
Developer setup and installation
********************************

When developing jobflow-remote, one does not necessarily need to set up
a remote runner environment and database.
Instead, one can use the containerized setup provided as part of the integration
tests.
This requires a `Docker engine <https://docs.docker.com/engine/install/>`_ to be running on your local machine,
as it will create and launch containers running MongoDB and Slurm to test job submission.

These tests do not run by default (i.e., when simply running ``pytest``) as they conflict with the
units tests, but can instead be installed and then invoked with:

.. code-block:: shell
pip install .[tests]
CI=1 pytest tests/integration
When adding new features to jobflow-remote, please consider adding an
integration test to ensure that the feature works as expected, before
following the contributing instructions at :ref:`contributing`.

.. warning::

The integration tests will create a container running MongoDB and Slurm
on your local machine that will be cleaned up when the tests finish.
If you ``KeyboardInterrupt`` the tests, the container may not be cleaned
successfully.
A random free port will be chosen for Slurm and MongoDB each; if you
encounter errors with these ports (as the process can be system-dependent),
please raise an issue detailing your setup.
In this case, you may wish to manually override the pytest fixtures for
port specification in ``tests/integration/conftest.py`` (but do not commit
these changes).

0 comments on commit 21a7492

Please sign in to comment.