Does anyone know how to automate UWP with Desktop Bridge (Desktop Extension) package build (.appxupload/.appxbundle) by using MSbuild tool?
I've got the setup like on the following blog.
For the simple UWP app (without Desktop Extension) I’m able to this with the following command:
msbuild UWP.sln /p:Configuration=Release;AppxBundle=Always;AppxBundlePlatforms=”x86|x64|ARM”;UapAppxPackageBuildMode=StoreUpload
However, when I try it on Package.wapproj I’ve got a bunch of errors.
For instance, although Package project has a certificate, UWP project also demands one (why?), when I workaround that problem, msbuild demands a build.appxrecipe from bin/Debug, although I’m building Release etc. 
Same experience here, but I manage to bypass the "Could not find a recipe file" error by build x86 and x64 project separately, and then run the msbuild command to package both. Here are my notes:
Because my solution has one Desktop Extension project, several c# projects, and a few test projects, I have to specify <AppxBundle>Always</AppxBundle> or <AppxBundle>Never</AppxBundle> in the project files, one by one.
Clean both x86 and x64.
Build x86 first. msbuild .\MyApp.sln /p:Configuration=Release /p:Platform=x86
Build x64. msbuild .\MyApp.sln /p:Configuration=Release /p:Platform=x64
Run this msbuild command in command line:
msbuild .\MyApp.sln /p:Configuration=Debug /p:AppxBundlePlatforms="x86|x64" /p:AppxPackageDir="C:\Develop\MyApp\AppPackages\" /p:UapAppxPackageBuildMode=StoreUpload
Note that I have to add AppxPackageDir in the command, otherwise it will only bundle x64, not x86. I don't know why yet.
Then you will see all the bundle folders are created under the AppxPackageDir, both x64 and x86. The one single upload bundle will be created outside of the folders.
It takes forever to build the release builds, but it works in command line. Automation, here we go!
In order to build with VS2017 using msbuild the command that succeeded for me was:
\path\to\msbuild.exe UWP.sln ^
    /m /p:platform=x86 /p:platform=x64 /p:platform=arm ^
    /p:Configuration=Release ^
    /p:AppxBundle=Always ^
    /p:AppxBundlePlatforms="x64|x86|ARM" ^
    /p:UapAppxPackageBuildMode=StoreUpload ^
    /Consoleloggerparameters:verbosity=minimal
But in order to build it with VS2019, after a lot of stress, bleeding and cursing, this worked:
First, change the content of the Package.wapproj to have
<AppxBundlePlatforms>x86|x64|arm</AppxBundlePlatforms>
<UapAppxPackageBuildMode>StoreAndSideload</UapAppxPackageBuildMode>
and then just run a single msbuild command:
\path\to\msbuild.exe UWP.sln /m ^
    /p:Configuration=Release ^
    /p:platform=x64 /p:platform=x86 /p:platform=arm ^
    /Consoleloggerparameters:verbosity=minimal ^
    /Fileloggerparameters:verbosity=quiet ^
    -nodeReuse:false
This built all the platforms and package for side-loading and upload in one shot.
I had to quiet the file logger because for multi-processor build there is a race condition for multiple ilc.exe processes where it said that ilclog.csv could not be opened because it is used by another process. Idiotic.
I tried building each platform separately without /m switch, and then build the package, and nothing worked, every time i had the recipe error.
They have an open bug for recipe error - https://github.com/microsoft/msbuild/issues/4930
The above solution finally did it for vs2019.
Thank you Microsoft for making our life easy with each new release of whatever, and for making documentation so helpful and resourceful.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With