终于能写点没人写过的东西了。因为有个包不太想往 npm 发,自己又得引用,所以就想着 GitHub 一把梭,直接把包发 GitHub 上再引用。下面逐步讲解一下这个 GitHub Actions 的写法,就用自己的项目来举例:
因为我用的是 TypeScript,所以需要编译。在 tsconfig.json
中需要配好输出文件夹:
如果想要保留输出的包里面的类型定义,引入时好带上类型,(也就是那些 d.ts
文件),那么需要把 declaration 设置为 true。
接下来是 Github Actions 的配置:
1 2 3 4 5 6 7 8 9 10 11 12 13
| name: Release
on: push: branches: ['main']
jobs: build: runs-on: ubuntu-latest
strategy: matrix: node-version: [18.x]
|
前面没什么好说的,监视 main 分支提交,设置环境。
1 2 3 4 5 6
| steps: - uses: actions/checkout@v3 - name: Use Node.js ${{ matrix.node-version }} uses: actions/setup-node@v3 with: node-version: ${{ matrix.node-version }}
|
检出并设置 node 环境,没什么好说的。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| - name: Install pnpm uses: pnpm/action-setup@v2 id: pnpm-install with: version: 7 run_install: false - name: Get pnpm store directory id: pnpm-cache shell: bash run: | echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT - name: Setup pnpm cache uses: actions/cache@v3 with: path: ${{ steps.pnpm-cache.outputs.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} restore-keys: | ${{ runner.os }}-pnpm-store- - name: Install dependencies run: pnpm install
|
因为我用的是 pnpm,GitHub actions 并不原生支持 pnpm 所以还得装一下,出自 pnpm 自己出的设置。
1 2 3 4 5 6 7 8 9 10 11
| - name: build run: pnpm run build - name: read version id: version uses: ashley-taylor/read-json-property-action@v1.0 with: path: ./package.json property: version - name: pack run: | tar -zcvf prism-core.tar.gz ./dist ./template package.json README.md
|
第一步:build;第二步:从 package.json 读取版本号,后面要用;第三步:打包。注意 npm install 似乎不支持 zip 包所以要打包成 tarball。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| - name: Create Release id: create_release uses: actions/create-release@latest env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: tag_name: v${{steps.version.outputs.value}} release_name: v${{steps.version.outputs.value}} draft: false prerelease: false - name: Upload Release Asset id: upload-release-asset uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: upload_url: ${{ steps.create_release.outputs.upload_url }} asset_path: ./prism-core.tar.gz asset_name: prism-core.tar.gz asset_content_type: application/x-tar
|
第一步:生成 release,这时就得用到前面的版本号了。第二步:上传 release,注意这步需要打开项目 actions 的读写权限,在 actions/general 里面的 Workflow permissions。
这样每次提交完都会生成 release (记得改版本号)
接下来是引入,只要 npm install 自动 release 出来的 tarball 网址就可以了,比如我的是:npm install https://github.com/nulla2011/prism-core/releases/download/v0.2.4/prism-core.tar.gz
,每回提交完只需更改网址里的版本号再 npm i
就可以了。或者可以 npm install https://github.com/nulla2011/prism-core/releases/latest/download/prism-core.tar.gz
,但是这样没标版本号容易出问题,需要注意一下。
最后附上完整的 Github Actions 配置:
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
| name: Release
on: push: branches: ['main']
jobs: build: runs-on: ubuntu-latest
strategy: matrix: node-version: [18.x]
steps: - uses: actions/checkout@v3 - name: Use Node.js ${{ matrix.node-version }} uses: actions/setup-node@v3 with: node-version: ${{ matrix.node-version }} - name: Install pnpm uses: pnpm/action-setup@v2 id: pnpm-install with: version: 7 run_install: false - name: Get pnpm store directory id: pnpm-cache shell: bash run: | echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT - name: Setup pnpm cache uses: actions/cache@v3 with: path: ${{ steps.pnpm-cache.outputs.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} restore-keys: | ${{ runner.os }}-pnpm-store- - name: Install dependencies run: pnpm install - name: build run: pnpm run build - name: read version id: version uses: ashley-taylor/read-json-property-action@v1.0 with: path: ./package.json property: version - name: pack run: | tar -zcvf prism-core.tar.gz ./dist ./template package.json README.md - name: Create Release id: create_release uses: actions/create-release@latest env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: tag_name: v${{steps.version.outputs.value}} release_name: v${{steps.version.outputs.value}} draft: false prerelease: false - name: Upload Release Asset id: upload-release-asset uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: upload_url: ${{ steps.create_release.outputs.upload_url }} asset_path: ./prism-core.tar.gz asset_name: prism-core.tar.gz asset_content_type: application/x-tar
|