2019년 11월 27일 수요일

Jenkins에서 유니티로 실행한 Shell Script 가 끝나질 않는 문제 삽질 이야기


1. 우리팀 빌드머신은 iMac 이고 젠킨스로 빌드하고 있다.

2. 어셋 번들 파일 서버는 Amazon S3에 마련되어 있어 각 버전별로 폴더를 만들어서 업로드 하고 싶었다.

3. 버전이 클라이언트의 특정 변수에 설정되어 있어서 쉘크립트를 젠킨스가 직접 실행할수 없다. 서버 개발자 분께 부탁해서 버전을 파라메터로 받아서 S3의 버전 이름 폴더에 파일을 업로드 할 수 있는 스크립트를 만들었다.

4. 해당 스크립트를 어셋 번들 생성 후 유니티 코드로 호출 할 수 있도록 함수를 만들었다.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
static void RunQaBundleUploadScript()
    {
        Debug.Log($"업로드 스크립트 실행 준비");
        if (psi == null)
        {
            psi = new System.Diagnostics.ProcessStartInfo();
        }
        var v = new GlobalConfig.VersionInfo();
        string args =
            Path.Combine(Application.dataPath,
            $"Editor/QaBundleUploadScript/qa_{EditorUserBuildSettings.activeBuildTarget.ToString().ToLower()}_patch.sh {v.ClientVersionToString()}");

        psi.FileName = "/bin/sh";
        psi.UseShellExecute = false;
        psi.RedirectStandardOutput = true;
        psi.Arguments = args;
        psi.WindowStyle = System.Diagnostics.ProcessWindowStyle.Minimized;
        psi.CreateNoWindow = true;
        var proc = System.Diagnostics.Process.Start(psi);
        proc.WaitForExit();//로그 출력을 위해
        var log = proc.StandardOutput.ReadToEnd();

        Debug.Log($"업로드 스크립트 실행 완료 {args}\n{log}");
    }

5. 단순 실행이 아니라 로그도 보고 싶어서 WaitForExit 와 ReadToEnd 를 사용하였다.
6. 유니티 에디터에서 해당 함수를 테스트 하고 동작이 확인되어 젠킨스 빌드를 돌렸는데 빌드도 되고 S3에 업로드도 잘 되었지만 젠킨스의 빌드 상태가 종료되지 않고 계속 대기상태가 유지되었다.
7. 서버 개발자분께서 알려 주셔서 WaitForExit 와 ReadToEnd 의 소스 코드를 다음과 같이 수정하니 젠킨스 빌드가 정상적으로 종료 되었다.


1
2
3
4
5
6
using(var proc = System.Diagnostics.Process.Start(psi))
{
    var log = proc.StandardOutput.ReadToEnd();
    proc.WaitForExit();
    Debug.Log($"업로드 스크립트 실행 완료 {DateTime.Now}\n{args}");
}

댓글 없음:

댓글 쓰기