Monkey CI is intended to be a highly customizable and powerful continuous integration tool. The key features are:
It is (very remotely) inspired by Lambda-CD, but I did not use any of their code. Only the part where you use Clojure as the build script language ;-).
Why build another CI tool is so many already exist? Well, throughout my career I've used quite a few: Jenkins, Travis, GCP build, Bitbucket, Gitlab, Teamcity, Tekton... All have their strong points, and all have their weak points. But almost all have the same issue: their scripting is not powerful enough for my needs. And since my pipelines are not that special (I think), I can assume that many people experience the same problem. They are great for demo cases and very simple builds, but as soon as you go past the elementary and want to set up pipelines with even moderate complexity, and want to reduce copy/pasting as much as possible, you end up in trouble. And since CI tools should be the forerunners in "good coding practices", I should expect no less from the build scripts they make us write, no?
The core problem, as I see it, is that they all work with Yaml files, probably to make it more user-friendly. This is great for novice users with simple builds, but as said before, you quickly run into limitations. Then you're forced to use Yaml anchors and whatnot. And those have limitations too. And apart from that you're also often forced to insert complicated bash scripting to solve some specific problems. So after a while it becomes a program of it's own. And in my view, programs require programming languages!
I'm a big fan of Lisp-like languages in general, and Clojure in particular. Mostly because of it's elegance and simple syntax. And Clojure nicely bridges the gap with the "real world": you can write in an elegant language and your code is actually usable! And that's also why I think it could be a nice fit for some kind of scripting (see also Babashka). You don't need complicated syntax and directory structures, a Clojure program can be as simple as a single file.
So that's the aim here: to provide the full power of Clojure to build pipelines, and also introduce coding best-practices to the build process. By that I mean things like unit testing. Wouldn't it be great if you could unit-test your build pipelines? If you could run it locally to see if everything works, that you don't need to do any debugging in the CI environment?
I intend to incorporate as much features as possible that I like in other CI tools. These include:
Also, to make migration easier, it would be cool to add support for the build scripts of other CI tools. If that is even feasibly. Or, alternatively, some way to convert scripts into the MonkeyCI format. In any case it should be avoided that users need to rewrite all their build scripts if they want to migrate.
Of course, I wouldn't be building this if I saw that the existing tooling provided me with everything I need or want. So what I want to add:
This repository contains the source code for the Monkey CI application. It consists of the build application that actually runs the script and the infra project that holds the Terraform configuration for the cloud configuration.
The application is written in Clojure and is set up in a modular way. Communication between the modules is done using events (probably using Kafka, or maybe Artemis).
The code consists of several modules. gui
contains the frontend code, app
contains the code for the application itself (the backend) and test-lib
is a
library that can be included in build script unit tests.
clojure -X:test
clojure -X:test:watch
clojure -X:test:coverage
clojure -M:run
The test runner used is Kaocha, which
runs the clojure.test
tests. Depending on the aliases you include, plugins are
activated or not (see the deps.edn file).
Initially we're using CircleCI to build the app, but as Monkey-CI matures, it will be built "by itself" as it were.
Copyright (c) 2023 by Monkey Projects BV
https://www.monkey-projects.be
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close