Skip to main content

A CLI tool for Dodona

Project description

Command Line Interface for Dodona

PyPI page: https://pypi.org/project/DodonaCLI/#description

Contents:

  1. Disclaimers
  2. How to install
  3. How to use
  4. How to update
  5. All flags
  6. Roadmap

Disclaimers

  • DodonaCLI is an independent tool created by me, a student, and is not officially affiliated with the Dodona service or its team. Dodona, provided by the dedicated team at UGent University, offers an exceptional service, and this tool has been created as a complementary project. Only issues related to the Dodona website itself should be directed to the official Dodona support channels. Issues with the CLI tool should be posted on this project’s Issues.

  • Although the exercise-description formatting is decent, do NOT rely on this for tests and exams! The printed description may be incomplete, or even incorrect. Please be aware of this!

  • All efforts to display text in an orderly fashion were made using a Linux GNOME-terminal. If it doesn’t look good in your terminal, you probably are not running a GNOME-terminal. As this is open-source software, feel free to add terminal-detection to make things pretty for your terminal too, but this isn’t feasible to do for me.

  • This project was made on Linux, and was tested in the Command Prompt on Windows and on the zsh shell on macOS. For those platforms, you’ll find an installation guide below. If you wish to use this in other terminals, you’ll have to experiment yourself.

How to install

pip install DodonaCLI

Alternatively, you can git clone https://github.com/BWindey/DodonaCLI and when inside the DodonaCLI folder, do pip install -e .. This is mostly useful for those wanting to change/add to the code.

Tab-completion is supported for bash. You can download "dodonacli_completion_script.sh" from GitHub, and source it in your ~/.bashrc. This is currently not supported (tested, tried, ...) for other shells than bash. If you know how to support your platform, please reach out to me.

There is also a manual page. You can download "dodonacli.1.gz" and save this in a folder included in $(manpath).

How to use

There are three main things you can do with Dodona: displaying info (dodona display), selecting (dodona select) and posting exercises (dodona post). The behaviour of displaying and selecting will depend on your current selection, which can be viewed with dodona status. You can imagine it as a tree structure:

  • courses
    • exercise series
      • exercises

If nothing is selected, you’ll need to select a course first, then an exercise series, then an exercise. You can always see all your available options with dodona display. Posting a solution will only work if you have selected an exercise, and can be done with dodona post <SOLUTION_FILE>. This tree-like structure also explains the name of the deselect-flag: up and uptop.

The first time you use DodonaCLI, the program will ask you for an API token, which you can generate on your Dodona-profile page. This will be stored in a file 'config.json' in the same directory as this python script. If you ever delete this file, you’ll need to re-enter your API token. You can either keep a back-up of your token somewhere else, or just generate a new token whenever you (accidently) deleted your old token.

If there is some boilerplate code associated with an exercise, it will get printed out to the terminal once you select the exercise. You can also find it in the file 'boilerplate'. You can use it to write your solution in, and post it, but be aware that this file gets overwritten when you select a new exercise that has boilerplate-code attached (not all do).

Flags that could be important

There currently are 3 flags that can be important when working with non-standard exercises.

  • --force
  • --hidden
  • --other

They are all context-specific. A short explanation can be found in the help-pages, a slightly longer one here:

Force

This flag is used in combination with the display command, when viewing exercise-series and exercise-descriptions. It will do its best to render the html and markdown of the web-page in your terminal. You'll quickly see why this is hidden behind this flag: the formatting can be aweful. For some exercise-descriptions this can however be a nice addition, and in the future the formatting-"engine" can improve.

Hidden

This flag is used in combination with the select command, when selecting an exercise-series that is hidden. Series can be hidden when they are used in tests or exams, and to get to them you'll receive a link to it from your teachers. This link will be of the form ".../series//?token=". The only correct syntax to then select that hidden series with DodonaCLI is: dodona select --hidden <TOKEN> <SERIES-ID>

Other

This flag is used in combination with the select command, when selecting a course you're not registered for. This allows you for example to select courses from previous years to try out those old tests or exams. You cannot find these courses when using display, so you'll need the correct course-id to select it, not the course-name.

How to update

Updating is simple: pip install DodonaCLI --update

Alternatively, if you installed it with cloning from GitHub, you can git pull and pip build . again like you would install it.

Roadmap

More features to maybe add in the future:

  • add indicator to series to mark if all their exercises are completely solved
  • user-settings (f.e. auto-download of files, language, formatting, ...)
  • easy (automatic?) downloading of files mentioned in exercise description
  • be able to mark as read via terminal for ContentPage
  • use links at top of solution files to ignore the configs and straight post to right exercise, like the plugins
  • implement a dodona next command to immediatly select the next course/series/exercise, depending on the current selection.

Not important, but valid ideas:

  • (plugin) for syntax-checking before posting, so you get a quicker response in case of a syntax error, depends on the type of exercise (bash, java, python, C, C++, R, ...)
  • caching to make it feel like a real command, very fast! Currently, you’ll often have to wait a few hundred milliseconds for the API call to return
  • look into https://textual.textualize.io/getting_started/ to maybe use that??

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

DodonaCLI-2023.12.31.tar.gz (23.6 kB view hashes)

Uploaded Source

Built Distribution

DodonaCLI-2023.12.31-py3-none-any.whl (23.7 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page