Azure DevOps Artifacts
Azure Artifacts
1. Create Porject
data:image/s3,"s3://crabby-images/51cc8/51cc8492983168311ba1944b5e4afbcf0d15ecea" alt=""
2. 寫一個簡單的套件並推送到倉庫
data:image/s3,"s3://crabby-images/cd293/cd2933f5c0647c6eb8840cb48b3f4dbbdbc69de6" alt=""
index.js
1 2 3
| module.exports = (str) => { console.log('str :', str); };
|
3. Artifacts > Connect to feed
data:image/s3,"s3://crabby-images/a61bf/a61bf97e48f26e20e8c8bd251149a687f78d4bc3" alt=""
4. 選 NPM 倉庫
data:image/s3,"s3://crabby-images/f17d0/f17d00f9fd8619a5a728a0fdcb5619a1ee6f5ea4" alt=""
5. 複製內容
data:image/s3,"s3://crabby-images/86c22/86c22cf0859ffb787eca8a3be44b07cf29baecf4" alt=""
6. 新增一個 .npmrc 並將內容貼上
data:image/s3,"s3://crabby-images/dc7a1/dc7a1db504658c90aeab1ad60b764fa718075bec" alt=""
7. Generate npm credentials
data:image/s3,"s3://crabby-images/29161/29161516fc56c211218172aba9133f1ca7985d64" alt=""
8. 在 User 底下建立一個 .npmrc 並將內容貼上
data:image/s3,"s3://crabby-images/3c9cb/3c9cb50a324a675fd2c7ca6dcfb8736ee38e7496" alt=""
9. publish
data:image/s3,"s3://crabby-images/1fc75/1fc7598afbe1c1b7caeeede2dc7d318ac5735201" alt=""
10. 檢查是否推送成功
data:image/s3,"s3://crabby-images/287dd/287dd389fd530e235485db968f0a468b8fb421af" alt=""
11.安裝套件
新增.npmrc 將內容貼上
data:image/s3,"s3://crabby-images/86c22/86c22cf0859ffb787eca8a3be44b07cf29baecf4" alt=""
install
1
| npm install mypackage@1.0.0
|
index.js
1 2 3 4
| const f = require('mypackage'); f('Hello mypackage');
console.log('Hello Word 123');
|
data:image/s3,"s3://crabby-images/97d12/97d120cc9ea82009057adde2731433a26dff58ef" alt=""
使用 Azure Pipeline (CI)
1. 先設定 Artifacts 權限
1.1 Artifacts > 右上角齒輪 > Feed settings
data:image/s3,"s3://crabby-images/3a782/3a782faed630eedda26d39548e2c30f797e2bd79" alt=""
data:image/s3,"s3://crabby-images/9745e/9745e0b77efffd9d3f5e21d16a41064458ae8949" alt=""
2.2 Permissons > 右上角三點 > 加入 Allow project-scoped builds & Allow builds and releases
data:image/s3,"s3://crabby-images/927b6/927b6dda35630aaa07603041e8f561d816555f1d" alt=""
2. Pipeline > 選 New Pipeline
data:image/s3,"s3://crabby-images/c7a84/c7a84f7ac478e51adc832be3d01a9dc084f9de4f" alt=""
3. 選 Azure Respose Git 後選自己的專案
data:image/s3,"s3://crabby-images/2f030/2f030dc4c8acbc107b9a18404d5b58891c8686a8" alt=""
data:image/s3,"s3://crabby-images/0dc40/0dc4089f617cc95c226adfb287081c5c16c65f37" alt=""
4. 選 Node.js
data:image/s3,"s3://crabby-images/86d93/86d93f5c727e0601811d0a8048ba90e5bca5b041" alt=""
5. 載入預設範本
範本會啟動一個 ubuntu 的容器做CI
data:image/s3,"s3://crabby-images/ccf00/ccf000fbbd80c7796de35af128e4fcdcfae53941" alt=""
6. 編輯步驟,點選右邊 Show assistant
data:image/s3,"s3://crabby-images/3d959/3d959b49ea2f8f89a933bc36f8deb6187148da43" alt=""
data:image/s3,"s3://crabby-images/39866/39866fc14ec9a2fd570ffebca35bb92e18a0eb8b" alt=""
7. 選 npm 並加入三個步驟
data:image/s3,"s3://crabby-images/a8fdd/a8fdd574cbbba504e5322c4371d82143e12bb89c" alt=""
7.1 npm install
data:image/s3,"s3://crabby-images/388e4/388e41c185be015c9328e3d8a2d83e21eec12bab" alt=""
7.2 npm version
data:image/s3,"s3://crabby-images/96654/96654dc110c7d7243c8984041f1cc34ef64cbb82" alt=""
7.3 npm publish
data:image/s3,"s3://crabby-images/950bf/950bfcc23876316640c15068dc1ca1e2cc7ff4c0" alt=""
7.4 加入 name 標籤 跟 variables 標籤
1 2 3 4
| name: 1.0$(Rev:.r)
variables: tag: "$(Build.BuildNumber)"
|
以下是完整yml檔 (customFeed 要改成自己的)
azure-pipelines.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
| trigger: - master
name: 1.0$(Rev:.r)
pool: vmImage: 'ubuntu-latest'
variables: tag: "$(Build.BuildNumber)"
steps: - task: NodeTool@0 inputs: versionSpec: '10.x' displayName: 'Install Node.js'
- task: Npm@1 inputs: command: 'install' customRegistry: 'useFeed' customFeed: '4a2334a5-bdf9-4111-a296-45ec69953953/648d8565-b9df-4a54-a9e9-f506420b558e'
- task: Npm@1 inputs: command: 'custom' customCommand: 'version $(tag) --no-git-tag-version' customRegistry: 'useFeed' customFeed: '4a2334a5-bdf9-4111-a296-45ec69953953/648d8565-b9df-4a54-a9e9-f506420b558e'
- task: Npm@1 inputs: command: 'publish' publishRegistry: 'useFeed' publishFeed: '4a2334a5-bdf9-4111-a296-45ec69953953/648d8565-b9df-4a54-a9e9-f506420b558e'
|
8. Save and Run
因為有設定 pull request ,所以不能直接 commit master,所以選 create a new branch for this commit
data:image/s3,"s3://crabby-images/1162b/1162ba4075ca6b570e5853ad5ffb96a47813f361" alt=""
data:image/s3,"s3://crabby-images/f1b0a/f1b0abf8ee2816a4d239b9a5057da522e337f293" alt=""
data:image/s3,"s3://crabby-images/d6374/d63744cb19d401539adff69baa50f01f40bd6fd9" alt=""
data:image/s3,"s3://crabby-images/59601/596017a9fd94cd7b6d4e42f866d5165334ea92bd" alt=""
9. 回到 Repos > Pull Resquest 回 master
完成之後可以看到 多了一個 azure-pipelines.yml
data:image/s3,"s3://crabby-images/d6241/d6241de493203752eebaf0293b8e0a9c133b9da3" alt=""
data:image/s3,"s3://crabby-images/7ee95/7ee95f1f536f0642a39f7f363a725af0452e7310" alt=""
參考