Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

88 lines
3.0 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System.Collections.Generic;
using System.Threading.Tasks;
using Squidex.ClientLibrary;
using Xunit;
namespace LoadTest
{
public class ContentQueryBenchmarks : IClassFixture<ClientQueryFixture>
{
public ClientQueryFixture Fixture { get; }
public ContentQueryBenchmarks(ClientQueryFixture fixture)
{
Fixture = fixture;
}
public static IEnumerable<object[]> Loads()
{
int[] users = { 1, 5, 10, 20, 50, 100 };
int[] loads = { 5, 10, 20, 50, 100 };
foreach (var user in users)
{
foreach (var load in loads)
{
yield return new object[] { user, load };
}
}
}
[Theory]
[MemberData(nameof(Loads))]
public async Task Should_return_all(int numUsers, int numIterationsPerUser)
{
await Run.Parallel(numUsers, numIterationsPerUser, async () =>
{
await Fixture.Client.GetAsync(new ODataQuery { OrderBy = "data/value/iv asc" });
});
}
[Theory]
[MemberData(nameof(Loads))]
public async Task Should_return_items_with_skip(int numUsers, int numIterationsPerUser)
{
await Run.Parallel(numUsers, numIterationsPerUser, async () =>
{
await Fixture.Client.GetAsync(new ODataQuery { Skip = 5, OrderBy = "data/value/iv asc" });
});
}
[Theory]
[MemberData(nameof(Loads))]
public async Task Should_return_items_with_skip_and_top(int numUsers, int numIterationsPerUser)
{
await Run.Parallel(numUsers, numIterationsPerUser, async () =>
{
await Fixture.Client.GetAsync(new ODataQuery { Skip = 2, Top = 5, OrderBy = "data/value/iv asc" });
});
}
[Theory]
[MemberData(nameof(Loads))]
public async Task Should_return_items_with_ordering(int numUsers, int numIterationsPerUser)
{
await Run.Parallel(numUsers, numIterationsPerUser, async () =>
{
await Fixture.Client.GetAsync(new ODataQuery { Skip = 2, Top = 5, OrderBy = "data/value/iv desc" });
});
}
[Theory]
[MemberData(nameof(Loads))]
public async Task Should_return_items_with_filter(int numUsers, int numIterationsPerUser)
{
await Run.Parallel(numUsers, numIterationsPerUser, async () =>
{
await Fixture.Client.GetAsync(new ODataQuery { Filter = "data/value/iv gt 3 and data/value/iv lt 7", OrderBy = "data/value/iv asc" });
});
}
}
}