You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
EntityFrameworkCore.Jet/test/EFCore.Jet.FunctionalTests/IncludeOneToOneJetTest.cs

72 lines
2.1 KiB
C#

using System.Linq;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Query;
using Xunit;
namespace EntityFramework.Jet.FunctionalTests
{
public class IncludeOneToOneJetTest : IncludeOneToOneTestBase, IClassFixture<OneToOneQueryJetFixture>
{
public override void Include_person()
{
base.Include_person();
Assert.Equal(
@"SELECT [a].[Id], [a].[City], [a].[Street], [a.Resident].[Id], [a.Resident].[Name]
FROM [Address] AS [a]
INNER JOIN [Person] AS [a.Resident] ON [a].[Id] = [a.Resident].[Id]",
Sql);
}
public override void Include_person_shadow()
{
base.Include_person_shadow();
Assert.Equal(
@"SELECT [a].[Id], [a].[City], [a].[PersonId], [a].[Street], [a.Resident].[Id], [a.Resident].[Name]
FROM [Address2] AS [a]
INNER JOIN [Person2] AS [a.Resident] ON [a].[PersonId] = [a.Resident].[Id]",
Sql);
}
public override void Include_address()
{
base.Include_address();
Assert.Equal(
@"SELECT [p].[Id], [p].[Name], [p.Address].[Id], [p.Address].[City], [p.Address].[Street]
FROM [Person] AS [p]
LEFT JOIN [Address] AS [p.Address] ON [p].[Id] = [p.Address].[Id]",
Sql);
}
public override void Include_address_shadow()
{
base.Include_address_shadow();
Assert.Equal(
@"SELECT [p].[Id], [p].[Name], [p.Address].[Id], [p.Address].[City], [p.Address].[PersonId], [p.Address].[Street]
FROM [Person2] AS [p]
LEFT JOIN [Address2] AS [p.Address] ON [p].[Id] = [p.Address].[PersonId]",
Sql);
}
private readonly OneToOneQueryJetFixture _fixture;
public IncludeOneToOneJetTest(OneToOneQueryJetFixture fixture)
{
_fixture = fixture;
}
protected override DbContext CreateContext()
{
return _fixture.CreateContext();
}
private string Sql
{
get { return _fixture.TestSqlLoggerFactory.SqlStatements.Last(); }
}
}
}