Skip to content

Latest commit

 

History

History
67 lines (48 loc) · 2.96 KB

CONTRIBUTING.md

File metadata and controls

67 lines (48 loc) · 2.96 KB

General guidelines

  1. When contributing to this repository, please first discuss the change you wish to make via issue, email, or any other method with the owners of this repository before making a change.
  2. Any changes you make (unless they are very minor) should be covered by Unit tests.
  3. You should test your changes by running the modified version of the plugin with your installation of Anki.

Dependencies

If you want to add new library dependency - add them to the Pipfile.
The dependency management is implemented using https://pipenv.org/

UI Files

The config window is build using QtDesigner, which you can get by running sudo apt install qtcreator on Linux, or simply download from https://build-system.fman.io/qt-designer-download

In Qt Designer you can create UI files using a simple GUI, and save them as a .ui file in the ui_files folder.

Run pip install PyQt5 to get the pyuic5 on your system.

Then the pyuic5 module can be used to convert them to python. See the generate_ui.sh script for examples, and all new UI files should be added there for automation.

This script is run automatically when packaging the extension in package_plugin.sh but needs to be done manually if the UI files are changed in the dev environment.

Testing

Testing you changes in Anki

  1. If you have the production version of CrowdAnki installed - remove it from Anki.
  2. Run fetch_dependencies.sh - this will download the dependencies required for CrowdAnki to operate and put them into the crowd_anki/dist directory.
  3. Add a symlink to the Anki plugins directory (you can find it via Tools>Add-ons>View Files) pointing to crowd_anki directory (you should not name the symlink crowd_anki though, see #62).

At this point if you start Anki - it'd be using your development version of CrowdAnki.
If you made some changes to the plugin while Anki is running and want to test them - you need to restart Anki, as plugins are loaded on Anki startup.

Unit testing

CrowdAnki is using Mamba as a test runner. And it makes use of expects assertion library.

The combination of these two tools allows you to write beautiful Spec-style tests in Python.

Misc

Windows development

This guide is using some shell scripts, using them is not a hard requirement, but being able to run them would make your life easier.
You can achieve that in a variety of ways:

References