-
-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathTestDbContext.cs
More file actions
127 lines (104 loc) · 3.56 KB
/
TestDbContext.cs
File metadata and controls
127 lines (104 loc) · 3.56 KB
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
namespace PhenX.EntityFrameworkCore.BulkInsert.Tests.DbContext;
public class TestDbContext : TestDbContextBase
{
public DbSet<TestEntity> TestEntities { get; set; } = null!;
public DbSet<TestEntityWithJson> TestEntitiesWithJson { get; set; } = null!;
public DbSet<TestEntityWithGuidId> TestEntitiesWithGuidId { get; set; } = null!;
public DbSet<TestEntityWithConverters> TestEntitiesWithConverter { get; set; } = null!;
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithConverters>(builder =>
{
builder.Property(e => e.CreatedAt)
.HasConversion(new DateTimeToBinaryConverter());
});
modelBuilder.Entity<TestEntityWithGuidId>(builder =>
{
builder.Property(e => e.Id)
.ValueGeneratedNever();
});
}
}
public class TestDbContextPostgreSql : TestDbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithJson>(b =>
{
b.Property(x => x.JsonArray).AsJsonString("jsonb");
b.Property(x => x.JsonObject).AsJsonString("jsonb");
});
modelBuilder.Entity<TestEntity>(b =>
{
b.Property(x => x.StringEnumValue).HasColumnType("text");
});
}
}
public class TestDbContextMySql : TestDbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithJson>(b =>
{
b.Property(x => x.JsonArray).AsJsonString("json");
b.Property(x => x.JsonObject).AsJsonString("json");
});
modelBuilder.Entity<TestEntity>(b =>
{
b.Property(x => x.StringEnumValue).HasColumnType("text");
});
}
}
public class TestDbContextSqlServer : TestDbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithJson>(b =>
{
b.Property(x => x.JsonArray).AsJsonString(null);
b.Property(x => x.JsonObject).AsJsonString(null);
});
modelBuilder.Entity<TestEntity>(b =>
{
b.Property(x => x.StringEnumValue).HasColumnType("text");
});
}
}
public class TestDbContextSqlite : TestDbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithJson>(b =>
{
b.Property(x => x.JsonArray).AsJsonString(null);
b.Property(x => x.JsonObject).AsJsonString(null);
});
modelBuilder.Entity<TestEntity>(b =>
{
b.Property(x => x.StringEnumValue).HasColumnType("text");
});
}
}
public class TestDbContextOracle : TestDbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<TestEntityWithJson>(b =>
{
b.Property(x => x.JsonArray).AsJsonString(null);
b.Property(x => x.JsonObject).AsJsonString(null);
});
modelBuilder.Entity<TestEntity>(b =>
{
b.Property(x => x.StringEnumValue).HasColumnType("nvarchar2(255)");
});
}
}