Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://gitlab.com/stcarrez/porion
Porion is an automation system that helps automate the building, testing and
deployment of software development projects.
https://gitlab.com/stcarrez/porion
Ada builder continuous integration
Last synced: 2 months ago
JSON representation
Porion is an automation system that helps automate the building, testing and deployment of software development projects.
- Host: gitlab.com
- URL: https://gitlab.com/stcarrez/porion
- Owner: stcarrez
- License: other
- Created: 2021-11-27T14:37:08.360Z (about 3 years ago)
- Default Branch: master
- Last Synced: 2024-08-05T01:11:09.186Z (6 months ago)
- Topics: Ada, builder, continuous integration
- Stars: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-ada - porion - Continuous integration server and agent that helps automate the building, testing and deployment. (Deployment / Continuous Integration)
README
# Porion
[![License](http://img.shields.io/badge/license-APACHE2-blue.svg)](LICENSE)
[![Build Status](https://img.shields.io/endpoint?url=https://porion.vacs.fr/porion/api/v1/projects/porion/badges/build.json)](https://porion.vacs.fr/porion/projects/view/porion/summary)
[![Test Status](https://img.shields.io/endpoint?url=https://porion.vacs.fr/porion/api/v1/projects/porion/badges/tests.json)](https://porion.vacs.fr/porion/projects/view/porion/xunits)
[![Coverage](https://img.shields.io/endpoint?url=https://porion.vacs.fr/porion/api/v1/projects/porion/badges/coverage.json)](https://porion.vacs.fr/porion/projects/view/porion/summary)
[![semver](https://img.shields.io/badge/semver-2.0.0-blue.svg?cacheSeconds=2592000)]()# TL;DR
Porion is an automation system that helps automate the building, testing and
deployment of software development projects.First create the porion workspace directory:
```
porion init workspace-dir
```Then register a project to build:
```
porion add https://github.com/stcarrez/ada-util.git
porion add project-2.0.tar.gz
```Build a project from the build queue or build a specific project:
```
porion build
porion build ada-util
porion build project-2.0
```Check for changes in sources and update the build queue:
```
porion check
```Add a remote build node:
```
porion node ssh://user@hostname/home/build-directory
```Add a build recipe labeled `remote` for project `ada-util` on build node `hostname`:
```
porion add --recipe ada-util~remote@hostname
```Get information about a project or a build number:
```
porion info ada-util
porion info ada-util:2
```Version 0.16.0 - Under development
- Run the build process with a pseudo TTY to solve output order issues
- Fix handling the recipe name in identification strings for some commandsVersion 0.15.0 - Jul 2024
- Improvement of build environment configuration setup
- Preliminary support for per-project secret keys[List all versions](https://gitlab.com/stcarrez/porion/blob/master/NEWS.md)
# Overview
Porion is a continuous integration server and agent that helps automate the building,
testing and deployment of software development projects written in any language.
Porion maintains a list of projects with build recipes to build these projects.
It periodically checks for changes in projects and it schedules a build when a project
is modified. Porion uses a build node to build a project and the build node can
be the current host or a specific remote host registered for that purpose.Porion uses a workspace directory to maintain the list of projects, their build status
and build area. The workspace directory contains a SQLite database which is used
to maintain the list of projects, build nodes, build recipes, build queue and build
results.The steps to use Porion are the following:
- the Porion workspace directory is created by using the `porion init` command,
- projects are registered by using the `porion add` command with enough information to
allow Porion to checkout the source and detect changes. When a project is added
Porion will guess a set of build recipes for the new project.
- project build recipes and build steps are updated and configured on the project
by using either `porion add --recipe` or `porion step` commands.# Porion commands
`porion` provides the following commands:
* `add`: add a new project or a new recipe
* `build`: build the project
* `check`: check for changes and update the build queue
* `config`: get or configure a global parameter
* `depend`: add or remove project dependencies
* `edit`: edit the project configuration
* `help`: print some help
* `info`: report some information about a project or a build
* `init`: setup the build agent node
* `list`: list the projects, nodes, builds
* `logs`: display the build logs
* `node`: add, update or remove build nodes
* `remove`: remove a project and its build data
* `set`: set a project, branch or recipe variable
* `status`: status about the workspace or a project
* `step`: control the build steps# Porion Debian Binaries
Ubuntu 20.04 packages are available to help you install the `porion`
and `porion-server` commands more easily. You can configure your Ubuntu system as follows:```
wget -O - https://apt.vacs.fr/apt.vacs.fr.gpg.key | sudo apt-key add -
sudo add-apt-repository "deb https://apt.vacs.fr/ubuntu-focal focal main"
```And then install the `porion-server` package:
```
sudo apt-get install porion-server
```# Building Porion
To build `porion` you will need the GNAT Ada compiler, either
the FSF version available in Debian, FreeBSD systems NetBSD or the
AdaCore GNAT Community 2021 edition.## Development Host Installation
### Ubuntu
Install the following packages:
```
sudo apt-get install -y make gnat gprbuild git libsqlite3-dev
```### FreeBSD 14
Install the following packages:
```
pkg install gmake gnat13 gprbuild git
pkg install xmlada sqlite3 unzip
```## Getting the sources
The project uses a sub-module to help you in the integration and build
process. You should checkout the project with the following commands:```
git clone --recursive https://gitlab.com/stcarrez/porion.git
cd porion
```## Configuration
To configure `porion`, use the following command:
```
./configure
```## Build
Then, build the application:
```
make
```And install it:
```
make install
```# Documents
* Man page: [porion (1)](https://gitlab.com/stcarrez/porion/blob/master/docs/porion.md)
* Man page: [porion-server (8)](https://gitlab.com/stcarrez/porion/blob/master/docs/porion-server.md)# Presentations
* [Implementing a build manager in Ada](https://www.slideshare.net/StephaneCarrez1/implementing-a-build-manager-in-ada)
# Sites Using Porion
* [Porion Build Manager](https://porion.vacs.fr/porion/index.html)
# Porion server development setup
Typescript development setup:
```
pkg install npm-node18-8.13.0
npm install typescript --save-dev
npm install --save @types/jquery
npm install --save @types/flot
```To build the Javascript files:
```
make build-ts
```