티스토리 뷰
매우 간단하게 github action을 시작해볼수 있는 github action을 작성해보도록 합시다
github action 은 yaml 포맷으로 작성이 되는데요
기본형이 되는 다음의 내용을 작성해봅시다
// action.yml
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 16
- run: npm ci
- run: npm test
하나씩 항목을 살펴봅시다
uses 에
actions/checkout@v3
actions/setup-node@v3
라고 나와있는 부분은
이미 다른 사람이 만들어 생성되어있는 액션을 가져다 쓴다고 생각하시면 됩니다
actions/checkout@v3
actions/setup-node@v3
두개의 액션을 가져다 쓰는데요
actions/checkout@v3는 repository를 checkout 하는 액션입니다
actions/setup-node@v3는 node환경을 셋업하는 액션입니다
이름이 아주 직관적이지요?
그런데 actions/setup-node@v3 밑에
with라는 이름으로
node-version: 16 이라고 표기되어있습니다
actions/setup-node@v3는 여러 파라메터를 받을수 있는데요
액션에 필요한 파라메터를 전송할때 with를 사용합니다
with를 통해 node-version 이라는 파라메터를 보냈는데요
node-version을 16버전을 사용하겠다라는 의미겠죠?
그리고
run : npm ci
이것은 말그대로 npm ci 명령어를 실행합니다
체크아웃한 repo의 package.json, package-lock.json을 이용해 패키지들을 설치합니다
그리고 마지막으로
run : npm test
여러분의 레파지토리에 npm test 명령어가 설정되어있다면
npm test 명령어를 실행합니다
당연히 여러분들이 만들어놓은 테스트 케이스들이 동작을 하겠지요?
짧고 쉬운 설명을 마쳤는데요
심화로 들어가봅시다
npm ci 명령어를 통해 패키지를 설치하는것은 사실 상당한 시간이 걸리는 작업입니다
추가적인 패키지의 설치가 없이 아주 작은 코드를 변경할때도 액션이 긴 시간 수행이 될텐데요
depecency에 아무런 변경이 없는 경우에 node_modules를 캐시를 하게 된다면
이 액션이 좀 더 빠르게 동작할수 있겠죠?
actions/setup-node@v3는
내부적으로 action/cache를 사용하여 캐싱을 할수 있는 기능을 제공합니다
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 16
cache: 'npm'
- run: npm ci
- run: npm test
with에 cache : 'npm' 이라는 파라메터를 추가로 전달하게 되면
이 프로젝트가 npm 패키지라는것을 인식하여 루트경로에 위치한 package-lock.json 파일의 해시값을 키로하여
캐시를 저장합니다
그래서 다음 실행부터는 install 과정을 건너뛰고 좀 더 빠르게 액션이 수행됩니다
// ./github/workflows/acton.yml
name : nodejs CI
on:
push:
branches: [master]
pull_request:
branches: [master]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 16
cache: 'npm'
- run: npm ci
- run: npm test
자 이제 이렇게 최종적으로 완성된 yml 파일을 프로젝트의 .github/workflow 폴더를 생성하여 두게되면
master 브랜치의 push 또는 pull_request가 생성될때 이 액션이 수행되게 됩니다
스케줄에 기반하여 정기적으로 액션을 수행할수도 있구요
한번 만들어볼까요?
'WEB2.0 > 프로그래밍' 카테고리의 다른 글
아직도 손으로 한땀한땀 response model을 만들고 계신가요? (0) | 2023.04.06 |
---|---|
javascript로 글자수 세기 위한 노력 (0) | 2023.04.05 |
as const 로 object를 견고하게 만들기 (0) | 2023.03.08 |
당신의 typescript 함수를 순수하게 만들어줄 readonly (0) | 2023.03.07 |
typescript의 인터페이스는 javscript에는 없습니다 (0) | 2023.03.06 |
- Total
- Today
- Yesterday
- 경진대회
- 벤처
- 공모전
- CSS
- iPhone
- 창업
- 대학생
- 웹표준
- 애플
- 스마트폰
- 네이버
- php
- JavaScript
- 앱
- 아이폰
- 아이디어
- 자바스크립트
- 게임
- 구글
- 안드로이드
- 앱스토어
- 소프트웨어
- 어플리케이션
- android
- 모바일
- AWS
- Apple
- 트위터
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |