Показанный далее тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), или именем, начинающимся с буквы "Н" (нечувствительно к регистру символов), и демонстрирует использование метода EF.Functions.Like. Обратите внимание, что включать групповой символ (%) вы должны самостоятельно.

[Fact]

public void ShouldGetCustomersWithLastNameWOrH

{

  IQueryable query = Context.Customers

    .Where(x => EF.Functions.Like(x.PersonalInformation.LastName, "W%") ||

                EF.Functions.Like(x.PersonalInformation.LastName, "H%"));

  var qs = query.ToQueryString;

  List customers = query.ToList;

  Assert.Equal(3, customers.Count);

}

Запрос LINQ транслируется в следующий код SQL (обратите внимание, что проверка на null не делается):

SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],

       [c].[LastName] FROM [Dbo].[Customers] AS [c]

WHERE ([c].[LastName] LIKE N'W%') OR ([c].[LastName] LIKE N'H%')

В приведенном ниже тесте из класса CarTests.cs применяется [Theory] для проверки количества записей Car в таблице Inventory на основе MakeId (метод IgnoreQueryFilters рассматривался в разделе "Глобальные фильтры запросов" главы 22):

[Theory]

[InlineData(1, 2)]

[InlineData(2, 1)]

[InlineData(3, 1)]

[InlineData(4, 2)]

[InlineData(5, 3)]

[InlineData(6, 1)]

public void ShouldGetTheCarsByMake(int makeId, int expectedCount)

{

  IQueryable query =

    Context.Cars.IgnoreQueryFilters.Where(x => x.MakeId == makeId);

  var qs = query.ToQueryString;

  var cars = query.ToList;

  Assert.Equal(expectedCount, cars.Count);

}

Каждая строка [InlineData] становится уникальным тестом в средстве запуска тестов. В этом примере обрабатываются шесть тестов и в отношении базы данных выполняются шесть запросов. Вот как выглядит код SQL для одного из тестов (единственным отличием в запросах для других тестов в [Theory] будет значение MakeId):

DECLARE @__makeId_0 int = 1;

SELECT [i].[Id], [i].[Color], [i].[IsDrivable], [i].[MakeId], [i].[PetName],

       [i].[TimeStamp] FROM [dbo].[Inventory] AS [i]

WHERE [i].[MakeId] = @__makeId_0

Следующий тест [Theory] показывает фильтрованный запрос с CustomerOrderViewModel (поместите тест в файл класса OrderTests.cs):

[Theory]

[InlineData("Black",2)]

[InlineData("Rust",1)]

[InlineData("Yellow",1)]

[InlineData("Green",0)]

[InlineData("Pink",1)]

[InlineData("Brown",0)]

public void ShouldGetAllViewModelsByColor(string color, int expectedCount)

{

    var query = _repo.GetOrdersViewModel.Where(x=>x.Color == color);

    var qs = query.ToQueryString;

    var orders = query.ToList;

    Assert.Equal(expectedCount,orders.Count);

}

Для первого теста [InlineData] генерируется такой запрос:

DECLARE @__color_0 nvarchar(4000) = N'Black';

SELECT [c].[Color], [c].[FirstName], [c].[IsDrivable], [c].[LastName],

       [c].[Make], [c].[PetName] FROM [dbo].[CustomerOrderView] AS [c]

WHERE [c].[Color] = @__color_0

<p id="AutBody_Root1028"><strong>Сортировка записей</strong></p>

Методы OrderBy и OrderByDescending устанавливают для запроса сортировку (сортировки) по возрастанию и по убыванию. Если требуются дальнейшие сортировки, тогда используйте методы ThenBy и ThenByDescending. Сортировка демонстрируется в тесте ниже:

[Fact]

public void ShouldSortByLastNameThenFirstName

{

Перейти на страницу:

Похожие книги