1
0
mirror of https://github.com/ohwgiles/laminar.git synced 2024-10-27 20:34:20 +00:00
Go to file
Maximilian Seesslen accdff2405 Added support for metadata for job runs
With the `laminarc tag` command the build scripts can augment runs with
metadata. This can be SCM-oriented information like the used branch or
source-version.
The metadata is a list of key/value pairs. The metadata is automatically
shown in the run-view of a job in the web UI.

Each call of `laminarc tag` can assign one key/value pair.

Example:
```
laminarc tag $JOBNAME $NUMBER` \
		Branch "$(git -C $WORKSPACE branch --show-current)"
```
2024-03-28 00:20:09 +01:00
docker cmake: more appropriate use of CMAKE_INSTALL_PREFIX 2020-06-20 15:59:35 +12:00
etc Have at least some minimal logging 2023-03-01 11:25:46 +13:00
examples nginx example: trailing slash on proxy_pass argument 2022-01-22 15:18:43 +13:00
pkg pkg: move to debian 11 (bullseye) 2022-01-28 19:28:30 +13:00
src Added support for metadata for job runs 2024-03-28 00:20:09 +01:00
test test: assert on >= 5 rather than strictly == 2022-01-28 19:44:40 +13:00
CMakeLists.txt Added support for metadata for job runs 2024-03-28 00:20:09 +01:00
COPYING Added GPLv3 license file. 2017-10-11 09:56:26 +02:00
README.md README.md: add pkg-config 2024-02-27 12:48:28 +13:00
UserManual.md Added support for metadata for job runs 2024-03-28 00:20:09 +01:00

Laminar CI status

Laminar (https://laminar.ohwg.net) is a lightweight and modular Continuous Integration service for Linux. It is self-hosted and developer-friendly, eschewing a configuration UI in favour of simple version-controllable configuration files and scripts.

Laminar encourages the use of existing GNU/Linux tools such as bash and cron instead of reinventing them.

Although the status and progress front-end is very user-friendly, administering a Laminar instance requires writing shell scripts and manually editing configuration files. That being said, there is nothing esoteric here and the guide should be straightforward for anyone with even very basic Linux server administration experience.

See the website and the documentation for more information.

Building from source

First install development packages for capnproto (version 0.7.0 or newer), rapidjson, sqlite and boost (for the header-only multi_index_container library) from your distribution's repository or other source.

On Debian Bullseye, this can be done with:

sudo apt install \
		 capnproto cmake g++ libboost-dev libcapnp-dev \
     libsqlite3-dev rapidjson-dev zlib1g-dev pkg-config

Then compile and install laminar with:

git clone https://github.com/ohwgiles/laminar.git
cd laminar
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr
make -j "$(nproc)"
# Warning: the following will overwrite an existing /etc/laminar.conf
sudo make install

make install includes a systemd unit file. If you intend to use it, consider creating a new user laminar or modifying the user specified in the unit file.

Packaging for distributions

The pkg directory contains shell scripts which use docker to build native packages (deb,rpm) for common Linux distributions. Note that these are very simple packages which may not completely conform to the distribution's packaging guidelines, however they may serve as a starting point for creating an official package, or may be useful if the official package lags.

Contributing

Issues and pull requests via GitHub are most welcome. All pull requests must adhere to the Developer Certificate of Origin.