Skip to content

Commit

Permalink
[mono-runtimes] Update @(MonoFacadeAssembly)
Browse files Browse the repository at this point in the history
Fixes: dotnet#1879

Add the following Facade assemblies to `@(MonoFacadeAssembly)`:

  * `System.Buffers.dll`
  * `System.Memory.dll`
  * `System.Net.Http.Rtc.dll`
  * `System.Threading.Tasks.Extensions.dll`

Note: list was reordered to be sorted as per **sort**(1), and
generated with the following shell code on macOS:

	$ cd external/mono/mcs/class/Facades
	$ for d in `find . -depth 1 -type d | grep -v 'netstandard\|System.Drawing.Primitives' | sort -f` ; do
	  n=`basename "$d"`;
	  echo "    <MonoFacadeAssembly Include=\"$n.dll\" />";
	done | pbcopy

The `netstandard` and `System.Drawing.Primitives` directory are
excluded so that the comment and following `@(MonoFacadeAssembly)`
entries in `ProfileAssemblies.projitems` are still relevant.
  • Loading branch information
jonpryor committed Nov 21, 2018
1 parent 9ae7454 commit f947ba3
Show file tree
Hide file tree
Showing 2 changed files with 266 additions and 12 deletions.
249 changes: 249 additions & 0 deletions Documentation/workflow/HowToBumpMono.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,249 @@
# How To Bump Mono

There will eventually be two ways that xamarin-android depends on mono:

1. Via [source code](#mono-source), or
2. Via [mono archive](#mono-archive)


<a name="mono-source" />

## Mono Source

When using mono from source -- which is required for all versions of mono
before the `mono/2018-10` release branch -- the
[`external/mono`](../../external) git submodule reference is used.

Currently, many parts of the xamarin-android build system *require* the
presence and use of mono source code, including:

* The [`src/Mono.Posix`](../../src/Mono.Posix) and
[`src/Mono.Data.Sqlite`](../../src/Mono.Data.Sqlite) builds.
* Inclusion of PDB2MDB source code within
[`src/Xamarin.Android.Build.Tasks`](../../src/Xamarin.Android.Build.Tasks).
* Inclusion of networking and related code into
[`src/monodroid`](../../src/monodroid).

We are working to remove these source dependencies so that we can support using
a [Mono Archive](#mono-archive) in the future.

Until a Mono Archive *exists* and can be *used*, source code integration must
fulfill the following checklist:

- [ ] [Update `.gitmodules`](#update-gitmodules).
- [ ] [Update `external/mono` submodule reference](#update-mono-submodule).
- [ ] [Update system mono used for the build](#update-system-mono).
- [ ] [Update `MonoAndroid` Profile Assemblies](#update-profile)
- [ ] [Ensure it *builds*](#build).
- [ ] [Ensure unit tests *pass*](#unit-tests).
- [ ] [Check for API Breakage](#api-validation).
- [ ] [Create a Pull Request](#create-pr).
- [ ] [Ask for QA Validation](#qa-validation) (***LAST***).


<a name="update-gitmodules" />

### Update `.gitmodules`

Update [`.gitmodules`](../../.gitmodules) to refer to the correct mono branch.


<a name="update-mono-submodule" />

### Update `external/mono`

Update the git submodule reference that [`external/mono`](../../external) refers to:

cd external/mono
git checkout BRANCH-NAME
git pull --rebase


<a name="update-system-mono" />

### Update system mono

The `$(MonoRequiredMinimumVersion)` and `$(MonoRequiredMaximumVersion)` values
within [`Configuration.props`](../../Configuration.props)
should be updated to correspond to the version number used in the mono submodule.

These version numbers can be found in
[mono's `configure.ac`](https://github.com/mono/mono/blob/master/configure.ac)
in the `AC_INIT()` statement.

The `$(_DarwinMonoFramework)` and `%(RequiredProgram.DarwinMinimumUrl)` values
within [`build-tools/dependencies/dependencies.projitems`](../../build-tools/dependencies/dependencies.projitems)
should be updated to corresponds to the version number used in the mono submodule.

`%(DarwinMinimumUrl)` must be a macOS `.pkg` file and must exist.

For example, see commit 606675b5:

```diff
diff --git a/Configuration.props b/Configuration.props
index a2a9c1d1..ec78ddb4 100644
--- a/Configuration.props
+++ b/Configuration.props
@@ -70,8 +70,8 @@
<JavaInteropSourceDirectory Condition=" '$(JavaInteropSourceDirectory)' == '' ">$(MSBuildThisFileDirectory)external\Java.Interop</JavaInteropSourceDirectory>
<LlvmSourceDirectory Condition=" '$(LlvmSourceDirectory)' == '' ">$(MSBuildThisFileDirectory)external\llvm</LlvmSourceDirectory>
<MonoSourceDirectory>$(MSBuildThisFileDirectory)external\mono</MonoSourceDirectory>
- <MonoRequiredMinimumVersion Condition=" '$(MonoRequiredMinimumVersion)' == '' ">5.14.0</MonoRequiredMinimumVersion>
- <MonoRequiredMaximumVersion Condition=" '$(MonoRequiredMaximumVersion)' == '' ">5.15.0</MonoRequiredMaximumVersion>
+ <MonoRequiredMinimumVersion Condition=" '$(MonoRequiredMinimumVersion)' == '' ">5.16.0</MonoRequiredMinimumVersion>
+ <MonoRequiredMaximumVersion Condition=" '$(MonoRequiredMaximumVersion)' == '' ">5.17.0</MonoRequiredMaximumVersion>
<IgnoreMaxMonoVersion Condition=" '$(IgnoreMaxMonoVersion)' == '' ">True</IgnoreMaxMonoVersion>
<MonoRequiredDarwinMinimumVersion>$(MonoRequiredMinimumVersion).0</MonoRequiredDarwinMinimumVersion>
<LinkerSourceDirectory>$(MSBuildThisFileDirectory)external\mono\external\linker</LinkerSourceDirectory>
diff --git a/build-tools/dependencies/dependencies.projitems b/build-tools/dependencies/dependencies.projitems
index f4a2f60e..1bd5d8c2 100644
--- a/build-tools/dependencies/dependencies.projitems
+++ b/build-tools/dependencies/dependencies.projitems
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
- <_DarwinMonoFramework>MonoFramework-MDK-5.14.0.141.macos10.xamarin.universal.pkg</_DarwinMonoFramework>
+ <_DarwinMonoFramework>MonoFramework-MDK-5.16.0.106.macos10.xamarin.universal.pkg</_DarwinMonoFramework>
<_AptGetInstall>apt-get -f -u install</_AptGetInstall>
</PropertyGroup>
<ItemGroup>
@@ -59,7 +59,7 @@
<MaximumVersion Condition=" '$(IgnoreMaxMonoVersion)' == '' Or '$(IgnoreMaxMonoVersion)' == 'False' " >$(MonoRequiredMaximumVersion)</MaximumVersion>
<DarwinMinimumVersion>$(MonoRequiredDarwinMinimumVersion)</DarwinMinimumVersion>
<CurrentVersionCommand>$(MSBuildThisFileDirectory)..\scripts\mono-version</CurrentVersionCommand>
- <DarwinMinimumUrl>https://xamjenkinsartifact.azureedge.net/build-package-osx-mono/2018-04/116/8ae8c52383b43892fb7a35dbf0992738bd52fa90/$(_DarwinMonoFramework)</DarwinMinimumUrl>
+ <DarwinMinimumUrl>https://xamjenkinsartifact.azureedge.net/build-package-osx-mono/2018-06/78/341142d7656f43239a041b2c44f00acfb8fa7c59/$(_DarwinMonoFramework)</DarwinMinimumUrl>
<DarwinInstall>installer -pkg "$(AndroidToolchainCacheDirectory)\$(_DarwinMonoFramework)" -target /</DarwinInstall>
</RequiredProgram>
</ItemGroup>
```


<a name="update-profile" />

### Update `MonoAndroid` Profile Assemblies

[`src/mono-runtimes/ProfileAssemblies.projitems`](../../src/mono-runtimes/ProfileAssemblies.projitems)
has three item groups that may need to be updated:

* `@(MonoFacadeAssembly)`
* `@(MonoProfileAssembly)`
* `@(MonoTestAssembly)`

There must be a `@(MonoFacadeAssembly)` entry for every Facade assembly that
must be shipped in the SDK. Facade assemblies are installed into the
`bin/$(Configuration)/lib/xamarin.android/xbuild-frameworks/MonoAndroid/v1.0/Facades`
directory.

The `@(MonoFacadeAssembly)` list can be updated with this shell code on macOS:

$ cd external/mono/mcs/class/Facades
$ for d in `find . -depth 1 -type d | grep -v 'netstandard\|System.Drawing.Primitives\|System.Net.Http.Rtc' | sort -f` ; do
n=`basename "$d"`;
echo " <MonoFacadeAssembly Include=\"$n.dll\" />";
done | pbcopy

The `@(MonoProfileAssembly)` item group is for non-Facade assemblies, which are
installed into the
`bin/$(Configuration)/lib/xamarin.android/xbuild-frameworks/MonoAndroid/v1.0`
directory. This item group must be updated whenever a new BCL assembly is added.

The `@(MonoTestAssembly)` item group contains unit test assemblies, executed by
[`tests/BCL-Tests`](../../tests/BCL-Tests).
The `%(MonoTestAssembly.SourcePath)` item metadata is the directory name within
`external/mono/mcs/class` which contains files needed for execution by the unit
tests.
The `%(MonoTestAssembly.TestType)` item metadata is the *type* of unit test
assembly; valid values are `xunit` (for xUnit unit test assemblies),
`reference` (for ???), and the empty string/not set (for NUnit assemblies).


<a name="build" />

### Ensure it *builds*

`make all` only builds a subset of the full Xamarin.Android SDK: support
for only select ABIs (host OS, x86, armeabi-v7a), only one `Mono.Android.dll`
version, and *no* builds for Windows support.

Ensure that `make all` builds *first*. Once that builds, move on to using
`make jenkins`, which adds support for *all* ABIs, *plus* AOT and LLVM
compilers, plus Windows binaries.

See [`Documentation/building/unix-instructions.md`](../building/unix-instructions.md).


<a name="unit-tests" />

### Ensure Unit Tests *Pass*

Run the unit tests by using `make all-tests run-all-tests`.

All unit tests should pass.

See [`Documentation/building/unix-instructions.md`](../building/unix-instructions.md).


<a name="create-pr" />

### Create a Pull Request

Create a Pull Request (PR) on the https://github.com/xamarin/xamarin-android repo.

Add the **full-mono-integration-build** label to the PR. This ensures that
the PR build is the full `make jenkins` build.

The resulting PR *should* be green before merging.


<a name="api-valiation" />

### Check for API Breakage

The `make run-api-compatibility-tests` target will check the built assemblies
for API breakage.

PR builds may report API breakage in the left-hand pane, in an
**API Compatibility Checks** link. If the API Compatibility Checks link is
not present, no API breakage was detected.

For example, this build:

<https://jenkins.mono-project.com/job/xamarin-android-pr-builder/4577/>

links to this set of reported API breakage:

<https://jenkins.mono-project.com/job/xamarin-android-pr-builder/4577/API_20Compatibility_20Checks/>

**To fix reported API breakage**, the mono sources may need to be updated, *or*
the [`xamarin/xamarin-android-api-compatibility`](https://github.com/xamarin/xamarin-android-api-compatibility/)
repo will need to be updated to "accept" the reported breakage, by updating
the [`external/xamarin-android-api-compatibility`](../../external) submodule
reference.

See the xamarin-android-api-compatibility repo for details.


<a name="qa-validation" />

### Ask for QA Validation

Asking QA for validation should be done ***last***.

Once QA approves, the mono bump PR can be merged.


<a name="mono-archive" />

## Mono Archives

A "Mono Archive" is a binary package (`.zip` file) which contains *binary*
mono artifacts, *not* source code.

See also:

* The [Mono SDKs Integration project](https://github.com/xamarin/xamarin-android/projects/10)
* Commit f970cd50

TODO. :-)
29 changes: 17 additions & 12 deletions src/mono-runtimes/ProfileAssemblies.projitems
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,16 @@
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<MonoFacadeAssembly Include="Microsoft.Win32.Primitives.dll" />
<MonoFacadeAssembly Include="Microsoft.Win32.Registry.AccessControl.dll" />
<MonoFacadeAssembly Include="Microsoft.Win32.Registry.dll" />
<MonoFacadeAssembly Include="Microsoft.Win32.Registry.AccessControl.dll" />
<MonoFacadeAssembly Include="System.AppContext.dll" />
<MonoFacadeAssembly Include="System.Collections.Concurrent.dll" />
<MonoFacadeAssembly Include="System.Buffers.dll" />
<MonoFacadeAssembly Include="System.Collections.dll" />
<MonoFacadeAssembly Include="System.Collections.Concurrent.dll" />
<MonoFacadeAssembly Include="System.Collections.NonGeneric.dll" />
<MonoFacadeAssembly Include="System.Collections.Specialized.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.Annotations.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.Annotations.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.EventBasedAsync.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.Primitives.dll" />
<MonoFacadeAssembly Include="System.ComponentModel.TypeConverter.dll" />
Expand All @@ -29,13 +30,13 @@
<MonoFacadeAssembly Include="System.Diagnostics.Tracing.dll" />
<MonoFacadeAssembly Include="System.Drawing.Common.dll" />
<MonoFacadeAssembly Include="System.Dynamic.Runtime.dll" />
<MonoFacadeAssembly Include="System.Globalization.Calendars.dll" />
<MonoFacadeAssembly Include="System.Globalization.dll" />
<MonoFacadeAssembly Include="System.Globalization.Calendars.dll" />
<MonoFacadeAssembly Include="System.Globalization.Extensions.dll" />
<MonoFacadeAssembly Include="System.IO.Compression.ZipFile.dll" />
<MonoFacadeAssembly Include="System.IO.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.AccessControl.dll" />
<MonoFacadeAssembly Include="System.IO.Compression.ZipFile.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.AccessControl.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.DriveInfo.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.Primitives.dll" />
<MonoFacadeAssembly Include="System.IO.FileSystem.Watcher.dll" />
Expand All @@ -47,8 +48,10 @@
<MonoFacadeAssembly Include="System.Linq.Expressions.dll" />
<MonoFacadeAssembly Include="System.Linq.Parallel.dll" />
<MonoFacadeAssembly Include="System.Linq.Queryable.dll" />
<MonoFacadeAssembly Include="System.Memory.dll" />
<MonoFacadeAssembly Include="System.Net.AuthenticationManager.dll" />
<MonoFacadeAssembly Include="System.Net.Cache.dll" />
<MonoFacadeAssembly Include="System.Net.Http.Rtc.dll" />
<MonoFacadeAssembly Include="System.Net.HttpListener.dll" />
<MonoFacadeAssembly Include="System.Net.Mail.dll" />
<MonoFacadeAssembly Include="System.Net.NameResolution.dll" />
Expand All @@ -61,8 +64,8 @@
<MonoFacadeAssembly Include="System.Net.Sockets.dll" />
<MonoFacadeAssembly Include="System.Net.Utilities.dll" />
<MonoFacadeAssembly Include="System.Net.WebHeaderCollection.dll" />
<MonoFacadeAssembly Include="System.Net.WebSockets.Client.dll" />
<MonoFacadeAssembly Include="System.Net.WebSockets.dll" />
<MonoFacadeAssembly Include="System.Net.WebSockets.Client.dll" />
<MonoFacadeAssembly Include="System.ObjectModel.dll" />
<MonoFacadeAssembly Include="System.Reflection.dll" />
<MonoFacadeAssembly Include="System.Reflection.DispatchProxy.dll" />
Expand All @@ -76,8 +79,8 @@
<MonoFacadeAssembly Include="System.Resources.ReaderWriter.dll" />
<MonoFacadeAssembly Include="System.Resources.ResourceManager.dll" />
<MonoFacadeAssembly Include="System.Resources.Writer.dll" />
<MonoFacadeAssembly Include="System.Runtime.CompilerServices.VisualC.dll" />
<MonoFacadeAssembly Include="System.Runtime.dll" />
<MonoFacadeAssembly Include="System.Runtime.CompilerServices.VisualC.dll" />
<MonoFacadeAssembly Include="System.Runtime.Extensions.dll" />
<MonoFacadeAssembly Include="System.Runtime.Handles.dll" />
<MonoFacadeAssembly Include="System.Runtime.InteropServices.dll" />
Expand All @@ -96,12 +99,12 @@
<MonoFacadeAssembly Include="System.Security.Cryptography.Csp.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.DeriveBytes.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encoding.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encryption.Aes.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encryption.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encryption.Aes.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encryption.ECDiffieHellman.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Encryption.ECDsa.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Hashing.Algorithms.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Hashing.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Hashing.Algorithms.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.OpenSsl.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Pkcs.dll" />
<MonoFacadeAssembly Include="System.Security.Cryptography.Primitives.dll" />
Expand All @@ -118,14 +121,15 @@
<MonoFacadeAssembly Include="System.ServiceModel.Primitives.dll" />
<MonoFacadeAssembly Include="System.ServiceModel.Security.dll" />
<MonoFacadeAssembly Include="System.ServiceProcess.ServiceController.dll" />
<MonoFacadeAssembly Include="System.Text.Encoding.CodePages.dll" />
<MonoFacadeAssembly Include="System.Text.Encoding.dll" />
<MonoFacadeAssembly Include="System.Text.Encoding.CodePages.dll" />
<MonoFacadeAssembly Include="System.Text.Encoding.Extensions.dll" />
<MonoFacadeAssembly Include="System.Text.RegularExpressions.dll" />
<MonoFacadeAssembly Include="System.Threading.AccessControl.dll" />
<MonoFacadeAssembly Include="System.Threading.dll" />
<MonoFacadeAssembly Include="System.Threading.AccessControl.dll" />
<MonoFacadeAssembly Include="System.Threading.Overlapped.dll" />
<MonoFacadeAssembly Include="System.Threading.Tasks.dll" />
<MonoFacadeAssembly Include="System.Threading.Tasks.Extensions.dll" />
<MonoFacadeAssembly Include="System.Threading.Tasks.Parallel.dll" />
<MonoFacadeAssembly Include="System.Threading.Thread.dll" />
<MonoFacadeAssembly Include="System.Threading.ThreadPool.dll" />
Expand All @@ -139,6 +143,7 @@
<MonoFacadeAssembly Include="System.Xml.XPath.XDocument.dll" />
<MonoFacadeAssembly Include="System.Xml.XPath.XmlDocument.dll" />
<MonoFacadeAssembly Include="System.Xml.Xsl.Primitives.dll" />

<!--
System.Drawing.Primitives and netstandard need a reference to Mono.Android.dll so their
build is driven from the XA repo by invoking make in the Mono submodule and passing the path
Expand Down

0 comments on commit f947ba3

Please sign in to comment.