Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Dynamic-Tests] Replace Microsoft.CSharp reference with NuGet package. #1067

Merged
merged 1 commit into from
Dec 14, 2022

Conversation

jpobst
Copy link
Contributor

@jpobst jpobst commented Dec 12, 2022

Each CI job reports the following warnings:

C:\hostedtoolcache\windows\dotnet\sdk\7.0.100-rc.1.22431.12\Microsoft.Common.CurrentVersion.targets(2350,5): warning MSB3245: Could not resolve this reference. Could not locate the assembly "Microsoft.CSharp". Check to make sure the assembly exists on disk. If this reference is required by your code, you may get compilation errors. [D:\a\_work\1\s\tests\Java.Interop.Dynamic-Tests\Java.Interop.Dynamic-Tests.csproj::TargetFramework=net7.0]
C:\hostedtoolcache\windows\dotnet\sdk\7.0.100-rc.1.22431.12\Microsoft.Common.CurrentVersion.targets(2350,5): warning MSB3243: No way to resolve conflict between "Microsoft.CSharp, Version=7.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" and "Microsoft.CSharp". Choosing "Microsoft.CSharp, Version=7.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" arbitrarily. [D:\a\_work\1\s\tests\Java.Interop.Dynamic-Tests\Java.Interop.Dynamic-Tests.csproj::TargetFramework=net7.0]

Fix this by using a <PackageReference> to Microsoft.CSharp instead of a <Reference>.

@jpobst jpobst marked this pull request as ready for review December 13, 2022 14:53
@jonpryor jonpryor merged commit 525a45d into main Dec 14, 2022
@jonpryor jonpryor deleted the csharp-warning branch December 14, 2022 21:04
jonpryor pushed a commit to dotnet/android that referenced this pull request Dec 16, 2022
Context: 4da2792
Context: dotnet/java-interop@d3ea180
Context: dotnet/java-interop@15c8879

Changes: dotnet/java-interop@149d70f...f8d77fa

  * dotnet/java-interop@f8d77faf: [generator] Better support deprecated property getter/setters. (dotnet/java-interop#1062)
  * dotnet/java-interop@5e6209ea: [generator] Obsolete&SupportedOSPlatform attributes on enum members (dotnet/java-interop#1066)
  * dotnet/java-interop@15c88797: [generator] Use decl type's @deprecated-since if < member's (dotnet/java-interop#1068)
  * dotnet/java-interop@525a45d5: [Java.Interop.Dynamic-Tests] Use Microsoft.CSharp NuGet package (dotnet/java-interop#1067)

Background: member deprecations can be "historically weird" in Android.
For example, in API-21 [`android/app/ActionBar.TabListener`][0] was
deprecated:

	@deprecated
	/* partial */ interface TabListener {
	    void onTabReselected(ActionBar.Tab tab, FragmentTransaction ft);
	    // …
	}

The type being deprecated means that its members are *implicitly*
deprecated.

In API-29 the members were *explicitly* deprecated:

	@deprecated
	/* partial */ interface TabListener {
	    @deprecated
	    void onTabReselected(ActionBar.Tab tab, FragmentTransaction ft);
	    // …
	}

Before dotnet/java-interop@d3ea180c, this resulted in the binding:

	[Obsolete]
	partial interface ITabListener {
	    [Obsolete]
	    void OnTabReselected(ActionBar.Tab? tab, FragmentTransaction? ft);
	    // …
	}

Commit dotnet/java-interop@d3ea180c added support for
`[ObsoletedOSPlatform]` to `generator`, which *changed* the binding to:

	[Obsolete] // because it was deprecated in our min-supported API-21
	partial interface ITabListener {
	    [ObsoletedOSPlatform ("android29.0")]
	    void OnTabReselected(ActionBar.Tab? tab, FragmentTransaction? ft);
	    // …
	}

This resulted in *lots* of changes in commit 4da2792 to
`tests/api-compatibility/acceptable-breakages-vReference-net7.0.txt`
because `[Obsolete]` was were replaced by `[ObsoletedOSPlatform]`:

	CannotRemoveAttribute : Attribute 'System.ObsoleteAttribute' exists on 'Android.App.ActionBar.ITabListener.OnTabReselected(Android.App.ActionBar.Tab, Android.App.FragmentTransaction)' in the contract but not the implementation

Commit dotnet/java-interop@15c88797 updates type members to have the
same deprecation status as their declaring type, when the member was
deprecated *after* the type was deprecated.  This means we *now*
bind `ITabListener` as:

	[Obsolete] // because it was deprecated in our min-supported API-21
	partial interface ITabListener {
	    [Obsolete]
	    void OnTabReselected(ActionBar.Tab? tab, FragmentTransaction? ft);
	    // …
	}

which matches the state of things pre- dotnet/java-interop@d3ea180c,
which means we no longer need to ignore all those
`CannotRemoveAttribute` messages.  dotnet/java-interop@15c88797 thus
"unintentionally partially reverts" 4da2792 (yay?), simply because
the prior state of affairs in which a member was deprecated *after*
the declaring type, while valid, didn't make any sense.

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Jonathan Pobst <jonathan.pobst@microsoft.com>

[0]: https://developer.android.com/reference/android/app/ActionBar.TabListener
@github-actions github-actions bot locked and limited conversation to collaborators Apr 12, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants