-
Notifications
You must be signed in to change notification settings - Fork 8
119 lines (103 loc) · 4 KB
/
pr-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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
name: Hugin API Pull Request Pipeline
on: [ pull_request ]
jobs:
ansible-syntax-check:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
# Install python3 pip and ansible latest
- name: Install python and ansible
run: sudo apt update && sudo apt install -y python3-pip && sudo pip3 install ansible
# If `roles` folder exists, create a playbook_repo.yml playbook to perform the syntax check
- name: Creating playbook_repo.yml from roles folder (if exists)
run: test -d "hugin-api/ansible/roles" || exit 0 && echo $LINE1 > playbook_repo.yml && echo $LINE2 >> playbook_repo.yml && printf " roles:\n" >> playbook_repo.yml && for i in `ls hugin-api/ansible/roles`; do echo " - $i" >> playbook_repo.yml; done
env:
LINE1: "---"
LINE2: "- hosts: localhost"
# Check ansible syntax if roles folder exists (repo with playbooks and roles)
- name: Ansible Syntax Check of all roles of the playbook
run: test -f "playbook_repo.yml" || exit 0 && ansible-playbook $GITHUB_WORKSPACE/playbook_repo.yml --syntax-check
env:
ANSIBLE_ACTION_WARNINGS: False
# If `roles` folder does not exist, assume we are in a repository containing just the role
- name: Creating role_repo.yml from roles folder (if exists)
run: test -d "tasks" || exit 0 && echo $LINE1 > /tmp/role_repo.yml && echo $LINE2 >> /tmp/role_repo.yml && printf " roles:\n" >> /tmp/role_repo.yml && printf " - `echo $GITHUB_REPOSITORY | tr "/" "\n" | tail -1`\n" >> /tmp/role_repo.yml
env:
LINE1: "---"
LINE2: "- hosts: localhost"
# Copy the repo content for syntax check
- name: Copy the repo content to /tmp/ for syntax check
run: test -f "/tmp/role_repo.yml" || exit 0 && mkdir -p /tmp/roles/ && cd .. && cp -a `echo $GITHUB_REPOSITORY | tr "/" "\n" | tail -1` /tmp/roles/
# Check ansible syntax if tasks folder exists (repo with just the role)
- name: Ansible Syntax Check of role
run: test -f "/tmp/role_repo.yml" || exit 0 && ANSIBLE_ROLES_PATH=/tmp/roles ansible-playbook /tmp/role_repo.yml --syntax-check
env:
ANSIBLE_ACTION_WARNINGS: False
build:
name: Build
runs-on: ubuntu-latest
needs: ansible-syntax-check
strategy:
matrix:
node-version: [18.x] # add 19 and 20 when it's released
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- name: Install
run: npm install
- name: Build
run: npm run build --if-present
# test:
# name: Test
# runs-on: ubuntu-latest
# needs: [ build ]
# services:
# postgres:
# image: postgres:latest
# env:
# POSTGRES_DB: hugin_api_test
# POSTGRES_USER: postgres
# POSTGRES_PASSWORD: test1234
# ports:
# - 5432:5432
# options: >-
# --health-cmd pg_isready
# --health-interval 10s
# --health-timeout 5s
# --health-retries 5
# env:
# NODE_ENV: test
# TEST_DATABASE_URL: postgres://postgres:[email protected]:5432/hugin_api_test
#
# strategy:
# matrix:
# node-version: [18.x] # add 19 and 20 when it's released
#
# steps:
# - uses: actions/checkout@v3
#
# - name: Use Node.js ${{ matrix.node-version }}
# uses: actions/setup-node@v2
# with:
# node-version: ${{ matrix.node-version }}
#
# - name: Install
# run: npm install
# env:
# CI: true
#
# - name: Unit Test
# run: npm run test
# env:
# CI: true
#
# - name: Code Coverage
# run: npm run code-coverage
# env:
# CI: true