mirror of
https://github.com/ppy/osu.git
synced 2025-01-27 15:53:19 +08:00
Add basic coverage of current behaviour of beatmap reimport
This commit is contained in:
parent
068063a43a
commit
ec477a3ebf
@ -670,6 +670,61 @@ namespace osu.Game.Tests.Database
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestImportThenReimportWithNewDifficulty()
|
||||||
|
{
|
||||||
|
RunTestWithRealmAsync(async (realm, storage) =>
|
||||||
|
{
|
||||||
|
var importer = new BeatmapImporter(storage, realm);
|
||||||
|
using var store = new RealmRulesetStore(realm, storage);
|
||||||
|
|
||||||
|
string? pathOriginal = TestResources.GetTestBeatmapForImport();
|
||||||
|
|
||||||
|
string pathMissingOneBeatmap = pathOriginal.Replace(".osz", "_missing_difficulty.osz");
|
||||||
|
|
||||||
|
string extractedFolder = $"{pathOriginal}_extracted";
|
||||||
|
Directory.CreateDirectory(extractedFolder);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
using (var zip = ZipArchive.Open(pathOriginal))
|
||||||
|
zip.WriteToDirectory(extractedFolder);
|
||||||
|
|
||||||
|
// remove one difficulty before first import
|
||||||
|
new FileInfo(Directory.GetFiles(extractedFolder, "*.osu").First()).Delete();
|
||||||
|
|
||||||
|
using (var zip = ZipArchive.Create())
|
||||||
|
{
|
||||||
|
zip.AddAllFromDirectory(extractedFolder);
|
||||||
|
zip.SaveTo(pathMissingOneBeatmap, new ZipWriterOptions(CompressionType.Deflate));
|
||||||
|
}
|
||||||
|
|
||||||
|
var firstImport = await importer.Import(new ImportTask(pathMissingOneBeatmap));
|
||||||
|
Assert.That(firstImport, Is.Not.Null);
|
||||||
|
|
||||||
|
Assert.That(realm.Realm.All<BeatmapSetInfo>().Where(s => !s.DeletePending), Has.Count.EqualTo(1));
|
||||||
|
Assert.That(realm.Realm.All<BeatmapSetInfo>().First(s => !s.DeletePending).Beatmaps, Has.Count.EqualTo(11));
|
||||||
|
|
||||||
|
// Second import matches first but contains one extra .osu file.
|
||||||
|
var secondImport = await importer.Import(new ImportTask(pathOriginal));
|
||||||
|
Assert.That(secondImport, Is.Not.Null);
|
||||||
|
|
||||||
|
Assert.That(realm.Realm.All<BeatmapInfo>(), Has.Count.EqualTo(23));
|
||||||
|
Assert.That(realm.Realm.All<BeatmapSetInfo>(), Has.Count.EqualTo(2));
|
||||||
|
|
||||||
|
Assert.That(realm.Realm.All<BeatmapSetInfo>().Where(s => !s.DeletePending), Has.Count.EqualTo(1));
|
||||||
|
Assert.That(realm.Realm.All<BeatmapSetInfo>().First(s => !s.DeletePending).Beatmaps, Has.Count.EqualTo(12));
|
||||||
|
|
||||||
|
// check the newly "imported" beatmap is not the original.
|
||||||
|
Assert.That(firstImport?.ID, Is.Not.EqualTo(secondImport?.ID));
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
Directory.Delete(extractedFolder, true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestImportThenReimportAfterMissingFiles()
|
public void TestImportThenReimportAfterMissingFiles()
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user