1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-15 08:12:56 +08:00

Ensure exception is only thrown once on rollback

This commit is contained in:
Dean Herbert 2019-06-10 18:13:33 +09:00
parent dcdb806120
commit 28b2a516e3

View File

@ -11,6 +11,7 @@ using NUnit.Framework;
using osu.Framework.Platform; using osu.Framework.Platform;
using osu.Game.IPC; using osu.Game.IPC;
using osu.Framework.Allocation; using osu.Framework.Allocation;
using osu.Framework.Logging;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.IO; using osu.Game.IO;
using osu.Game.Tests.Resources; using osu.Game.Tests.Resources;
@ -96,24 +97,31 @@ namespace osu.Game.Tests.Beatmaps.IO
{ {
try try
{ {
int itemAddRemoveFireCount = 0;
int loggedExceptionCount = 0;
Logger.NewEntry += l =>
{
if (l.Target == LoggingTarget.Database && l.Exception != null)
Interlocked.Increment(ref loggedExceptionCount);
};
var osu = loadOsu(host); var osu = loadOsu(host);
var manager = osu.Dependencies.Get<BeatmapManager>(); var manager = osu.Dependencies.Get<BeatmapManager>();
var files = osu.Dependencies.Get<FileStore>(); var files = osu.Dependencies.Get<FileStore>();
int fireCount = 0;
// ReSharper disable once AccessToModifiedClosure // ReSharper disable once AccessToModifiedClosure
manager.ItemAdded += (_, __) => fireCount++; manager.ItemAdded += (_, __) => Interlocked.Increment(ref itemAddRemoveFireCount);
manager.ItemRemoved += _ => fireCount++; manager.ItemRemoved += _ => Interlocked.Increment(ref itemAddRemoveFireCount);
var imported = await LoadOszIntoOsu(osu); var imported = await LoadOszIntoOsu(osu);
Assert.AreEqual(0, fireCount -= 1); Assert.AreEqual(0, itemAddRemoveFireCount -= 1);
imported.Hash += "-changed"; imported.Hash += "-changed";
manager.Update(imported); manager.Update(imported);
Assert.AreEqual(0, fireCount -= 2); Assert.AreEqual(0, itemAddRemoveFireCount -= 2);
Assert.AreEqual(1, manager.GetAllUsableBeatmapSets().Count); Assert.AreEqual(1, manager.GetAllUsableBeatmapSets().Count);
Assert.AreEqual(1, manager.QueryBeatmapSets(_ => true).ToList().Count); Assert.AreEqual(1, manager.QueryBeatmapSets(_ => true).ToList().Count);
@ -145,7 +153,7 @@ namespace osu.Game.Tests.Beatmaps.IO
} }
// no events should be fired in the case of a rollback. // no events should be fired in the case of a rollback.
Assert.AreEqual(0, fireCount); Assert.AreEqual(0, itemAddRemoveFireCount);
Assert.AreEqual(1, manager.GetAllUsableBeatmapSets().Count); Assert.AreEqual(1, manager.GetAllUsableBeatmapSets().Count);
Assert.AreEqual(1, manager.QueryBeatmapSets(_ => true).ToList().Count); Assert.AreEqual(1, manager.QueryBeatmapSets(_ => true).ToList().Count);
@ -153,6 +161,8 @@ namespace osu.Game.Tests.Beatmaps.IO
Assert.AreEqual(18, files.QueryFiles(_ => true).Count()); Assert.AreEqual(18, files.QueryFiles(_ => true).Count());
Assert.AreEqual(18, files.QueryFiles(f => f.ReferenceCount == 1).Count()); Assert.AreEqual(18, files.QueryFiles(f => f.ReferenceCount == 1).Count());
Assert.AreEqual(1, loggedExceptionCount);
} }
finally finally
{ {