-
Notifications
You must be signed in to change notification settings - Fork 1
156 lines (142 loc) · 4.49 KB
/
nodejs.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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
name: Test, Build & Publish
on:
push:
branches: '**'
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install Node.js
uses: actions/setup-node@v3
with:
node-version: 18
- name: install pnpm
run: npm i -g pnpm
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: pnpm install, build, and test
run: |
pnpm install
pnpm run lint
pnpm run build
pnpm run test
env:
CI: true
ember-try:
name: ember-try (${{ matrix.scenario }})
needs: test
timeout-minutes: 15
runs-on: ubuntu-latest
continue-on-error: ${{ matrix.experimental }}
env:
CI: 'true'
strategy:
fail-fast: false
matrix:
experimental: [false]
scenario:
- release
include:
- scenario: beta
experimental: true
- scenario: canary
experimental: true
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install Node.js
uses: actions/setup-node@v3
with:
node-version: 18
- name: install pnpm
run: npm i -g pnpm
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies (pnpm)
run: pnpm install
# - name: Setup ember-try scenario
# working-directory: ./test-app
# run: ./node_modules/.bin/ember try:one ember-${{ matrix.scenario }} --skip-cleanup --- cat package.json
- name: Build V2 addon
working-directory: ./carbon-components-ember
run: pnpm run build
- name: Build test app
working-directory: ./test-app
env:
EMBROIDER_TEST_SETUP_FORCE: classic
run: pnpm run classic:build-ember
- name: Run test
working-directory: ./test-app
env:
EMBROIDER_TEST_SETUP_FORCE: classic
run: pnpm run classic:test-ember
deploy:
needs: [test, ember-try]
if: github.ref == 'refs/heads/main'
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [16.x]
steps:
- uses: actions/checkout@v3
with:
ssh-key: ${{ secrets.DEPLOY_KEY }}
- name: Install Node.js
uses: actions/setup-node@v3
with:
node-version: 18
- name: install pnpm
run: npm i -g pnpm
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: pnpm install, build, and deploy docs
run: |
mkdir ~/.ssh
ssh-keyscan github.com >> ~/.ssh/known_hosts
pnpm install
version=$(cat package.json | jq -r '.version')
git fetch --unshallow
git fetch --all --tags
TAG=v$version
cd ./carbon-components-ember
pnpm run build
cd ..
cd doc-app
if git rev-parse "$TAG" >/dev/null 2>&1; then
echo "tag exists";
else
EMBROIDER_TEST_SETUP_FORCE=classic ADDON_DOCS_UPDATE_LATEST=false ADDON_DOCS_VERSION_PATH=$TAG ./node_modules/.bin/ember deploy production
EMBROIDER_TEST_SETUP_FORCE=classic ADDON_DOCS_UPDATE_LATEST=true ADDON_DOCS_VERSION_PATH=$TAG ./node_modules/.bin/ember deploy production
fi
EMBROIDER_TEST_SETUP_FORCE=classic ADDON_DOCS_UPDATE_LATEST=false ADDON_DOCS_VERSION_PATH=main ./node_modules/.bin/ember deploy production
env:
CI: true
DEPLOY_KEY: ${{ secrets.DEPLOY_KEY }}