package current_gitlab

  1. Overview
  2. Docs
GitLab plugin for OCurrent

Install

Dune Dependency

Authors

Maintainers

Sources

current-0.6.4.tbz
sha256=e6cafa330166719e3f8bf30a4ffeec79b0f290e3dcd420c4a53d6a55912f961d
sha512=42d703a524ab61e3fd623ab4b1681bbe59c1d4426bebadb1bb50c3e6fcbb59d1aecb8041f2b6d09a9cb5eb5b6f79ec7b07eb4254ec39de30d406c20d4da7d664

Description

OCurrent provides an OCaml eDSL for writing CI/CD pipelines.

This package provides primitives for interacting with GitLab. It can monitor and clone remote GitLab repositories, and can push GitLab status messages to show the results of testing PRs and branches.

Published: 01 Mar 2023

README

OCurrent

OCurrent allows you to specify a workflow / pipeline for keeping things up-to-date.

For example, the pipeline shown above fetches the head of a GitHub repository's master branch, builds it, runs the tests, and deploys the binary if the tests pass. When a new commit is pushed, it runs the pipeline again.

Another use might be to keep the GitHub build status of each PR in your Git repository showing the result of fetching, building and testing the PR's head commit. If the head commit changes, the result must be recalculated.

An OCurrent pipeline is written using an OCaml eDSL. When OCurrent evaluates it, it records the inputs used (e.g. the current set of open PRs and the head of each one), monitors them, and automatically recalculates when an input changes.

Larger uses of OCurrent include the OCaml Docker base image builder and ocaml-ci, which is the CI that tests this repository itself.

Documentation

The OCurrent docs contains user documentation and examples. In particular, you might like to start by reading about the example pipelines or how to write your own plugins.

For technical docs, see the API Documentation.

Licensing

OCurrent is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

Dependencies (16)

  1. yojson
  2. rresult >= "0.6.0"
  3. result >= "1.5"
  4. prometheus >= "0.7"
  5. ppx_deriving_yojson >= "3.6.1"
  6. lwt >= "5.6.1"
  7. logs >= "0.7.0"
  8. gitlab-unix >= "0.1.4" & < "0.1.8"
  9. fmt >= "0.8.9"
  10. cohttp-lwt-unix >= "4.0.0"
  11. cmdliner >= "1.1.0"
  12. ocaml >= "4.08.0"
  13. current_web = version
  14. current_git = version
  15. current = version
  16. dune >= "3.3"

Dev Dependencies (1)

  1. odoc with-doc

Used by (1)

  1. current_examples = "0.6.4"

Conflicts

None