mirror of
https://github.com/wismna/ModernKeePass.git
synced 2025-10-03 15:40:18 -04:00
Create DB works correctly
Sample data moved to application Tests updated (still not working - splat) WIP
This commit is contained in:
@@ -9,7 +9,6 @@ using ModernKeePass.Domain.Interfaces;
|
||||
using ModernKeePass.Infrastructure.KeePass;
|
||||
using NSubstitute;
|
||||
using NUnit.Framework;
|
||||
using FileInfo = ModernKeePass.Domain.Dtos.FileInfo;
|
||||
|
||||
namespace ModernKeePass.KeePassDatabaseTests
|
||||
{
|
||||
@@ -17,106 +16,99 @@ namespace ModernKeePass.KeePassDatabaseTests
|
||||
public class DatabaseTests
|
||||
{
|
||||
private IDatabaseProxy _database;
|
||||
private FileInfo _fileInfo;
|
||||
private IFileProxy _fileProxy;
|
||||
private readonly Credentials _credentials = new Credentials
|
||||
{
|
||||
Password = "test"
|
||||
};
|
||||
|
||||
|
||||
[SetUp]
|
||||
public void SetUp()
|
||||
{
|
||||
var dateTime = Substitute.For<IDateTime>();
|
||||
var fileProxy = Substitute.For<IFileProxy>();
|
||||
fileProxy.OpenBinaryFile(Arg.Any<string>()).Returns(async parameters =>
|
||||
_fileProxy = Substitute.For<IFileProxy>();
|
||||
_fileProxy.OpenBinaryFile(Arg.Any<string>()).Returns(async parameters =>
|
||||
{
|
||||
await using var stream = File.Open((string) parameters[0], FileMode.OpenOrCreate);
|
||||
var contents = new byte[stream.Length];
|
||||
await stream.ReadAsync(contents, 0, (int) stream.Length);
|
||||
return contents;
|
||||
});
|
||||
fileProxy.WriteBinaryContentsToFile(Arg.Any<string>(), Arg.Any<byte[]>()).Returns(async parameters =>
|
||||
_fileProxy.WriteBinaryContentsToFile(Arg.Any<string>(), Arg.Any<byte[]>()).Returns(async parameters =>
|
||||
{
|
||||
await using var stream = File.Open((string)parameters[0], FileMode.OpenOrCreate);
|
||||
var contents = (byte[]) parameters[1];
|
||||
await stream.WriteAsync(contents, 0, contents.Length);
|
||||
});
|
||||
var mapper = new Mapper(new MapperConfiguration(cfg => { cfg.AddProfile(typeof(EntryMappingProfile)); }));
|
||||
_database = new KeePassDatabaseClient(fileProxy, mapper, dateTime);
|
||||
_database = new KeePassDatabaseClient(mapper, dateTime);
|
||||
}
|
||||
|
||||
[TearDown]
|
||||
public void TearDown()
|
||||
{
|
||||
_database.CloseDatabase();
|
||||
if (!string.IsNullOrEmpty(_fileInfo?.Path)) File.Delete(_fileInfo.Path);
|
||||
//if (!string.IsNullOrEmpty(_fileInfo?.Path)) File.Delete(_fileInfo.Path);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task TestOpen()
|
||||
{
|
||||
var fileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx")
|
||||
};
|
||||
var file = await _fileProxy.OpenBinaryFile(Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx"));
|
||||
|
||||
var rootGroup = await _database.Open(fileInfo, _credentials);
|
||||
Assert.That(rootGroup.Name, Is.EqualTo("TestDatabase"));
|
||||
Assert.That(rootGroup.Entries.Count(), Is.EqualTo(2));
|
||||
await _database.Open(file, _credentials);
|
||||
var rootGroup = _database.GetGroup(_database.RootGroupId);
|
||||
|
||||
Assert.That(_database.Name, Is.EqualTo("TestDatabase"));
|
||||
Assert.That(rootGroup.Entries.Count, Is.EqualTo(2));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task TestCreateAndSave()
|
||||
{
|
||||
_fileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Path.GetTempPath(), "NewDatabase.kdbx")
|
||||
};
|
||||
var path = Path.Combine(Path.GetTempPath(), "NewDatabase.kdbx");
|
||||
var newFile = await _fileProxy.OpenBinaryFile(path);
|
||||
|
||||
await _database.Create(_fileInfo, _credentials);
|
||||
await _database.SaveDatabase();
|
||||
await _database.Create(newFile, _credentials);
|
||||
var result = await _database.SaveDatabase();
|
||||
await _fileProxy.WriteBinaryContentsToFile(path, result);
|
||||
_database.CloseDatabase();
|
||||
|
||||
Assert.DoesNotThrowAsync(async () => { await _database.Open(_fileInfo, _credentials); });
|
||||
Assert.DoesNotThrowAsync(async () => { await _database.Open(newFile, _credentials); });
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task TestSaveAs()
|
||||
{
|
||||
var originalFileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx")
|
||||
};
|
||||
_fileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx")
|
||||
};
|
||||
var currentPath = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx");
|
||||
var originalFile = await _fileProxy.OpenBinaryFile(Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx"));
|
||||
var currentFile = await _fileProxy.OpenBinaryFile(currentPath);
|
||||
await _database.Open(originalFile, _credentials);
|
||||
|
||||
await _database.Open(originalFileInfo, _credentials);
|
||||
await _database.SaveDatabase(_fileInfo.Path);
|
||||
var result = await _database.SaveDatabase(currentFile);
|
||||
await _fileProxy.WriteBinaryContentsToFile(currentPath, result);
|
||||
_database.CloseDatabase();
|
||||
|
||||
Assert.DoesNotThrowAsync(async () => { await _database.Open(_fileInfo, _credentials); });
|
||||
Assert.DoesNotThrowAsync(async () => { await _database.Open(currentFile, _credentials); });
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task TestAddGroup()
|
||||
{
|
||||
var originalFileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx")
|
||||
};
|
||||
_fileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx")
|
||||
};
|
||||
var currentPath = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx");
|
||||
var originalFile = await _fileProxy.OpenBinaryFile(Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx"));
|
||||
var currentFile = await _fileProxy.OpenBinaryFile(currentPath);
|
||||
var newGroup = new GroupEntity {Name = "New Group Test"};
|
||||
await _database.Open(originalFile, _credentials);
|
||||
|
||||
var rootGroup = await _database.Open(originalFileInfo, _credentials);
|
||||
await _database.AddGroup(rootGroup.Id, newGroup.Id);
|
||||
await _database.SaveDatabase(_fileInfo.Path);
|
||||
await _database.AddGroup(_database.RootGroupId, newGroup.Id);
|
||||
var result = await _database.SaveDatabase(currentFile);
|
||||
await _fileProxy.WriteBinaryContentsToFile(currentPath, result);
|
||||
_database.CloseDatabase();
|
||||
rootGroup = await _database.Open(_fileInfo, _credentials);
|
||||
|
||||
await _database.Open(currentFile, _credentials);
|
||||
var rootGroup = _database.GetGroup(_database.RootGroupId);
|
||||
|
||||
Assert.That(newGroup.Id, Is.Not.Empty);
|
||||
Assert.That(rootGroup.SubGroups.Count, Is.EqualTo(7));
|
||||
@@ -126,24 +118,22 @@ namespace ModernKeePass.KeePassDatabaseTests
|
||||
[Test]
|
||||
public async Task TestAddEntry()
|
||||
{
|
||||
var originalFileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx")
|
||||
};
|
||||
_fileInfo = new FileInfo
|
||||
{
|
||||
Path = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx")
|
||||
};
|
||||
var currentPath = Path.Combine(Path.GetTempPath(), "SavedDatabase.kdbx");
|
||||
var newEntry = new EntryEntity
|
||||
{
|
||||
Name = "New Entry Test"
|
||||
};
|
||||
var originalFile = await _fileProxy.OpenBinaryFile(Path.Combine(Directory.GetCurrentDirectory(), "Data", "TestDatabase.kdbx"));
|
||||
var currentFile = await _fileProxy.OpenBinaryFile(currentPath);
|
||||
await _database.Open(originalFile, _credentials);
|
||||
|
||||
var rootGroup = await _database.Open(originalFileInfo, _credentials);
|
||||
await _database.AddEntry(rootGroup.Id, newEntry.Id);
|
||||
await _database.SaveDatabase(_fileInfo.Path);
|
||||
await _database.AddEntry(_database.RootGroupId, newEntry.Id);
|
||||
var result = await _database.SaveDatabase(currentFile);
|
||||
await _fileProxy.WriteBinaryContentsToFile(currentPath, result);
|
||||
_database.CloseDatabase();
|
||||
rootGroup = await _database.Open(_fileInfo, _credentials);
|
||||
|
||||
await _database.Open(currentFile, _credentials);
|
||||
var rootGroup = _database.GetGroup(_database.RootGroupId);
|
||||
|
||||
Assert.That(newEntry.Id, Is.Not.Empty);
|
||||
Assert.That(rootGroup.Entries.Count, Is.EqualTo(3));
|
||||
|
Reference in New Issue
Block a user