diff --git a/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.BuildOrder.targets b/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.BuildOrder.targets index 4a4a3432258..4bfa0ff3d74 100644 --- a/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.BuildOrder.targets +++ b/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.BuildOrder.targets @@ -187,6 +187,7 @@ properties that determine build ordering. <_CompileBindingJavaDependsOnTargets> _AdjustJavacVersionArguments; + _GetLibraryImports; _DetermineBindingJavaLibrariesToCompile; _GetJavaPlatformJar; diff --git a/src/Xamarin.Android.Build.Tasks/Tests/Xamarin.Android.Build.Tests/BuildTest.cs b/src/Xamarin.Android.Build.Tasks/Tests/Xamarin.Android.Build.Tests/BuildTest.cs index 0d4182e2003..9405f155328 100644 --- a/src/Xamarin.Android.Build.Tasks/Tests/Xamarin.Android.Build.Tests/BuildTest.cs +++ b/src/Xamarin.Android.Build.Tasks/Tests/Xamarin.Android.Build.Tests/BuildTest.cs @@ -1554,6 +1554,35 @@ public void CheckLintConfigMerging () } } + [Test] + public void BuildApplicationWithJavaSourceUsingAndroidX ([Values(true, false)] bool isRelease) + { + var proj = new XamarinAndroidApplicationProject () { + IsRelease = isRelease, + OtherBuildItems = { + new BuildItem (AndroidBuildActions.AndroidJavaSource, "ToolbarEx.java") { + TextContent = () => @"package com.unnamedproject.unnamedproject; +import android.content.Context; +import androidx.appcompat.widget.Toolbar; +public class ToolbarEx { + public static Toolbar GetToolbar (Context context) { + return new Toolbar (context); + } +} +", + Encoding = Encoding.ASCII + }, + } + }; + proj.PackageReferences.Add (KnownPackages.AndroidXAppCompat); + using (var b = CreateApkBuilder ()) { + b.ThrowOnBuildFailure = false; + Assert.IsTrue (b.Build (proj), "Build should have succeeded"); + + Assert.IsTrue (b.Clean (proj), "Clean should have succeeded."); + } + } + [Test] public void BuildApplicationCheckThatAddStaticResourcesTargetDoesNotRerun () {