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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12610정성태4/22/20217985.NET Framework: 1046. C# - 컴파일 시점에 참조할 수 없는 타입을 포함한 이벤트 핸들러를 Reflection을 이용해 구독하는 방법파일 다운로드1
12609정성태4/22/20219359.NET Framework: 1045. C# - 런타임 시점에 이벤트 핸들러를 만들어 Reflection을 이용해 구독하는 방법파일 다운로드1
12608정성태4/21/202110270.NET Framework: 1044. C# - Generic Host를 이용해 .NET 5로 리눅스 daemon 프로그램 만드는 방법 [9]파일 다운로드1
12607정성태4/21/20218821.NET Framework: 1043. C# - 실행 시점에 동적으로 Delegate 타입을 만드는 방법파일 다운로드1
12606정성태4/21/202112910.NET Framework: 1042. C# - enum 값을 int로 암시적(implicit) 형변환하는 방법? [2]파일 다운로드1
12605정성태4/18/20218848.NET Framework: 1041. C# - AssemblyID, ModuleID를 관리 코드에서 구하는 방법파일 다운로드1
12604정성태4/18/20217520VS.NET IDE: 163. 비주얼 스튜디오 속성 창의 "Build(빌드)" / "Configuration(구성)"에서의 "활성" 의미
12603정성태4/16/20218412VS.NET IDE: 162. 비주얼 스튜디오 - 상속받은 컨트롤이 디자인 창에서 지원되지 않는 문제
12602정성태4/16/20219618VS.NET IDE: 161. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 [1]
12601정성태4/15/20218729.NET Framework: 1040. C# - REST API 대신 github 클라이언트 라이브러리를 통해 프로그래밍으로 접근
12600정성태4/15/20218892.NET Framework: 1039. C# - Kubeconfig의 token 설정 및 인증서 구성을 자동화하는 프로그램
12599정성태4/14/20219617.NET Framework: 1038. C# - 인증서 및 키 파일로부터 pfx/p12 파일을 생성하는 방법파일 다운로드1
12598정성태4/14/20219713.NET Framework: 1037. openssl의 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 (2)파일 다운로드1
12597정성태4/13/20219767개발 환경 구성: 569. csproj의 내용을 공통 설정할 수 있는 Directory.Build.targets / Directory.Build.props 파일
12596정성태4/12/20219499개발 환경 구성: 568. Windows의 80 포트 점유를 해제하는 방법
12595정성태4/12/20218917.NET Framework: 1036. SQL 서버 - varbinary 타입에 대한 문자열의 CAST, CONVERT 변환을 C# 코드로 구현
12594정성태4/11/20218352.NET Framework: 1035. C# - kubectl 명령어 또는 REST API 대신 Kubernetes 클라이언트 라이브러리를 통해 프로그래밍으로 접근 [1]파일 다운로드1
12593정성태4/10/20219560개발 환경 구성: 567. Docker Desktop for Windows - kubectl proxy 없이 k8s 대시보드 접근 방법
12592정성태4/10/20219400개발 환경 구성: 566. Docker Desktop for Windows - k8s dashboard의 Kubeconfig 로그인 및 Skip 방법
12591정성태4/9/202112674.NET Framework: 1034. C# - byte 배열을 Hex(16진수) 문자열로 고속 변환하는 방법 [2]파일 다운로드1
12590정성태4/9/20219140.NET Framework: 1033. C# - .NET 4.0 이하에서 Console.IsInputRedirected 구현 [1]
12589정성태4/8/202110468.NET Framework: 1032. C# - Environment.OSVersion의 문제점 및 윈도우 운영체제의 버전을 구하는 다양한 방법 [1]
12588정성태4/7/202111027개발 환경 구성: 565. PowerShell - New-SelfSignedCertificate를 사용해 CA 인증서 생성 및 인증서 서명 방법
12587정성태4/6/202111842개발 환경 구성: 564. Windows 10 - ClickOnce 배포처럼 사용할 수 있는 MSIX 설치 파일 [1]
12586정성태4/5/20219526오류 유형: 710. Windows - Restart-Computer / shutdown 명령어 수행 시 Access is denied(E_ACCESSDENIED)
12585정성태4/5/20219278개발 환경 구성: 563. 기본 생성된 kubeconfig 파일의 내용을 새롭게 생성한 인증서로 구성하는 방법
... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...