mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 18:03:11 +08:00
Add protection against migrating to a nested folder
This commit is contained in:
parent
19f117ae53
commit
0690d81bbb
@ -220,6 +220,54 @@ namespace osu.Game.Tests.NonVisual
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestMigrationToNestedTargetFails()
|
||||||
|
{
|
||||||
|
using (HeadlessGameHost host = new CleanRunHeadlessGameHost(nameof(TestMigrationToSameTargetFails)))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var osu = loadOsu(host);
|
||||||
|
|
||||||
|
Assert.DoesNotThrow(() => osu.Migrate(customPath));
|
||||||
|
|
||||||
|
string subFolder = Path.Combine(customPath, "sub");
|
||||||
|
|
||||||
|
Directory.CreateDirectory(subFolder);
|
||||||
|
|
||||||
|
Assert.Throws<ArgumentException>(() => osu.Migrate(subFolder));
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
host.Exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestMigrationToSeeminglyNestedTarget()
|
||||||
|
{
|
||||||
|
using (HeadlessGameHost host = new CleanRunHeadlessGameHost(nameof(TestMigrationToSeeminglyNestedTarget)))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var osu = loadOsu(host);
|
||||||
|
|
||||||
|
Assert.DoesNotThrow(() => osu.Migrate(customPath));
|
||||||
|
|
||||||
|
string subFolder = customPath + "sub";
|
||||||
|
|
||||||
|
Directory.CreateDirectory(subFolder);
|
||||||
|
|
||||||
|
osu.Migrate(subFolder);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
host.Exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private OsuGameBase loadOsu(GameHost host)
|
private OsuGameBase loadOsu(GameHost host)
|
||||||
{
|
{
|
||||||
var osu = new OsuGameBase();
|
var osu = new OsuGameBase();
|
||||||
|
@ -48,9 +48,16 @@ namespace osu.Game.IO
|
|||||||
var source = new DirectoryInfo(GetFullPath("."));
|
var source = new DirectoryInfo(GetFullPath("."));
|
||||||
var destination = new DirectoryInfo(newLocation);
|
var destination = new DirectoryInfo(newLocation);
|
||||||
|
|
||||||
if (source.FullName == destination.FullName)
|
// using Uri is the easiest way to check equality and contains (https://stackoverflow.com/a/7710620)
|
||||||
|
var sourceUri = new Uri(source.FullName + Path.DirectorySeparatorChar);
|
||||||
|
var destinationUri = new Uri(destination.FullName + Path.DirectorySeparatorChar);
|
||||||
|
|
||||||
|
if (sourceUri == destinationUri)
|
||||||
throw new ArgumentException("Destination provided is already the current location", nameof(newLocation));
|
throw new ArgumentException("Destination provided is already the current location", nameof(newLocation));
|
||||||
|
|
||||||
|
if (sourceUri.IsBaseOf(destinationUri))
|
||||||
|
throw new ArgumentException("Destination provided is inside the source", nameof(newLocation));
|
||||||
|
|
||||||
// ensure the new location has no files present, else hard abort
|
// ensure the new location has no files present, else hard abort
|
||||||
if (destination.Exists)
|
if (destination.Exists)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user