-
Notifications
You must be signed in to change notification settings - Fork 533
Build Performance Results
This is a comparison between Visual Studio 15.8.4 and what will be shipped 15.9 Preview 3.
Our core focus here is improving the developer loop, in cases such as:
- You have a currently built/deployed Xamarin.Forms app.
- You change one line of XAML in your NetStandard Xamarin.Forms project.
- You build/deploy again.
Along the way if we happened to find something to improve initial builds, that would be a bonus.
- Hello Forms: File | New Xamarin.Forms project with a NetStandard library. Using project template from 15.8.4.
- SmartHotel360: A sample Xamarin.Forms app with 99 NuGet packages, using a fork so we have updated Xamarin.Forms to 3.0.x.
To see specific details about changes made see what was shipped in 15.9 P3 here.
-
Build
or build -
SignAndroidPackage
or package, this creates the Android APK file and signs it -
Install
or deploy, this deploys the APK to the attached device
I performed all of these timings with a USB-connected Pixel 2 device.
App | 15.8 | 15.8 Log | 15.9 | 15.9 Log |
---|---|---|---|---|
Hello Forms (no changes) | 00:02.99 | binlog | 00:02.75 | binlog |
Hello Forms (XAML change) | 00:08.03 | binlog | 00:06.63 | binlog |
SmartHotel360 (no changes) | 00:03.74 | binlog | 00:03.54 | binlog |
SmartHotel360 (XAML change) | 00:10.62 | binlog | 00:08.34 | binlog |
App | 15.8 | 15.8 Log | 15.9 | 15.9 Log |
---|---|---|---|---|
Hello Forms (first) | 00:15.22 | binlog | 00:12.90 | binlog |
Hello Forms (no changes) | 00:03.07 | binlog | 00:02.83 | binlog |
Hello Forms (XAML change) | 00:07.06 | binlog | 00:06.63 | binlog |
SmartHotel360 (first) | 00:17.39 | binlog | 00:15.65 | binlog |
SmartHotel360 (no changes) | 00:03.88 | binlog | 00:03.69 | binlog |
SmartHotel360 (XAML change) | 00:09.03 | binlog | 00:05.10 | binlog |
We regressed very slightly on the initial build time here, but I
believe due to #deletebinobj related fixes. These are fixes for
"correctness" of our build, where developers could get a strange error
that is resolved by deleting their bin
and obj
directories. I
believe these fixes have added time to the build, but it is important
to be correct before optimizing things. We also improved the first
deployment times, so there is certainly some tradeoff here.
App | 15.8 | 15.8 Log | 15.9 | 15.9 Log |
---|---|---|---|---|
Hello Forms (build) | 00:35.93 | binlog | 00:37.33 | binlog |
Hello Forms (package) | 00:07.74 | binlog | 00:07.33 | binlog |
Hello Forms (deploy) | 00:15.22 | binlog | 00:12.90 | binlog |
SmartHotel360 (build) | 01:04.20 | binlog | 01:05.90 | binlog |
SmartHotel360 (package) | 00:10.65 | binlog | 00:10.53 | binlog |
SmartHotel360 (deploy) | 00:17.39 | binlog | 00:15.65 | binlog |
A build with no changes is generally 2-3 seconds, which is certainly improved from what it was 6 months ago. We are still working on this, as there are still a few MSBuild targets running on every build that could be skipped (or improved).
Since these timings run build, package, and deploy in three distinct steps, this overhead is present in all three builds.
There are some additional changes in master that will improve initial build times. These are still in progress, but should be coming soon! I'll update the numbers as they are available.
In PR #2105, I was seeing a massive improvement to first builds of "Hello World" apps.
I realized since I was timing builds with only the OSS
xamarin-android, I was basically timing builds without Fast Deployment
. This feature sideloads assemblies (and is enabled by
proprietary Xamarin.Android code), and so .NET assemblies are not
embedded in the APK by default.
This meant that the PCL facade assemblies were being embedded in the APK during my timing. That explains the huge difference in build times I measured, since making Java.Interop a non-PCL enabled OSS xamarin-android to not embed as many assemblies.
However, this changes was still great, since it improved initial deployment times, as seen in the times above.
Some notes on what we should always do when timing builds.
- Always start with a clean working copy!
git clean -dxf
- Time Release builds of
Xamarin.Android.Build.Tasks.dll
. - Time changes within the context of the proprietary Xamarin.Android code.
- If possible, potentially even deploy the changes to the system Xamarin.Android install.
- Time more than one project. Record everyting. Put it in the commit message!
It is possible we should look into some kind of CI setup / scripting to make these easier.
- APK Tests on the Hyper V Emulator
- Design Time Build System
- Profile MSBuild Tasks
- Diagnose Fast Deployment Issues
- Preview layout XML files with Android Studio
- Documentation