Entityframework.docs: Workarounds for Xamarin.iOS app with EFCore 2.0

Created on 6 Jan 2018  路  10Comments  路  Source: dotnet/EntityFramework.Docs

Updated to current known issues and workarounds:

  • For Xamarin.Android, use package.config instead of PackageReference (dependent on https://github.com/xamarin/xamarin-android/issues/1196).
  • For Xamarin.Android, try changing AndroidLinkMode to SdkOnly ( https://github.com/aspnet/EntityFrameworkCore/issues/11027#issuecomment-374425403) or other workarounds to preserve additional reflection metadata, e.g. [assembly: Preserve (typeof (System.Linq.Queryable), AllMembers = true)] (dependent on https://github.com/aspnet/EntityFrameworkCore/issues/10963) or using a LinkDescription.xml file.
  • For SQLite, use SQLitePCL.Batteries_V2.Init() (see https://github.com/ericsink/SQLitePCL.raw/wiki/SQLitePCL.Batteries.Init).
  • Tooling is blocked on the fact that the linker used by Xamarin removes assembly level attributes (see https://github.com/xamarin/xamarin-macios/issues/3655).

Good sample app link applying workarounds by @cwrea: https://github.com/cwrea/XamarinTodo/tree/master

Original Issue:

_From @alexdrl on November 21, 2017 8:44_

A Xamarin.iOS app with EFCore 2.0 needs a call to

```c#
SQLitePCL.Batteries_V2.Init();

If the call is not made, the app initialization throws this error message. 

You need to call SQLitePCL.raw.SetProvider(). If you are using a bundle package, this is done by calling SQLitePCL.Batteries.Init().
```
Like explained here

Steps to reproduce

Xamarin.iOS project working with EFCore 2.0. Solution with a common .NET Standard project which shares code between iOS and Android, using PackageReference.

Further technical details

EF Core version: 2.0.0
Database Provider: Microsoft.EntityFrameworkCore.Sqlite
Operating system: iOS
IDE: Visual Studio 15.4

_Copied from original issue: aspnet/EntityFrameworkCore#10361_

area-xamarin punted-for-2.2

Most helpful comment

Worth noting here, with respect to the Entity Framework Core 2.1 release, and the Visual Studio 15.7.3 releases of Xamarin.iOS and Xamarin.Android:

At present, the only known workaround for Xamarin mobile app developers wishing to use Entity Framework Core is to not upgrade to the 2.1 release. i.e. Stay on 2.0.3 until the underlying Xamarin platforms have addressed deficiencies related to the new System.Memory 4.5 dependency that was introduced (indirectly) as part of the newer packages that EF Core 2.1 now depends on. I am not aware of any timeline with respect to when these issues may be fixed.

All 10 comments

Correct. I don't think Xamarin.iOS can handle the Assembly.Load() call. And binding directly to SQLitePCLRaw.batteries_v2.dll will cause problems if you're not using a bundle.

_From @alexdrl on November 22, 2017 18:27_

I use the SQLitePCLraw assembly that gets added as a transitive dependency, and call that Init method, the app works correctly. In the project assets json, the Xamarin.iOS SQLitePCLraw package gets restored correctly.

We should probably document this on the Supported .NET Implementations page or thereabouts.

_From @alexdrl on November 22, 2017 18:31_

The documentation already stated that there are problems in Xamarin.iOS but there is no page that describes this (or other) workarounds.

Worth noting here, with respect to the Entity Framework Core 2.1 release, and the Visual Studio 15.7.3 releases of Xamarin.iOS and Xamarin.Android:

At present, the only known workaround for Xamarin mobile app developers wishing to use Entity Framework Core is to not upgrade to the 2.1 release. i.e. Stay on 2.0.3 until the underlying Xamarin platforms have addressed deficiencies related to the new System.Memory 4.5 dependency that was introduced (indirectly) as part of the newer packages that EF Core 2.1 now depends on. I am not aware of any timeline with respect to when these issues may be fixed.

@cwrea Thank you for mentioning this. I would've spent hours debugging that issue if I hadn't seen your comment first! Literally saved us hundreds of dollars!

@dfoulk You're welcome. FWIW, since I posted that, there's hope that Visual Studio 15.8 Preview 3 may address these issues. See my comment from a couple of days ago at https://github.com/xamarin/xamarin-macios/issues/4168#issuecomment-398521666 ... I haven't tried the preview myself, yet. Tied up in other project work at the moment.

@cwrea very weird. I'm running ef core 2.1 on my android and native UWP and it works and builds fine (debug and release) , but I'm using Microsoft.Extentions.primitives version 2.0

@Pinox Do you have linking enabled? The oustanding Android issue is specific to having linking enabled.

@cwrea In release mode I have "SDK Assemblies" and in debug mode "none".

Edit
Ignore my comments as this morning my projects also do not work anymore with ef core 2.1

Was this page helpful?
0 / 5 - 0 ratings

Related issues

weitzhandler picture weitzhandler  路  4Comments

SychevIgor picture SychevIgor  路  4Comments

ctaggart picture ctaggart  路  3Comments

jaxidian picture jaxidian  路  4Comments

ajcvickers picture ajcvickers  路  4Comments