aboutsummaryrefslogtreecommitdiff
path: root/BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-11-12 18:31:41 +0800
committercrupest <crupest@outlook.com>2020-11-12 18:31:41 +0800
commit1dfafd9400c158576f9ede8f3012356746cb5ae0 (patch)
treef9b0fbfe0c7f2c67f9410a3a5f9821afaacec5de /BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs
parent33f1358f4e5359329d28177384420e29abea3445 (diff)
downloadtimeline-1dfafd9400c158576f9ede8f3012356746cb5ae0.tar.gz
timeline-1dfafd9400c158576f9ede8f3012356746cb5ae0.tar.bz2
timeline-1dfafd9400c158576f9ede8f3012356746cb5ae0.zip
feat: Add user permission service.
TODO: Add unit tests.
Diffstat (limited to 'BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs')
-rw-r--r--BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs47
1 files changed, 47 insertions, 0 deletions
diff --git a/BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs b/BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs
new file mode 100644
index 00000000..838787e9
--- /dev/null
+++ b/BackEnd/Timeline.Tests/Services/DatabaseBasedTest.cs
@@ -0,0 +1,47 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Threading.Tasks;
+using Timeline.Entities;
+using Timeline.Tests.Helpers;
+using Xunit;
+
+namespace Timeline.Tests.Services
+{
+ public abstract class DatabaseBasedTest : IAsyncLifetime
+ {
+ protected TestDatabase TestDatabase { get; } = new TestDatabase();
+ protected DatabaseContext Database { get; private set; }
+
+ public async Task InitializeAsync()
+ {
+ await TestDatabase.InitializeAsync();
+ Database = TestDatabase.CreateContext();
+ await OnDatabaseCreatedAsync();
+ OnDatabaseCreated();
+ }
+
+ public async Task DisposeAsync()
+ {
+ BeforeDatabaseDestroy();
+ await BeforeDatabaseDestroyAsync();
+ await Database.DisposeAsync();
+ await TestDatabase.DisposeAsync();
+ }
+
+
+ protected virtual void OnDatabaseCreated() { }
+ protected virtual void BeforeDatabaseDestroy() { }
+
+
+ protected virtual Task OnDatabaseCreatedAsync()
+ {
+ return Task.CompletedTask;
+ }
+
+ protected virtual Task BeforeDatabaseDestroyAsync()
+ {
+ return Task.CompletedTask;
+ }
+ }
+}