osu/osu.Game.Rulesets.Osu.Tests/OsuBeatmapConversionTest.cs

75 lines
2.5 KiB
C#
Raw Normal View History

// 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.
2018-04-13 09:19:50 +00:00
using System;
using System.Collections.Generic;
using NUnit.Framework;
using osu.Framework.MathUtils;
using osu.Game.Rulesets.Objects;
using osu.Game.Rulesets.Objects.Types;
using osu.Game.Rulesets.Osu.Objects;
using osu.Game.Rulesets.Osu.UI;
2018-04-13 09:19:50 +00:00
using osu.Game.Tests.Beatmaps;
namespace osu.Game.Rulesets.Osu.Tests
{
[TestFixture]
public class OsuBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
2018-04-13 09:19:50 +00:00
{
protected override string ResourceAssembly => "osu.Game.Rulesets.Osu";
[TestCase("basic")]
[TestCase("colinear-perfect-curve")]
2018-06-13 16:28:28 +00:00
[TestCase("slider-ticks")]
2018-04-13 09:19:50 +00:00
public new void Test(string name)
{
base.Test(name);
}
protected override IEnumerable<ConvertValue> CreateConvertValue(HitObject hitObject)
{
switch (hitObject)
{
case Slider slider:
foreach (var nested in slider.NestedHitObjects)
yield return createConvertValue(nested);
2019-02-28 04:31:40 +00:00
break;
default:
yield return createConvertValue(hitObject);
2019-02-28 04:31:40 +00:00
break;
}
2018-04-13 09:19:50 +00:00
ConvertValue createConvertValue(HitObject obj) => new ConvertValue
2018-04-13 09:19:50 +00:00
{
StartTime = obj.StartTime,
EndTime = (obj as IHasEndTime)?.EndTime ?? obj.StartTime,
X = (obj as IHasPosition)?.X ?? OsuPlayfield.BASE_SIZE.X / 2,
Y = (obj as IHasPosition)?.Y ?? OsuPlayfield.BASE_SIZE.Y / 2,
2018-04-13 09:19:50 +00:00
};
}
protected override Ruleset CreateRuleset() => new OsuRuleset();
2018-04-13 09:19:50 +00:00
}
public struct ConvertValue : IEquatable<ConvertValue>
2018-04-13 09:19:50 +00:00
{
/// <summary>
/// A sane value to account for osu!stable using <see cref="int"/>s everywhere.
2018-04-13 09:19:50 +00:00
/// </summary>
private const double conversion_lenience = 2;
public double StartTime;
public double EndTime;
public float X;
public float Y;
2018-04-13 09:19:50 +00:00
public bool Equals(ConvertValue other)
=> Precision.AlmostEquals(StartTime, other.StartTime, conversion_lenience)
2018-04-13 09:19:50 +00:00
&& Precision.AlmostEquals(EndTime, other.EndTime, conversion_lenience)
&& Precision.AlmostEquals(X, other.X, conversion_lenience)
&& Precision.AlmostEquals(Y, other.Y, conversion_lenience);
2018-04-13 09:19:50 +00:00
}
}