작은 릴리스를 수행하고 태그를 지정하기 전에 새 버전의 프로그램을 반영하도록 package.json을 업데이트하고 싶습니다.
파일을 package.json
자동으로 편집하는 방법이 있습니까?
사용겠습니까 git pre-release hook
도움을?
작은 릴리스를 수행하고 태그를 지정하기 전에 새 버전의 프로그램을 반영하도록 package.json을 업데이트하고 싶습니다.
파일을 package.json
자동으로 편집하는 방법이 있습니까?
사용겠습니까 git pre-release hook
도움을?
답변:
npm version
아마 정답 일 것입니다. 대안을 제공하기 위해 grunt-bump 권장 합니다. 그것은 angular.js의 사람 중 하나에 의해 유지됩니다.
용법:
grunt bump
>> Version bumped to 0.0.2
grunt bump:patch
>> Version bumped to 0.0.3
grunt bump:minor
>> Version bumped to 0.1.0
grunt bump
>> Version bumped to 0.1.1
grunt bump:major
>> Version bumped to 1.0.0
어쨌든 grunt를 사용하는 경우 가장 간단한 해결책 일 수 있습니다.
npm version
?
npm --no-git-tag-version version patch
.
올바른 대답
그렇게하려면 npm version patch
=)
나의 옛 대답
pre-release
원래 에는 후크 가 없습니다 git
. 적어도 man githooks
표시하지 않습니다.
당신이 사용하는 경우 git-extra
( https://github.com/visionmedia/git-extras ), 예를 들어, 당신은 사용할 수 있습니다 pre-release
당신은에서 볼 수 있듯이, 그것에 의해 구현되는 후크를 https://github.com/visionmedia/ git-extras / blob / master / bin / git-release . .git/hook/pre-release.sh
파일을 편집 하는 실행 파일 만 필요 package.json
합니다. 커밋, 푸시 및 태깅은 git release
명령에 의해 수행됩니다 .
에 대한 확장명을 사용하지 않는 경우 git
쉘 스크립트를 작성하고 (이름을 지정 함 git-release.sh
) git release
다음과 같이 별명을 지정할 수 있습니다 .
git config --global alias.release '!sh path/to/pre-release.sh $1'
git release 0.4
를 실행할 것보다을 사용할 수 있습니다 path/to/pre-release.sh 0.4
. 스크립트는 package.json
태그를 편집 하여 서버로 푸시 할 수 있습니다.
git release
그에 따라 package.json을 업데이트하지 않습니다 ... github.com/visionmedia/git-extras/issues/150 : D
.git/hooks/pre-release.sh
포함 : echo -e "{\n\"version\": "$1"\n}" > package.json
및 사용해보십시오git release $version
이것이 일반적으로 프로젝트에서 수행하는 작업입니다.
npm version patch
git add *;
git commit -m "Commit message"
git push
npm publish
첫 번째 줄 npm version patch
은에서 패치 버전을 1 (xx1 ~ xx2) 증가시킵니다 package.json
. 그런 다음 package.json
수정 된 시점을 포함하여 모든 파일을 추가합니다 . 그런 다음 평소 git commit
와 git push
, 마지막 npm publish
으로 모듈을 게시합니다.
이것이 의미가 있기를 바랍니다 ...
머서.
npm version patch
있는 한, 커밋 자체를 수행합니다. 그러나 태그를 github에 푸시하려면을해야한다고 생각합니다 git push --tags
.
npm version patch
합니다. 버전 번호가 충돌 하고 즉시 변경 사항이 적용됩니다.
npm version patch
나를 위해 아무것도 저 지르지 않습니다.
npm version
.
보다 최신의 접근 방식을 제공합니다.
package.json
"scripts": {
"eslint": "eslint index.js",
"pretest": "npm install",
"test": "npm run eslint",
"preversion": "npm run test",
"version": "",
"postversion": "git push && git push --tags && npm publish"
}
그런 다음 실행하십시오.
npm version minor --force -m "Some message to commit"
어느 것 :
... 테스트 실행 ...
package.json
다음 부 버전으로 변경하십시오 (예 : 1.8.1-1.9.0)
당신의 변화를 밀어
새로운 자식 태그 릴리스를 만들고
npm 패키지를 게시하십시오.
--force
누가 보스인지 보여줘야합니다! 농담 옆으로 https://github.com/npm/npm/issues/8620 참조
"deploy-minor": "npm version minor --force -m \"version %s\""
기억해야 할 것은 npm run deploy-minor
:)
또한 버전 범프를 원하지만 태그 또는 새로운 커밋을 원하지 않는 경우 플래그를 npm version
사용할 수 있습니다 --no-git-tag-version
.
npm --no-git-tag-version version patch
원사를 사용하는 경우 사용할 수 있습니다
yarn version --patch
이것은 package.json
patch로 버전을 증가 (0.0.x)
시키고 커밋하고 형식으로 태그 지정합니다v0.0.0
마찬가지로 당신이 사용하여 사소한 또는 주요 버전 범프 수 있습니다 --minor
또는--major
자식으로 밀 때 태그를 밀어야합니다. --follow-tags
git push --follow-tags
스크립트를 만들 수도 있습니다
"release-it": "yarn version --patch && git push --follow-tags"
간단히 입력하여 실행하십시오. yarn release-it
나는 husky 와 git-branch-is를 사용하고 있습니다 :
허스키 v1 + 기준 :
// package.json
{
"husky": {
"hooks": {
"post-merge": "(git-branch-is master && npm version minor ||
(git-branch-is dev && npm --no-git-tag-version version patch)",
}
}
}
허스키 V1 이전 :
"scripts": {
...
"postmerge": "(git-branch-is master && npm version minor ||
(git-branch-is dev && npm --no-git-tag-version version patch)",
...
},
NPM 버전 에 대해서 더 읽어보세요.
웹팩 또는 Vue.js
webpack 또는 Vue.js를 사용하는 경우 자동 삽입 버전-Webpack 플러그인을 사용하여 UI에이를 표시 할 수 있습니다.
NUXT
에서 nuxt.config.js
:
var WebpackAutoInject = require('webpack-auto-inject-version');
module.exports = {
build: {
plugins: [
new WebpackAutoInject({
// options
// example:
components: {
InjectAsComment: false
},
}),
]
},
}
template
바닥 글에서 예를 들어 내부 :
<p> All rights reserved © 2018 [v[AIV]{version}[/AIV]]</p>
postmerge
있지만 이제는 구성 post-merge
내부에 husky: {hooks:{}}
있습니다. 어떤 문제가 git-branch-is
있습니까?
이 질문에 대한 답변에 명확성을 추가하고 싶습니다.
여기에 문제를 올바르게 해결하고 해결책을 제시하는 몇 가지 대답이 있다고 생각했지만 올바른 대답은 아닙니다. 이 질문에 대한 정답은npm version
package.json 파일을 자동으로 편집하는 방법이 있습니까?
예, npm version
필요한 경우 명령 을 실행하는 것입니다 . npm version 여기에서 자세한 내용을 읽을 수 있지만 기본 사용법은 버전 npm version patch
에 3 자리 순서를 추가합니다 package.json
(1.0. X )
git 시험판 후크를 사용하면 도움이됩니까?
npm version
필요에 따라 시험판 후크 에서 명령 을 실행하도록 구성 할 수 있지만, 이것이 CD / CI 파이프에 필요하거나 없는지 여부에 따라 다르지만 npm version
명령 없이 git pre-release
후크는 "쉽게"수행 할 수 없습니다 이랑package.json
npm version
정답 인 이유 는 다음과 같습니다.
package.json
사용중인 npm
경우 사용중인 경우에 npm
액세스 할 수 npm scripts
있습니다.npm scripts
액세스 할 수 npm version
있습니다.다른 도구가 제안 된 다른 답변이 잘못되었습니다.
gulp-bump
작동하지만 장기적으로 문제를 일으킬 수있는 다른 추가 패키지가 필요합니다 (내 답변의 포인트 3)
grunt-bump
작동하지만 장기적으로 문제를 일으킬 수있는 다른 추가 패키지가 필요합니다 (내 답변의 포인트 3)
먼저 버전 번호를 업그레이드하기위한 규칙을 이해해야합니다. 시맨틱 버전 에 대한 자세한 내용은 여기를 참조하십시오.
각 버전에는 xyz 버전이 있으며 여기에 아래와 같이 다른 목적으로 정의됩니다.
스크립트를 실행하기 위해 package.json에서 스크립트를 정의 할 수 있습니다.
"script": {
"buildmajor": "npm version major && ng build --prod",
"buildminor": "npm version minor && ng build --prod",
"buildpatch": "npm version patch && ng build --prod"
}
터미널에서 다음과 같은 요구 사항에 따라 npm 실행하면됩니다.
npm run buildpatch
git repo에서 실행하면 기본 git-tag-version이 true이고 원하지 않으면 스크립트에 아래 명령을 추가 할 수 있습니다.
--no-git-tag-version
예를 들어 : "npm --no-git-tag-version version major && ng build --prod"
변경 유형이라고 알려진 커밋 메시지의 태그를 기반으로 자동 의미 버전 관리를 수행 할 수 있는 도구 를 만들었습니다 . 이는 시맨틱 버전 관리 사양과 함께 앵귤러 커밋 메시지 컨벤션을 밀접하게 따릅니다.
이 도구를 사용하여 npm CLI를 사용하여 package.json의 버전을 자동으로 변경할 수 있습니다 ( 여기 에 설명되어 있음 ).
또한 이러한 커밋에서 변경 로그를 만들 수 있으며 변경 유형에 따라 커밋을 만드는 메뉴 (커밋 메시지의 맞춤법 검사기 포함)도 있습니다. 나는 그것을 확인하고 그것을 읽을 수있는 모든 것을보기 위해 문서를 읽는 것이 좋습니다.
시맨틱 버전 관리를 자동화하기 위해 CICD Pipeline에 필요한 요구 사항을 찾을 수 없기 때문에 도구를 작성했습니다. 차라리 실제 변경 사항이 버전보다 무엇이고 내 도구가 하루를 절약하는 데 중점을 둡니다.
도구의 이론적 근거에 대한 자세한 내용은 다음을 참조하십시오 .