aboutsummaryrefslogtreecommitdiff
path: root/Timeline.Tests/Mock
diff options
context:
space:
mode:
author杨宇千 <crupest@outlook.com>2019-08-18 18:07:50 +0800
committer杨宇千 <crupest@outlook.com>2019-08-18 18:07:50 +0800
commit39aa54bb10da8b76a4021feb984b8aad0df6269b (patch)
tree21b4c77e48f34e1a72858209e4d4d6d7978b663a /Timeline.Tests/Mock
parent2d672de8ea109c923d5a8697e44d5cbbf976ead2 (diff)
downloadtimeline-39aa54bb10da8b76a4021feb984b8aad0df6269b.tar.gz
timeline-39aa54bb10da8b76a4021feb984b8aad0df6269b.tar.bz2
timeline-39aa54bb10da8b76a4021feb984b8aad0df6269b.zip
Add avatar service.
Diffstat (limited to 'Timeline.Tests/Mock')
-rw-r--r--Timeline.Tests/Mock/Data/TestDatabase.cs46
1 files changed, 46 insertions, 0 deletions
diff --git a/Timeline.Tests/Mock/Data/TestDatabase.cs b/Timeline.Tests/Mock/Data/TestDatabase.cs
new file mode 100644
index 00000000..09c77dce
--- /dev/null
+++ b/Timeline.Tests/Mock/Data/TestDatabase.cs
@@ -0,0 +1,46 @@
+using Microsoft.Data.Sqlite;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Diagnostics;
+using System;
+using Timeline.Entities;
+
+namespace Timeline.Tests.Mock.Data
+{
+ public class TestDatabase : IDisposable
+ {
+ private readonly SqliteConnection _databaseConnection;
+ private readonly DatabaseContext _databaseContext;
+
+ public TestDatabase()
+ {
+ _databaseConnection = new SqliteConnection("Data Source=:memory:;");
+ _databaseConnection.Open();
+
+ var options = new DbContextOptionsBuilder<DatabaseContext>()
+ .UseSqlite(_databaseConnection)
+ .ConfigureWarnings(builder =>
+ {
+ builder.Throw(RelationalEventId.QueryClientEvaluationWarning);
+ })
+ .Options;
+
+ _databaseContext = new DatabaseContext(options);
+
+ // init with mock data
+ _databaseContext.Database.EnsureCreated();
+ _databaseContext.Users.AddRange(MockUsers.Users);
+ _databaseContext.SaveChanges();
+ }
+
+ public void Dispose()
+ {
+ _databaseContext.Dispose();
+
+ _databaseConnection.Close();
+ _databaseConnection.Dispose();
+ }
+
+ public SqliteConnection DatabaseConnection => _databaseConnection;
+ public DatabaseContext DatabaseContext => _databaseContext;
+ }
+}