aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/DEVELOPMENT.md
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2023-07-12 22:12:56 +0200
committerEgor Tensin <Egor.Tensin@gmail.com>2023-07-12 22:14:06 +0200
commit3979be4ccee7702a8bbe10bd6dc512eae6e21949 (patch)
tree9fc2923bb561bf234819b26a57703acfb88cb1dc /DEVELOPMENT.md
parentMakefile: add shortcuts for integration tests (diff)
downloadcgitize-3979be4ccee7702a8bbe10bd6dc512eae6e21949.tar.gz
cgitize-3979be4ccee7702a8bbe10bd6dc512eae6e21949.zip
add DEVELOPMENT.md
Diffstat (limited to 'DEVELOPMENT.md')
-rw-r--r--DEVELOPMENT.md42
1 files changed, 42 insertions, 0 deletions
diff --git a/DEVELOPMENT.md b/DEVELOPMENT.md
new file mode 100644
index 0000000..7006dc4
--- /dev/null
+++ b/DEVELOPMENT.md
@@ -0,0 +1,42 @@
+Workspace setup
+---------------
+
+* Create a virtual Python environment: `make venv`
+* Use the virtual environment: `. .venv/bin/activate`
+ * Deactivate the environment when you're done: `deactivate`
+* Make sure unit tests work: `make test/unit`
+
+Development
+-----------
+
+* Run unit tests: `make test/unit`
+* There're three integration tests: `local`, `docker` and `example`.
+Run them using
+
+ make test/local
+ sudo make test/docker
+ make test/example
+
+ * The `example` test uses the forges' APIs and might easily hit rate
+limits.
+Set environment variables described in [examples/cgitize.toml] to use "access
+tokens" and get much higher rate limits.
+
+[examples/cgitize.toml]: examples/cgitize.toml
+
+Upgrading dependencies
+----------------------
+
+* Upgrade virtual environment packages: `make venv/upgrade`
+* Upgrade base Docker images.
+ * Find the current base images using `git grep -P 'FROM \w+:'`
+* Upgrade the [cmark-gfm] version used in the [cgitize-frontend Docker image].
+
+[cmark-gfm]: https://github.com/github/cmark-gfm
+[cgitize-frontend Docker image]: docker/frontend/Dockerfile
+
+Releases
+--------
+
+* Make a git tag for a new minor version using `make tag`.
+You can then review it and push using `git push --tags`.