diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 0000000..3e8a1d8 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,137 @@ +# How to contribute + +If your not sure what you can do or you need to ask a question or just want to talk about ComicTagger head over to the [discussions tab](https://github.com/comictagger/comictagger/discussions/categories/general) and start a discussion + +## Tests + +We have tests written using pytest! Some of them even pass! If you are contributing code any tests you can write are appreciated. + +A great place to start is extending the tests that are already made. + +For example the file tests/filenames.py has lists of filenames to be parsed in the format: +```py + pytest.param( + "Star Wars - War of the Bounty Hunters - IG-88 (2021) (Digital) (Kileko-Empire).cbz", + "number ends series, no-issue", + { + "issue": "", + "series": "Star Wars - War of the Bounty Hunters - IG-88", + "volume": "", + "year": "2021", + "remainder": "(Digital) (Kileko-Empire)", + "issue_count": "", + }, + marks=pytest.mark.xfail, + ) +``` + +A test consists of 3-4 parts +1. The filename to be parsed +2. The reason it might fail +3. What the result of parsing the filename should be +4. `marks=pytest.mark.xfail` This marks the test as expected to fail + +If you are not comfortable creating a pull request you can [open an issue](https://github.com/comictagger/comictagger/issues/new/choose) or [start a discussion](https://github.com/comictagger/comictagger/discussions/new) + +## Submitting changes + +Please open a [GitHub Pull Request](https://github.com/comictagger/comictagger/pull/new/develop) with a clear list of what you've done (read more about [pull requests](http://help.github.com/pull-requests/)). When you send a pull request, we will love you forever if you include tests. We can always use more test coverage. Please run the code tools below and make sure all of your commits are atomic (one feature per commit). + +## Contributing Code + +Currently only python 3.9 is supported however 3.10 will probably work if you try it + +Those on linux should install `Pillow` from the system package manager if possible and if the GUI and/or the CBR/RAR comicbooks are going to be used `pyqt5` and `unrar-cffi` should be installed from the system package manager + +Those on macOS will need to ensure that you are using python3 in x86 mode either by installing an x86 only version of python or using the universal installer and using `python3-intel64` instead of `python3` + +1. Clone the repository +``` +git clone https://github.com/comictagger/comictagger.git +``` + +2. It is preferred to use a virtual env for running from source, adding the `--system-site-packages` allows packages already installed via the system package manager to be used: + +``` +python3 -m venv --system-site-packages venv +``` + +3. Activate the virtual env: +``` +. venv/bin/activate +``` +or if on windows PowerShell +``` +. venv/bin/activate.ps1 +``` + +4. install dependencies: +```bash +pip install -r requirements_dev.txt -r requirements.txt +# if installing optional dependencies +pip install -r requirements-GUI.txt -r requirements-CBR.txt +``` + +5. install ComicTagger +``` +pip install . +``` + +6. (optionall) run pytest to ensure that their are no failures (xfailed means expected failure) +``` +$ pytest +============================= test session starts ============================== +platform darwin -- Python 3.9.12, pytest-7.1.1, pluggy-1.0.0 +rootdir: /Users/timmy/build/source/comictagger +collected 61 items + +tests/test_FilenameParser.py ..x......x.xxx.xx....xxxxxx.xx.x..xxxxxxx [ 67%] +tests/test_comicarchive.py x... [ 73%] +tests/test_rename.py ..xxx.xx..XXX.XX [100%] + +================== 27 passed, 29 xfailed, 5 xpassed in 2.68s =================== +``` + +7. Make your changes +8. run code tools and correct any issues +```bash +black . +isort . +flake8 . +pytest +``` + +black: formats all of the code consistently so there are no surprises
+isort: sorts imports so that you can always find where an import is located
+flake8: checks for code quality and style (warns for unused imports and similar issues)
+pytest: runs tests for ComicTagger functionality + + +if on mac or linux most of this can be accomplished by running +``` +make install +# or make PYTHON=python3-intel64 install +. venv/bin/activate +make CI +``` +There is also `make check` which will run all of the code tools in a read-only capacity +``` +$ make check +venv/bin/black --check . +All done! ✨ 🍰 ✨ +52 files would be left unchanged. +venv/bin/isort --check . +Skipped 6 files +venv/bin/flake8 . +venv/bin/pytest +============================= test session starts ============================== +platform darwin -- Python 3.9.12, pytest-7.1.1, pluggy-1.0.0 +rootdir: /Users/timmy/build/source/comictagger +collected 61 items + +tests/test_FilenameParser.py ..x......x.xxx.xx....xxxxxx.xx.x..xxxxxxx [ 67%] +tests/test_comicarchive.py x... [ 73%] +tests/test_rename.py ..xxx.xx..XXX.XX [100%] + +================== 27 passed, 29 xfailed, 5 xpassed in 2.68s =================== +``` \ No newline at end of file diff --git a/Makefile b/Makefile index 451d9ec..a91e402 100644 --- a/Makefile +++ b/Makefile @@ -6,9 +6,10 @@ SITE_PACKAGES := $(shell $(PYTHON) -c 'import sysconfig; print(sysconfig.get_pat PACKAGE_PATH = $(SITE_PACKAGES)/comictagger-$(VERSION_STR).dist-info VENV := $(shell echo $${VIRTUAL_ENV-venv}) -PY3 := $(shell command -v python3 2> /dev/null) +PY3 := $(shell command -v $(PYTHON) 2> /dev/null) PYTHON_VENV := $(VENV)/bin/python INSTALL_STAMP := $(VENV)/.install.stamp +INSTALL_GUI_STAMP := $(VENV)/.install-GUI.stamp ifeq ($(OS),Windows_NT) @@ -24,13 +25,13 @@ else FINAL_NAME=ComicTagger-$(VERSION_STR) endif -.PHONY: all clean pydist upload dist CI check +.PHONY: all clean pydist upload dist CI check run all: clean dist $(PYTHON_VENV): @if [ -z $(PY3) ]; then echo "Python 3 could not be found."; exit 2; fi - $(PY3) -m venv $(VENV) + $(PY3) -m venv --system-site-packages $(VENV) clean: find . -type d -name "__pycache__" | xargs rm -rf {}; @@ -70,6 +71,11 @@ $(INSTALL_STAMP): $(PYTHON_VENV) requirements.txt requirements_dev.txt $(PYTHON_VENV) -m pip install -e . touch $(INSTALL_STAMP) +install-GUI: $(INSTALL_GUI_STAMP) +$(INSTALL_GUI_STAMP): requirements-GUI.txt + $(PYTHON_VENV) -m pip install -r requirements-GUI.txt + touch $(INSTALL_GUI_STAMP) + ins: $(PACKAGE_PATH) $(PACKAGE_PATH): $(PIP) install . diff --git a/README.md b/README.md index 846eb09..04c4e1b 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -[![Build Status](https://travis-ci.org/comictagger/comictagger.svg?branch=develop)](https://travis-ci.org/comictagger/comictagger) +[![Build](https://github.com/comictagger/comictagger/actions/workflows/build.yaml/badge.svg)](https://github.com/comictagger/comictagger/actions/workflows/build.yaml) [![Gitter chat](https://badges.gitter.im/gitterHQ/gitter.png)](https://gitter.im/comictagger/community) [![Google Group](https://img.shields.io/badge/discuss-on%20groups-%23207de5)](https://groups.google.com/forum/#!forum/comictagger) [![Twitter](https://img.shields.io/badge/%40comictagger-twitter-lightgrey)](https://twitter.com/comictagger) @@ -21,7 +21,7 @@ ComicTagger is a **multi-platform** app for **writing metadata to digital comics * Native read only support for **CBR** digital comics: full support enabled installing additional [rar tools](https://www.rarlab.com/download.htm) * Command line interface (CLI) enabling **custom scripting** and **batch operations on large collections** -For details, screen-shots, release notes, and more, visit [the Wiki](https://github.com/comictagger/comictagger/wiki) +For details, screen-shots, and more, visit [the Wiki](https://github.com/comictagger/comictagger/wiki) ## Installation @@ -40,11 +40,11 @@ A pip package is provided, you can install it with: $ pip3 install comictagger[GUI] ``` +There are two optional dependencies GUI and CBR. You can install the optional dependencies by specifying one or more of `GUI`,`CBR` or `all` in braces e.g. `comictagger[CBR,GUI]` + ### From source - 1. Ensure you have a recent version of python3 installed + 1. Ensure you have python 3.9 installed 2. Clone this repository `git clone https://github.com/comictagger/comictagger.git` 3. `pip3 install -r requirements_dev.txt` - 4. Optionally install the GUI `pip3 install -r requirements-GUI.txt` - 5. Optionally install CBR support `pip3 install -r requirements-CBR.txt` - 6. `python3 comictagger.py` + 7. `pip3 install .` or `pip3 install .[GUI]`