Summary of the issue
Calling Include on an EFCachedDbSet does not include the property as expected.
Environment
.NET Core SDK version: 3.1.1 (latest stable)
Microsoft.EntityFrameworkCore version: 3.1.1 (latest stable)
EFSecondLevelCache.Core version: 2.9.1 (latest stable)
Example code/Steps to reproduce:
I'm using the following entity extracted from my MSSQL DB.
public class Category : Entity<string>
{
public string Name { get; private set; }
public string ParentCategoryId { get; private set; }
public ICollection<Category> SubCategories { get; private set; }
protected Category() { }
}
In EF Core, the binding is created as followed:
builder.Entity<Category>(m =>
{
#region Mappings
m.ToTable("Category", "social");
m.Property(x => x.Id)
.HasColumnName("CategoryId");
m.HasKey(x => x.Id);
m.HasMany(x => x.SubCategories)
.WithOne()
.HasForeignKey(x => x.ParentCategoryId);
#endregion
});
Outputs
When I call the following code, SubCategories are all NULL.
db
.Set<Category>()
**.Cacheable(CacheExpirationMode.Absolute, TimeSpan.FromDays(7))**
**.Include(x => x.SubCategories)**
.ToListAsync(token);
If I move the include before the Cacheable(), then it works fine.
db
.Set<Category>()
**.Include(x => x.SubCategories)**
**.Cacheable(CacheExpirationMode.Absolute, TimeSpan.FromDays(7))**
.ToListAsync(token);
I assume it's related to #39. It would convenient if we could call the include on the EFCachedDbSet. This way we can keep the Cache mgt code within one class (the DbContext)

Summary of the issue
Calling
Includeon anEFCachedDbSetdoes not include the property as expected.Environment
Example code/Steps to reproduce:
I'm using the following entity extracted from my MSSQL DB.
In EF Core, the binding is created as followed:
Outputs
When I call the following code,
SubCategoriesare allNULL.If I move the include before the
Cacheable(), then it works fine.I assume it's related to #39. It would convenient if we could call the
includeon theEFCachedDbSet. This way we can keep the Cache mgt code within one class (the DbContext)