概要

WPFアプリケーションのテストやビルドを、GitLab Runnerを使ってやろうとしたらはまりました。

なぜはまったのかと、どのような方法をすればよいのかについて書きました。

やりたいこと

私は、ソースコードの管理として、主にGitLabを利用しています。GitLabでは、GitLab Runnerをインストールしたサーバーを用意して、それと連携をすることで、CI/CDをすることができます。今回は、このGitLabのCI/CD機能を利用して、Windows Presentation Foundation(WPF)アプリケーションのビルドをすることにしました。

WPFは、Windows専用のデスクトップアプリケーションソフトウェアを作成するフレームワークです。Windowsでしか動かすつもりがないソフトウェアについては、これを使うと簡単にソフトウェアを作ることができるので、重宝しています。ソースコードの管理は、前述のとおり、GitLabを利用しているのですが、せっかくならば、Gitのタグをつけたら、自動でビルドをしてリリースを行いたいところです。

しかしながら、実際にCI/CDでWPFを利用したソフトのビルドをしようとすると、とてもはまりました。

問題

GitLab Runnerは、Linux上で動かしていました。そうすると、次のコマンドを実行してビルドを行った際に、エラーが発生しました。

dotnet publish -c Release

error : MSB4803: The task "ResolveComReference" is not supported on the .NET Core version of MSBuild. Please use the .NET Framework version of MSBuild. See https://aka.ms/msbuild/MSB4803 for further details.

エラーの内容としては、COMの参照がサポートされていないというものです。

いろいろと調べてみると、これは、Linuxでビルドしようとしている関係で、WindowsでのWPFのビルドとは異なるコンパイラを利用しているため、ビルドできないということのようです。

Windows、Linux、macOSの複数のOSでビルドができる.NETを利用しているため、このようなエラーが出るのはおかしいと思ったのですが、WPFのビルドには、Windowsにのみ対応したコンパイラを利用してビルドが行われます。つまり、LinuxやmacOSなどのWindows以外の環境では、Windows専用のWPFのビルドはできません。

解決方法

私の環境では、GitLab RunnerをLinuxにインストールして使っていたため、この問題にぶつかりました。この問題を解決するには、Windows上でビルドを行います。

例えば、GitLab RunnerをWindowsにインストールすることで解決できます。

しかし、WindowsにGitLab Runnerをインストールするというのはとても面倒です。Windowsのライセンスを用意するのも大変ですし、サーバーを借りるにしても、Linuxよりも高価ですので、維持しにくいという問題もあります。

そこで今回は、WPFのCI/CDをすることを諦めました。

さいごに

最終的に、GitLab RunnerでCI/CDをすることを諦めるという、かっこ悪い結果となりました。

もしも、Windows Serverなどを利用していて、リソースが余っているということであれば、インストールなどしてみるとよいかもしれません。

みなさんの参考になればうれしいです。