Skip to content

Commit 9dd3289

Browse files
saputkinArthur Saputkin
and
Arthur Saputkin
authored
CI: migrate from CircleCI to GitHub actions (#69)
* Create main.yml * rm circleci, fix vuln * typo fix * testing run on node container * testinf fore_color variable * permissions to release job * homepage +git for semantic release * add codeQL action * newline at end of codeql yml Co-authored-by: Arthur Saputkin <[email protected]>
1 parent 21548c2 commit 9dd3289

File tree

5 files changed

+13355
-244
lines changed

5 files changed

+13355
-244
lines changed

.circleci/config.yml

Lines changed: 0 additions & 50 deletions
This file was deleted.

.github/workflows/codeql-analysis.yml

Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
# For most projects, this workflow file will not need changing; you simply need
2+
# to commit it to your repository.
3+
#
4+
# You may wish to alter this file to override the set of languages analyzed,
5+
# or to provide custom queries or build logic.
6+
#
7+
# ******** NOTE ********
8+
# We have attempted to detect the languages in your repository. Please check
9+
# the `language` matrix defined below to confirm you have the correct set of
10+
# supported CodeQL languages.
11+
#
12+
name: "CodeQL"
13+
14+
on:
15+
push:
16+
branches: [ master ]
17+
pull_request:
18+
# The branches below must be a subset of the branches above
19+
branches: [ master ]
20+
schedule:
21+
- cron: '15 4 * * 3'
22+
23+
jobs:
24+
analyze:
25+
name: Analyze
26+
runs-on: ubuntu-latest
27+
permissions:
28+
actions: read
29+
contents: read
30+
security-events: write
31+
32+
strategy:
33+
fail-fast: false
34+
matrix:
35+
language: [ 'javascript' ]
36+
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ]
37+
# Learn more:
38+
# https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed
39+
40+
steps:
41+
- name: Checkout repository
42+
uses: actions/checkout@v2
43+
44+
# Initializes the CodeQL tools for scanning.
45+
- name: Initialize CodeQL
46+
uses: github/codeql-action/init@v1
47+
with:
48+
languages: ${{ matrix.language }}
49+
# If you wish to specify custom queries, you can do so here or in a config file.
50+
# By default, queries listed here will override any specified in a config file.
51+
# Prefix the list here with "+" to use these queries and those in the config file.
52+
# queries: ./path/to/local/query, your-org/your-repo/queries@main
53+
54+
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
55+
# If this step fails, then you should remove it and run the build manually (see below)
56+
- name: Autobuild
57+
uses: github/codeql-action/autobuild@v1
58+
59+
# ℹ️ Command-line programs to run using the OS shell.
60+
# 📚 https://git.io/JvXDl
61+
62+
# ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
63+
# and modify them (or add more) to build your code if your project
64+
# uses a compiled language
65+
66+
#- run: |
67+
# make bootstrap
68+
# make release
69+
70+
- name: Perform CodeQL Analysis
71+
uses: github/codeql-action/analyze@v1

.github/workflows/main.yml

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
name: CI
2+
3+
on: [ push, pull_request ]
4+
5+
jobs:
6+
7+
lockfile-lint:
8+
name: Lockfile lint
9+
runs-on: ubuntu-latest
10+
steps:
11+
- uses: actions/checkout@v2
12+
- uses: actions/setup-node@v2
13+
with:
14+
node-version: '14'
15+
- name: lint lock file
16+
run: npx lockfile-lint --path package-lock.json --allowed-hosts npm --validate-https
17+
18+
test:
19+
runs-on: ubuntu-latest
20+
env:
21+
FORCE_COLOR: 3
22+
strategy:
23+
matrix:
24+
node-version: [10.x, 12.x, 14.x, 16.x]
25+
needs: lockfile-lint
26+
name: Unit Tests Node ${{ matrix.node }} (${{ matrix.platform }})
27+
steps:
28+
- uses: actions/checkout@v2
29+
- uses: actions/setup-node@v2
30+
with:
31+
node-version: ${{ matrix.node-version }}
32+
- uses: actions/cache@v2
33+
with:
34+
path: '**/node_modules'
35+
key: ${{ matrix.node-version }}-node-${{ hashFiles('**/package-lock.json') }}
36+
- name: install dependencies
37+
if: steps.cache.outputs.cache-hit != 'true'
38+
run: npm ci
39+
- name: Units Tests + Prepare Coveralls
40+
run: npm run test:ci
41+
- name: Coveralls
42+
uses: coverallsapp/github-action@master
43+
if: matrix.node-version == '14.x'
44+
with:
45+
github-token: ${{ secrets.GITHUB_TOKEN }}
46+
47+
release:
48+
name: release
49+
permissions:
50+
actions: write
51+
checks: write
52+
contents: write
53+
deployments: write
54+
issues: write
55+
packages: write
56+
pull-requests: write
57+
repository-projects: write
58+
security-events: write
59+
statuses: write
60+
needs: [ test, lockfile-lint ]
61+
runs-on: 'ubuntu-latest'
62+
if: github.event_name == 'push' && github.ref == 'refs/heads/master'
63+
steps:
64+
- name: Checkout
65+
uses: actions/checkout@v2
66+
- name: Setup Node
67+
uses: actions/setup-node@v2
68+
with:
69+
node-version: '14.x'
70+
- name: Install dependencies
71+
run: npm ci --ignore-scripts
72+
- name: Release
73+
env:
74+
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
75+
NPM_TOKEN: ${{secrets.NPM_TOKEN }}
76+
run: npx semantic-release

0 commit comments

Comments
 (0)