Skip to main content

A CLI tool for managing large amounts of GitHub repositories

Project description

Repomate

Build Status Code Coverage Documentation Status PyPi Version Supported Python Versions Supported Platforms License Code Style: Black

Important: Repomate has changed name to RepoBee. Please see RepoBee's GitHub page for details.

Overview

Repomate is A CLI tool for administrating large amounts of GitHub repositories, geared towards teachers and GitHub Enterprise. Repomate is currently being used for the introductory courses in computer science at KTH Royal Technical Institute of Technology. The courses have roughly 200 students and several thousands of repositories, allowing us to test Repomate at quite a large scale.

Install

Repomate is on PyPi, so python3 -m pip install repomate should do the trick. See the install instructions for more elaborate instructions.

Getting started

The best way to get started with Repomate is to head over to the Docs, where you (among other things) will find the user guide. It covers the use of Repomate's varous commands by way of practical example, and should set you on the right path with little effort.

Why Repomate?

Repomate was developed at KTH Royal Technical Institute of Technology to help teachers and teaching assistants administrate GitHub repositories. It is inspired by the old teachers_pet tool, with added features and a user experience more to our liking. Features range from creating student repositories based on master (template) repos, to opening and closing issues in bulk, to assigning peer reviews and cloning repos in bulk. Some parts of Repomate can be customized using a simple but powerful plugin system. For example, the repomate-junit4 plugin allows for automatically running JUnit4 test classes on production code in student repos. Below is the output from running repomate -h, giving brief descriptions of each of the main features:

$ repomate -h
usage: repomate [-h] [-v]
                {show-config,setup,update,migrate,clone,open-issues,
                 close-issues,list-issues,assign-reviews,
                 purge-review-teams,check-reviews,verify-settings}
                ...

A CLI tool for administering large amounts of git repositories on GitHub
instances. See the full documentation at https://repomate.readthedocs.io

positional arguments:
  {show-config,setup,update,migrate,clone,open-issues,
   close-issues,list-issues,assign-reviews,
   purge-review-teams,check-reviews,verify-settings}
    show-config         Show the configuration file
    setup               Setup student repos.
    update              Update existing student repos.
    migrate             Migrate master repositories into the target
                        organization.
    clone               Clone student repos.
    open-issues         Open issues in student repos.
    close-issues        Close issues in student repos.
    list-issues         List issues in student repos.
    assign-reviews      Randomly assign students to peer review each others'
                        repos.
    purge-review-teams  Remove all review teams associated with the specified
                        students and master repos.
    check-reviews       Fetch all peer review teams for the specified student
                        repos, and check which assigned reviews have been done
                        (i.e. which issues have been opened).
    verify-settings     Verify your settings, such as the base url and the
                        OAUTH token.

optional arguments:
  -h, --help            show this help message and exit
  -v, --version         Display version info

Roadmap

As of December 17th 2018, Repomate's CLI is a stable release and adheres to Semantic Versioning 2.0.0. The internals of Repomate do not adhere to this versioning, so using Repomate as a library is not recommended.

The plugin system is still to be considered in the beta phase, as it has seen much less live action use than the rest of the CLI. Features are highly unlikely to be cut, but hooks may be modified as new use-cases arise.

License

This software is licensed under the MIT License. See the LICENSE file for specifics.

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

repomate-1.1.3.tar.gz (37.4 kB view details)

Uploaded Source

Built Distribution

repomate-1.1.3-py3-none-any.whl (43.0 kB view details)

Uploaded Python 3

File details

Details for the file repomate-1.1.3.tar.gz.

File metadata

  • Download URL: repomate-1.1.3.tar.gz
  • Upload date:
  • Size: 37.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.2

File hashes

Hashes for repomate-1.1.3.tar.gz
Algorithm Hash digest
SHA256 a309f8ae64e21e4e7a05e18731c927154650d348277faeb93a6e09fd53ef3b60
MD5 9b91570d7640c7f235c12caf3795fd07
BLAKE2b-256 0c0fb55fca2d4384cacc39ef4dea77ea091a3a14af3a8d384bd55c42741d12df

See more details on using hashes here.

File details

Details for the file repomate-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: repomate-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 43.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.2

File hashes

Hashes for repomate-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d3f2e34e91a14e80f033ab624d0012de16ccc847d9e9091c4a628cb72702af6f
MD5 4b534fa92078d536f4c64e92bad9a1b5
BLAKE2b-256 531b3b8a0a295eeb42cc19639e12930246e4507077c7dae66ee419cc8c997a05

See more details on using hashes here.

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