added LastSync to TwitterUser (wip)
This commit is contained in:
parent
8708a529d6
commit
8146b6ea5a
3 changed files with 33 additions and 16 deletions
|
@ -23,7 +23,7 @@ namespace BirdsiteLive.DAL.Postgres.DataAccessLayers
|
||||||
public class DbInitializerPostgresDal : PostgresBase, IDbInitializerDal
|
public class DbInitializerPostgresDal : PostgresBase, IDbInitializerDal
|
||||||
{
|
{
|
||||||
private readonly PostgresTools _tools;
|
private readonly PostgresTools _tools;
|
||||||
private readonly Version _currentVersion = new Version(1,0);
|
private readonly Version _currentVersion = new Version(2, 0);
|
||||||
private const string DbVersionType = "db-version";
|
private const string DbVersionType = "db-version";
|
||||||
|
|
||||||
#region Ctor
|
#region Ctor
|
||||||
|
@ -32,7 +32,7 @@ namespace BirdsiteLive.DAL.Postgres.DataAccessLayers
|
||||||
_tools = tools;
|
_tools = tools;
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
public async Task<Version> GetCurrentDbVersionAsync()
|
public async Task<Version> GetCurrentDbVersionAsync()
|
||||||
{
|
{
|
||||||
var query = $"SELECT * FROM {_settings.DbVersionTableName} WHERE type = @type";
|
var query = $"SELECT * FROM {_settings.DbVersionTableName} WHERE type = @type";
|
||||||
|
@ -65,17 +65,7 @@ namespace BirdsiteLive.DAL.Postgres.DataAccessLayers
|
||||||
return _currentVersion;
|
return _currentVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Tuple<Version, Version>[] GetMigrationPatterns()
|
public async Task<Version> InitDbAsync()
|
||||||
{
|
|
||||||
return new Tuple<Version, Version>[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task MigrateDbAsync(Version from, Version to)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task InitDbAsync()
|
|
||||||
{
|
{
|
||||||
// Create version table
|
// Create version table
|
||||||
var createVersion = $@"CREATE TABLE {_settings.DbVersionTableName}
|
var createVersion = $@"CREATE TABLE {_settings.DbVersionTableName}
|
||||||
|
@ -124,14 +114,37 @@ namespace BirdsiteLive.DAL.Postgres.DataAccessLayers
|
||||||
await _tools.ExecuteRequestAsync(createCachedTweets);
|
await _tools.ExecuteRequestAsync(createCachedTweets);
|
||||||
|
|
||||||
// Insert version to db
|
// Insert version to db
|
||||||
|
var firstVersion = new Version(1, 0);
|
||||||
using (var dbConnection = Connection)
|
using (var dbConnection = Connection)
|
||||||
{
|
{
|
||||||
dbConnection.Open();
|
dbConnection.Open();
|
||||||
|
|
||||||
await dbConnection.ExecuteAsync(
|
await dbConnection.ExecuteAsync(
|
||||||
$"INSERT INTO {_settings.DbVersionTableName} (type,major,minor) VALUES(@type,@major,@minor)",
|
$"INSERT INTO {_settings.DbVersionTableName} (type,major,minor) VALUES(@type,@major,@minor)",
|
||||||
new { type = DbVersionType, major = _currentVersion.Major, minor = _currentVersion.Minor });
|
new { type = DbVersionType, major = firstVersion.Major, minor = firstVersion.Minor });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return firstVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Tuple<Version, Version>[] GetMigrationPatterns()
|
||||||
|
{
|
||||||
|
return new[]
|
||||||
|
{
|
||||||
|
new Tuple<Version, Version>(new Version(1,0), new Version(2,0))
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<Version> MigrateDbAsync(Version from, Version to)
|
||||||
|
{
|
||||||
|
if (from == new Version(1, 0) && to == new Version(2, 0))
|
||||||
|
{
|
||||||
|
var addLastSync = $@"ALTER TABLE {_settings.TwitterUserTableName} ADD lastSync TIMESTAMP (2) WITHOUT TIME ZONE";
|
||||||
|
await _tools.ExecuteRequestAsync(addLastSync);
|
||||||
|
return new Version(2, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task DeleteAllAsync()
|
public async Task DeleteAllAsync()
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
namespace BirdsiteLive.DAL.Models
|
using System;
|
||||||
|
|
||||||
|
namespace BirdsiteLive.DAL.Models
|
||||||
{
|
{
|
||||||
public class SyncTwitterUser
|
public class SyncTwitterUser
|
||||||
{
|
{
|
||||||
|
@ -7,5 +9,7 @@
|
||||||
|
|
||||||
public long LastTweetPostedId { get; set; }
|
public long LastTweetPostedId { get; set; }
|
||||||
public long LastTweetSynchronizedForAllFollowersId { get; set; }
|
public long LastTweetSynchronizedForAllFollowersId { get; set; }
|
||||||
|
|
||||||
|
public DateTime LastSync { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -35,11 +35,11 @@ namespace BirdsiteLive.DAL.Postgres.Tests.DataAccessLayers
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task InitDbAsync()
|
public async Task InitDbAsync()
|
||||||
{
|
{
|
||||||
|
var mandatory = new Version(1, 0);
|
||||||
var dal = new DbInitializerPostgresDal(_settings, _tools);
|
var dal = new DbInitializerPostgresDal(_settings, _tools);
|
||||||
|
|
||||||
await dal.InitDbAsync();
|
await dal.InitDbAsync();
|
||||||
var current = await dal.GetCurrentDbVersionAsync();
|
var current = await dal.GetCurrentDbVersionAsync();
|
||||||
var mandatory = dal.GetMandatoryDbVersion();
|
|
||||||
Assert.IsNotNull(current);
|
Assert.IsNotNull(current);
|
||||||
Assert.AreEqual(mandatory.Minor, current.Minor);
|
Assert.AreEqual(mandatory.Minor, current.Minor);
|
||||||
Assert.AreEqual(mandatory.Major, current.Major);
|
Assert.AreEqual(mandatory.Major, current.Major);
|
||||||
|
|
Loading…
Add table
Reference in a new issue