mirror of
https://github.com/ppy/osu.git
synced 2024-12-14 15:33:05 +08:00
Add test coverage of beatmap updates transferring collection hashes
This commit is contained in:
parent
ca68574473
commit
2ae5a34c0e
@ -9,6 +9,7 @@ using System.Linq.Expressions;
|
|||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Collections;
|
||||||
using osu.Game.Database;
|
using osu.Game.Database;
|
||||||
using osu.Game.Models;
|
using osu.Game.Models;
|
||||||
using osu.Game.Overlays.Notifications;
|
using osu.Game.Overlays.Notifications;
|
||||||
@ -400,6 +401,122 @@ namespace osu.Game.Tests.Database
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// If all difficulties in the original beatmap set are in a collection, presume the user also wants new difficulties added.
|
||||||
|
/// </summary>
|
||||||
|
[TestCase(false)]
|
||||||
|
[TestCase(true)]
|
||||||
|
public void TestCollectionTransferNewBeatmap(bool allOriginalBeatmapsInCollection)
|
||||||
|
{
|
||||||
|
RunTestWithRealmAsync(async (realm, storage) =>
|
||||||
|
{
|
||||||
|
var importer = new BeatmapImporter(storage, realm);
|
||||||
|
using var rulesets = new RealmRulesetStore(realm, storage);
|
||||||
|
|
||||||
|
using var __ = getBeatmapArchive(out string pathOriginal);
|
||||||
|
using var _ = getBeatmapArchiveWithModifications(out string pathMissingOneBeatmap, directory =>
|
||||||
|
{
|
||||||
|
// remove one difficulty before first import
|
||||||
|
directory.GetFiles("*.osu").First().Delete();
|
||||||
|
});
|
||||||
|
|
||||||
|
var importBeforeUpdate = await importer.Import(new ImportTask(pathMissingOneBeatmap));
|
||||||
|
|
||||||
|
Assert.That(importBeforeUpdate, Is.Not.Null);
|
||||||
|
Debug.Assert(importBeforeUpdate != null);
|
||||||
|
|
||||||
|
int beatmapsToAddToCollection = 0;
|
||||||
|
|
||||||
|
importBeforeUpdate.PerformWrite(s =>
|
||||||
|
{
|
||||||
|
var beatmapCollection = s.Realm.Add(new BeatmapCollection("test collection"));
|
||||||
|
beatmapsToAddToCollection = s.Beatmaps.Count - (allOriginalBeatmapsInCollection ? 0 : 1);
|
||||||
|
|
||||||
|
for (int i = 0; i < beatmapsToAddToCollection; i++)
|
||||||
|
beatmapCollection.BeatmapMD5Hashes.Add(s.Beatmaps[i].MD5Hash);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Second import matches first but contains one extra .osu file.
|
||||||
|
var importAfterUpdate = await importer.ImportAsUpdate(new ProgressNotification(), new ImportTask(pathOriginal), importBeforeUpdate.Value);
|
||||||
|
|
||||||
|
Assert.That(importAfterUpdate, Is.Not.Null);
|
||||||
|
Debug.Assert(importAfterUpdate != null);
|
||||||
|
|
||||||
|
importAfterUpdate.PerformRead(updated =>
|
||||||
|
{
|
||||||
|
string[] hashes = updated.Realm.All<BeatmapCollection>().Single().BeatmapMD5Hashes.ToArray();
|
||||||
|
|
||||||
|
if (allOriginalBeatmapsInCollection)
|
||||||
|
{
|
||||||
|
Assert.That(updated.Beatmaps.Count, Is.EqualTo(beatmapsToAddToCollection + 1));
|
||||||
|
Assert.That(hashes, Has.Length.EqualTo(updated.Beatmaps.Count));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Collection contains one less than the original beatmap, and two less after update (new difficulty included).
|
||||||
|
Assert.That(updated.Beatmaps.Count, Is.EqualTo(beatmapsToAddToCollection + 2));
|
||||||
|
Assert.That(hashes, Has.Length.EqualTo(beatmapsToAddToCollection));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// If a difficulty in the original beatmap set is modified, the updated version should remain in any collections it was in.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestCollectionTransferModifiedBeatmap()
|
||||||
|
{
|
||||||
|
RunTestWithRealmAsync(async (realm, storage) =>
|
||||||
|
{
|
||||||
|
var importer = new BeatmapImporter(storage, realm);
|
||||||
|
using var rulesets = new RealmRulesetStore(realm, storage);
|
||||||
|
|
||||||
|
using var __ = getBeatmapArchive(out string pathOriginal);
|
||||||
|
using var _ = getBeatmapArchiveWithModifications(out string pathModified, directory =>
|
||||||
|
{
|
||||||
|
// Modify one .osu file with different content.
|
||||||
|
var firstOsuFile = directory.GetFiles("*[Hard]*.osu").First();
|
||||||
|
|
||||||
|
string existingContent = File.ReadAllText(firstOsuFile.FullName);
|
||||||
|
|
||||||
|
File.WriteAllText(firstOsuFile.FullName, existingContent + "\n# I am new content");
|
||||||
|
});
|
||||||
|
|
||||||
|
var importBeforeUpdate = await importer.Import(new ImportTask(pathOriginal));
|
||||||
|
|
||||||
|
Assert.That(importBeforeUpdate, Is.Not.Null);
|
||||||
|
Debug.Assert(importBeforeUpdate != null);
|
||||||
|
|
||||||
|
string originalHash = string.Empty;
|
||||||
|
|
||||||
|
importBeforeUpdate.PerformWrite(s =>
|
||||||
|
{
|
||||||
|
var beatmapCollection = s.Realm.Add(new BeatmapCollection("test collection"));
|
||||||
|
originalHash = s.Beatmaps.Single(b => b.DifficultyName == "Hard").MD5Hash;
|
||||||
|
|
||||||
|
beatmapCollection.BeatmapMD5Hashes.Add(originalHash);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Second import matches first but contains one extra .osu file.
|
||||||
|
var importAfterUpdate = await importer.ImportAsUpdate(new ProgressNotification(), new ImportTask(pathModified), importBeforeUpdate.Value);
|
||||||
|
|
||||||
|
Assert.That(importAfterUpdate, Is.Not.Null);
|
||||||
|
Debug.Assert(importAfterUpdate != null);
|
||||||
|
|
||||||
|
importAfterUpdate.PerformRead(updated =>
|
||||||
|
{
|
||||||
|
string[] hashes = updated.Realm.All<BeatmapCollection>().Single().BeatmapMD5Hashes.ToArray();
|
||||||
|
string updatedHash = updated.Beatmaps.Single(b => b.DifficultyName == "Hard").MD5Hash;
|
||||||
|
|
||||||
|
Assert.That(hashes, Has.Length.EqualTo(1));
|
||||||
|
Assert.That(hashes.First(), Is.EqualTo(updatedHash));
|
||||||
|
|
||||||
|
Assert.That(updatedHash, Is.Not.EqualTo(originalHash));
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
private static void checkCount<T>(RealmAccess realm, int expected, Expression<Func<T, bool>>? condition = null) where T : RealmObject
|
private static void checkCount<T>(RealmAccess realm, int expected, Expression<Func<T, bool>>? condition = null) where T : RealmObject
|
||||||
{
|
{
|
||||||
var query = realm.Realm.All<T>();
|
var query = realm.Realm.All<T>();
|
||||||
|
Loading…
Reference in New Issue
Block a user