tylersong 1.0.9 → 1.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cursor/plans/-----------8c733d2f.plan.md +158 -0
- package/.editorconfig +15 -0
- package/.eslintrc.json +33 -0
- package/.github/workflows/ci.yml +59 -25
- package/.github/workflows/deploy.yml +7 -13
- package/.github/workflows/publish.yml +30 -297
- package/.prettierrc +13 -0
- package/README.md +133 -45
- package/dist/index.js +61 -23
- package/dist/index.js.map +1 -1
- package/docs/auto-deployment.md +191 -0
- package/docs/deployment.md +82 -0
- package/docs/development.md +394 -0
- package/docs/direct-deployment.md +116 -0
- package/docs/discord-setup.md +158 -0
- package/docs/github-actions-fixes.md +142 -0
- package/docs/improvements.md +287 -0
- package/docs/pipeline.md +228 -0
- package/docs/testing.md +173 -0
- package/docs/usage.md +112 -0
- package/docs/workflows.md +176 -0
- package/package.json +16 -3
- package/src/index.ts +77 -32
- package/test/index.test.ts +167 -0
- package/tsconfig.eslint.json +9 -0
- package/tsconfig.json +1 -1
- package/vitest.config.ts +22 -0
package/dist/index.js
CHANGED
|
@@ -3,15 +3,37 @@ import inquirer from "inquirer";
|
|
|
3
3
|
import chalk from "chalk";
|
|
4
4
|
import { program } from "commander";
|
|
5
5
|
import { exec } from "child_process";
|
|
6
|
+
import { readFileSync } from "fs";
|
|
7
|
+
import { fileURLToPath } from "url";
|
|
8
|
+
import { dirname, join } from "path";
|
|
9
|
+
// package.json에서 버전 동적으로 읽기
|
|
10
|
+
const getPackageVersion = () => {
|
|
11
|
+
try {
|
|
12
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
13
|
+
const __dirname = dirname(__filename);
|
|
14
|
+
const packagePath = join(__dirname, "..", "package.json");
|
|
15
|
+
const packageJson = JSON.parse(readFileSync(packagePath, "utf-8"));
|
|
16
|
+
return packageJson.version;
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
console.error(chalk.red("⚠️ 버전 정보를 읽을 수 없습니다."));
|
|
20
|
+
return "1.0.0";
|
|
21
|
+
}
|
|
22
|
+
};
|
|
6
23
|
const openUrl = (url) => {
|
|
7
24
|
const command = process.platform === "win32"
|
|
8
25
|
? "start"
|
|
9
26
|
: process.platform === "darwin"
|
|
10
27
|
? "open"
|
|
11
28
|
: "xdg-open";
|
|
12
|
-
exec(`${command} ${url}
|
|
29
|
+
exec(`${command} ${url}`, (error) => {
|
|
30
|
+
if (error) {
|
|
31
|
+
console.error(chalk.red("❌ 브라우저를 열 수 없습니다."));
|
|
32
|
+
console.error(chalk.yellow(`수동으로 방문해주세요: ${url}`));
|
|
33
|
+
}
|
|
34
|
+
});
|
|
13
35
|
};
|
|
14
|
-
program.version(
|
|
36
|
+
program.version(getPackageVersion());
|
|
15
37
|
program.option("-g, --github", "GitHub 프로필 열기");
|
|
16
38
|
program.parse(process.argv);
|
|
17
39
|
const options = program.opts();
|
|
@@ -21,9 +43,10 @@ if (Object.keys(options).length > 0) {
|
|
|
21
43
|
process.exit(0);
|
|
22
44
|
}
|
|
23
45
|
const main = async () => {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
46
|
+
try {
|
|
47
|
+
// 도움말 옵션 체크
|
|
48
|
+
if (process.argv.includes("--help")) {
|
|
49
|
+
console.log(chalk.yellow(`
|
|
27
50
|
╭───────────────────────────────╮
|
|
28
51
|
│ 사용 방법 │
|
|
29
52
|
├───────────────────────────────┤
|
|
@@ -35,36 +58,51 @@ const main = async () => {
|
|
|
35
58
|
│ -h, --help 도움말 │
|
|
36
59
|
╰───────────────────────────────╯
|
|
37
60
|
`));
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
61
|
+
process.exit(0);
|
|
62
|
+
}
|
|
63
|
+
// 사용자 질문
|
|
64
|
+
const answer = await inquirer.prompt([
|
|
65
|
+
{
|
|
66
|
+
type: "confirm",
|
|
67
|
+
name: "showInfo",
|
|
68
|
+
message: chalk.cyan("✨ 저에 대해 궁금하신가요?"),
|
|
69
|
+
default: true,
|
|
70
|
+
},
|
|
71
|
+
]);
|
|
72
|
+
if (answer.showInfo) {
|
|
73
|
+
console.log(chalk.bold.cyan(`
|
|
51
74
|
╭───────────────────────────────────────────╮
|
|
52
75
|
│ 🚀 Developer Profile 🚀 │
|
|
53
76
|
╰───────────────────────────────────────────╯
|
|
54
77
|
|
|
55
78
|
`) +
|
|
56
|
-
|
|
79
|
+
chalk.green(`👋 안녕하세요!
|
|
57
80
|
💻 개발자 ${chalk.bold.yellow("송민성")}입니다.
|
|
58
81
|
|
|
59
82
|
`) +
|
|
60
|
-
|
|
83
|
+
chalk.hex("#fef6e1")(`📌 Github: ${chalk.underline.whiteBright(`https://github.com/alstjd0051`)}
|
|
61
84
|
`) +
|
|
62
|
-
|
|
85
|
+
chalk.blue(`✉️ E-mail: ${chalk.underline.whiteBright(`wsc7202@gmail.com`)}
|
|
63
86
|
`) +
|
|
64
|
-
|
|
87
|
+
chalk.magenta(`
|
|
65
88
|
💡 더 많은 정보는 ${chalk.bold("--help")}를 통해 확인해주세요.
|
|
66
89
|
`));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
catch (error) {
|
|
93
|
+
console.error(chalk.red("\n❌ 오류가 발생했습니다:"));
|
|
94
|
+
if (error instanceof Error) {
|
|
95
|
+
console.error(chalk.yellow(error.message));
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
console.error(chalk.yellow("알 수 없는 오류가 발생했습니다."));
|
|
99
|
+
}
|
|
100
|
+
process.exit(1);
|
|
67
101
|
}
|
|
68
102
|
};
|
|
69
|
-
main().catch(
|
|
103
|
+
main().catch((error) => {
|
|
104
|
+
console.error(chalk.red("\n❌ 치명적인 오류가 발생했습니다:"));
|
|
105
|
+
console.error(error);
|
|
106
|
+
process.exit(1);
|
|
107
|
+
});
|
|
70
108
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAEA,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
# 자동 배포 시스템 가이드
|
|
2
|
+
|
|
3
|
+
## 🎯 개요
|
|
4
|
+
이 시스템은 main 브랜치에 PR이 merge될 때 자동으로 버전을 업데이트하고 NPM에 배포하는 완전 자동화된 배포 시스템입니다.
|
|
5
|
+
|
|
6
|
+
## 🚀 작동 방식
|
|
7
|
+
|
|
8
|
+
### 1. 자동 트리거
|
|
9
|
+
- **main 브랜치로의 PR merge**: CI 완료 후 자동 배포 시작
|
|
10
|
+
- **main 브랜치로의 직접 push**: 즉시 자동 배포 시작
|
|
11
|
+
- **태그 push**: 기존 태그 기반 배포 유지
|
|
12
|
+
|
|
13
|
+
### 2. 자동 버전 결정 (Semantic Versioning)
|
|
14
|
+
커밋 메시지를 분석하여 자동으로 버전 타입을 결정합니다:
|
|
15
|
+
|
|
16
|
+
#### 🔴 Major 버전 (X.0.0)
|
|
17
|
+
```bash
|
|
18
|
+
# Breaking changes
|
|
19
|
+
git commit -m "feat!: completely new API structure"
|
|
20
|
+
git commit -m "fix!: remove deprecated method"
|
|
21
|
+
git commit -m "feat: add new feature
|
|
22
|
+
|
|
23
|
+
BREAKING CHANGE: This removes the old API"
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
#### 🟡 Minor 버전 (0.X.0)
|
|
27
|
+
```bash
|
|
28
|
+
# New features
|
|
29
|
+
git commit -m "feat: add user profile management"
|
|
30
|
+
git commit -m "feat(auth): implement OAuth login"
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
#### 🟢 Patch 버전 (0.0.X)
|
|
34
|
+
```bash
|
|
35
|
+
# Bug fixes, docs, chores (default)
|
|
36
|
+
git commit -m "fix: resolve login redirect issue"
|
|
37
|
+
git commit -m "docs: update README"
|
|
38
|
+
git commit -m "chore: update dependencies"
|
|
39
|
+
git commit -m "style: fix code formatting"
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
### 3. 자동 실행 과정
|
|
43
|
+
1. **CI 실행**: 테스트, 빌드, 린팅
|
|
44
|
+
2. **버전 분석**: 현재 버전 vs NPM 배포 버전 비교
|
|
45
|
+
3. **자동 버전 업데이트**: 필요 시 package.json 및 소스코드 버전 업데이트
|
|
46
|
+
4. **자동 커밋**: 버전 업데이트 커밋 생성 및 푸시
|
|
47
|
+
5. **빌드 및 배포**: TypeScript 빌드 후 NPM 배포
|
|
48
|
+
6. **알림**: Discord 및 콘솔 알림
|
|
49
|
+
|
|
50
|
+
## 📋 사전 설정 요구사항
|
|
51
|
+
|
|
52
|
+
### 1. GitHub Secrets 설정
|
|
53
|
+
```bash
|
|
54
|
+
# NPM 토큰 설정 (필수)
|
|
55
|
+
NPM_TOKEN=your_npm_token_here
|
|
56
|
+
|
|
57
|
+
# Discord 알림 (선택사항)
|
|
58
|
+
DISCORD_WEBHOOK_URL=your_discord_webhook_url
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### 2. NPM 토큰 생성 방법
|
|
62
|
+
1. [npmjs.com](https://www.npmjs.com)에 로그인
|
|
63
|
+
2. Profile → Access Tokens → Generate New Token
|
|
64
|
+
3. **Automation** 타입 선택
|
|
65
|
+
4. 생성된 토큰을 GitHub Repository Settings → Secrets에 `NPM_TOKEN`으로 추가
|
|
66
|
+
|
|
67
|
+
## 🎨 Conventional Commits 가이드
|
|
68
|
+
|
|
69
|
+
### 기본 형식
|
|
70
|
+
```
|
|
71
|
+
<type>[optional scope]: <description>
|
|
72
|
+
|
|
73
|
+
[optional body]
|
|
74
|
+
|
|
75
|
+
[optional footer(s)]
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
### 주요 타입들
|
|
79
|
+
| 타입 | 설명 | 버전 영향 |
|
|
80
|
+
|------|------|-----------|
|
|
81
|
+
| `feat` | 새로운 기능 | Minor |
|
|
82
|
+
| `fix` | 버그 수정 | Patch |
|
|
83
|
+
| `docs` | 문서 변경 | Patch |
|
|
84
|
+
| `style` | 코드 스타일 변경 | Patch |
|
|
85
|
+
| `refactor` | 코드 리팩토링 | Patch |
|
|
86
|
+
| `test` | 테스트 추가/수정 | Patch |
|
|
87
|
+
| `chore` | 빌드/설정 변경 | Patch |
|
|
88
|
+
| `!` | Breaking Change | Major |
|
|
89
|
+
|
|
90
|
+
### 실제 예시
|
|
91
|
+
```bash
|
|
92
|
+
# 새 기능 추가 (Minor 버전 증가)
|
|
93
|
+
git commit -m "feat: add interactive CLI menu"
|
|
94
|
+
|
|
95
|
+
# 버그 수정 (Patch 버전 증가)
|
|
96
|
+
git commit -m "fix: resolve command parsing error"
|
|
97
|
+
|
|
98
|
+
# Breaking Change (Major 버전 증가)
|
|
99
|
+
git commit -m "feat!: redesign CLI interface"
|
|
100
|
+
|
|
101
|
+
# 상세한 설명이 있는 커밋
|
|
102
|
+
git commit -m "feat: add color themes
|
|
103
|
+
|
|
104
|
+
- Add dark and light theme options
|
|
105
|
+
- Implement theme persistence
|
|
106
|
+
- Update help text with theme info"
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
## 🔧 워크플로우 파일 구성
|
|
110
|
+
|
|
111
|
+
### 주요 작업들
|
|
112
|
+
1. **check-ci**: CI 상태 확인
|
|
113
|
+
2. **auto-version**: 자동 버전 업데이트 및 결정
|
|
114
|
+
3. **version-check**: 태그 기반 배포용 버전 확인
|
|
115
|
+
4. **publish**: NPM 배포 실행
|
|
116
|
+
5. **notify**: 결과 알림
|
|
117
|
+
|
|
118
|
+
### 트리거 조건
|
|
119
|
+
```yaml
|
|
120
|
+
on:
|
|
121
|
+
push:
|
|
122
|
+
branches: [main] # main 브랜치 직접 push
|
|
123
|
+
tags: ["v*"] # 태그 push
|
|
124
|
+
workflow_run:
|
|
125
|
+
workflows: ["Continuous Integration"]
|
|
126
|
+
types: [completed] # CI 완료 후
|
|
127
|
+
branches: [main]
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
## 📊 배포 시나리오
|
|
131
|
+
|
|
132
|
+
### 시나리오 1: 첫 PR merge
|
|
133
|
+
```
|
|
134
|
+
현재 NPM: v1.0.5
|
|
135
|
+
현재 코드: v1.0.5
|
|
136
|
+
→ 자동으로 v1.0.6으로 업데이트 후 배포
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
### 시나리오 2: 이미 다른 버전인 경우
|
|
140
|
+
```
|
|
141
|
+
현재 NPM: v1.0.5
|
|
142
|
+
현재 코드: v1.0.6
|
|
143
|
+
→ 버전 업데이트 없이 v1.0.6 즉시 배포
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### 시나리오 3: 태그 기반 배포
|
|
147
|
+
```
|
|
148
|
+
태그 push: v1.1.0
|
|
149
|
+
→ 버전 체크만 하고 즉시 배포
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
## 🚨 주의사항
|
|
153
|
+
|
|
154
|
+
### 1. 권한 설정
|
|
155
|
+
- GitHub Actions에 repository write 권한 필요
|
|
156
|
+
- NPM 토큰이 올바르게 설정되어야 함
|
|
157
|
+
|
|
158
|
+
### 2. 커밋 메시지 규칙
|
|
159
|
+
- Conventional Commits 형식 권장
|
|
160
|
+
- 명확하고 일관된 메시지 작성
|
|
161
|
+
|
|
162
|
+
### 3. CI/CD 최적화
|
|
163
|
+
- `[skip ci]` 태그로 무한 루프 방지
|
|
164
|
+
- 버전 업데이트 커밋은 자동으로 CI 건너뛰기
|
|
165
|
+
|
|
166
|
+
## 🎉 장점
|
|
167
|
+
|
|
168
|
+
### ✅ 완전 자동화
|
|
169
|
+
- 수동 버전 관리 불필요
|
|
170
|
+
- 실수 방지 및 일관성 보장
|
|
171
|
+
|
|
172
|
+
### ✅ Semantic Versioning 준수
|
|
173
|
+
- 커밋 메시지 기반 자동 버전 결정
|
|
174
|
+
- 표준화된 버전 관리
|
|
175
|
+
|
|
176
|
+
### ✅ 실시간 알림
|
|
177
|
+
- Discord 및 콘솔 배포 상태 알림
|
|
178
|
+
- 성공/실패 즉시 확인
|
|
179
|
+
|
|
180
|
+
## 🔍 디버깅
|
|
181
|
+
|
|
182
|
+
### 로그 확인 위치
|
|
183
|
+
- GitHub Actions → 해당 워크플로우 실행 → 각 작업 로그
|
|
184
|
+
|
|
185
|
+
### 일반적인 문제들
|
|
186
|
+
1. **NPM 토큰 오류**: Secrets 설정 확인
|
|
187
|
+
2. **버전 충돌**: NPM에서 같은 버전 이미 배포됨
|
|
188
|
+
3. **빌드 실패**: TypeScript 컴파일 오류 확인
|
|
189
|
+
4. **권한 오류**: GitHub token 권한 확인
|
|
190
|
+
|
|
191
|
+
이제 PR만 merge하면 자동으로 버전이 업데이트되고 NPM에 배포됩니다! 🚀
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
# 배포 가이드
|
|
2
|
+
|
|
3
|
+
## CI/CD 파이프라인
|
|
4
|
+
|
|
5
|
+
이 프로젝트는 모듈화된 GitHub Actions를 사용한 자동 배포 시스템을 구축했습니다.
|
|
6
|
+
|
|
7
|
+
> 📖 **워크플로우 구조**: 자세한 내용은 [docs/workflows.md](./workflows.md)를 참고해주세요.
|
|
8
|
+
|
|
9
|
+
### 트리거 조건
|
|
10
|
+
|
|
11
|
+
#### 1. Pull Request
|
|
12
|
+
|
|
13
|
+
- `main` 브랜치로의 PR 시 테스트와 빌드만 실행
|
|
14
|
+
- Node.js와 Bun 두 환경에서 모두 테스트
|
|
15
|
+
|
|
16
|
+
#### 2. Main 브랜치 Push
|
|
17
|
+
|
|
18
|
+
- `main` 브랜치에 직접 push 시
|
|
19
|
+
- 버전이 변경된 경우에만 NPM에 자동 배포
|
|
20
|
+
- package.json의 버전과 NPM에 이미 배포된 버전을 비교
|
|
21
|
+
|
|
22
|
+
#### 3. 태그 Push
|
|
23
|
+
|
|
24
|
+
- `v*` 형태의 태그 push 시 무조건 NPM에 배포
|
|
25
|
+
- 예: `v1.0.5`, `v2.1.0`
|
|
26
|
+
|
|
27
|
+
### 배포 워크플로우
|
|
28
|
+
|
|
29
|
+
```mermaid
|
|
30
|
+
graph LR
|
|
31
|
+
A[Code Push] --> B{브랜치 확인}
|
|
32
|
+
B -->|main| C[버전 체크]
|
|
33
|
+
B -->|태그| F[즉시 배포]
|
|
34
|
+
C -->|변경됨| D[테스트 & 빌드]
|
|
35
|
+
C -->|동일함| E[배포 스킵]
|
|
36
|
+
D --> F[NPM 배포]
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### 수동 배포 방법
|
|
40
|
+
|
|
41
|
+
#### 1. 버전 업데이트 후 main 브랜치 배포
|
|
42
|
+
|
|
43
|
+
```bash
|
|
44
|
+
# 버전 업데이트
|
|
45
|
+
npm version patch # 또는 minor, major
|
|
46
|
+
|
|
47
|
+
# main 브랜치에 push (자동 배포됨)
|
|
48
|
+
git push origin main
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
#### 2. 태그를 통한 배포
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
# 버전 업데이트
|
|
55
|
+
npm version patch
|
|
56
|
+
|
|
57
|
+
# 태그와 함께 push (즉시 배포됨)
|
|
58
|
+
git push origin main --tags
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### 환경 변수 설정
|
|
62
|
+
|
|
63
|
+
GitHub Repository Settings에서 다음 Secret을 설정해야 합니다:
|
|
64
|
+
|
|
65
|
+
- `NPM_TOKEN`: NPM 계정의 액세스 토큰
|
|
66
|
+
|
|
67
|
+
### 지원 런타임
|
|
68
|
+
|
|
69
|
+
- **Node.js 20.x**: 메인 런타임
|
|
70
|
+
- **Bun Latest**: 성능 테스트 및 대안 빌드
|
|
71
|
+
|
|
72
|
+
### 빌드 산출물
|
|
73
|
+
|
|
74
|
+
- TypeScript 컴파일된 JavaScript 파일들
|
|
75
|
+
- 타입 정의 파일 (.d.ts)
|
|
76
|
+
- 소스맵 파일
|
|
77
|
+
|
|
78
|
+
### 주의사항
|
|
79
|
+
|
|
80
|
+
1. **버전 관리**: package.json의 버전을 먼저 업데이트해야 배포됩니다
|
|
81
|
+
2. **테스트 통과**: 모든 테스트가 통과해야 배포가 진행됩니다
|
|
82
|
+
3. **권한**: NPM_TOKEN이 올바르게 설정되어야 합니다
|