Posted on :: Tags: ,

Discovering GitHub APIs while learning Clojure

As a developer, it's important to keep on learning/discovering stuff. Quoting The Pragmatic Programmer :

Invest Regularly in Your Knowledge Portfolio

My last project "for learning" was to create a command-line tool, named hubstats, that outputs a summary for pull requests GitHub. This tool aims at giving some metrics for me and my team.

The real purposes were to practice Clojure (which I knew little) but also to discover REST and GraphQL GitHub APIs.

Moreover, I was lucky to interact with a colleague of mine who is an advanced Clojure developer. That was really cool, thanks Jérôme aka @jprudent!


## What is _hubstats_?

hubstats is a simple command line tool that outputs, for a given GitHub repository, the number of opened/commented/merged pull requests by author for a given period (last week, since a given date, etc.).

Here is an output example:

lein run --organization softwarevidal --repository arthur --token $token
pull requests for softwarevidal/arthur ->
    since 1 week(s):
        9 opened / 56 commented / 5 closed
        opened per author: {"cmahalin" 5, "jcgay" 2, "AElMehdiVidal" 2}
        commented per author: {"vidal-rm" 30, "jcgay" 17, "cmahalin" 9}
        closed per author: {"cmahalin" 2, "AElMehdiVidal" 2, "jprudent" 1}

## How does it work?

I have chosen Clojure, a language that is different from the language that I use every day (Java).

The following characteristics appealed to me:

  • dynamic and interactive development: code is short and simple, which seems cool for an internal tool; what's more, the REPL is a base tool that greatly fit to a discovery mindset.
  • functional programming: functions are first-class citizen, immutability and function recursion are basics
  • Lisp: Clojure is a Lisp, so writing code is a bit different from C-like languages ; Code is data and can be edited via paredit (emacs-like mode for editing code while keeping parentheses balanced).
  • simplicity: Clojure encourages too use small libraries instead of huge frameworks.

See Clojure Rationale.

My dev setup:


## So what?

What I liked:

  • a "parenthesis" (haha!) with my daily Java routines/habits
  • paredit is confusing at first, then pleasant to use
  • REPL rocks for
    • shaping code (acts as a draft for new code)
    • troubleshooting bugs (example: incorrect GitHub pagination traversing that led to out-of-memory crash)
  • unit tests are easy to write (example: with-redefs macro can be used to mock functions: https://clojuredocs.org/clojure.core/with-redefs)

What I did not like:

  • WTFs when runtime bugs occurred (obscure stack traces)
  • integrated documentation lacks examples. I often had to browse Clojure Docs to understand Clojure base functions via useful examples.

## What's next?

Some ideas for some evolutions (or an other project, maybe?):

[edit from 2024-12-30: GitHub GraphQL link has been updated]

That's all folk! 😉