Skip to content

Commit d1c22e8

Browse files
committed
Merge branch 'main' into dev/grendel/perfetto-integration
* main: [Xamarin.Android.Build.Tasks] fix detection of "Android libraries" (#8904) [Mono.Android] fix potential leak of RunnableImplementors (#8900)
2 parents 7d0165e + 8e1871b commit d1c22e8

File tree

2 files changed

+25
-9
lines changed

2 files changed

+25
-9
lines changed

src/Xamarin.Android.Build.Tasks/Tests/Xamarin.Android.Build.Tests/BuildWithLibraryTests.cs

Lines changed: 19 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -269,11 +269,7 @@ public void ProjectDependencies ([Values(true, false)] bool projectReference)
269269
};
270270
libB.Sources.Clear ();
271271
libB.Sources.Add (new BuildItem.Source ("Foo.cs") {
272-
TextContent = () => @"public class Foo {
273-
public Foo () {
274-
var bar = new Bar();
275-
}
276-
}",
272+
TextContent = () => "public class Foo : Bar { }",
277273
});
278274

279275
var libC = new XamarinAndroidLibraryProject () {
@@ -283,7 +279,7 @@ public Foo () {
283279
};
284280
libC.Sources.Clear ();
285281
libC.Sources.Add (new BuildItem.Source ("Bar.cs") {
286-
TextContent = () => "public class Bar { }",
282+
TextContent = () => "public class Bar : Java.Lang.Object { }",
287283
});
288284
libC.Sources.Add (new BuildItem ("EmbeddedResource", "Foo.resx") {
289285
TextContent = () => InlineData.ResxWithContents ("<data name=\"CancelButton\"><value>Cancel</value></data>")
@@ -309,8 +305,8 @@ public Foo () {
309305
ProjectName = "AppA",
310306
IsRelease = true,
311307
Sources = {
312-
new BuildItem.Source ("Bar.cs") {
313-
TextContent = () => "public class Bar : Foo { }",
308+
new BuildItem.Source ("Baz.cs") {
309+
TextContent = () => "public class Baz : Foo { }",
314310
},
315311
new BuildItem ("EmbeddedResource", "Foo.resx") {
316312
TextContent = () => InlineData.ResxWithContents ("<data name=\"CancelButton\"><value>Cancel</value></data>")
@@ -321,6 +317,10 @@ public Foo () {
321317
}
322318
};
323319
appA.AddReference (libB);
320+
if (!projectReference) {
321+
// @(ProjectReference) implicits adds this reference. For `class Baz : Foo : Bar`:
322+
appA.OtherBuildItems.Add (new BuildItem.Reference ($@"..\{libC.ProjectName}\bin\Release\{libC.TargetFramework}\{libC.ProjectName}.dll"));
323+
}
324324
var appBuilder = CreateApkBuilder (Path.Combine (path, appA.ProjectName));
325325
Assert.IsTrue (appBuilder.Build (appA), $"{appA.ProjectName} should succeed");
326326

@@ -332,6 +332,17 @@ public Foo () {
332332
helper.AssertContainsEntry ($"assemblies/{libC.ProjectName}.dll");
333333
helper.AssertContainsEntry ($"assemblies/es/{appA.ProjectName}.resources.dll");
334334
helper.AssertContainsEntry ($"assemblies/es/{libC.ProjectName}.resources.dll");
335+
336+
var intermediate = Path.Combine (Root, appBuilder.ProjectDirectory, appA.IntermediateOutputPath);
337+
var dexFile = Path.Combine (intermediate, "android", "bin", "classes.dex");
338+
FileAssert.Exists (dexFile);
339+
340+
// NOTE: the crc hashes here might change one day, but if we used [Android.Runtime.Register("")]
341+
// LibraryB.dll would have a reference to Mono.Android.dll, which invalidates the test.
342+
string className = "Lcrc6414a4b78410c343a2/Bar;";
343+
Assert.IsTrue (DexUtils.ContainsClass (className, dexFile, AndroidSdkPath), $"`{dexFile}` should include `{className}`!");
344+
className = "Lcrc646d2d82b4d8b39bd8/Foo;";
345+
Assert.IsTrue (DexUtils.ContainsClass (className, dexFile, AndroidSdkPath), $"`{dexFile}` should include `{className}`!");
335346
}
336347

337348
[Test]

src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.cs

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -277,8 +277,13 @@ public static void LogWarning (object log, string msg, params object [] args)
277277
#if MSBUILD
278278
public static bool IsMonoAndroidAssembly (ITaskItem assembly)
279279
{
280+
// NOTE: look for both MonoAndroid and Android
280281
var tfi = assembly.GetMetadata ("TargetFrameworkIdentifier");
281-
if (string.Compare (tfi, "MonoAndroid", StringComparison.OrdinalIgnoreCase) == 0)
282+
if (tfi.IndexOf ("Android", StringComparison.OrdinalIgnoreCase) != -1)
283+
return true;
284+
285+
var tpi = assembly.GetMetadata ("TargetPlatformIdentifier");
286+
if (tpi.IndexOf ("Android", StringComparison.OrdinalIgnoreCase) != -1)
282287
return true;
283288

284289
var hasReference = assembly.GetMetadata ("HasMonoAndroidReference");

0 commit comments

Comments
 (0)