-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.gitlab-ci.yml
104 lines (94 loc) · 3.91 KB
/
.gitlab-ci.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# This file is a template, and might need editing before it works on your project.
# To contribute improvements to CI/CD templates, please follow the Development guide at:
# https://docs.gitlab.com/ee/development/cicd/templates.html
# This specific template is located at:
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Python.gitlab-ci.yml
# Official language image. Look for the different tagged releases at:
# https://hub.docker.com/r/library/python/tags/
---
image: python:3.8.10
services:
- docker:dind
# Change pip's cache directory to be inside the project directory since we can
# only cache local items.
variables:
PIP_CACHE_DIR: "$CI_PROJECT_DIR/.cache/pip"
# Pip's cache doesn't store the python packages
# https://pip.pypa.io/en/stable/reference/pip_install/#caching
#
# If you want to also cache the installed packages, you have to install
# them in a virtualenv and cache it as well.
cache:
paths:
- .cache/pip
- .venv/
stages:
- build
- test
- publish
test:
image: docker:stable-dind
stage: test
before_script:
- apk add --no-cache python3 python3-dev py3-pip gcc git curl build-base autoconf automake py3-cryptography linux-headers musl-dev libffi-dev openssl-dev openssh
- docker info
- python3 --version # Print out python version for debugging
- python3 -m pip install virtualenv
- virtualenv .venv
- source ./.venv/bin/activate
- python3 -m pip install -r requirements.txt
- ansible --version
- molecule --version
script:
- pip install -r requirements-test.txt
- molecule test
artifacts:
reports:
junit: reports/*_test-result.xml
# run:
# script:
# - python setup.py bdist_wheel
# # an alternative approach is to install and run:
# - pip install dist/*
# # run the command here
# artifacts:
# paths:
# - dist/*.whl
pages:
stage: publish
script:
- pip install -r requirements-doc.txt
- cd doc ; make html
- mv build/html/ ../public/
artifacts:
paths:
- public
rules:
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
galaxy:
stage: publish
variables:
GALAXY_ROLE_NAME: $(echo "$CI_PROJECT_NAME" | tr '-' '_')
GALAXY_ROLE_FULLNAME: "$GITLAB_USER_LOGIN.$GALAXY_ROLE_NAME"
GALAXY_ROLE_ID: "ansible-galaxy info $ANSIBLE_GALAXY_NAME | grep -E 'id: [0-9]' | awk {'print $2'}"
BADGE_LINK_URL_GALAXY_ROLE: https://galaxy.ansible.com/$GITLAB_USER_LOGIN/$GALAXY_ROLE_NAME
BADGE_IMAGE_URL_GALAXY_ROLE: "https://img.shields.io/ansible/role/$GALAXY_ROLE_ID"
BADGE_LINK_URL_GALAXY_DOWNLOADS: https://galaxy.ansible.com/$GITLAB_USER_LOGIN/$GALAXY_ROLE_NAME
BADGE_IMAGE_URL_GALAXY_DOWNLOADS: "https://img.shields.io/ansible/role/d/$GALAXY_ROLE_ID"
BADGE_LINK_URL_GALAXY_SCORE: https://galaxy.ansible.com/$GITLAB_USER_LOGIN/$GALAXY_ROLE_NAME
BADGE_IMAGE_URL_GALAXY_SCORE: "https://img.shields.io/ansible/quality/$GALAXY_ROLE_ID"
GITLAB_API_BADGE_ENDPOINT: "https://gitlab.example.com/api/v4/projects/:id/badges"
before_script:
- curl -s https://raw.githubusercontent.com/profclems/glab/trunk/scripts/install.sh | sh
script: |
echo "Ansible Galaxy contains role $GALAXY_ROLE_FULLNAME with id=$GALAXY_ROLE_ID"
echo "GALAXY_ROLE_FULLNAME=$GALAXY_ROLE_FULLNAME" >> galaxy.env
echo "GALAXY_ROLE_ID=$GALAXY_ROLE_ID" >> galaxy.env
curl --request POST --header "PRIVATE-TOKEN: $GITLAB_TOKEN" --data "link_url=$BADGE_LINK_URL_GALAXY_ROLE&image_url=BADGE_IMAGE_URL_GALAXY_ROLE" "$GITLAB_API_BADGE_ENDPOINT"
curl --request POST --header "PRIVATE-TOKEN: $GITLAB_TOKEN" --data "link_url=$BADGE_LINK_URL_GALAXY_DOWNLOADS&image_url=BADGE_IMAGE_URL_GALAXY_DOWNLOADS" "$GITLAB_API_BADGE_ENDPOINT"
curl --request POST --header "PRIVATE-TOKEN: $GITLAB_TOKEN" --data "link_url=$BADGE_LINK_URL_GALAXY_SCORE&image_url=BADGE_IMAGE_URL_GALAXY_SCORE" "$GITLAB_API_BADGE_ENDPOINT"
allow_failure: true
when: manual
artifacts:
reports:
dotenv: galaxy.env