Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법

csproj에 빌드 이벤트를 설정한 경우, 대개는 개발자 PC에서 빌드하는 경우에만 실행하고 싶을 것입니다. 즉, Azure Devops 같은 환경에서는 빌드 이벤트 실행을 생략하고 싶을 수 있는데요, 이럴 때는 환경 변수를 이용하면 됩니다.

따라서 azure-pipelines.yml에 현재 Azure 환경에서 빌드 중이라는 플래그 변수로써 환경 변수를 아무거나 하나 등록해 두고,

trigger:
- main

pool:
  vmImage: 'windows-latest'

variables:
  solution: '**/*.sln'
  buildPlatform: 'Any CPU'
  buildConfiguration: 'Release'
  azureDevopsBuild: true

...[생략]...

csproj 파일 내의 빌드 이벤트에는 저 조건을 이용해 빌드 포함 여부를 결정하면 됩니다.

...[생략]...

  <PropertyGroup Condition=" '$(azureDevopsBuild)' == '' " >
    <PostBuildEvent>
SET PSTargetName=$(TargetName)
SET PSTargetDir=$(TargetDir)

PowerShell -NoProfile -ExecutionPolicy unrestricted -file $(SolutionDir)makezip.ps1

robocopy $(TargetDir) $(SolutionDir)Binaries *.zip

exit 0
</PostBuildEvent>
  </PropertyGroup>

...[생략]...

저런 식으로 PropertyGroup에 설정해 주면 로컬에서 빌드 시에는 azureDevopsBuild 환경 변수가 없으므로 정상적으로 PostBuildEvent가 실행되지만, Azure Devops의 파이프라인에서 빌드 시에는 PostBuildEvent가 실행되지 않습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/1/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)
1822정성태12/3/201428330개발 환경 구성: 252. Xamarin 라이선스 관리 [8]
1821정성태12/1/201435975VS.NET IDE: 96. Visual Studio에서 /* ~ */ 주석을 위한 단축키(매크로)
1820정성태11/23/201423396.NET Framework: 485. Mono Profiler에서 IL 코드 변경이 가능할까? - 두 번째 이야기파일 다운로드1
1819정성태11/22/201423300오류 유형: 264. MSBuild 에러 - warning MSB3052: The parameter to the compiler is invalid,
1818정성태11/22/201426806개발 환경 구성: 251. NUMA 노드 수에 따른 IIS Worker Process(w3wp.exe) 설정 [1]
1817정성태11/22/201429965VS.NET IDE: 95. Macros for Visual Studio 2013 [1]
1816정성태11/20/201424488.NET Framework: 484. Mono Profiler에서 IL 코드 변경이 가능할까?
1815정성태11/18/201422509.NET Framework: 483. 코드로 살펴 보는 ETW의 활성화 시점 [2]
1814정성태11/18/201423988오류 유형: 263. Unable to find the requested .Net Framework Data Provider. It may not be installed.
1813정성태11/18/201425450오류 유형: 262. Build Events에 robocopy 작업이 있는 경우 "VCEnd exited with code 3" 오류 발생
1812정성태11/17/201423787.NET Framework: 482. ETW 자동 생성 코드의 VerificationException 예외 발생
1811정성태11/16/201425285.NET Framework: 481. Mono 내부의 문자열 처리 방식은 UTF-8
1810정성태11/15/201462532.NET Framework: 480. C# - 배치 파일 실행하고 출력 결과를 얻는 방법 [4]
1809정성태11/11/201427044.NET Framework: 479. Mono Profiler를 Unity의 Plugin으로 사용하는 방법
1808정성태11/11/201426948.NET Framework: 478. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 [2]
1807정성태11/10/201434045개발 환경 구성: 250. 서버용 Socket에서 사용하는 포트가 충돌한다면?파일 다운로드1
1806정성태11/10/201429788.NET Framework: 477. SeCreateGlobalPrivilege 특권과 WCF NamedPipe
1805정성태11/5/201426099.NET Framework: 476. Visual Studio에서 Mono용 Profiler 개발 [3]파일 다운로드1
1804정성태11/5/201432443.NET Framework: 475. ETW(Event Tracing for Windows)를 C#에서 사용하는 방법 [9]파일 다운로드1
1803정성태11/4/201423001오류 유형: 261. Windows Server Backup 오류 - Error in backup of E:\$Extend\$RmMetadata\$TxfLog
1802정성태11/4/201426227오류 유형: 260. 이벤트 로그 - Windows Error Reporting / AEAPPINVW8
1801정성태11/4/201432010오류 유형: 259. 이벤트 로그 - Windows Error Reporting / IPX Assertion / KorIME.exe [1]
1800정성태11/4/201422335오류 유형: 258. 이벤트 로그 - Starting a SMART disk polling operation in Automatic mode.
1799정성태11/4/201426681오류 유형: 257. 이벤트 로그 - The WMI Performance Adapter service entered the stopped state.
1798정성태11/4/201435245오류 유형: 256. 이벤트 로그 - The WinHTTP Web Proxy Auto-Discovery Service service entered the stopped state. [1]
1797정성태11/4/201421252오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
... 121  122  123  124  125  126  127  128  129  130  131  132  [133]  134  135  ...