Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 5개 있습니다.)
개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
; https://www.sysnet.pe.kr/2/0/12541

개발 환경 구성: 545. github workflow/actions에서 빌드시 snk 파일 다루는 방법 - Encrypted secrets
; https://www.sysnet.pe.kr/2/0/12546

개발 환경 구성: 546. github workflow/actions에서 nuget 패키지 등록하는 방법
; https://www.sysnet.pe.kr/2/0/12548

개발 환경 구성: 547. github workflow/actions에서 Visual Studio Marketplace 패키지 등록하는 방법
; https://www.sysnet.pe.kr/2/0/12552

개발 환경 구성: 623. Visual Studio 2022 빌드 환경을 위한 github Actions 설정
; https://www.sysnet.pe.kr/2/0/12904




github workflow/actions에서 nuget 패키지 등록하는 방법

물론 이에 대해서도 github marketplace에 등록된 action이 있으므로,

Publish NuGet
; https://github.com/marketplace/actions/publish-nuget

아래와 같은 방법으로 사용하면 됩니다.

Use GitHub actions to publish NuGet packages
; https://lukelowrey.com/use-github-actions-to-publish-nuget-packages/

따라서, nuget에 등록하는데 사용하는 API key를 "Encrypted secrets"에 (이 글에서는 NUGET_API_KEY라는 이름으로) 등록한 후, 다음과 같은 식으로 사용하는 코드를 추가하면 됩니다.

- name: Publish NuGet
  id: pub_nuget
  uses: brandedoutcast/publish-nuget@v2.5.5
  with:
    PROJECT_FILE_PATH: ./XmlSrcGenerator/XmlSrcGenerator.csproj
    NUGET_KEY: ${{secrets.NUGET_API_KEY}}
    TAG_COMMIT: false
    INCLUDE_SYMBOLS: true

만약 이렇게 등록한 nupkg 파일을 github의 release에도 올리고 싶다면 "github repo의 Release 활성화 및 Actions를 이용한 자동화 방법" 글에서 소개했던 create_release 작업의 추가와 함께 아래와 같은 actions/upload-release-asset 작업이 필요합니다.

- name: Upload Nuget Release Asset
  id: upload-nuget-release-asset
  uses: actions/upload-release-asset@v1
  env:
    GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  with:
    upload_url: ${{ needs.create_release.outputs.upload_url }}
    asset_path: ${{ steps.pub_nuget.outputs.PACKAGE_PATH }}
    asset_name: ${{ steps.pub_nuget.outputs.PACKAGE_NAME }}
    asset_content_type: application/octet-stream

참고로, action의 "OUTPUTS" 변수들은 모두 대소문자 구분을 하기 때문에 반드시 문서를 확인하시고 정확히 일치하는 이름을 사용해야 합니다. (예를 들어 위의 yml에서 outputs.package_path라고 쓰면 빈 문자열이 반환됩니다.)

마지막으로 위에서 설명한 내용의 실제 사용 예를 다음의 yml 파일에 적용했습니다.

XmlCodeGenerator/.github/workflows/git-releases.yml
; https://github.com/stjeong/XmlCodeGenerator/blob/master/.github/workflows/git-releases.yml




이미 같은 버전의 패키지가 nuget에 등록되어 있다면 actions/upload-release-asset 작업은 실패 없이 그냥 넘어가게 됩니다. 단지 이런 경우 output으로 출력하는 outputs.PACKAGE_PATH 값이 비어 있게 됩니다. 그래서 이런 상황이라면 nupkg 파일을 github releases에도 업로드하는 actions/upload-release-asset 작업을 수행하는 경우 다음과 같이 오류 메시지가 발생하며 빌드 실패를 합니다.

Run actions/upload-release-asset@v1
  with:
    upload_url: https://uploads.github.com/repos/stjeong/XmlCodeGenerator/releases/39255023/assets{?name,label}
    asset_content_type: application/octet-stream
  env:
    SOLUTION_FILE_PATH: .
    BUILD_CONFIGURATION: Release
    GITHUB_TOKEN: ***
Error: Input required and not supplied: asset_path

만약 실패를 원하지 않는다면 if 조건을 추가해 upload-release-asset 작업을 생략하는 식으로 대응할 수 있습니다.

- name: Upload Nuget Release Asset
  if: steps.pub_nuget.outputs.PACKAGE_PATH != ''
  id: upload-nuget-release-asset
  uses: actions/upload-release-asset@v1
  ...[생략]...




기타 유의할 점이 하나 있다면, nuget api token의 만료가 보통 1년 단위이기 때문에 매해 secrets.NUGET_API_KEY를 갱신시켜줘야 한다는 것을 잊지 마시고. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/16/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  132  133  134  [135]  ...
NoWriterDateCnt.TitleFile(s)
1713정성태7/11/201445345Windows: 98. 윈도우 시스템 디스크 용량 확보를 위한 "Package Cache" 폴더 이동 [1]
1712정성태7/10/201433890.NET Framework: 450. 영문 윈도우에서 C# 콘솔 프로그램의 유니코드 출력 방법 [3]
1711정성태7/10/201438846Windows: 97. cmd.exe 창에서 사용할 폰트를 추가하는 방법 [1]
1710정성태7/8/201431539개발 환경 구성: 230. 유니코드의 Surrogate Pair, Supplementary Characters가 뭘까요?파일 다운로드2
1709정성태7/8/201428132VS.NET IDE: 91. Visual Studio에서 32/64비트 IIS Express 실행하는 방법
1708정성태7/7/201425490VS.NET IDE: 90. Visual Studio - 사용자 정의 정적 분석 규칙 만드는 방법 [3]파일 다운로드1
1707정성태7/4/201423626.NET Framework: 449. C#에서 C++로 VARIANT 넘겨주는 방법파일 다운로드1
1706정성태7/3/201422071.NET Framework: 448. .NET SmartClient 컨트롤을 윈도우 8/2012에서 활성화하는 방법파일 다운로드1
1705정성태7/2/201436490VC++: 78. 보이어-무어(Boyer-Moore) 알고리즘이 정말 빠를까? [6]파일 다운로드1
1704정성태7/2/201422918.NET Framework: 447. w3wp.exe AppPool 재생(recycle)하는 방법 정리
1703정성태7/2/201423682.NET Framework: 446. Assembly.Load를 이용해 GAC에 등록된 어셈블리를 로드하는 방법 [1]파일 다운로드1
1702정성태6/23/201423552Phone: 11. Xamarin.Forms - 2. XAML을 이용한 페이지 개발파일 다운로드1
1701정성태6/23/201435786개발 환경 구성: 229. .NET Reflector + Reflexil 도구를 이용해 DLL 코드 변경 [4]
1700정성태6/23/201422542VS.NET IDE: 89. Visual Studio에서 기본 제공되는 성능 프로파일 [2]
1699정성태6/22/201424811Phone: 10. Xamarin.Forms - 1. Forms 시작하기 [2]파일 다운로드1
1698정성태6/22/201426722.NET Framework: 445. [부연 설명] 쉬운 C# 코드를 어럽게 이해하기 [2]
1697정성태6/22/201422376VS.NET IDE: 88. Visual Studio에서 직접 컴파일하는 IL 언어 확장 도구 - IL Support
1696정성태6/22/201421845.NET Framework: 444. clojure와 C#을 통해 이해하는 Sequence와 Vector 형식의 차이점 [1]
1695정성태6/21/201420916개발 환경 구성: 228. PowerShell ISE에서 (입력 기능이 있는) 콘솔 응용 프로그램을 시작하는 방법
1694정성태6/21/201422538개발 환경 구성: 227. 닷넷 용 ClojureCLR 개발환경 설정
1693정성태6/20/201423064개발 환경 구성: 226. Clojure 언어의 윈도우 개발환경 설정
1692정성태6/19/201433475오류 유형: 231. Visual Studio 2013 한글 버전 설치 오류 - The form specified for the subject is not one supported or known by the specified trust provider
1691정성태6/18/201428869개발 환경 구성: 225. 유닉스 계열의 tail 명령어가 제공되는 PowerShell [1]
1690정성태6/18/201431599개발 환경 구성: 224. DirectShow 예제 구하는 방법 [3]
1689정성태6/18/201428528오류 유형: 230. C++ 가변 인자 사용시 va_start 파라미터 전달 방법 [2]
1688정성태6/15/201421292오류 유형: 229. 갤럭시 노트 3 환경에서 Xamarin 앱 배포 충돌
... 121  122  123  124  125  126  127  128  129  130  131  132  133  134  [135]  ...