Skip to content

Commit 87ea5e1

Browse files
authored
Merge pull request #18 from The-SudoStart/ci
Ci
2 parents 22df0b7 + 1c7ea78 commit 87ea5e1

1 file changed

Lines changed: 87 additions & 0 deletions

File tree

.github/workflows/ci.yml

Lines changed: 87 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,87 @@
1+
name: CI
2+
3+
on:
4+
push:
5+
branches: main
6+
pull_request:
7+
branches: [main]
8+
9+
concurrency:
10+
group: ${{ github.workflow }}-${{ github.ref }}
11+
cancel-in-progress: true
12+
13+
env:
14+
NODE_VERSION: "20"
15+
16+
jobs:
17+
lint:
18+
name: Lint & Type-check
19+
runs-on: ubuntu-latest
20+
steps:
21+
- uses: actions/checkout@v4
22+
23+
- uses: pnpm/action-setup@v4
24+
25+
- uses: actions/setup-node@v4
26+
with:
27+
node-version: ${{ env.NODE_VERSION }}
28+
cache: pnpm
29+
30+
- name: Install dependencies
31+
run: pnpm install --frozen-lockfile
32+
33+
- name: Run ESLint
34+
run: pnpm lint
35+
36+
- name: TypeScript type-check
37+
run: pnpm exec tsc --noEmit
38+
39+
build:
40+
name: Build
41+
runs-on: ubuntu-latest
42+
needs: lint
43+
steps:
44+
- uses: actions/checkout@v4
45+
46+
- uses: pnpm/action-setup@v4
47+
48+
- uses: actions/setup-node@v4
49+
with:
50+
node-version: ${{ env.NODE_VERSION }}
51+
cache: pnpm
52+
53+
- name: Install dependencies
54+
run: pnpm install --frozen-lockfile
55+
56+
- name: Build
57+
run: pnpm build
58+
env:
59+
GROQ_API_KEY: ${{ secrets.GROQ_API_KEY || 'gsk_placeholder_for_ci_build' }}
60+
61+
- name: Upload build artifact
62+
uses: actions/upload-artifact@v4
63+
with:
64+
name: nextjs-build
65+
path: .next/
66+
retention-days: 1
67+
audit:
68+
name: Security Audit
69+
runs-on: ubuntu-latest
70+
steps:
71+
- uses: actions/checkout@v4
72+
73+
- uses: pnpm/action-setup@v4
74+
with:
75+
version: ${{ env.PNPM_VERSION }}
76+
77+
- uses: actions/setup-node@v4
78+
with:
79+
node-version: ${{ env.NODE_VERSION }}
80+
cache: pnpm
81+
82+
- name: Install dependencies
83+
run: pnpm install --frozen-lockfile
84+
85+
- name: Audit dependencies
86+
run: pnpm audit --audit-level=high
87+
continue-on-error: true

0 commit comments

Comments
 (0)