Skip to content

This is a simple script to generate a documentation for your Gitlab CI

License

Notifications You must be signed in to change notification settings

Pixselve/gitlab-pipeline-to-md

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

21 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

βš™οΈ Gitlab CI documentation generator

Nuit de l'info 2022

This is a simple script to generate a documentation for your Gitlab CI

Usage

You must have node installed on your computer.

npx gitlab-pipeline-to-md -i <input file> -o <output file>

Input file

The input file must be a valid yaml file.
You can find an example in the example directory.

Output file

The output file is a md file.
You can find a generated example in the example directory.

Acknowledgments

Project made during the Nuit de l'info 2022.


Demo

Input file

Open
stages:
- sast
- pages

workflow:
  name: 'Pipeline for branch: $CI_COMMIT_BRANCH'

variables:
  DEPLOY_SITE: "https://example.com/"
  DEPLOY_ENVIRONMENT:
    description: "The deployment target. Change this variable to 'canary' or 'production' if needed."
    value: "staging"

# SAST (Code & dependency check)
sast:
  stage: sast
include:
  - template: Security/SAST.gitlab-ci.yml
  - project: 'my-group/my-project'
    file: '/templates/.gitlab-ci-template.yml'
  - project: 'my-group/my-subgroup/my-project-2'
    file:
      - '/templates/.builds.yml'
      - '/templates/.tests.yml'
  - remote: 'https://gitlab.com/example-project/-/raw/main/.gitlab-ci.yml'
default:
  image: ruby:3.0
  timeout: 3 hours 30 minutes
  interruptible: true
  before_script:
    - npm install
  retry:
    max: 2
    when: runner_system_failure
  artifacts:
    paths:
      - public/
      - public/
    exclude:
      - binaries/**/*.o
    expire_in: 1 week
    expose_as: 'artifact 1'
    name: "job1-artifacts-file"
    public: false
    reports:
      awd: rspec.xml
      awdawd: rspec.xml
    untracked: true
    when: on_failure
  cache:
    key: binaries-cache
    paths:
      - binaries/*.apk
      - .config

# Build website
pages:
  stage: pages
  image: node:lts
  before_script:
    - npm install
  script:
    - npm run build
    - rm -r public/
    - cp -r build/ public/
    - echo $CI_PAGES_URL
  artifacts:
    paths:
      - public/
      - public/
    exclude:
      - binaries/**/*.o
    expire_in: 1 week
    expose_as: 'artifact 1'
    name: "job1-artifacts-file"
    public: false
    reports:
      awd: rspec.xml
      awdawd: rspec.xml
    untracked: true
    when: on_failure
  rules:
    - if: $CI_COMMIT_REF_NAME == "main"
    - if: $CI_COMMIT_REF_NAME == "main"
  environment:
    name: production
    kubernetes:
      namespace: production
      deployment: website
      service: website
  needs:
    - project: namespace/group/project-name
      job: build-1
      ref: main
      artifacts: true
    - project: namespace/group/project-name-2
      job: build-2
      ref: main
      artifacts: true

docker build:
  script: docker build -t my-image:$CI_COMMIT_REF_SLUG .
  rules:
    - if: $CI_PIPELINE_SOURCE == "merge_request_event"
      changes:
        paths:
          - Dockerfile
          - Dockerfile
        compare_to: 'refs/heads/branch1'


job:
  variables:
    DEPLOY_VARIABLE: "default-deploy"
  coverage: '/Code coverage: \d+\.\d+/'
  rules:
    - if: $CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH
      when: manual
      changes:
        - Dockerfile
      variables:                              # Override DEPLOY_VARIABLE defined
        DEPLOY_VARIABLE: "deploy-production"  # at the job level.
    - if: $CI_COMMIT_REF_NAME =~ /feature/
      when: never
      variables:
        IS_A_FEATURE: "true"                  # Define a new variable.
      changes:
        paths:
          - Dockerfile
    - exists:
        - Dockerfile
  script:
    - echo "Run script with $DEPLOY_VARIABLE as an argument"
    - echo "Run another script if $IS_A_FEATURE exists"

Result

Open

Pipeline for branch: $CI_COMMIT_BRANCH

πŸ“₯ Includes

Type Value
Template Security/SAST.gitlab-ci.yml
Project my-group/my-project
Project my-group/my-subgroup/my-project-2
Remote https://gitlab.com/example-project/-/raw/main/.gitlab-ci.yml

🌍 Default properties

Image Interruptible Timeout Retry

Artifacts

Untracked on_failure

βœ… Paths: public/, public/

❌ Exclude: binaries/**/*.o

⌚ Expire in: 1 week

πŸ“Š Reports: awd: rspec.xml, awdawd: rspec.xml

Cache

Key Paths Untracked Policy When
Cache key binaries/*.apk, .config ❌ Cache policy on_success

Before scripts

npm install

πŸ“‘ Variables

Name Value Description
DEPLOY_SITE https://example.com/
DEPLOY_ENVIRONMENT staging The deployment target. Change this variable to 'canary' or 'production' if needed.

πŸ“Š Workflow overview

flowchart LR
subgraph sast_STAGE[sast]
sast[sast]
end
subgraph pages_STAGE[pages]
pages[pages]
end
subgraph test_STAGE[test]
docker_build[docker build]
job[job]
end
sast_STAGE --> pages_STAGE
pages_STAGE --> test_STAGE

Loading

πŸ“ƒ Stages

βš™οΈ sast

sast

βš™οΈ pages

pages

Image

Before Scripts

npm install

Scripts

npm run build
rm -r public/
cp -r build/ public/
echo $CI_PAGES_URL

Artifacts

Untracked on_failure

βœ… Paths: public/, public/

❌ Exclude: binaries/**/*.o

⌚ Expire in: 1 week

πŸ“Š Reports: awd: rspec.xml, awdawd: rspec.xml

Rules

When Condition Allow failure Variables Changes Exists
on_success $CI_COMMIT_REF_NAME == "main" ❌
on_success $CI_COMMIT_REF_NAME == "main" ❌

environment

  • name: production
  • kubernetes:
    • namespace: production
    • deployment: website
    • service: website

needs

  • project: namespace/group/project-name

  • job: build-1

  • ref: main

  • project: namespace/group/project-name-2

  • job: build-2

  • ref: main

βš™οΈ test

docker build

Scripts

docker build -t my-image:$CI_COMMIT_REF_SLUG .

Rules

When Condition Allow failure Variables Changes Exists
on_success $CI_PIPELINE_SOURCE == "merge_request_event" ❌ Dockerfile β€’ Dockerfile

job

Scripts

echo "Run script with $DEPLOY_VARIABLE as an argument"
echo "Run another script if $IS_A_FEATURE exists"

Variables

Name Value Description
DEPLOY_VARIABLE default-deploy

coverage

/Code coverage: \d+.\d+/

Rules

When Condition Allow failure Variables Changes Exists
manual $CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH ❌ DEPLOY_VARIABLE: deploy-production Dockerfile
never $CI_COMMIT_REF_NAME =~ /feature/ ❌ IS_A_FEATURE: true Dockerfile
on_success - ❌ Dockerfile

About

This is a simple script to generate a documentation for your Gitlab CI

Topics

Resources

License

Stars

Watchers

Forks