-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathMultiInterface_AI_EG_Runner.cs
101 lines (81 loc) · 4.18 KB
/
MultiInterface_AI_EG_Runner.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
using Orleans.Providers;
using System;
using System.Threading.Tasks;
using Xunit;
using Xunit.Abstractions;
using Orleans.Indexing.Facet;
using System.Collections.Generic;
namespace Orleans.Indexing.Tests.MultiInterface
{
#region PartitionedPerKey
// NFT only; FT cannot be configured to be Eager.
// Active Indexes cannot be partitioned PerKey
#endregion // PartitionedPerKey
#region PartitionedPerSilo
// NFT only; FT cannot be configured to be Eager.
public class NFT_Props_Person_AI_EG_PS : IPersonProperties
{
[Index(typeof(IActiveHashIndexPartitionedPerSilo<string, INFT_Grain_Person_AI_EG_PS>), IsEager = true, IsUnique = false)] // PerSilo cannot be Unique
public string Name { get; set; }
[Index(typeof(IActiveHashIndexPartitionedPerSilo<int, INFT_Grain_Person_AI_EG_PS>), IsEager = true, IsUnique = false, NullValue = "0")]
public int Age { get; set; }
}
public class NFT_Props_Job_AI_EG_PS : IJobProperties
{
[Index(typeof(IActiveHashIndexPartitionedPerSilo<string, INFT_Grain_Job_AI_EG_PS>), IsEager = true, IsUnique = false)] // PerSilo cannot be Unique
public string Title { get; set; }
[Index(typeof(IActiveHashIndexPartitionedPerSilo<string, INFT_Grain_Job_AI_EG_PS>), IsEager = true, IsUnique = false)]
public string Department { get; set; }
}
public class NFT_Props_Employee_AI_EG_PS : IEmployeeProperties
{
[Index(typeof(IActiveHashIndexPartitionedPerSilo<int, INFT_Grain_Employee_AI_EG_PS>), IsEager = true, IsUnique = false, NullValue = "-1")] // PerSilo cannot be Unique
public int EmployeeId { get; set; }
}
public interface INFT_Grain_Person_AI_EG_PS : IIndexableGrain<NFT_Props_Person_AI_EG_PS>, IPersonGrain, IGrainWithIntegerKey
{
}
public interface INFT_Grain_Job_AI_EG_PS : IIndexableGrain<NFT_Props_Job_AI_EG_PS>, IJobGrain, IGrainWithIntegerKey
{
}
public interface INFT_Grain_Employee_AI_EG_PS : IIndexableGrain<NFT_Props_Employee_AI_EG_PS>, IEmployeeGrain, IGrainWithIntegerKey
{
}
public class NFT_Grain_Employee_AI_EG_PS : TestEmployeeGrain<EmployeeGrainState>,
INFT_Grain_Person_AI_EG_PS, INFT_Grain_Job_AI_EG_PS, INFT_Grain_Employee_AI_EG_PS
{
public NFT_Grain_Employee_AI_EG_PS(
[NonFaultTolerantWorkflowIndexedState(IndexingConstants.IndexedGrainStateName, IndexingConstants.MEMORY_STORAGE_PROVIDER_NAME)]
IIndexedState<EmployeeGrainState> indexedState)
: base(indexedState) { }
}
#endregion // PartitionedPerSilo
#region SingleBucket
// NFT only; FT cannot be configured to be Eager.
// Active Indexes cannot be partitioned SingleBucket
#endregion // SingleBucket
public abstract class MultiInterface_AI_EG_Runner : IndexingTestRunnerBase
{
protected MultiInterface_AI_EG_Runner(BaseIndexingFixture fixture, ITestOutputHelper output)
: base(fixture, output)
{
}
[Fact, TestCategory("BVT"), TestCategory("Indexing")]
public async Task Test_NFT_Grain_Employee_AI_EG_PS()
{
await base.TestEmployeeIndexesWithDeactivations<INFT_Grain_Person_AI_EG_PS, NFT_Props_Person_AI_EG_PS,
INFT_Grain_Job_AI_EG_PS, NFT_Props_Job_AI_EG_PS,
INFT_Grain_Employee_AI_EG_PS, NFT_Props_Employee_AI_EG_PS>();
}
internal static IEnumerable<Func<IndexingTestRunnerBase, int, Task>> GetAllTestTasks(TestIndexPartitionType testIndexTypes)
{
if (testIndexTypes.HasFlag(TestIndexPartitionType.PerSilo))
{
yield return (baseRunner, intAdjust) => baseRunner.TestEmployeeIndexesWithDeactivations<
INFT_Grain_Person_AI_EG_PS, NFT_Props_Person_AI_EG_PS,
INFT_Grain_Job_AI_EG_PS, NFT_Props_Job_AI_EG_PS,
INFT_Grain_Employee_AI_EG_PS, NFT_Props_Employee_AI_EG_PS>(intAdjust);
}
}
}
}