3 releases
0.1.0 |
|
---|---|
0.0.4 | Mar 17, 2024 |
0.0.3 |
|
0.0.2 | Mar 16, 2024 |
0.0.1 | Mar 13, 2024 |
#606 in Command line utilities
26KB
475 lines
SimpleCI - Dead simple CI/CD pipeline executor
⚠️ SimpleCI was originaly written in Python. Some features may be missing for now! See python version repo here.
Simple-CI is a CI/CD pipeline executor similar to gitlab CI/CD but in local. It's triggered by a git hook after a commit and executes directives given by user in a simple script named .simple-ci.yml, placed at the root of the directory. The artifacts (logs, compiled binairies, etc) are stored in a folder at the same level that the project folder named [project name]-simple-ci.
Why simple-CI?
Automation pipelines like GitLab CI/CD are great tools for improving software development. However, the syntax can be tidious and the user relies completely on gitlab and it's runners (even though you can create your own runners). Furthermore, installing tools like gitlab or jenkins locally consumes a lot of resources and requires having them running in the background.
Simple-CI/CD solves these issues by providing a dead simple way for the user to run a CI/CD pipeline:
- Start simple-ci in your repository.
- Build your pipeline in the .simple-ci.yml file.
- Commit a change with git and let the pipeline execute itself.
- Profit!
Check the Wiki for more in-depth documentation.
Commands
simpleci start
: Create the git hook.simpleci stop
: Delete git hook (The pipeline will not be executed).simpleci init
: Create the git hook and the .simple-ci.yml file.simpleci exec
: Executes the pipeline.simpleci clean
: Remove all artifacts files.
Simple example of .simple-ci.yml script
variables:
GLOBAL_VAR: "last"
stages:
- stage1
- stage2
stage1:
variables:
MYVAR: "second"
jobs:
- job1
- job2
stage2:
inside_docker:
image: ruby:2.7
path: /tmp/
jobs:
- job3
job1:
variables:
fie_name: "new_file"
artifacts:
paths:
- new_file
script:
- echo "This is the first job."
- touch $file_name
job2:
inside_docker:
image: ubuntu
path: /
script:
- echo "This is the $MYVAR job."
job3:
script:
- echo "This is the $GLOBAL_VAR job, that will be executed after stage1 is completed."
You will find the complete syntax documentation on the Wiki
Installation
cargo install simpleci
Dependencies
- bash
- git
Contributing
Feel free to submit any issues is you want to contribute.
Roadmap
- Basic functionnality: script, job and stage pipelines
- Keyword: Variables (define environment variables before job execution)
- Pipeline logs
- Gitlab CI/CD pipeline
- Config file
- Git hook creation
- Multi-language support
- Keyword: Docker (execute jobs in docker)
- Keyword: Artifacts (Files saved after pipeline execution)
- Keyword: Cache (Use previous files created in previous jobs)
- Add tests
- only-if (test the condition. if true -> run the job)
- never-if (test the condition. if true -> don't run the job)
- Custom hooks (pre-commit, post-commit, pre-push...)
- secrets (store variables without displaying them)
- Custom shell (bash, fish, zsh...)
- Custom output color
Dependencies
~4–15MB
~133K SLoC