mirror of https://github.com/ppy/osu
Simplify tests
This commit is contained in:
parent
60c93d2c6d
commit
a9cbabf711
|
@ -1,6 +1,7 @@
|
|||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||
// See the LICENCE file in the repository root for full licence text.
|
||||
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NUnit.Framework;
|
||||
using osu.Game.Beatmaps;
|
||||
|
@ -20,93 +21,78 @@ public partial class TestSceneCatchReverseSelection : TestSceneEditor
|
|||
[Test]
|
||||
public void TestReverseSelectionTwoFruits()
|
||||
{
|
||||
float fruit1OldX = default;
|
||||
float fruit2OldX = default;
|
||||
CatchHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
addObjects([
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 200,
|
||||
X = fruit1OldX = 0,
|
||||
X = 0,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 400,
|
||||
X = fruit2OldX = 20,
|
||||
X = 20,
|
||||
}
|
||||
]);
|
||||
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
selectEverything();
|
||||
reverseSelection();
|
||||
|
||||
AddAssert("fruit1 is at fruit2's X",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(0).EffectiveX,
|
||||
() => Is.EqualTo(fruit2OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit2 is at fruit1's X",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(1).EffectiveX,
|
||||
() => Is.EqualTo(fruit1OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit2 is not a new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(1).NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionThreeFruits()
|
||||
{
|
||||
float fruit1OldX = default;
|
||||
float fruit2OldX = default;
|
||||
float fruit3OldX = default;
|
||||
CatchHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
addObjects([
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 200,
|
||||
X = fruit1OldX = 0,
|
||||
X = 0,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 400,
|
||||
X = fruit2OldX = 20,
|
||||
X = 20,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 600,
|
||||
X = fruit3OldX = 40,
|
||||
X = 40,
|
||||
}
|
||||
]);
|
||||
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
selectEverything();
|
||||
reverseSelection();
|
||||
|
||||
AddAssert("fruit1 is at fruit3's X",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(0).EffectiveX,
|
||||
() => Is.EqualTo(fruit3OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit2's X is unchanged",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(1).EffectiveX,
|
||||
() => Is.EqualTo(fruit2OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit3's is at fruit1's X",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(2).EffectiveX,
|
||||
() => Is.EqualTo(fruit1OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit3 is not a new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(2).NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionFruitAndJuiceStream()
|
||||
{
|
||||
CatchHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
addObjects([
|
||||
new Fruit
|
||||
{
|
||||
|
@ -128,28 +114,25 @@ public void TestReverseSelectionFruitAndJuiceStream()
|
|||
}
|
||||
]);
|
||||
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
selectEverything();
|
||||
reverseSelection();
|
||||
|
||||
AddAssert("First element is juice stream",
|
||||
() => EditorBeatmap.HitObjects.First().GetType(),
|
||||
() => Is.EqualTo(typeof(JuiceStream))
|
||||
);
|
||||
|
||||
AddAssert("Last element is fruit",
|
||||
() => EditorBeatmap.HitObjects.Last().GetType(),
|
||||
() => Is.EqualTo(typeof(Fruit))
|
||||
);
|
||||
|
||||
AddAssert("Fruit is not new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(0).NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionTwoFruitsAndJuiceStream()
|
||||
{
|
||||
CatchHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
addObjects([
|
||||
new Fruit
|
||||
{
|
||||
|
@ -176,122 +159,79 @@ public void TestReverseSelectionTwoFruitsAndJuiceStream()
|
|||
}
|
||||
]);
|
||||
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
selectEverything();
|
||||
reverseSelection();
|
||||
|
||||
AddAssert("First element is juice stream",
|
||||
() => EditorBeatmap.HitObjects.First().GetType(),
|
||||
() => Is.EqualTo(typeof(JuiceStream))
|
||||
);
|
||||
|
||||
AddAssert("Middle element is Fruit",
|
||||
() => EditorBeatmap.HitObjects.ElementAt(1).GetType(),
|
||||
() => Is.EqualTo(typeof(Fruit))
|
||||
);
|
||||
|
||||
AddAssert("Last element is Fruit",
|
||||
() => EditorBeatmap.HitObjects.Last().GetType(),
|
||||
() => Is.EqualTo(typeof(Fruit))
|
||||
);
|
||||
|
||||
AddAssert("Last fruit is not new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().Last().NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionTwoCombos()
|
||||
{
|
||||
float fruit1OldX = default;
|
||||
float fruit2OldX = default;
|
||||
float fruit3OldX = default;
|
||||
|
||||
float fruit4OldX = default;
|
||||
float fruit5OldX = default;
|
||||
float fruit6OldX = default;
|
||||
CatchHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
addObjects([
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 200,
|
||||
X = fruit1OldX = 0,
|
||||
X = 0,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 400,
|
||||
X = fruit2OldX = 20,
|
||||
X = 20,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 600,
|
||||
X = fruit3OldX = 40,
|
||||
X = 40,
|
||||
},
|
||||
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 800,
|
||||
NewCombo = true,
|
||||
X = fruit4OldX = 60,
|
||||
X = 60,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 1000,
|
||||
X = fruit5OldX = 80,
|
||||
X = 80,
|
||||
},
|
||||
new Fruit
|
||||
{
|
||||
StartTime = 1200,
|
||||
X = fruit6OldX = 100,
|
||||
X = 100,
|
||||
}
|
||||
]);
|
||||
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
selectEverything();
|
||||
reverseSelection();
|
||||
|
||||
AddAssert("fruit1 is at fruit6 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(0).EffectiveX,
|
||||
() => Is.EqualTo(fruit6OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit2 is at fruit5 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(1).EffectiveX,
|
||||
() => Is.EqualTo(fruit5OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit3 is at fruit4 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(2).EffectiveX,
|
||||
() => Is.EqualTo(fruit4OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit4 is at fruit3 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(3).EffectiveX,
|
||||
() => Is.EqualTo(fruit3OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit5 is at fruit2 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(4).EffectiveX,
|
||||
() => Is.EqualTo(fruit2OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit6 is at fruit1 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(5).EffectiveX,
|
||||
() => Is.EqualTo(fruit1OldX)
|
||||
);
|
||||
|
||||
AddAssert("fruit1 is new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(0).NewCombo,
|
||||
() => Is.EqualTo(true)
|
||||
);
|
||||
|
||||
AddAssert("fruit4 is new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<Fruit>().ElementAt(3).NewCombo,
|
||||
() => Is.EqualTo(true)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
private void addObjects(CatchHitObject[] hitObjects) => AddStep("Add objects", () => EditorBeatmap.AddRange(hitObjects));
|
||||
|
||||
private IEnumerable<CatchHitObject> getObjects() => EditorBeatmap.HitObjects.OfType<CatchHitObject>();
|
||||
|
||||
private IEnumerable<bool> getObjectNewCombos() => getObjects().Select(ho => ho.NewCombo);
|
||||
|
||||
private void selectEverything()
|
||||
{
|
||||
AddStep("Select everything", () =>
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||
// See the LICENCE file in the repository root for full licence text.
|
||||
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NUnit.Framework;
|
||||
using osu.Game.Beatmaps;
|
||||
|
@ -20,30 +21,33 @@ public partial class TestSceneOsuReverseSelection : TestSceneOsuEditor
|
|||
[Test]
|
||||
public void TestReverseSelectionTwoCircles()
|
||||
{
|
||||
Vector2 circle1OldPosition = default;
|
||||
Vector2 circle2OldPosition = default;
|
||||
OsuHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
AddStep("Add circles", () =>
|
||||
{
|
||||
var circle1 = new HitCircle
|
||||
{
|
||||
StartTime = 0,
|
||||
Position = circle1OldPosition = new Vector2(208, 240)
|
||||
Position = new Vector2(208, 240)
|
||||
};
|
||||
var circle2 = new HitCircle
|
||||
{
|
||||
StartTime = 200,
|
||||
Position = circle2OldPosition = new Vector2(256, 144)
|
||||
Position = new Vector2(256, 144)
|
||||
};
|
||||
|
||||
EditorBeatmap.AddRange([circle1, circle2]);
|
||||
});
|
||||
|
||||
AddStep("Select circles", () =>
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects);
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
AddStep("Select circles", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||
|
||||
AddStep("Reverse selection", () =>
|
||||
{
|
||||
InputManager.PressKey(Key.LControl);
|
||||
|
@ -51,55 +55,45 @@ public void TestReverseSelectionTwoCircles()
|
|||
InputManager.ReleaseKey(Key.LControl);
|
||||
});
|
||||
|
||||
AddAssert("circle1 is at circle2 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(0).Position,
|
||||
() => Is.EqualTo(circle2OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle2 is at circle1 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(1).Position,
|
||||
() => Is.EqualTo(circle1OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle2 is not a new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(1).NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionThreeCircles()
|
||||
{
|
||||
Vector2 circle1OldPosition = default;
|
||||
Vector2 circle2OldPosition = default;
|
||||
Vector2 circle3OldPosition = default;
|
||||
OsuHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
AddStep("Add circles", () =>
|
||||
{
|
||||
var circle1 = new HitCircle
|
||||
{
|
||||
StartTime = 0,
|
||||
Position = circle1OldPosition = new Vector2(208, 240)
|
||||
Position = new Vector2(208, 240)
|
||||
};
|
||||
var circle2 = new HitCircle
|
||||
{
|
||||
StartTime = 200,
|
||||
Position = circle2OldPosition = new Vector2(256, 144)
|
||||
Position = new Vector2(256, 144)
|
||||
};
|
||||
var circle3 = new HitCircle
|
||||
{
|
||||
StartTime = 400,
|
||||
Position = circle3OldPosition = new Vector2(304, 240)
|
||||
Position = new Vector2(304, 240)
|
||||
};
|
||||
|
||||
EditorBeatmap.AddRange([circle1, circle2, circle3]);
|
||||
});
|
||||
|
||||
AddStep("Select circles", () =>
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects);
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
AddStep("Select circles", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||
|
||||
AddStep("Reverse selection", () =>
|
||||
{
|
||||
InputManager.PressKey(Key.LControl);
|
||||
|
@ -107,26 +101,16 @@ public void TestReverseSelectionThreeCircles()
|
|||
InputManager.ReleaseKey(Key.LControl);
|
||||
});
|
||||
|
||||
AddAssert("circle1 is at circle3 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(0).Position,
|
||||
() => Is.EqualTo(circle3OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle3 is at circle1 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(2).Position,
|
||||
() => Is.EqualTo(circle1OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle3 is not a new combo",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(2).NewCombo,
|
||||
() => Is.EqualTo(false)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void TestReverseSelectionCircleAndSlider()
|
||||
{
|
||||
Vector2 circleOldPosition = default;
|
||||
OsuHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
Vector2 sliderHeadOldPosition = default;
|
||||
Vector2 sliderTailOldPosition = default;
|
||||
|
||||
|
@ -135,7 +119,7 @@ public void TestReverseSelectionCircleAndSlider()
|
|||
var circle = new HitCircle
|
||||
{
|
||||
StartTime = 0,
|
||||
Position = circleOldPosition = new Vector2(208, 240)
|
||||
Position = new Vector2(208, 240)
|
||||
};
|
||||
var slider = new Slider
|
||||
{
|
||||
|
@ -156,14 +140,14 @@ public void TestReverseSelectionCircleAndSlider()
|
|||
EditorBeatmap.AddRange([circle, slider]);
|
||||
});
|
||||
|
||||
AddStep("Select objects", () =>
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
var circle = (HitCircle)EditorBeatmap.HitObjects[0];
|
||||
var slider = (Slider)EditorBeatmap.HitObjects[1];
|
||||
|
||||
EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects);
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
AddStep("Select objects", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||
|
||||
AddStep("Reverse selection", () =>
|
||||
{
|
||||
InputManager.PressKey(Key.LControl);
|
||||
|
@ -171,10 +155,8 @@ public void TestReverseSelectionCircleAndSlider()
|
|||
InputManager.ReleaseKey(Key.LControl);
|
||||
});
|
||||
|
||||
AddAssert("circle is at the same position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(0).Position,
|
||||
() => Is.EqualTo(circleOldPosition)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
|
||||
AddAssert("Slider head is at slider tail", () =>
|
||||
Vector2.Distance(EditorBeatmap.HitObjects.OfType<Slider>().ElementAt(0).Position, sliderTailOldPosition) < 1);
|
||||
|
@ -186,8 +168,8 @@ public void TestReverseSelectionCircleAndSlider()
|
|||
[Test]
|
||||
public void TestReverseSelectionTwoCirclesAndSlider()
|
||||
{
|
||||
Vector2 circle1OldPosition = default;
|
||||
Vector2 circle2OldPosition = default;
|
||||
OsuHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
Vector2 sliderHeadOldPosition = default;
|
||||
Vector2 sliderTailOldPosition = default;
|
||||
|
@ -197,12 +179,12 @@ public void TestReverseSelectionTwoCirclesAndSlider()
|
|||
var circle1 = new HitCircle
|
||||
{
|
||||
StartTime = 0,
|
||||
Position = circle1OldPosition = new Vector2(208, 240)
|
||||
Position = new Vector2(208, 240)
|
||||
};
|
||||
var circle2 = new HitCircle
|
||||
{
|
||||
StartTime = 200,
|
||||
Position = circle2OldPosition = new Vector2(256, 144)
|
||||
Position = new Vector2(256, 144)
|
||||
};
|
||||
var slider = new Slider
|
||||
{
|
||||
|
@ -223,11 +205,14 @@ public void TestReverseSelectionTwoCirclesAndSlider()
|
|||
EditorBeatmap.AddRange([circle1, circle2, slider]);
|
||||
});
|
||||
|
||||
AddStep("Select objects", () =>
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects);
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
AddStep("Select objects", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||
|
||||
AddStep("Reverse selection", () =>
|
||||
{
|
||||
InputManager.PressKey(Key.LControl);
|
||||
|
@ -235,15 +220,8 @@ public void TestReverseSelectionTwoCirclesAndSlider()
|
|||
InputManager.ReleaseKey(Key.LControl);
|
||||
});
|
||||
|
||||
AddAssert("circle1 is at circle2 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(0).Position,
|
||||
() => Is.EqualTo(circle2OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle2 is at circle1 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(1).Position,
|
||||
() => Is.EqualTo(circle1OldPosition)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
|
||||
AddAssert("Slider head is at slider tail", () =>
|
||||
Vector2.Distance(EditorBeatmap.HitObjects.OfType<Slider>().ElementAt(0).Position, sliderTailOldPosition) < 1);
|
||||
|
@ -255,57 +233,55 @@ public void TestReverseSelectionTwoCirclesAndSlider()
|
|||
[Test]
|
||||
public void TestReverseSelectionTwoCombos()
|
||||
{
|
||||
Vector2 circle1OldPosition = default;
|
||||
Vector2 circle2OldPosition = default;
|
||||
Vector2 circle3OldPosition = default;
|
||||
|
||||
Vector2 circle4OldPosition = default;
|
||||
Vector2 circle5OldPosition = default;
|
||||
Vector2 circle6OldPosition = default;
|
||||
OsuHitObject[] objects = null!;
|
||||
bool[] newCombos = null!;
|
||||
|
||||
AddStep("Add circles", () =>
|
||||
{
|
||||
var circle1 = new HitCircle
|
||||
{
|
||||
StartTime = 0,
|
||||
Position = circle1OldPosition = new Vector2(216, 240)
|
||||
Position = new Vector2(216, 240)
|
||||
};
|
||||
var circle2 = new HitCircle
|
||||
{
|
||||
StartTime = 200,
|
||||
Position = circle2OldPosition = new Vector2(120, 192)
|
||||
Position = new Vector2(120, 192)
|
||||
};
|
||||
var circle3 = new HitCircle
|
||||
{
|
||||
StartTime = 400,
|
||||
Position = circle3OldPosition = new Vector2(216, 144)
|
||||
Position = new Vector2(216, 144)
|
||||
};
|
||||
|
||||
var circle4 = new HitCircle
|
||||
{
|
||||
StartTime = 646,
|
||||
NewCombo = true,
|
||||
Position = circle4OldPosition = new Vector2(296, 240)
|
||||
Position = new Vector2(296, 240)
|
||||
};
|
||||
var circle5 = new HitCircle
|
||||
{
|
||||
StartTime = 846,
|
||||
Position = circle5OldPosition = new Vector2(392, 162)
|
||||
Position = new Vector2(392, 162)
|
||||
};
|
||||
var circle6 = new HitCircle
|
||||
{
|
||||
StartTime = 1046,
|
||||
Position = circle6OldPosition = new Vector2(296, 144)
|
||||
Position = new Vector2(296, 144)
|
||||
};
|
||||
|
||||
EditorBeatmap.AddRange([circle1, circle2, circle3, circle4, circle5, circle6]);
|
||||
});
|
||||
|
||||
AddStep("Select circles", () =>
|
||||
AddStep("store objects & new combo data", () =>
|
||||
{
|
||||
EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects);
|
||||
objects = getObjects().ToArray();
|
||||
newCombos = getObjectNewCombos().ToArray();
|
||||
});
|
||||
|
||||
AddStep("Select circles", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||
|
||||
AddStep("Reverse selection", () =>
|
||||
{
|
||||
InputManager.PressKey(Key.LControl);
|
||||
|
@ -313,35 +289,12 @@ public void TestReverseSelectionTwoCombos()
|
|||
InputManager.ReleaseKey(Key.LControl);
|
||||
});
|
||||
|
||||
AddAssert("circle1 is at circle6 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(0).Position,
|
||||
() => Is.EqualTo(circle6OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle2 is at circle5 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(1).Position,
|
||||
() => Is.EqualTo(circle5OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle3 is at circle4 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(2).Position,
|
||||
() => Is.EqualTo(circle4OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle4 is at circle3 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(3).Position,
|
||||
() => Is.EqualTo(circle3OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle5 is at circle2 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(4).Position,
|
||||
() => Is.EqualTo(circle2OldPosition)
|
||||
);
|
||||
|
||||
AddAssert("circle6 is at circle1 position",
|
||||
() => EditorBeatmap.HitObjects.OfType<HitCircle>().ElementAt(5).Position,
|
||||
() => Is.EqualTo(circle1OldPosition)
|
||||
);
|
||||
AddAssert("objects reversed", getObjects, () => Is.EqualTo(objects.Reverse()));
|
||||
AddAssert("new combo positions preserved", getObjectNewCombos, () => Is.EqualTo(newCombos));
|
||||
}
|
||||
|
||||
private IEnumerable<OsuHitObject> getObjects() => EditorBeatmap.HitObjects.OfType<OsuHitObject>();
|
||||
|
||||
private IEnumerable<bool> getObjectNewCombos() => getObjects().Select(ho => ho.NewCombo);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue