mirror of
https://github.com/ppy/osu.git
synced 2025-01-22 22:03:21 +08:00
Merge branch 'master' into remove-macos-recommendation
This commit is contained in:
commit
c9dc6628fc
2
.github/workflows/ci.yml
vendored
2
.github/workflows/ci.yml
vendored
@ -114,7 +114,7 @@ jobs:
|
|||||||
dotnet-version: "8.0.x"
|
dotnet-version: "8.0.x"
|
||||||
|
|
||||||
- name: Install .NET workloads
|
- name: Install .NET workloads
|
||||||
run: dotnet workload install maui-android
|
run: dotnet workload install android
|
||||||
|
|
||||||
- name: Compile
|
- name: Compile
|
||||||
run: dotnet build -c Debug osu.Android.slnf
|
run: dotnet build -c Debug osu.Android.slnf
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
<EmbedAssembliesIntoApk>true</EmbedAssembliesIntoApk>
|
<EmbedAssembliesIntoApk>true</EmbedAssembliesIntoApk>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="ppy.osu.Framework.Android" Version="2024.1112.0" />
|
<PackageReference Include="ppy.osu.Framework.Android" Version="2024.1118.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<!-- Fody does not handle Android build well, and warns when unchanged.
|
<!-- Fody does not handle Android build well, and warns when unchanged.
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
<ItemGroup Label="Package References">
|
<ItemGroup Label="Package References">
|
||||||
<PackageReference Include="System.IO.Packaging" Version="8.0.1" />
|
<PackageReference Include="System.IO.Packaging" Version="8.0.1" />
|
||||||
<PackageReference Include="DiscordRichPresence" Version="1.2.1.24" />
|
<PackageReference Include="DiscordRichPresence" Version="1.2.1.24" />
|
||||||
<PackageReference Include="Velopack" Version="0.0.869" />
|
<PackageReference Include="Velopack" Version="0.0.915" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Label="Resources">
|
<ItemGroup Label="Resources">
|
||||||
<EmbeddedResource Include="lazer.ico" />
|
<EmbeddedResource Include="lazer.ico" />
|
||||||
|
@ -29,7 +29,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -59,7 +59,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -99,7 +99,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
Mod = new CatchModRelax(),
|
Mod = new CatchModRelax(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
PassCondition = passCondition,
|
PassCondition = passCondition,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -24,7 +24,7 @@ namespace osu.Game.Rulesets.Catch.Tests
|
|||||||
{
|
{
|
||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -10,7 +10,7 @@ namespace osu.Game.Rulesets.Catch.Edit
|
|||||||
{
|
{
|
||||||
public partial class CatchDistanceSnapProvider : ComposerDistanceSnapProvider
|
public partial class CatchDistanceSnapProvider : ComposerDistanceSnapProvider
|
||||||
{
|
{
|
||||||
protected override double ReadCurrentDistanceSnap(HitObject before, HitObject after)
|
public override double ReadCurrentDistanceSnap(HitObject before, HitObject after)
|
||||||
{
|
{
|
||||||
// osu!catch's distance snap implementation is limited, in that a custom spacing cannot be specified.
|
// osu!catch's distance snap implementation is limited, in that a custom spacing cannot be specified.
|
||||||
// Therefore this functionality is not currently used.
|
// Therefore this functionality is not currently used.
|
||||||
|
@ -70,6 +70,8 @@ namespace osu.Game.Rulesets.Catch.Edit
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override Drawable CreateHitObjectInspector() => new CatchHitObjectInspector(DistanceSnapProvider);
|
||||||
|
|
||||||
protected override IEnumerable<TernaryButton> CreateTernaryButtons()
|
protected override IEnumerable<TernaryButton> CreateTernaryButtons()
|
||||||
=> base.CreateTernaryButtons()
|
=> base.CreateTernaryButtons()
|
||||||
.Concat(DistanceSnapProvider.CreateTernaryButtons());
|
.Concat(DistanceSnapProvider.CreateTernaryButtons());
|
||||||
|
41
osu.Game.Rulesets.Catch/Edit/CatchHitObjectInspector.cs
Normal file
41
osu.Game.Rulesets.Catch/Edit/CatchHitObjectInspector.cs
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// 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.Linq;
|
||||||
|
using osu.Game.Rulesets.Catch.Objects;
|
||||||
|
using osu.Game.Rulesets.Objects;
|
||||||
|
using osu.Game.Screens.Edit.Compose.Components;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Catch.Edit
|
||||||
|
{
|
||||||
|
public partial class CatchHitObjectInspector(CatchDistanceSnapProvider snapProvider) : HitObjectInspector
|
||||||
|
{
|
||||||
|
protected override void AddInspectorValues(HitObject[] objects)
|
||||||
|
{
|
||||||
|
base.AddInspectorValues(objects);
|
||||||
|
|
||||||
|
if (objects.Length > 0)
|
||||||
|
{
|
||||||
|
HitObject firstSelectedHitObject = objects.MinBy(ho => ho.StartTime)!;
|
||||||
|
HitObject lastSelectedHitObject = objects.MaxBy(ho => ho.GetEndTime())!;
|
||||||
|
|
||||||
|
HitObject? precedingObject = EditorBeatmap.HitObjects.LastOrDefault(ho => ho.GetEndTime() < firstSelectedHitObject.StartTime);
|
||||||
|
HitObject? nextObject = EditorBeatmap.HitObjects.FirstOrDefault(ho => ho.StartTime > lastSelectedHitObject.GetEndTime());
|
||||||
|
|
||||||
|
if (precedingObject != null && precedingObject is not BananaShower)
|
||||||
|
{
|
||||||
|
double previousSnap = snapProvider.ReadCurrentDistanceSnap(precedingObject, firstSelectedHitObject);
|
||||||
|
AddHeader("To previous");
|
||||||
|
AddValue($"{previousSnap:#,0.##}x");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nextObject != null && nextObject is not BananaShower)
|
||||||
|
{
|
||||||
|
double nextSnap = snapProvider.ReadCurrentDistanceSnap(lastSelectedHitObject, nextObject);
|
||||||
|
AddHeader("To next");
|
||||||
|
AddValue($"{nextSnap:#,0.##}x");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,7 @@ using System.Linq;
|
|||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Rulesets.Mania.Edit.Blueprints;
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
using osu.Game.Rulesets.Mania.UI;
|
using osu.Game.Rulesets.Mania.UI;
|
||||||
using osu.Game.Screens.Edit.Compose.Components;
|
using osu.Game.Screens.Edit.Compose.Components;
|
||||||
@ -106,7 +107,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Editor
|
|||||||
AddStep("select everything", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
AddStep("select everything", () => EditorBeatmap.SelectedHitObjects.AddRange(EditorBeatmap.HitObjects));
|
||||||
AddStep("start drag", () =>
|
AddStep("start drag", () =>
|
||||||
{
|
{
|
||||||
InputManager.MoveMouseTo(this.ChildrenOfType<Column>().First());
|
InputManager.MoveMouseTo(this.ChildrenOfType<NoteSelectionBlueprint>().Single(blueprint => blueprint.IsSelected && blueprint.HitObject.StartTime == 0));
|
||||||
InputManager.PressButton(MouseButton.Left);
|
InputManager.PressButton(MouseButton.Left);
|
||||||
});
|
});
|
||||||
AddStep("end drag", () =>
|
AddStep("end drag", () =>
|
||||||
|
39
osu.Game.Rulesets.Mania.Tests/ManiaScoreProcessorTest.cs
Normal file
39
osu.Game.Rulesets.Mania.Tests/ManiaScoreProcessorTest.cs
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
// 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 NUnit.Framework;
|
||||||
|
using osu.Game.Rulesets.Mania.Scoring;
|
||||||
|
using osu.Game.Rulesets.Scoring;
|
||||||
|
using osu.Game.Scoring;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Mania.Tests
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class ManiaScoreProcessorTest
|
||||||
|
{
|
||||||
|
[TestCase(ScoreRank.X, 1, HitResult.Perfect)]
|
||||||
|
[TestCase(ScoreRank.X, 0.99, HitResult.Great)]
|
||||||
|
[TestCase(ScoreRank.D, 0.1, HitResult.Great)]
|
||||||
|
[TestCase(ScoreRank.X, 0.99, HitResult.Perfect, HitResult.Great)]
|
||||||
|
[TestCase(ScoreRank.X, 0.99, HitResult.Great, HitResult.Great)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Perfect, HitResult.Good)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Perfect, HitResult.Ok)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Perfect, HitResult.Meh)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Perfect, HitResult.Miss)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Great, HitResult.Good)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Great, HitResult.Ok)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Great, HitResult.Meh)]
|
||||||
|
[TestCase(ScoreRank.S, 0.99, HitResult.Great, HitResult.Miss)]
|
||||||
|
public void TestRanks(ScoreRank expected, double accuracy, params HitResult[] results)
|
||||||
|
{
|
||||||
|
var scoreProcessor = new ManiaScoreProcessor();
|
||||||
|
|
||||||
|
Dictionary<HitResult, int> resultsDict = new Dictionary<HitResult, int>();
|
||||||
|
foreach (var result in results)
|
||||||
|
resultsDict[result] = resultsDict.GetValueOrDefault(result) + 1;
|
||||||
|
|
||||||
|
Assert.That(scoreProcessor.RankFromScore(accuracy, resultsDict), Is.EqualTo(expected));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -19,7 +19,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new ManiaBeatmap(new StageDefinition(1))
|
CreateBeatmap = () => new ManiaBeatmap(new StageDefinition(1))
|
||||||
{
|
{
|
||||||
HitObjects = new List<ManiaHitObject>
|
HitObjects = new List<ManiaHitObject>
|
||||||
{
|
{
|
||||||
|
@ -29,7 +29,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
&& Precision.AlmostEquals(Player.ScoreProcessor.Accuracy.Value, 0.9836, 0.01)
|
&& Precision.AlmostEquals(Player.ScoreProcessor.Accuracy.Value, 0.9836, 0.01)
|
||||||
&& Player.ScoreProcessor.TotalScore.Value == 946_049,
|
&& Player.ScoreProcessor.TotalScore.Value == 946_049,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
||||||
Difficulty = { OverallDifficulty = 10 },
|
Difficulty = { OverallDifficulty = 10 },
|
||||||
@ -56,7 +56,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
&& Player.ScoreProcessor.Accuracy.Value == 1
|
&& Player.ScoreProcessor.Accuracy.Value == 1
|
||||||
&& Player.ScoreProcessor.TotalScore.Value == (long)(1_000_000 * doubleTime.ScoreMultiplier),
|
&& Player.ScoreProcessor.TotalScore.Value == (long)(1_000_000 * doubleTime.ScoreMultiplier),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
||||||
Difficulty = { OverallDifficulty = 10 },
|
Difficulty = { OverallDifficulty = 10 },
|
||||||
|
@ -74,7 +74,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new ManiaModHidden(),
|
Mod = new ManiaModHidden(),
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
||||||
Breaks = { new BreakPeriod(2000, 28000) }
|
Breaks = { new BreakPeriod(2000, 28000) }
|
||||||
|
@ -74,7 +74,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new ManiaModHidden(),
|
Mod = new ManiaModHidden(),
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
||||||
Breaks = { new BreakPeriod(2000, 28000) }
|
Breaks = { new BreakPeriod(2000, 28000) }
|
||||||
|
@ -36,7 +36,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModPerfect(),
|
Mod = new ManiaModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -59,7 +59,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModPerfect(),
|
Mod = new ManiaModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModSuddenDeath(),
|
Mod = new ManiaModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -51,7 +51,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModSuddenDeath(),
|
Mod = new ManiaModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -3,21 +3,39 @@
|
|||||||
|
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Rulesets.Mania.Skinning.Default;
|
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
||||||
{
|
{
|
||||||
public partial class EditBodyPiece : DefaultBodyPiece
|
public partial class EditBodyPiece : CompositeDrawable
|
||||||
{
|
{
|
||||||
|
private readonly Container border;
|
||||||
|
|
||||||
|
public EditBodyPiece()
|
||||||
|
{
|
||||||
|
InternalChildren = new Drawable[]
|
||||||
|
{
|
||||||
|
border = new Container
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Masking = true,
|
||||||
|
BorderThickness = 3,
|
||||||
|
Child = new Box
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Alpha = 0,
|
||||||
|
AlwaysPresent = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(OsuColour colours)
|
private void load(OsuColour colours)
|
||||||
{
|
{
|
||||||
AccentColour.Value = colours.Yellow;
|
border.BorderColour = colours.YellowDarker;
|
||||||
|
|
||||||
Background.Alpha = 0.5f;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override Drawable CreateForeground() => base.CreateForeground().With(d => d.Alpha = 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Extensions.Color4Extensions;
|
using osu.Framework.Extensions.Color4Extensions;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
@ -26,10 +27,11 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
|||||||
{
|
{
|
||||||
Height = DefaultNotePiece.NOTE_HEIGHT;
|
Height = DefaultNotePiece.NOTE_HEIGHT;
|
||||||
|
|
||||||
CornerRadius = 5;
|
InternalChild = new EditNotePiece
|
||||||
Masking = true;
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
InternalChild = new DefaultNotePiece();
|
Height = 1,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void LoadComplete()
|
protected override void LoadComplete()
|
||||||
@ -60,19 +62,23 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
|||||||
{
|
{
|
||||||
base.OnDrag(e);
|
base.OnDrag(e);
|
||||||
Dragging?.Invoke(e.ScreenSpaceMousePosition);
|
Dragging?.Invoke(e.ScreenSpaceMousePosition);
|
||||||
|
updateState();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnDragEnd(DragEndEvent e)
|
protected override void OnDragEnd(DragEndEvent e)
|
||||||
{
|
{
|
||||||
base.OnDragEnd(e);
|
base.OnDragEnd(e);
|
||||||
DragEnded?.Invoke();
|
DragEnded?.Invoke();
|
||||||
|
updateState();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateState()
|
private void updateState()
|
||||||
{
|
{
|
||||||
|
InternalChild.Colour = Colour4.White;
|
||||||
|
|
||||||
var colour = colours.Yellow;
|
var colour = colours.Yellow;
|
||||||
|
|
||||||
if (IsHovered)
|
if (IsHovered || IsDragged)
|
||||||
colour = colour.Lighten(1);
|
colour = colour.Lighten(1);
|
||||||
|
|
||||||
Colour = colour;
|
Colour = colour;
|
||||||
|
@ -2,28 +2,63 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Rulesets.Mania.Skinning.Default;
|
using osu.Game.Rulesets.Mania.UI;
|
||||||
|
using osu.Game.Rulesets.UI.Scrolling;
|
||||||
|
using osuTK;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
namespace osu.Game.Rulesets.Mania.Edit.Blueprints.Components
|
||||||
{
|
{
|
||||||
public partial class EditNotePiece : CompositeDrawable
|
public partial class EditNotePiece : CompositeDrawable
|
||||||
{
|
{
|
||||||
|
private readonly Container border;
|
||||||
|
private readonly Box box;
|
||||||
|
|
||||||
|
[Resolved]
|
||||||
|
private Column? column { get; set; }
|
||||||
|
|
||||||
public EditNotePiece()
|
public EditNotePiece()
|
||||||
{
|
{
|
||||||
Height = DefaultNotePiece.NOTE_HEIGHT;
|
InternalChildren = new Drawable[]
|
||||||
|
{
|
||||||
CornerRadius = 5;
|
border = new Container
|
||||||
Masking = true;
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
InternalChild = new DefaultNotePiece();
|
Masking = true,
|
||||||
|
BorderThickness = 3,
|
||||||
|
Child = new Box
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Alpha = 0,
|
||||||
|
AlwaysPresent = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
box = new Box
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Height = 3,
|
||||||
|
Anchor = Anchor.BottomCentre,
|
||||||
|
Origin = Anchor.BottomCentre,
|
||||||
|
},
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(OsuColour colours)
|
private void load(OsuColour colours)
|
||||||
{
|
{
|
||||||
Colour = colours.Yellow;
|
border.BorderColour = colours.YellowDark;
|
||||||
|
box.Colour = colours.YellowLight;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Update()
|
||||||
|
{
|
||||||
|
base.Update();
|
||||||
|
|
||||||
|
if (column != null)
|
||||||
|
Scale = new Vector2(1, column.ScrollingInfo.Direction.Value == ScrollingDirection.Down ? 1 : -1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,8 +4,10 @@
|
|||||||
using System;
|
using System;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
using osu.Framework.Utils;
|
using osu.Framework.Utils;
|
||||||
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
@ -17,9 +19,9 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
{
|
{
|
||||||
public partial class HoldNotePlacementBlueprint : ManiaPlacementBlueprint<HoldNote>
|
public partial class HoldNotePlacementBlueprint : ManiaPlacementBlueprint<HoldNote>
|
||||||
{
|
{
|
||||||
private readonly EditBodyPiece bodyPiece;
|
private EditBodyPiece bodyPiece = null!;
|
||||||
private readonly EditNotePiece headPiece;
|
private Circle headPiece = null!;
|
||||||
private readonly EditNotePiece tailPiece;
|
private Circle tailPiece = null!;
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private IScrollingInfo scrollingInfo { get; set; } = null!;
|
private IScrollingInfo scrollingInfo { get; set; } = null!;
|
||||||
@ -28,14 +30,29 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
|
|
||||||
public HoldNotePlacementBlueprint()
|
public HoldNotePlacementBlueprint()
|
||||||
: base(new HoldNote())
|
: base(new HoldNote())
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuColour colours)
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both;
|
RelativeSizeAxes = Axes.Both;
|
||||||
|
|
||||||
InternalChildren = new Drawable[]
|
InternalChildren = new Drawable[]
|
||||||
{
|
{
|
||||||
bodyPiece = new EditBodyPiece { Origin = Anchor.TopCentre },
|
bodyPiece = new EditBodyPiece { Origin = Anchor.TopCentre },
|
||||||
headPiece = new EditNotePiece { Origin = Anchor.Centre },
|
headPiece = new Circle
|
||||||
tailPiece = new EditNotePiece { Origin = Anchor.Centre }
|
{
|
||||||
|
Origin = Anchor.Centre,
|
||||||
|
Colour = colours.Yellow,
|
||||||
|
Height = 10
|
||||||
|
},
|
||||||
|
tailPiece = new Circle
|
||||||
|
{
|
||||||
|
Origin = Anchor.Centre,
|
||||||
|
Colour = colours.Yellow,
|
||||||
|
Height = 10
|
||||||
|
},
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Graphics.Primitives;
|
using osu.Framework.Graphics.Primitives;
|
||||||
using osu.Framework.Graphics.Shapes;
|
|
||||||
using osu.Game.Graphics;
|
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
|
using osu.Game.Rulesets.Mania.Objects.Drawables;
|
||||||
|
using osu.Game.Rulesets.UI.Scrolling;
|
||||||
using osu.Game.Screens.Edit;
|
using osu.Game.Screens.Edit;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
|
|
||||||
@ -17,9 +17,6 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
{
|
{
|
||||||
public partial class HoldNoteSelectionBlueprint : ManiaSelectionBlueprint<HoldNote>
|
public partial class HoldNoteSelectionBlueprint : ManiaSelectionBlueprint<HoldNote>
|
||||||
{
|
{
|
||||||
[Resolved]
|
|
||||||
private OsuColour colours { get; set; } = null!;
|
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private IEditorChangeHandler? changeHandler { get; set; }
|
private IEditorChangeHandler? changeHandler { get; set; }
|
||||||
|
|
||||||
@ -29,9 +26,12 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
[Resolved]
|
[Resolved]
|
||||||
private IPositionSnapProvider? positionSnapProvider { get; set; }
|
private IPositionSnapProvider? positionSnapProvider { get; set; }
|
||||||
|
|
||||||
|
private EditBodyPiece body = null!;
|
||||||
private EditHoldNoteEndPiece head = null!;
|
private EditHoldNoteEndPiece head = null!;
|
||||||
private EditHoldNoteEndPiece tail = null!;
|
private EditHoldNoteEndPiece tail = null!;
|
||||||
|
|
||||||
|
protected new DrawableHoldNote DrawableObject => (DrawableHoldNote)base.DrawableObject;
|
||||||
|
|
||||||
public HoldNoteSelectionBlueprint(HoldNote hold)
|
public HoldNoteSelectionBlueprint(HoldNote hold)
|
||||||
: base(hold)
|
: base(hold)
|
||||||
{
|
{
|
||||||
@ -42,9 +42,17 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
{
|
{
|
||||||
InternalChildren = new Drawable[]
|
InternalChildren = new Drawable[]
|
||||||
{
|
{
|
||||||
|
body = new EditBodyPiece
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Anchor = Anchor.BottomCentre,
|
||||||
|
Origin = Anchor.BottomCentre,
|
||||||
|
},
|
||||||
head = new EditHoldNoteEndPiece
|
head = new EditHoldNoteEndPiece
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.X,
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Anchor = Anchor.BottomCentre,
|
||||||
|
Origin = Anchor.BottomCentre,
|
||||||
DragStarted = () => changeHandler?.BeginChange(),
|
DragStarted = () => changeHandler?.BeginChange(),
|
||||||
Dragging = pos =>
|
Dragging = pos =>
|
||||||
{
|
{
|
||||||
@ -64,6 +72,8 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
tail = new EditHoldNoteEndPiece
|
tail = new EditHoldNoteEndPiece
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.X,
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Anchor = Anchor.BottomCentre,
|
||||||
|
Origin = Anchor.BottomCentre,
|
||||||
DragStarted = () => changeHandler?.BeginChange(),
|
DragStarted = () => changeHandler?.BeginChange(),
|
||||||
Dragging = pos =>
|
Dragging = pos =>
|
||||||
{
|
{
|
||||||
@ -79,19 +89,6 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
},
|
},
|
||||||
DragEnded = () => changeHandler?.EndChange(),
|
DragEnded = () => changeHandler?.EndChange(),
|
||||||
},
|
},
|
||||||
new Container
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Masking = true,
|
|
||||||
BorderThickness = 1,
|
|
||||||
BorderColour = colours.Yellow,
|
|
||||||
Child = new Box
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Alpha = 0,
|
|
||||||
AlwaysPresent = true,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,11 +96,23 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
|
||||||
|
head.Height = DrawableObject.Head.DrawHeight;
|
||||||
head.Y = HitObjectContainer.PositionAtTime(HitObject.Head.StartTime, HitObject.StartTime);
|
head.Y = HitObjectContainer.PositionAtTime(HitObject.Head.StartTime, HitObject.StartTime);
|
||||||
|
tail.Height = DrawableObject.Tail.DrawHeight;
|
||||||
tail.Y = HitObjectContainer.PositionAtTime(HitObject.Tail.StartTime, HitObject.StartTime);
|
tail.Y = HitObjectContainer.PositionAtTime(HitObject.Tail.StartTime, HitObject.StartTime);
|
||||||
Height = HitObjectContainer.LengthAtTime(HitObject.StartTime, HitObject.EndTime) + tail.DrawHeight;
|
Height = HitObjectContainer.LengthAtTime(HitObject.StartTime, HitObject.EndTime) + tail.DrawHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void OnDirectionChanged(ValueChangedEvent<ScrollingDirection> direction)
|
||||||
|
{
|
||||||
|
Origin = direction.NewValue == ScrollingDirection.Down ? Anchor.BottomCentre : Anchor.TopCentre;
|
||||||
|
|
||||||
|
foreach (var child in InternalChildren)
|
||||||
|
child.Anchor = Origin;
|
||||||
|
|
||||||
|
head.Scale = tail.Scale = body.Scale = new Vector2(1, direction.NewValue == ScrollingDirection.Down ? 1 : -1);
|
||||||
|
}
|
||||||
|
|
||||||
public override Quad SelectionQuad => ScreenSpaceDrawQuad;
|
public override Quad SelectionQuad => ScreenSpaceDrawQuad;
|
||||||
|
|
||||||
public override Vector2 ScreenSpaceSelectionPoint => head.ScreenSpaceDrawQuad.Centre;
|
public override Vector2 ScreenSpaceSelectionPoint => head.ScreenSpaceDrawQuad.Centre;
|
||||||
|
@ -37,16 +37,10 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
protected override void LoadComplete()
|
protected override void LoadComplete()
|
||||||
{
|
{
|
||||||
base.LoadComplete();
|
base.LoadComplete();
|
||||||
directionBindable.BindValueChanged(onDirectionChanged, true);
|
directionBindable.BindValueChanged(OnDirectionChanged, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onDirectionChanged(ValueChangedEvent<ScrollingDirection> direction)
|
protected abstract void OnDirectionChanged(ValueChangedEvent<ScrollingDirection> direction);
|
||||||
{
|
|
||||||
var anchor = direction.NewValue == ScrollingDirection.Up ? Anchor.TopCentre : Anchor.BottomCentre;
|
|
||||||
Anchor = Origin = anchor;
|
|
||||||
foreach (var child in InternalChildren)
|
|
||||||
child.Anchor = child.Origin = anchor;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Update()
|
protected override void Update()
|
||||||
{
|
{
|
||||||
|
@ -1,10 +1,12 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
using osuTK.Input;
|
using osuTK.Input;
|
||||||
|
|
||||||
@ -12,14 +14,25 @@ namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
|||||||
{
|
{
|
||||||
public partial class NotePlacementBlueprint : ManiaPlacementBlueprint<Note>
|
public partial class NotePlacementBlueprint : ManiaPlacementBlueprint<Note>
|
||||||
{
|
{
|
||||||
private readonly EditNotePiece piece;
|
private Circle piece = null!;
|
||||||
|
|
||||||
public NotePlacementBlueprint()
|
public NotePlacementBlueprint()
|
||||||
: base(new Note())
|
: base(new Note())
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both;
|
}
|
||||||
|
|
||||||
InternalChild = piece = new EditNotePiece { Origin = Anchor.Centre };
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuColour colours)
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both;
|
||||||
|
Masking = true;
|
||||||
|
|
||||||
|
InternalChild = piece = new Circle
|
||||||
|
{
|
||||||
|
Origin = Anchor.Centre,
|
||||||
|
Colour = colours.Yellow,
|
||||||
|
Height = 10
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void UpdateTimeAndPosition(SnapResult result)
|
public override void UpdateTimeAndPosition(SnapResult result)
|
||||||
|
@ -1,18 +1,42 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
using osu.Game.Rulesets.Mania.Edit.Blueprints.Components;
|
||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
|
using osu.Game.Rulesets.UI.Scrolling;
|
||||||
|
using osuTK;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
namespace osu.Game.Rulesets.Mania.Edit.Blueprints
|
||||||
{
|
{
|
||||||
public partial class NoteSelectionBlueprint : ManiaSelectionBlueprint<Note>
|
public partial class NoteSelectionBlueprint : ManiaSelectionBlueprint<Note>
|
||||||
{
|
{
|
||||||
|
private readonly EditNotePiece notePiece;
|
||||||
|
|
||||||
public NoteSelectionBlueprint(Note note)
|
public NoteSelectionBlueprint(Note note)
|
||||||
: base(note)
|
: base(note)
|
||||||
{
|
{
|
||||||
AddInternal(new EditNotePiece { RelativeSizeAxes = Axes.X });
|
Anchor = Anchor.BottomCentre;
|
||||||
|
Origin = Anchor.BottomCentre;
|
||||||
|
AddInternal(notePiece = new EditNotePiece
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Anchor = Anchor.BottomCentre,
|
||||||
|
Origin = Anchor.BottomCentre,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Update()
|
||||||
|
{
|
||||||
|
base.Update();
|
||||||
|
|
||||||
|
notePiece.Height = DrawableObject.DrawHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnDirectionChanged(ValueChangedEvent<ScrollingDirection> direction)
|
||||||
|
{
|
||||||
|
notePiece.Scale = new Vector2(1, direction.NewValue == ScrollingDirection.Down ? 1 : -1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
45
osu.Game.Rulesets.Mania/Edit/EditorColumn.cs
Normal file
45
osu.Game.Rulesets.Mania/Edit/EditorColumn.cs
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
// 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 osu.Framework.Graphics;
|
||||||
|
using osu.Game.Rulesets.Mania.Objects.Drawables;
|
||||||
|
using osu.Game.Rulesets.Mania.UI;
|
||||||
|
using osu.Game.Rulesets.Objects.Drawables;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Mania.Edit
|
||||||
|
{
|
||||||
|
public partial class EditorColumn : Column
|
||||||
|
{
|
||||||
|
public EditorColumn(int index, bool isSpecial)
|
||||||
|
: base(index, isSpecial)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnNewDrawableHitObject(DrawableHitObject drawableHitObject)
|
||||||
|
{
|
||||||
|
base.OnNewDrawableHitObject(drawableHitObject);
|
||||||
|
drawableHitObject.ApplyCustomUpdateState += (dho, state) =>
|
||||||
|
{
|
||||||
|
switch (dho)
|
||||||
|
{
|
||||||
|
// hold note heads are exempt from what follows due to the "freezing" mechanic
|
||||||
|
// which already ensures they'll never fade away on their own.
|
||||||
|
case DrawableHoldNoteHead:
|
||||||
|
break;
|
||||||
|
|
||||||
|
// mania features instantaneous hitobject fade-outs.
|
||||||
|
// this means that without manual intervention stopping the clock at the precise time of hitting the object
|
||||||
|
// means the object will fade out.
|
||||||
|
// this is anti-user in editor contexts, as the user is expecting to continue the see the note on the receptor line.
|
||||||
|
// therefore, apply a crude workaround to prevent it from going away.
|
||||||
|
default:
|
||||||
|
{
|
||||||
|
if (state == ArmedState.Hit)
|
||||||
|
dho.FadeTo(1).Delay(1).FadeOut().Expire();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
osu.Game.Rulesets.Mania/Edit/EditorStage.cs
Normal file
18
osu.Game.Rulesets.Mania/Edit/EditorStage.cs
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
// 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 osu.Game.Rulesets.Mania.Beatmaps;
|
||||||
|
using osu.Game.Rulesets.Mania.UI;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Mania.Edit
|
||||||
|
{
|
||||||
|
public partial class EditorStage : Stage
|
||||||
|
{
|
||||||
|
public EditorStage(int firstColumnIndex, StageDefinition definition, ref ManiaAction columnStartAction)
|
||||||
|
: base(firstColumnIndex, definition, ref columnStartAction)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override Column CreateColumn(int index, bool isSpecial) => new EditorColumn(index, isSpecial);
|
||||||
|
}
|
||||||
|
}
|
@ -13,5 +13,8 @@ namespace osu.Game.Rulesets.Mania.Edit
|
|||||||
: base(stages)
|
: base(stages)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override Stage CreateStage(int firstColumnIndex, StageDefinition stageDefinition, ref ManiaAction columnAction)
|
||||||
|
=> new EditorStage(firstColumnIndex, stageDefinition, ref columnAction);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ using osu.Game.Rulesets.Judgements;
|
|||||||
using osu.Game.Rulesets.Mania.Objects;
|
using osu.Game.Rulesets.Mania.Objects;
|
||||||
using osu.Game.Rulesets.Objects;
|
using osu.Game.Rulesets.Objects;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
|
using osu.Game.Scoring;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mania.Scoring
|
namespace osu.Game.Rulesets.Mania.Scoring
|
||||||
{
|
{
|
||||||
@ -58,6 +59,24 @@ namespace osu.Game.Rulesets.Mania.Scoring
|
|||||||
return GetBaseScoreForResult(result);
|
return GetBaseScoreForResult(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override ScoreRank RankFromScore(double accuracy, IReadOnlyDictionary<HitResult, int> results)
|
||||||
|
{
|
||||||
|
ScoreRank rank = base.RankFromScore(accuracy, results);
|
||||||
|
|
||||||
|
if (rank != ScoreRank.S)
|
||||||
|
return rank;
|
||||||
|
|
||||||
|
// SS is expected as long as all hitobjects have been hit with either a GREAT or PERFECT result.
|
||||||
|
|
||||||
|
bool anyImperfect =
|
||||||
|
results.GetValueOrDefault(HitResult.Good) > 0
|
||||||
|
|| results.GetValueOrDefault(HitResult.Ok) > 0
|
||||||
|
|| results.GetValueOrDefault(HitResult.Meh) > 0
|
||||||
|
|| results.GetValueOrDefault(HitResult.Miss) > 0;
|
||||||
|
|
||||||
|
return anyImperfect ? rank : ScoreRank.X;
|
||||||
|
}
|
||||||
|
|
||||||
private class JudgementOrderComparer : IComparer<HitObject>
|
private class JudgementOrderComparer : IComparer<HitObject>
|
||||||
{
|
{
|
||||||
public static readonly JudgementOrderComparer DEFAULT = new JudgementOrderComparer();
|
public static readonly JudgementOrderComparer DEFAULT = new JudgementOrderComparer();
|
||||||
|
@ -7,6 +7,7 @@ using osu.Framework.Graphics;
|
|||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using JetBrains.Annotations;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Graphics.Primitives;
|
using osu.Framework.Graphics.Primitives;
|
||||||
using osu.Game.Rulesets.Mania.Beatmaps;
|
using osu.Game.Rulesets.Mania.Beatmaps;
|
||||||
@ -71,7 +72,7 @@ namespace osu.Game.Rulesets.Mania.UI
|
|||||||
|
|
||||||
for (int i = 0; i < stageDefinitions.Count; i++)
|
for (int i = 0; i < stageDefinitions.Count; i++)
|
||||||
{
|
{
|
||||||
var newStage = new Stage(firstColumnIndex, stageDefinitions[i], ref columnAction);
|
var newStage = CreateStage(firstColumnIndex, stageDefinitions[i], ref columnAction);
|
||||||
|
|
||||||
playfieldGrid.Content[0][i] = newStage;
|
playfieldGrid.Content[0][i] = newStage;
|
||||||
|
|
||||||
@ -82,6 +83,9 @@ namespace osu.Game.Rulesets.Mania.UI
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Pure]
|
||||||
|
protected virtual Stage CreateStage(int firstColumnIndex, StageDefinition stageDefinition, ref ManiaAction columnAction) => new Stage(firstColumnIndex, stageDefinition, ref columnAction);
|
||||||
|
|
||||||
public override void Add(HitObject hitObject) => getStageByColumn(((ManiaHitObject)hitObject).Column).Add(hitObject);
|
public override void Add(HitObject hitObject) => getStageByColumn(((ManiaHitObject)hitObject).Column).Add(hitObject);
|
||||||
|
|
||||||
public override bool Remove(HitObject hitObject) => getStageByColumn(((ManiaHitObject)hitObject).Column).Remove(hitObject);
|
public override bool Remove(HitObject hitObject) => getStageByColumn(((ManiaHitObject)hitObject).Column).Remove(hitObject);
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using JetBrains.Annotations;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Extensions.ObjectExtensions;
|
using osu.Framework.Extensions.ObjectExtensions;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -134,12 +135,14 @@ namespace osu.Game.Rulesets.Mania.UI
|
|||||||
{
|
{
|
||||||
bool isSpecial = definition.IsSpecialColumn(i);
|
bool isSpecial = definition.IsSpecialColumn(i);
|
||||||
|
|
||||||
var column = new Column(firstColumnIndex + i, isSpecial)
|
var action = columnStartAction;
|
||||||
|
columnStartAction++;
|
||||||
|
var column = CreateColumn(firstColumnIndex + i, isSpecial).With(c =>
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
c.RelativeSizeAxes = Axes.Both;
|
||||||
Width = 1,
|
c.Width = 1;
|
||||||
Action = { Value = columnStartAction++ }
|
c.Action.Value = action;
|
||||||
};
|
});
|
||||||
|
|
||||||
topLevelContainer.Add(column.TopLevelContainer.CreateProxy());
|
topLevelContainer.Add(column.TopLevelContainer.CreateProxy());
|
||||||
columnBackgrounds.Add(column.BackgroundContainer.CreateProxy());
|
columnBackgrounds.Add(column.BackgroundContainer.CreateProxy());
|
||||||
@ -154,6 +157,9 @@ namespace osu.Game.Rulesets.Mania.UI
|
|||||||
RegisterPool<BarLine, DrawableBarLine>(50, 200);
|
RegisterPool<BarLine, DrawableBarLine>(50, 200);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Pure]
|
||||||
|
protected virtual Column CreateColumn(int index, bool isSpecial) => new Column(index, isSpecial);
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(ISkinSource skin)
|
private void load(ISkinSource skin)
|
||||||
{
|
{
|
||||||
|
@ -17,4 +17,8 @@
|
|||||||
<ProjectReference Include="..\osu.Game\osu.Game.csproj" />
|
<ProjectReference Include="..\osu.Game\osu.Game.csproj" />
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Osu\osu.Game.Rulesets.Osu.csproj" />
|
<ProjectReference Include="..\osu.Game.Rulesets.Osu\osu.Game.Rulesets.Osu.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup Label="Package References">
|
||||||
|
<PackageReference Include="DeepEqual" Version="2.0.0" />
|
||||||
|
<PackageReference Include="Moq" Version="4.17.2" />
|
||||||
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
@ -23,7 +23,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 4,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 4,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -68,7 +68,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -101,7 +101,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -131,7 +131,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -60,7 +60,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -90,7 +90,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Mod = mod,
|
Mod = mod,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
|
@ -21,7 +21,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
public void TestNoAdjustment() => CreateModTest(new ModTestData
|
public void TestNoAdjustment() => CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new OsuModDifficultyAdjust(),
|
Mod = new OsuModDifficultyAdjust(),
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = new BeatmapInfo
|
BeatmapInfo = new BeatmapInfo
|
||||||
{
|
{
|
||||||
|
@ -68,7 +68,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime < 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime < 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && !sliderDimmedBeforeStartTime;
|
return Player.GameplayState.HasPassed && !sliderDimmedBeforeStartTime;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
CreateBeatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
@ -114,7 +114,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && sliderDimmed;
|
return Player.GameplayState.HasPassed && sliderDimmed;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
CreateBeatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
@ -153,7 +153,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && sliderDimmed;
|
return Player.GameplayState.HasPassed && sliderDimmed;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
CreateBeatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -63,7 +63,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -98,7 +98,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -122,7 +122,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModHidden { OnlyFadeApproachCircles = { Value = true } },
|
Mod = new OsuModHidden { OnlyFadeApproachCircles = { Value = true } },
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -21,7 +21,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
public void TestCorrectReflections([Values] OsuModMirror.MirrorType type, [Values] bool withStrictTracking) => CreateModTest(new ModTestData
|
public void TestCorrectReflections([Values] OsuModMirror.MirrorType type, [Values] bool withStrictTracking) => CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new OsuBeatmap
|
CreateBeatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
|
@ -31,7 +31,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -71,7 +71,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -113,7 +113,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -61,7 +61,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModPerfect(),
|
Mod = new OsuModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -36,7 +36,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
AngleSharpness = { Value = angleSharpness }
|
AngleSharpness = { Value = angleSharpness }
|
||||||
},
|
},
|
||||||
Beatmap = jumpBeatmap,
|
CreateBeatmap = jumpBeatmap,
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true
|
PassCondition = () => true
|
||||||
});
|
});
|
||||||
@ -50,15 +50,15 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
AngleSharpness = { Value = angleSharpness }
|
AngleSharpness = { Value = angleSharpness }
|
||||||
},
|
},
|
||||||
Beatmap = streamBeatmap,
|
CreateBeatmap = streamBeatmap,
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true
|
PassCondition = () => true
|
||||||
});
|
});
|
||||||
|
|
||||||
private OsuBeatmap jumpBeatmap =>
|
private OsuBeatmap jumpBeatmap() =>
|
||||||
createHitCircleBeatmap(new[] { 100, 200, 300, 400 }, 8, 300, 2 * 300);
|
createHitCircleBeatmap(new[] { 100, 200, 300, 400 }, 8, 300, 2 * 300);
|
||||||
|
|
||||||
private OsuBeatmap streamBeatmap =>
|
private OsuBeatmap streamBeatmap() =>
|
||||||
createHitCircleBeatmap(new[] { 10, 20, 30, 40, 50, 60, 70, 80 }, 16, 150, 4 * 150);
|
createHitCircleBeatmap(new[] { 10, 20, 30, 40, 50, 60, 70, 80 }, 16, 150, 4 * 150);
|
||||||
|
|
||||||
private OsuBeatmap createHitCircleBeatmap(IEnumerable<int> spacings, int objectsPerSpacing, int interval, int beatLength)
|
private OsuBeatmap createHitCircleBeatmap(IEnumerable<int> spacings, int objectsPerSpacing, int interval, int beatLength)
|
||||||
|
@ -22,7 +22,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -62,7 +62,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -100,7 +100,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -130,7 +130,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -35,7 +35,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModSpunOut(),
|
Mod = new OsuModSpunOut(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = singleSpinnerBeatmap,
|
CreateBeatmap = singleSpinnerBeatmap,
|
||||||
PassCondition = () =>
|
PassCondition = () =>
|
||||||
{
|
{
|
||||||
// Bind to the first spinner's results for further tracking.
|
// Bind to the first spinner's results for further tracking.
|
||||||
@ -71,7 +71,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mods = mods,
|
Mods = mods,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = singleSpinnerBeatmap,
|
CreateBeatmap = singleSpinnerBeatmap,
|
||||||
PassCondition = () =>
|
PassCondition = () =>
|
||||||
{
|
{
|
||||||
var counter = Player.ChildrenOfType<SpinnerSpmCalculator>().SingleOrDefault();
|
var counter = Player.ChildrenOfType<SpinnerSpmCalculator>().SingleOrDefault();
|
||||||
@ -101,7 +101,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModSpunOut(),
|
Mod = new OsuModSpunOut(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = singleSpinnerBeatmap,
|
CreateBeatmap = singleSpinnerBeatmap,
|
||||||
PassCondition = () =>
|
PassCondition = () =>
|
||||||
{
|
{
|
||||||
// Bind to the first spinner's results for further tracking.
|
// Bind to the first spinner's results for further tracking.
|
||||||
@ -130,7 +130,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private Beatmap singleSpinnerBeatmap => new Beatmap
|
private Beatmap singleSpinnerBeatmap() => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModStrictTracking(),
|
Mod = new OsuModStrictTracking(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -30,7 +30,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSuddenDeath(),
|
Mod = new OsuModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -55,7 +55,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSuddenDeath(),
|
Mod = new OsuModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -36,7 +36,7 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
{
|
{
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Mod = new TestAutoMod(),
|
Mod = new TestAutoMod(),
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
||||||
},
|
},
|
||||||
@ -47,18 +47,16 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestMissViaNotHitting()
|
public void TestMissViaNotHitting()
|
||||||
{
|
{
|
||||||
var beatmap = new Beatmap
|
|
||||||
{
|
|
||||||
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
|
||||||
};
|
|
||||||
|
|
||||||
var hitWindows = new OsuHitWindows();
|
var hitWindows = new OsuHitWindows();
|
||||||
hitWindows.SetDifficulty(beatmap.Difficulty.OverallDifficulty);
|
hitWindows.SetDifficulty(IBeatmapDifficultyInfo.DEFAULT_DIFFICULTY);
|
||||||
|
|
||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = beatmap,
|
CreateBeatmap = () => new Beatmap
|
||||||
|
{
|
||||||
|
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
||||||
|
},
|
||||||
PassCondition = () => Player.Results.Count > 0 && Player.Results[0].TimeOffset >= hitWindows.WindowFor(HitResult.Meh) && !Player.Results[0].IsHit
|
PassCondition = () => Player.Results.Count > 0 && Player.Results[0].TimeOffset >= hitWindows.WindowFor(HitResult.Meh) && !Player.Results[0].IsHit
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,7 @@ namespace osu.Game.Rulesets.Osu.Edit
|
|||||||
{
|
{
|
||||||
public partial class OsuDistanceSnapProvider : ComposerDistanceSnapProvider
|
public partial class OsuDistanceSnapProvider : ComposerDistanceSnapProvider
|
||||||
{
|
{
|
||||||
protected override double ReadCurrentDistanceSnap(HitObject before, HitObject after)
|
public override double ReadCurrentDistanceSnap(HitObject before, HitObject after)
|
||||||
{
|
{
|
||||||
float expectedDistance = DurationToDistance(before, after.StartTime - before.GetEndTime());
|
float expectedDistance = DurationToDistance(before, after.StartTime - before.GetEndTime());
|
||||||
float actualDistance = Vector2.Distance(((OsuHitObject)before).EndPosition, ((OsuHitObject)after).Position);
|
float actualDistance = Vector2.Distance(((OsuHitObject)before).EndPosition, ((OsuHitObject)after).Position);
|
||||||
|
@ -13,7 +13,8 @@
|
|||||||
</Compile>
|
</Compile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Label="Project References">
|
<ItemGroup Label="Project References">
|
||||||
<ProjectReference Include="..\osu.Game\osu.Game.csproj" />
|
|
||||||
<ProjectReference Include="..\osu.Game.Rulesets.Taiko\osu.Game.Rulesets.Taiko.csproj" />
|
<ProjectReference Include="..\osu.Game.Rulesets.Taiko\osu.Game.Rulesets.Taiko.csproj" />
|
||||||
|
<ProjectReference Include="..\osu.Game.Tests\osu.Game.Tests.csproj" />
|
||||||
|
<ProjectReference Include="..\osu.Game\osu.Game.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
@ -31,6 +31,13 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
const double hit_time = 1;
|
const double hit_time = 1;
|
||||||
|
|
||||||
|
CreateModTest(new ModTestData
|
||||||
|
{
|
||||||
|
Mod = new TaikoModHidden(),
|
||||||
|
Autoplay = true,
|
||||||
|
PassCondition = checkAllMaxResultJudgements(2),
|
||||||
|
CreateBeatmap = () =>
|
||||||
|
{
|
||||||
var beatmap = new Beatmap<TaikoHitObject>
|
var beatmap = new Beatmap<TaikoHitObject>
|
||||||
{
|
{
|
||||||
HitObjects = new List<TaikoHitObject>
|
HitObjects = new List<TaikoHitObject>
|
||||||
@ -58,13 +65,8 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
};
|
};
|
||||||
|
|
||||||
beatmap.ControlPointInfo.Add(0, new EffectControlPoint { ScrollSpeed = 0.1f });
|
beatmap.ControlPointInfo.Add(0, new EffectControlPoint { ScrollSpeed = 0.1f });
|
||||||
|
return beatmap;
|
||||||
CreateModTest(new ModTestData
|
},
|
||||||
{
|
|
||||||
Mod = new TaikoModHidden(),
|
|
||||||
Autoplay = true,
|
|
||||||
PassCondition = checkAllMaxResultJudgements(2),
|
|
||||||
Beatmap = beatmap,
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,26 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestRelax()
|
public void TestRelax()
|
||||||
{
|
{
|
||||||
var beatmap = new TaikoBeatmap
|
var beatmapForReplay = createBeatmap();
|
||||||
|
|
||||||
|
foreach (var ho in beatmapForReplay.HitObjects)
|
||||||
|
ho.ApplyDefaults(beatmapForReplay.ControlPointInfo, beatmapForReplay.Difficulty);
|
||||||
|
|
||||||
|
var replay = new TaikoAutoGenerator(beatmapForReplay).Generate();
|
||||||
|
|
||||||
|
foreach (var frame in replay.Frames.OfType<TaikoReplayFrame>().Where(r => r.Actions.Any()))
|
||||||
|
frame.Actions = [TaikoAction.LeftCentre];
|
||||||
|
|
||||||
|
CreateModTest(new ModTestData
|
||||||
|
{
|
||||||
|
Mod = new TaikoModRelax(),
|
||||||
|
CreateBeatmap = createBeatmap,
|
||||||
|
ReplayFrames = replay.Frames,
|
||||||
|
Autoplay = false,
|
||||||
|
PassCondition = () => Player.ScoreProcessor.HasCompleted.Value && Player.ScoreProcessor.Accuracy.Value == 1,
|
||||||
|
});
|
||||||
|
|
||||||
|
TaikoBeatmap createBeatmap() => new TaikoBeatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
@ -25,22 +44,6 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
new Swell { StartTime = 1250, Duration = 500 },
|
new Swell { StartTime = 1250, Duration = 500 },
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
foreach (var ho in beatmap.HitObjects)
|
|
||||||
ho.ApplyDefaults(beatmap.ControlPointInfo, beatmap.Difficulty);
|
|
||||||
|
|
||||||
var replay = new TaikoAutoGenerator(beatmap).Generate();
|
|
||||||
|
|
||||||
foreach (var frame in replay.Frames.OfType<TaikoReplayFrame>().Where(r => r.Actions.Any()))
|
|
||||||
frame.Actions = [TaikoAction.LeftCentre];
|
|
||||||
|
|
||||||
CreateModTest(new ModTestData
|
|
||||||
{
|
|
||||||
Mod = new TaikoModRelax(),
|
|
||||||
Beatmap = beatmap,
|
|
||||||
ReplayFrames = replay.Frames,
|
|
||||||
Autoplay = false,
|
|
||||||
PassCondition = () => Player.ScoreProcessor.HasCompleted.Value && Player.ScoreProcessor.Accuracy.Value == 1,
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -65,7 +65,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -110,7 +110,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -136,7 +136,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -175,7 +175,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Extensions;
|
using osu.Framework.Extensions;
|
||||||
@ -9,6 +10,7 @@ using osu.Framework.Extensions.ObjectExtensions;
|
|||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
using osu.Game.Database;
|
using osu.Game.Database;
|
||||||
|
using osu.Game.IO.Archives;
|
||||||
using osu.Game.Tests.Resources;
|
using osu.Game.Tests.Resources;
|
||||||
using osu.Game.Tests.Visual;
|
using osu.Game.Tests.Visual;
|
||||||
using MemoryStream = System.IO.MemoryStream;
|
using MemoryStream = System.IO.MemoryStream;
|
||||||
@ -48,6 +50,47 @@ namespace osu.Game.Tests.Beatmaps.IO
|
|||||||
AddAssert("hit object is snapped", () => beatmap.Beatmap.HitObjects[0].StartTime, () => Is.EqualTo(28519).Within(0.001));
|
AddAssert("hit object is snapped", () => beatmap.Beatmap.HitObjects[0].StartTime, () => Is.EqualTo(28519).Within(0.001));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestExportStability()
|
||||||
|
{
|
||||||
|
IWorkingBeatmap beatmap = null!;
|
||||||
|
MemoryStream firstExport = null!;
|
||||||
|
MemoryStream secondExport = null!;
|
||||||
|
|
||||||
|
// Ensure importer encoding is correct
|
||||||
|
AddStep("import beatmap", () => beatmap = importBeatmapFromArchives(@"legacy-export-stability-test.olz"));
|
||||||
|
AddStep("export once", () =>
|
||||||
|
{
|
||||||
|
firstExport = new MemoryStream();
|
||||||
|
|
||||||
|
new LegacyBeatmapExporter(LocalStorage)
|
||||||
|
.ExportToStream((BeatmapSetInfo)beatmap.BeatmapInfo.BeatmapSet!, firstExport, null);
|
||||||
|
});
|
||||||
|
|
||||||
|
AddStep("import beatmap again", () => beatmap = importBeatmapFromStream(firstExport));
|
||||||
|
AddStep("export again", () =>
|
||||||
|
{
|
||||||
|
secondExport = new MemoryStream();
|
||||||
|
|
||||||
|
new LegacyBeatmapExporter(LocalStorage)
|
||||||
|
.ExportToStream((BeatmapSetInfo)beatmap.BeatmapInfo.BeatmapSet!, secondExport, null);
|
||||||
|
});
|
||||||
|
|
||||||
|
const string osu_filename = @"legacy export - stability test (spaceman_atlas) [].osu";
|
||||||
|
|
||||||
|
AddAssert("exports are identical",
|
||||||
|
() => getStringContentsOf(osu_filename, firstExport.GetBuffer()),
|
||||||
|
() => Is.EqualTo(getStringContentsOf(osu_filename, secondExport.GetBuffer())));
|
||||||
|
|
||||||
|
string getStringContentsOf(string filename, byte[] archiveBytes)
|
||||||
|
{
|
||||||
|
using var memoryStream = new MemoryStream(archiveBytes);
|
||||||
|
using var archiveReader = new ZipArchiveReader(memoryStream);
|
||||||
|
byte[] fileContent = archiveReader.GetStream(filename).ReadAllBytesToArray();
|
||||||
|
return Encoding.UTF8.GetString(fileContent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private IWorkingBeatmap importBeatmapFromStream(Stream stream)
|
private IWorkingBeatmap importBeatmapFromStream(Stream stream)
|
||||||
{
|
{
|
||||||
var imported = beatmaps.Import(new ImportTask(stream, "filename.osz")).GetResultSafely();
|
var imported = beatmaps.Import(new ImportTask(stream, "filename.osz")).GetResultSafely();
|
||||||
|
@ -148,6 +148,7 @@ namespace osu.Game.Tests.NonVisual.Filtering
|
|||||||
[TestCase("tags too", false)]
|
[TestCase("tags too", false)]
|
||||||
[TestCase("version", false)]
|
[TestCase("version", false)]
|
||||||
[TestCase("an auteur", true)]
|
[TestCase("an auteur", true)]
|
||||||
|
[TestCase("unit", false)]
|
||||||
public void TestCriteriaMatchingTerms(string terms, bool filtered)
|
public void TestCriteriaMatchingTerms(string terms, bool filtered)
|
||||||
{
|
{
|
||||||
var exampleBeatmapInfo = getExampleBeatmap();
|
var exampleBeatmapInfo = getExampleBeatmap();
|
||||||
@ -175,6 +176,7 @@ namespace osu.Game.Tests.NonVisual.Filtering
|
|||||||
[TestCase("\"Artist\"!", true)]
|
[TestCase("\"Artist\"!", true)]
|
||||||
[TestCase("\"The Artist\"!", false)]
|
[TestCase("\"The Artist\"!", false)]
|
||||||
[TestCase("\"the artist\"!", false)]
|
[TestCase("\"the artist\"!", false)]
|
||||||
|
[TestCase("\"unit tests\"!", false)]
|
||||||
[TestCase("\"\\\"", true)] // nasty case, covers properly escaping user input in underlying regex.
|
[TestCase("\"\\\"", true)] // nasty case, covers properly escaping user input in underlying regex.
|
||||||
public void TestCriteriaMatchingExactTerms(string terms, bool filtered)
|
public void TestCriteriaMatchingExactTerms(string terms, bool filtered)
|
||||||
{
|
{
|
||||||
|
@ -501,6 +501,18 @@ namespace osu.Game.Tests.NonVisual.Filtering
|
|||||||
Assert.That(visibleBeatmaps, Is.EqualTo(expectedBeatmapIndexes));
|
Assert.That(visibleBeatmaps, Is.EqualTo(expectedBeatmapIndexes));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestApplySourceQueries()
|
||||||
|
{
|
||||||
|
const string query = "find me songs with source=\"unit tests\" please";
|
||||||
|
var filterCriteria = new FilterCriteria();
|
||||||
|
FilterQueryParser.ApplyQueries(filterCriteria, query);
|
||||||
|
Assert.AreEqual("find me songs with please", filterCriteria.SearchText.Trim());
|
||||||
|
Assert.AreEqual(5, filterCriteria.SearchTerms.Length);
|
||||||
|
Assert.AreEqual("unit tests", filterCriteria.Source.SearchTerm);
|
||||||
|
Assert.That(filterCriteria.Source.MatchMode, Is.EqualTo(FilterCriteria.MatchMode.IsolatedPhrase));
|
||||||
|
}
|
||||||
|
|
||||||
private class CustomFilterCriteria : IRulesetFilterCriteria
|
private class CustomFilterCriteria : IRulesetFilterCriteria
|
||||||
{
|
{
|
||||||
public string? CustomValue { get; set; }
|
public string? CustomValue { get; set; }
|
||||||
|
@ -73,9 +73,9 @@ namespace osu.Game.Tests.NonVisual.Multiplayer
|
|||||||
AddStep("create room initially in gameplay", () =>
|
AddStep("create room initially in gameplay", () =>
|
||||||
{
|
{
|
||||||
var newRoom = new Room();
|
var newRoom = new Room();
|
||||||
newRoom.CopyFrom(SelectedRoom.Value);
|
newRoom.CopyFrom(SelectedRoom.Value!);
|
||||||
|
|
||||||
newRoom.RoomID.Value = null;
|
newRoom.RoomID = null;
|
||||||
MultiplayerClient.RoomSetupAction = room =>
|
MultiplayerClient.RoomSetupAction = room =>
|
||||||
{
|
{
|
||||||
room.State = MultiplayerRoomState.Playing;
|
room.State = MultiplayerRoomState.Playing;
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -21,12 +19,12 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
[HeadlessTest]
|
[HeadlessTest]
|
||||||
public partial class TestSceneCatchUpSyncManager : OsuTestScene
|
public partial class TestSceneCatchUpSyncManager : OsuTestScene
|
||||||
{
|
{
|
||||||
private GameplayClockContainer master;
|
private GameplayClockContainer master = null!;
|
||||||
private SpectatorSyncManager syncManager;
|
private SpectatorSyncManager syncManager = null!;
|
||||||
|
|
||||||
private Dictionary<SpectatorPlayerClock, int> clocksById;
|
private Dictionary<SpectatorPlayerClock, int> clocksById = null!;
|
||||||
private SpectatorPlayerClock player1;
|
private SpectatorPlayerClock player1 = null!;
|
||||||
private SpectatorPlayerClock player2;
|
private SpectatorPlayerClock player2 = null!;
|
||||||
|
|
||||||
[SetUp]
|
[SetUp]
|
||||||
public void Setup()
|
public void Setup()
|
||||||
|
Binary file not shown.
@ -12,6 +12,7 @@ using osu.Framework.Platform;
|
|||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
using osu.Game.Collections;
|
using osu.Game.Collections;
|
||||||
|
using osu.Game.Graphics.UserInterface;
|
||||||
using osu.Game.Overlays;
|
using osu.Game.Overlays;
|
||||||
using osu.Game.Overlays.Dialog;
|
using osu.Game.Overlays.Dialog;
|
||||||
using osu.Game.Rulesets;
|
using osu.Game.Rulesets;
|
||||||
@ -265,7 +266,6 @@ namespace osu.Game.Tests.Visual.Collections
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[Solo]
|
|
||||||
public void TestCollectionRenamedExternal()
|
public void TestCollectionRenamedExternal()
|
||||||
{
|
{
|
||||||
BeatmapCollection first = null!;
|
BeatmapCollection first = null!;
|
||||||
@ -338,10 +338,44 @@ namespace osu.Game.Tests.Visual.Collections
|
|||||||
AddUntilStep("collection has new name", () => first.Name == "First");
|
AddUntilStep("collection has new name", () => first.Name == "First");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestSearch()
|
||||||
|
{
|
||||||
|
BeatmapCollection first = null!;
|
||||||
|
|
||||||
|
AddStep("add two collections", () =>
|
||||||
|
{
|
||||||
|
Realm.Write(r =>
|
||||||
|
{
|
||||||
|
r.Add(new[]
|
||||||
|
{
|
||||||
|
first = new BeatmapCollection(name: "1"),
|
||||||
|
new BeatmapCollection(name: "2"),
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
assertCollectionName(0, "1");
|
||||||
|
assertCollectionName(1, "2");
|
||||||
|
|
||||||
|
AddStep("search for 1", () => dialog.ChildrenOfType<SearchTextBox>().Single().Current.Value = "1");
|
||||||
|
|
||||||
|
assertCollectionCount(1);
|
||||||
|
|
||||||
|
AddStep("change first collection name", () => Realm.Write(_ => first.Name = "First"));
|
||||||
|
|
||||||
|
assertCollectionCount(0);
|
||||||
|
|
||||||
|
AddStep("search for first", () => dialog.ChildrenOfType<SearchTextBox>().Single().Current.Value = "firs");
|
||||||
|
|
||||||
|
assertCollectionCount(1);
|
||||||
|
}
|
||||||
|
|
||||||
private void assertCollectionCount(int count)
|
private void assertCollectionCount(int count)
|
||||||
=> AddUntilStep($"{count} collections shown", () => dialog.ChildrenOfType<DrawableCollectionListItem>().Count() == count + 1); // +1 for placeholder
|
=> AddUntilStep($"{count} collections shown", () => dialog.ChildrenOfType<DrawableCollectionListItem>().Count(i => i.IsPresent) == count + 1); // +1 for placeholder
|
||||||
|
|
||||||
private void assertCollectionName(int index, string name)
|
private void assertCollectionName(int index, string name)
|
||||||
=> AddUntilStep($"item {index + 1} has correct name", () => dialog.ChildrenOfType<DrawableCollectionList>().Single().OrderedItems.ElementAt(index).ChildrenOfType<TextBox>().First().Text == name);
|
=> AddUntilStep($"item {index + 1} has correct name",
|
||||||
|
() => dialog.ChildrenOfType<DrawableCollectionList>().Single().OrderedItems.ElementAt(index).ChildrenOfType<TextBox>().First().Text == name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,18 +39,18 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
{
|
{
|
||||||
var room = new Room
|
var room = new Room
|
||||||
{
|
{
|
||||||
RoomID = { Value = 1234 },
|
RoomID = 1234,
|
||||||
Name = { Value = "Daily Challenge: June 4, 2024" },
|
Name = "Daily Challenge: June 4, 2024",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
||||||
{
|
{
|
||||||
RequiredMods = [new APIMod(new OsuModTraceable())],
|
RequiredMods = [new APIMod(new OsuModTraceable())],
|
||||||
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
||||||
}
|
}
|
||||||
},
|
],
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddHours(12) },
|
EndDate = DateTimeOffset.Now.AddHours(12),
|
||||||
Category = { Value = RoomCategory.DailyChallenge }
|
Category = RoomCategory.DailyChallenge
|
||||||
};
|
};
|
||||||
|
|
||||||
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
||||||
@ -62,18 +62,18 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
{
|
{
|
||||||
var room = new Room
|
var room = new Room
|
||||||
{
|
{
|
||||||
RoomID = { Value = 1234 },
|
RoomID = 1234,
|
||||||
Name = { Value = "Daily Challenge: June 4, 2024" },
|
Name = "Daily Challenge: June 4, 2024",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
||||||
{
|
{
|
||||||
RequiredMods = [new APIMod(new OsuModTraceable())],
|
RequiredMods = [new APIMod(new OsuModTraceable())],
|
||||||
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
||||||
}
|
}
|
||||||
},
|
],
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddHours(12) },
|
EndDate = DateTimeOffset.Now.AddHours(12),
|
||||||
Category = { Value = RoomCategory.DailyChallenge }
|
Category = RoomCategory.DailyChallenge
|
||||||
};
|
};
|
||||||
|
|
||||||
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
||||||
@ -91,18 +91,18 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
{
|
{
|
||||||
var room = new Room
|
var room = new Room
|
||||||
{
|
{
|
||||||
RoomID = { Value = 1234 },
|
RoomID = 1234,
|
||||||
Name = { Value = "Daily Challenge: June 4, 2024" },
|
Name = "Daily Challenge: June 4, 2024",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
new PlaylistItem(TestResources.CreateTestBeatmapSetInfo().Beatmaps.First())
|
||||||
{
|
{
|
||||||
RequiredMods = [new APIMod(new OsuModTraceable())],
|
RequiredMods = [new APIMod(new OsuModTraceable())],
|
||||||
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
||||||
}
|
}
|
||||||
},
|
],
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddHours(12) },
|
EndDate = DateTimeOffset.Now.AddHours(12),
|
||||||
Category = { Value = RoomCategory.DailyChallenge }
|
Category = RoomCategory.DailyChallenge
|
||||||
};
|
};
|
||||||
|
|
||||||
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
AddStep("add room", () => API.Perform(new CreateRoomRequest(room)));
|
||||||
|
@ -26,11 +26,6 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
|
|
||||||
private readonly Bindable<Room> room = new Bindable<Room>(new Room());
|
private readonly Bindable<Room> room = new Bindable<Room>(new Room());
|
||||||
|
|
||||||
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent) => new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent))
|
|
||||||
{
|
|
||||||
Model = { BindTarget = room }
|
|
||||||
};
|
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestBasicAppearance()
|
public void TestBasicAppearance()
|
||||||
{
|
{
|
||||||
@ -98,7 +93,7 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
new DailyChallengeTimeRemainingRing(),
|
new DailyChallengeTimeRemainingRing(room.Value),
|
||||||
breakdown = new DailyChallengeScoreBreakdown(),
|
breakdown = new DailyChallengeScoreBreakdown(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -125,8 +120,8 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
AddSliderStep("update time remaining", 0f, 1f, 0f, progress =>
|
AddSliderStep("update time remaining", 0f, 1f, 0f, progress =>
|
||||||
{
|
{
|
||||||
var startedTimeAgo = TimeSpan.FromHours(24) * progress;
|
var startedTimeAgo = TimeSpan.FromHours(24) * progress;
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now - startedTimeAgo;
|
room.Value.StartDate = DateTimeOffset.Now - startedTimeAgo;
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
AddStep("add normal score", () =>
|
AddStep("add normal score", () =>
|
||||||
{
|
{
|
||||||
|
@ -68,19 +68,19 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
{
|
{
|
||||||
API.Perform(new CreateRoomRequest(room = new Room
|
API.Perform(new CreateRoomRequest(room = new Room
|
||||||
{
|
{
|
||||||
RoomID = { Value = roomId },
|
RoomID = roomId,
|
||||||
Name = { Value = "Daily Challenge: June 4, 2024" },
|
Name = "Daily Challenge: June 4, 2024",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(CreateAPIBeatmap(new OsuRuleset().RulesetInfo))
|
new PlaylistItem(CreateAPIBeatmap(new OsuRuleset().RulesetInfo))
|
||||||
{
|
{
|
||||||
RequiredMods = [new APIMod(new OsuModTraceable())],
|
RequiredMods = [new APIMod(new OsuModTraceable())],
|
||||||
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
AllowedMods = [new APIMod(new OsuModDoubleTime())]
|
||||||
}
|
}
|
||||||
},
|
],
|
||||||
StartDate = { Value = DateTimeOffset.Now },
|
StartDate = DateTimeOffset.Now,
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddHours(24) },
|
EndDate = DateTimeOffset.Now.AddHours(24),
|
||||||
Category = { Value = RoomCategory.DailyChallenge }
|
Category = RoomCategory.DailyChallenge
|
||||||
}));
|
}));
|
||||||
});
|
});
|
||||||
AddStep("signal client", () => metadataClient.DailyChallengeUpdated(new DailyChallengeInfo { RoomID = roomId }));
|
AddStep("signal client", () => metadataClient.DailyChallengeUpdated(new DailyChallengeInfo { RoomID = roomId }));
|
||||||
|
@ -43,7 +43,7 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
AddStep("create leaderboard", () => Child = leaderboard = new DailyChallengeLeaderboard(new Room { RoomID = { Value = 1 } }, new PlaylistItem(Beatmap.Value.BeatmapInfo))
|
AddStep("create leaderboard", () => Child = leaderboard = new DailyChallengeLeaderboard(new Room { RoomID = 1 }, new PlaylistItem(Beatmap.Value.BeatmapInfo))
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
@ -86,7 +86,7 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
AddStep("create leaderboard", () => Child = leaderboard = new DailyChallengeLeaderboard(new Room { RoomID = { Value = 1 } }, new PlaylistItem(Beatmap.Value.BeatmapInfo))
|
AddStep("create leaderboard", () => Child = leaderboard = new DailyChallengeLeaderboard(new Room { RoomID = 1 }, new PlaylistItem(Beatmap.Value.BeatmapInfo))
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
|
@ -18,11 +18,6 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
{
|
{
|
||||||
private readonly Bindable<Room> room = new Bindable<Room>(new Room());
|
private readonly Bindable<Room> room = new Bindable<Room>(new Room());
|
||||||
|
|
||||||
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent) => new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent))
|
|
||||||
{
|
|
||||||
Model = { BindTarget = room }
|
|
||||||
};
|
|
||||||
|
|
||||||
[Cached]
|
[Cached]
|
||||||
private OverlayColourProvider colourProvider = new OverlayColourProvider(OverlayColourScheme.Plum);
|
private OverlayColourProvider colourProvider = new OverlayColourProvider(OverlayColourScheme.Plum);
|
||||||
|
|
||||||
@ -38,7 +33,7 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Colour = colourProvider.Background4,
|
Colour = colourProvider.Background4,
|
||||||
},
|
},
|
||||||
ring = new DailyChallengeTimeRemainingRing
|
ring = new DailyChallengeTimeRemainingRing(room.Value)
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
@ -59,29 +54,29 @@ namespace osu.Game.Tests.Visual.DailyChallenge
|
|||||||
|
|
||||||
AddStep("just started", () =>
|
AddStep("just started", () =>
|
||||||
{
|
{
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now.AddMinutes(-1);
|
room.Value.StartDate = DateTimeOffset.Now.AddMinutes(-1);
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
AddStep("midway through", () =>
|
AddStep("midway through", () =>
|
||||||
{
|
{
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now.AddHours(-12);
|
room.Value.StartDate = DateTimeOffset.Now.AddHours(-12);
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
AddStep("nearing end", () =>
|
AddStep("nearing end", () =>
|
||||||
{
|
{
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now.AddDays(-1).AddMinutes(8);
|
room.Value.StartDate = DateTimeOffset.Now.AddDays(-1).AddMinutes(8);
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
AddStep("already ended", () =>
|
AddStep("already ended", () =>
|
||||||
{
|
{
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now.AddDays(-2);
|
room.Value.StartDate = DateTimeOffset.Now.AddDays(-2);
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
AddSliderStep("manual progress", 0f, 1f, 0f, progress =>
|
AddSliderStep("manual progress", 0f, 1f, 0f, progress =>
|
||||||
{
|
{
|
||||||
var startedTimeAgo = TimeSpan.FromHours(24) * progress;
|
var startedTimeAgo = TimeSpan.FromHours(24) * progress;
|
||||||
room.Value.StartDate.Value = DateTimeOffset.Now - startedTimeAgo;
|
room.Value.StartDate = DateTimeOffset.Now - startedTimeAgo;
|
||||||
room.Value.EndDate.Value = room.Value.StartDate.Value.Value.AddDays(1);
|
room.Value.EndDate = room.Value.StartDate.Value.AddDays(1);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@ using osu.Framework.Testing;
|
|||||||
using osu.Framework.Utils;
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
|
using osu.Game.Graphics.UserInterface;
|
||||||
using osu.Game.Overlays;
|
using osu.Game.Overlays;
|
||||||
using osu.Game.Overlays.Notifications;
|
using osu.Game.Overlays.Notifications;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
@ -207,7 +208,25 @@ namespace osu.Game.Tests.Visual.Gameplay
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestBlockLoadViaFocus()
|
public void TestLoadNotBlockedViaArbitraryFocus()
|
||||||
|
{
|
||||||
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
||||||
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
||||||
|
|
||||||
|
AddUntilStep("click settings slider", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(loader.ChildrenOfType<OsuSliderBar<float>>().First());
|
||||||
|
InputManager.Click(MouseButton.Left);
|
||||||
|
|
||||||
|
return InputManager.FocusedDrawable is OsuSliderBar<float>;
|
||||||
|
});
|
||||||
|
|
||||||
|
AddUntilStep("wait for load ready", () => player?.LoadState == LoadState.Ready);
|
||||||
|
AddUntilStep("loads", () => !loader.IsCurrentScreen());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestBlockLoadViaOverlayFocus()
|
||||||
{
|
{
|
||||||
AddStep("load dummy beatmap", () => resetPlayer(false));
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
||||||
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
||||||
|
@ -42,14 +42,14 @@ namespace osu.Game.Tests.Visual.Menus
|
|||||||
beatmap.OnlineID = 1001;
|
beatmap.OnlineID = 1001;
|
||||||
getRoomRequest.TriggerSuccess(new Room
|
getRoomRequest.TriggerSuccess(new Room
|
||||||
{
|
{
|
||||||
RoomID = { Value = 1234 },
|
RoomID = 1234,
|
||||||
Name = { Value = "Aug 8, 2024" },
|
Name = "Aug 8, 2024",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmap)
|
new PlaylistItem(beatmap)
|
||||||
},
|
],
|
||||||
StartDate = { Value = DateTimeOffset.Now.AddMinutes(-30) },
|
StartDate = DateTimeOffset.Now.AddMinutes(-30),
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddSeconds(60) }
|
EndDate = DateTimeOffset.Now.AddSeconds(60)
|
||||||
});
|
});
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ namespace osu.Game.Tests.Visual.Mods
|
|||||||
MinimumAccuracy = { Value = 0.6 }
|
MinimumAccuracy = { Value = 0.6 }
|
||||||
},
|
},
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
||||||
{
|
{
|
||||||
@ -56,7 +56,7 @@ namespace osu.Game.Tests.Visual.Mods
|
|||||||
AccuracyJudgeMode = { Value = ModAccuracyChallenge.AccuracyMode.Standard }
|
AccuracyJudgeMode = { Value = ModAccuracyChallenge.AccuracyMode.Standard }
|
||||||
},
|
},
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
CreateBeatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
||||||
{
|
{
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Collections.Specialized;
|
using System.Collections.Specialized;
|
||||||
@ -31,7 +29,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
protected readonly BindableList<MultiplayerRoomUser> MultiplayerUsers = new BindableList<MultiplayerRoomUser>();
|
protected readonly BindableList<MultiplayerRoomUser> MultiplayerUsers = new BindableList<MultiplayerRoomUser>();
|
||||||
|
|
||||||
protected MultiplayerGameplayLeaderboard Leaderboard { get; private set; }
|
protected MultiplayerGameplayLeaderboard? Leaderboard { get; private set; }
|
||||||
|
|
||||||
protected virtual MultiplayerRoomUser CreateUser(int userId) => new MultiplayerRoomUser(userId);
|
protected virtual MultiplayerRoomUser CreateUser(int userId) => new MultiplayerRoomUser(userId);
|
||||||
|
|
||||||
@ -40,7 +38,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
private readonly BindableList<int> multiplayerUserIds = new BindableList<int>();
|
private readonly BindableList<int> multiplayerUserIds = new BindableList<int>();
|
||||||
private readonly BindableDictionary<int, SpectatorState> watchedUserStates = new BindableDictionary<int, SpectatorState>();
|
private readonly BindableDictionary<int, SpectatorState> watchedUserStates = new BindableDictionary<int, SpectatorState>();
|
||||||
|
|
||||||
private OsuConfigManager config;
|
private OsuConfigManager config = null!;
|
||||||
|
|
||||||
private readonly Mock<SpectatorClient> spectatorClient = new Mock<SpectatorClient>();
|
private readonly Mock<SpectatorClient> spectatorClient = new Mock<SpectatorClient>();
|
||||||
private readonly Mock<MultiplayerClient> multiplayerClient = new Mock<MultiplayerClient>();
|
private readonly Mock<MultiplayerClient> multiplayerClient = new Mock<MultiplayerClient>();
|
||||||
@ -133,7 +131,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
LoadComponentAsync(Leaderboard = CreateLeaderboard(), Add);
|
LoadComponentAsync(Leaderboard = CreateLeaderboard(), Add);
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("wait for load", () => Leaderboard.IsLoaded);
|
AddUntilStep("wait for load", () => Leaderboard!.IsLoaded);
|
||||||
|
|
||||||
AddStep("check watch requests were sent", () =>
|
AddStep("check watch requests were sent", () =>
|
||||||
{
|
{
|
||||||
@ -146,7 +144,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestScoreUpdates()
|
public void TestScoreUpdates()
|
||||||
{
|
{
|
||||||
AddRepeatStep("update state", UpdateUserStatesRandomly, 100);
|
AddRepeatStep("update state", UpdateUserStatesRandomly, 100);
|
||||||
AddToggleStep("switch compact mode", expanded => Leaderboard.Expanded.Value = expanded);
|
AddToggleStep("switch compact mode", expanded => Leaderboard!.Expanded.Value = expanded);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
@ -30,16 +28,16 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
protected abstract QueueMode Mode { get; }
|
protected abstract QueueMode Mode { get; }
|
||||||
|
|
||||||
protected BeatmapInfo InitialBeatmap { get; private set; }
|
protected BeatmapInfo InitialBeatmap { get; private set; } = null!;
|
||||||
protected BeatmapInfo OtherBeatmap { get; private set; }
|
protected BeatmapInfo OtherBeatmap { get; private set; } = null!;
|
||||||
|
|
||||||
protected IScreen CurrentScreen => multiplayerComponents.CurrentScreen;
|
protected IScreen CurrentScreen => multiplayerComponents.CurrentScreen;
|
||||||
protected IScreen CurrentSubScreen => multiplayerComponents.MultiplayerScreen.CurrentSubScreen;
|
protected IScreen CurrentSubScreen => multiplayerComponents.MultiplayerScreen.CurrentSubScreen;
|
||||||
|
|
||||||
private BeatmapManager beatmaps;
|
private BeatmapManager beatmaps = null!;
|
||||||
private BeatmapSetInfo importedSet;
|
private BeatmapSetInfo importedSet = null!;
|
||||||
|
|
||||||
private TestMultiplayerComponents multiplayerComponents;
|
private TestMultiplayerComponents multiplayerComponents = null!;
|
||||||
|
|
||||||
protected TestMultiplayerClient MultiplayerClient => multiplayerComponents.MultiplayerClient;
|
protected TestMultiplayerClient MultiplayerClient => multiplayerComponents.MultiplayerClient;
|
||||||
|
|
||||||
@ -75,15 +73,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddUntilStep("wait for lounge", () => multiplayerComponents.ChildrenOfType<LoungeSubScreen>().SingleOrDefault()?.IsLoaded == true);
|
AddUntilStep("wait for lounge", () => multiplayerComponents.ChildrenOfType<LoungeSubScreen>().SingleOrDefault()?.IsLoaded == true);
|
||||||
AddStep("open room", () => multiplayerComponents.ChildrenOfType<LoungeSubScreen>().Single().Open(new Room
|
AddStep("open room", () => multiplayerComponents.ChildrenOfType<LoungeSubScreen>().Single().Open(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = Mode },
|
QueueMode = Mode,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(InitialBeatmap)
|
new PlaylistItem(InitialBeatmap)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}));
|
}));
|
||||||
|
|
||||||
AddUntilStep("wait for room open", () => this.ChildrenOfType<MultiplayerMatchSubScreen>().FirstOrDefault()?.IsLoaded == true);
|
AddUntilStep("wait for room open", () => this.ChildrenOfType<MultiplayerMatchSubScreen>().FirstOrDefault()?.IsLoaded == true);
|
||||||
@ -98,7 +96,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestCreatedWithCorrectMode()
|
public void TestCreatedWithCorrectMode()
|
||||||
{
|
{
|
||||||
AddUntilStep("room created with correct mode", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == Mode);
|
AddUntilStep("room created with correct mode", () => MultiplayerClient.ClientAPIRoom?.QueueMode == Mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void RunGameplay()
|
protected void RunGameplay()
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -12,7 +10,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneCreateMultiplayerMatchButton : MultiplayerTestScene
|
public partial class TestSceneCreateMultiplayerMatchButton : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private CreateMultiplayerMatchButton button;
|
private CreateMultiplayerMatchButton button = null!;
|
||||||
|
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
{
|
{
|
||||||
@ -29,7 +27,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestButtonEnableStateChanges()
|
public void TestButtonEnableStateChanges()
|
||||||
{
|
{
|
||||||
IDisposable joiningRoomOperation = null;
|
IDisposable joiningRoomOperation = null!;
|
||||||
|
|
||||||
assertButtonEnableState(true);
|
assertButtonEnableState(true);
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
@ -10,6 +8,7 @@ using System.Threading.Tasks;
|
|||||||
using Moq;
|
using Moq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Cursor;
|
using osu.Framework.Graphics.Cursor;
|
||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
@ -25,14 +24,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
private readonly Room room = new Room
|
private readonly Room room = new Room
|
||||||
{
|
{
|
||||||
HasPassword = { Value = true }
|
Password = "*"
|
||||||
};
|
};
|
||||||
|
|
||||||
[Cached]
|
[Cached]
|
||||||
protected readonly OverlayColourProvider ColourProvider = new OverlayColourProvider(OverlayColourScheme.Pink);
|
protected readonly OverlayColourProvider ColourProvider = new OverlayColourProvider(OverlayColourScheme.Pink);
|
||||||
|
|
||||||
private DrawableLoungeRoom drawableRoom;
|
private DrawableLoungeRoom drawableRoom = null!;
|
||||||
private SearchTextBox searchTextBox;
|
private SearchTextBox searchTextBox = null!;
|
||||||
|
|
||||||
private readonly ManualResetEventSlim allowResponseCallback = new ManualResetEventSlim();
|
private readonly ManualResetEventSlim allowResponseCallback = new ManualResetEventSlim();
|
||||||
|
|
||||||
@ -78,6 +77,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
|
SelectedRoom = new Bindable<Room?>()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -87,7 +87,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestFocusViaKeyboardCommit()
|
public void TestFocusViaKeyboardCommit()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover popover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? popover = null;
|
||||||
|
|
||||||
AddAssert("search textbox has focus", () => checkFocus(searchTextBox));
|
AddAssert("search textbox has focus", () => checkFocus(searchTextBox));
|
||||||
AddStep("click room twice", () =>
|
AddStep("click room twice", () =>
|
||||||
@ -103,11 +103,11 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("enter password", () => popover.ChildrenOfType<OsuPasswordTextBox>().Single().Text = "password");
|
AddStep("enter password", () => popover.ChildrenOfType<OsuPasswordTextBox>().Single().Text = "password");
|
||||||
AddStep("commit via enter", () => InputManager.Key(Key.Enter));
|
AddStep("commit via enter", () => InputManager.Key(Key.Enter));
|
||||||
|
|
||||||
AddAssert("popover has focus", () => checkFocus(popover));
|
AddAssert("popover has focus", () => checkFocus(popover!));
|
||||||
|
|
||||||
AddStep("attempt another enter", () => InputManager.Key(Key.Enter));
|
AddStep("attempt another enter", () => InputManager.Key(Key.Enter));
|
||||||
|
|
||||||
AddAssert("popover still has focus", () => checkFocus(popover));
|
AddAssert("popover still has focus", () => checkFocus(popover!));
|
||||||
|
|
||||||
AddStep("unblock response", () => allowResponseCallback.Set());
|
AddStep("unblock response", () => allowResponseCallback.Set());
|
||||||
|
|
||||||
@ -122,7 +122,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestFocusViaMouseCommit()
|
public void TestFocusViaMouseCommit()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover popover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? popover = null;
|
||||||
|
|
||||||
AddAssert("search textbox has focus", () => checkFocus(searchTextBox));
|
AddAssert("search textbox has focus", () => checkFocus(searchTextBox));
|
||||||
AddStep("click room twice", () =>
|
AddStep("click room twice", () =>
|
||||||
@ -144,11 +144,11 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
InputManager.Click(MouseButton.Left);
|
InputManager.Click(MouseButton.Left);
|
||||||
});
|
});
|
||||||
|
|
||||||
AddAssert("popover has focus", () => checkFocus(popover));
|
AddAssert("popover has focus", () => checkFocus(popover!));
|
||||||
|
|
||||||
AddStep("attempt another click", () => InputManager.Click(MouseButton.Left));
|
AddStep("attempt another click", () => InputManager.Click(MouseButton.Left));
|
||||||
|
|
||||||
AddAssert("popover still has focus", () => checkFocus(popover));
|
AddAssert("popover still has focus", () => checkFocus(popover!));
|
||||||
|
|
||||||
AddStep("unblock response", () => allowResponseCallback.Set());
|
AddStep("unblock response", () => allowResponseCallback.Set());
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -32,51 +30,26 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Cached]
|
[Cached]
|
||||||
protected readonly OverlayColourProvider ColourProvider = new OverlayColourProvider(OverlayColourScheme.Plum);
|
protected readonly OverlayColourProvider ColourProvider = new OverlayColourProvider(OverlayColourScheme.Plum);
|
||||||
|
|
||||||
private readonly Bindable<Room> selectedRoom = new Bindable<Room>();
|
private readonly Bindable<Room?> selectedRoom = new Bindable<Room?>();
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestMultipleStatuses()
|
public void TestMultipleStatuses()
|
||||||
{
|
{
|
||||||
FillFlowContainer rooms = null;
|
FillFlowContainer rooms = null!;
|
||||||
|
|
||||||
AddStep("create rooms", () =>
|
AddStep("create rooms", () =>
|
||||||
{
|
{
|
||||||
Child = rooms = new FillFlowContainer
|
PlaylistItem item1 = new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
BeatmapInfo = { StarRating = 2.5 }
|
||||||
Origin = Anchor.Centre,
|
}.BeatmapInfo);
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
Size = new Vector2(0.9f),
|
PlaylistItem item2 = new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
||||||
Spacing = new Vector2(10),
|
|
||||||
Children = new Drawable[]
|
|
||||||
{
|
{
|
||||||
createLoungeRoom(new Room
|
BeatmapInfo = { StarRating = 4.5 }
|
||||||
{
|
}.BeatmapInfo);
|
||||||
Name = { Value = "Multiplayer room" },
|
|
||||||
Status = { Value = new RoomStatusOpen() },
|
PlaylistItem item3 = new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddDays(1) },
|
|
||||||
Type = { Value = MatchType.HeadToHead },
|
|
||||||
Playlist =
|
|
||||||
{
|
|
||||||
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
|
||||||
{
|
|
||||||
BeatmapInfo =
|
|
||||||
{
|
|
||||||
StarRating = 2.5
|
|
||||||
}
|
|
||||||
}.BeatmapInfo)
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
createLoungeRoom(new Room
|
|
||||||
{
|
|
||||||
Name = { Value = "Private room" },
|
|
||||||
Status = { Value = new RoomStatusOpenPrivate() },
|
|
||||||
HasPassword = { Value = true },
|
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddDays(1) },
|
|
||||||
Type = { Value = MatchType.HeadToHead },
|
|
||||||
Playlist =
|
|
||||||
{
|
|
||||||
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
|
||||||
{
|
{
|
||||||
BeatmapInfo =
|
BeatmapInfo =
|
||||||
{
|
{
|
||||||
@ -89,49 +62,61 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
TitleUnicode = "very very very very very very very very very very very long title",
|
TitleUnicode = "very very very very very very very very very very very long title",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}.BeatmapInfo)
|
}.BeatmapInfo);
|
||||||
}
|
|
||||||
|
Child = rooms = new FillFlowContainer
|
||||||
|
{
|
||||||
|
Anchor = Anchor.Centre,
|
||||||
|
Origin = Anchor.Centre,
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Size = new Vector2(0.9f),
|
||||||
|
Spacing = new Vector2(10),
|
||||||
|
Children = new Drawable[]
|
||||||
|
{
|
||||||
|
createLoungeRoom(new Room
|
||||||
|
{
|
||||||
|
Name = "Multiplayer room",
|
||||||
|
Status = new RoomStatusOpen(),
|
||||||
|
EndDate = DateTimeOffset.Now.AddDays(1),
|
||||||
|
Type = MatchType.HeadToHead,
|
||||||
|
Playlist = [item1],
|
||||||
|
CurrentPlaylistItem = item1
|
||||||
}),
|
}),
|
||||||
createLoungeRoom(new Room
|
createLoungeRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Playlist room with multiple beatmaps" },
|
Name = "Private room",
|
||||||
Status = { Value = new RoomStatusPlaying() },
|
Status = new RoomStatusOpenPrivate(),
|
||||||
EndDate = { Value = DateTimeOffset.Now.AddDays(1) },
|
Password = "*",
|
||||||
Playlist =
|
EndDate = DateTimeOffset.Now.AddDays(1),
|
||||||
{
|
Type = MatchType.HeadToHead,
|
||||||
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
Playlist = [item3],
|
||||||
{
|
CurrentPlaylistItem = item3
|
||||||
BeatmapInfo =
|
|
||||||
{
|
|
||||||
StarRating = 2.5
|
|
||||||
}
|
|
||||||
}.BeatmapInfo),
|
|
||||||
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo)
|
|
||||||
{
|
|
||||||
BeatmapInfo =
|
|
||||||
{
|
|
||||||
StarRating = 4.5
|
|
||||||
}
|
|
||||||
}.BeatmapInfo)
|
|
||||||
}
|
|
||||||
}),
|
}),
|
||||||
createLoungeRoom(new Room
|
createLoungeRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Finished room" },
|
Name = "Playlist room with multiple beatmaps",
|
||||||
Status = { Value = new RoomStatusEnded() },
|
Status = new RoomStatusPlaying(),
|
||||||
EndDate = { Value = DateTimeOffset.Now },
|
EndDate = DateTimeOffset.Now.AddDays(1),
|
||||||
|
Playlist = [item1, item2],
|
||||||
|
CurrentPlaylistItem = item1
|
||||||
}),
|
}),
|
||||||
createLoungeRoom(new Room
|
createLoungeRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Spotlight room" },
|
Name = "Finished room",
|
||||||
Status = { Value = new RoomStatusOpen() },
|
Status = new RoomStatusEnded(),
|
||||||
Category = { Value = RoomCategory.Spotlight },
|
EndDate = DateTimeOffset.Now,
|
||||||
}),
|
}),
|
||||||
createLoungeRoom(new Room
|
createLoungeRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Featured artist room" },
|
Name = "Spotlight room",
|
||||||
Status = { Value = new RoomStatusOpen() },
|
Status = new RoomStatusOpen(),
|
||||||
Category = { Value = RoomCategory.FeaturedArtist },
|
Category = RoomCategory.Spotlight,
|
||||||
|
}),
|
||||||
|
createLoungeRoom(new Room
|
||||||
|
{
|
||||||
|
Name = "Featured artist room",
|
||||||
|
Status = new RoomStatusOpen(),
|
||||||
|
Category = RoomCategory.FeaturedArtist,
|
||||||
}),
|
}),
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -145,24 +130,24 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestEnableAndDisablePassword()
|
public void TestEnableAndDisablePassword()
|
||||||
{
|
{
|
||||||
DrawableRoom drawableRoom = null;
|
DrawableRoom drawableRoom = null!;
|
||||||
Room room = null;
|
Room room = null!;
|
||||||
|
|
||||||
AddStep("create room", () => Child = drawableRoom = createLoungeRoom(room = new Room
|
AddStep("create room", () => Child = drawableRoom = createLoungeRoom(room = new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Room with password" },
|
Name = "Room with password",
|
||||||
Status = { Value = new RoomStatusOpen() },
|
Status = new RoomStatusOpen(),
|
||||||
Type = { Value = MatchType.HeadToHead },
|
Type = MatchType.HeadToHead,
|
||||||
}));
|
}));
|
||||||
|
|
||||||
AddUntilStep("wait for panel load", () => drawableRoom.ChildrenOfType<DrawableRoomParticipantsList>().Any());
|
AddUntilStep("wait for panel load", () => drawableRoom.ChildrenOfType<DrawableRoomParticipantsList>().Any());
|
||||||
|
|
||||||
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
||||||
|
|
||||||
AddStep("set password", () => room.Password.Value = "password");
|
AddStep("set password", () => room.Password = "password");
|
||||||
AddAssert("password icon visible", () => Precision.AlmostEquals(1, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
AddAssert("password icon visible", () => Precision.AlmostEquals(1, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
||||||
|
|
||||||
AddStep("unset password", () => room.Password.Value = string.Empty);
|
AddStep("unset password", () => room.Password = string.Empty);
|
||||||
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -179,43 +164,52 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
new DrawableMatchRoom(new Room
|
new DrawableMatchRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "A host-only room" },
|
Name = "A host-only room",
|
||||||
QueueMode = { Value = QueueMode.HostOnly },
|
QueueMode = QueueMode.HostOnly,
|
||||||
Type = { Value = MatchType.HeadToHead }
|
Type = MatchType.HeadToHead,
|
||||||
}),
|
})
|
||||||
|
{
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>()
|
||||||
|
},
|
||||||
new DrawableMatchRoom(new Room
|
new DrawableMatchRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "An all-players, team-versus room" },
|
Name = "An all-players, team-versus room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Type = { Value = MatchType.TeamVersus }
|
Type = MatchType.TeamVersus
|
||||||
}),
|
})
|
||||||
|
{
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>()
|
||||||
|
},
|
||||||
new DrawableMatchRoom(new Room
|
new DrawableMatchRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "A round-robin room" },
|
Name = "A round-robin room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayersRoundRobin },
|
QueueMode = QueueMode.AllPlayersRoundRobin,
|
||||||
Type = { Value = MatchType.HeadToHead }
|
Type = MatchType.HeadToHead
|
||||||
}),
|
})
|
||||||
|
{
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>()
|
||||||
|
},
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private DrawableRoom createLoungeRoom(Room room)
|
private DrawableRoom createLoungeRoom(Room room)
|
||||||
{
|
{
|
||||||
room.Host.Value ??= new APIUser { Username = "peppy", Id = 2 };
|
room.Host ??= new APIUser { Username = "peppy", Id = 2 };
|
||||||
|
|
||||||
if (room.RecentParticipants.Count == 0)
|
if (room.RecentParticipants.Count == 0)
|
||||||
{
|
{
|
||||||
room.RecentParticipants.AddRange(Enumerable.Range(0, 20).Select(i => new APIUser
|
room.RecentParticipants = Enumerable.Range(0, 20).Select(i => new APIUser
|
||||||
{
|
{
|
||||||
Id = i,
|
Id = i,
|
||||||
Username = $"User {i}"
|
Username = $"User {i}"
|
||||||
}));
|
}).ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new DrawableLoungeRoom(room)
|
return new DrawableLoungeRoom(room)
|
||||||
{
|
{
|
||||||
MatchingFilter = true,
|
MatchingFilter = true,
|
||||||
SelectedRoom = { BindTarget = selectedRoom }
|
SelectedRoom = selectedRoom
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -17,7 +15,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneDrawableRoomParticipantsList : OnlinePlayTestScene
|
public partial class TestSceneDrawableRoomParticipantsList : OnlinePlayTestScene
|
||||||
{
|
{
|
||||||
private DrawableRoomParticipantsList list;
|
private DrawableRoomParticipantsList list = null!;
|
||||||
|
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
{
|
{
|
||||||
@ -27,18 +25,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room
|
SelectedRoom.Value = new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "test room" },
|
Name = "test room",
|
||||||
Host =
|
Host = new APIUser
|
||||||
{
|
|
||||||
Value = new APIUser
|
|
||||||
{
|
{
|
||||||
Id = 2,
|
Id = 2,
|
||||||
Username = "peppy",
|
Username = "peppy",
|
||||||
}
|
}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Child = list = new DrawableRoomParticipantsList
|
Child = list = new DrawableRoomParticipantsList(SelectedRoom.Value)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
@ -124,7 +119,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddAssert("4 circles displayed", () => list.ChildrenOfType<UpdateableAvatar>().Count() == 4);
|
AddAssert("4 circles displayed", () => list.ChildrenOfType<UpdateableAvatar>().Count() == 4);
|
||||||
AddAssert("46 hidden users", () => list.ChildrenOfType<DrawableRoomParticipantsList.HiddenUserCount>().Single().Count == 46);
|
AddAssert("46 hidden users", () => list.ChildrenOfType<DrawableRoomParticipantsList.HiddenUserCount>().Single().Count == 46);
|
||||||
|
|
||||||
AddStep("remove from end", () => removeUserAt(SelectedRoom.Value.RecentParticipants.Count - 1));
|
AddStep("remove from end", () => removeUserAt(SelectedRoom.Value!.RecentParticipants.Count - 1));
|
||||||
AddAssert("4 circles displayed", () => list.ChildrenOfType<UpdateableAvatar>().Count() == 4);
|
AddAssert("4 circles displayed", () => list.ChildrenOfType<UpdateableAvatar>().Count() == 4);
|
||||||
AddAssert("45 hidden users", () => list.ChildrenOfType<DrawableRoomParticipantsList.HiddenUserCount>().Single().Count == 45);
|
AddAssert("45 hidden users", () => list.ChildrenOfType<DrawableRoomParticipantsList.HiddenUserCount>().Single().Count == 45);
|
||||||
|
|
||||||
@ -143,18 +138,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
private void addUser(int id)
|
private void addUser(int id)
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.RecentParticipants.Add(new APIUser
|
SelectedRoom.Value!.RecentParticipants = SelectedRoom.Value!.RecentParticipants.Append(new APIUser
|
||||||
{
|
{
|
||||||
Id = id,
|
Id = id,
|
||||||
Username = $"User {id}"
|
Username = $"User {id}"
|
||||||
});
|
}).ToArray();
|
||||||
SelectedRoom.Value.ParticipantCount.Value++;
|
SelectedRoom.Value!.ParticipantCount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void removeUserAt(int index)
|
private void removeUserAt(int index)
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.RecentParticipants.RemoveAt(index);
|
SelectedRoom.Value!.RecentParticipants = SelectedRoom.Value!.RecentParticipants.Where(u => !u.Equals(SelectedRoom.Value!.RecentParticipants[index])).ToArray();
|
||||||
SelectedRoom.Value.ParticipantCount.Value--;
|
SelectedRoom.Value!.ParticipantCount--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
@ -39,9 +37,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneDrawableRoomPlaylist : MultiplayerTestScene
|
public partial class TestSceneDrawableRoomPlaylist : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private TestPlaylist playlist;
|
private TestPlaylist playlist = null!;
|
||||||
|
private BeatmapManager manager = null!;
|
||||||
private BeatmapManager manager;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(GameHost host, AudioManager audio)
|
private void load(GameHost host, AudioManager audio)
|
||||||
@ -199,14 +196,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestDownloadButtonHiddenWhenBeatmapExists()
|
public void TestDownloadButtonHiddenWhenBeatmapExists()
|
||||||
{
|
{
|
||||||
Live<BeatmapSetInfo> imported = null;
|
Live<BeatmapSetInfo> imported = null!;
|
||||||
|
|
||||||
AddStep("import beatmap", () =>
|
AddStep("import beatmap", () =>
|
||||||
{
|
{
|
||||||
var beatmap = new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo;
|
var beatmap = new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo;
|
||||||
|
|
||||||
Debug.Assert(beatmap.BeatmapSet != null);
|
Debug.Assert(beatmap.BeatmapSet != null);
|
||||||
imported = manager.Import(beatmap.BeatmapSet);
|
imported = manager.Import(beatmap.BeatmapSet)!;
|
||||||
});
|
});
|
||||||
|
|
||||||
createPlaylistWithBeatmaps(() => imported.PerformRead(s => s.Beatmaps.Detach()));
|
createPlaylistWithBeatmaps(() => imported.PerformRead(s => s.Beatmaps.Detach()));
|
||||||
@ -378,7 +375,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
private void createPlaylist(Action<TestPlaylist> setupPlaylist = null)
|
private void createPlaylist(Action<TestPlaylist>? setupPlaylist = null)
|
||||||
{
|
{
|
||||||
AddStep("create playlist", () =>
|
AddStep("create playlist", () =>
|
||||||
{
|
{
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -26,9 +24,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneFreeModSelectOverlay : MultiplayerTestScene
|
public partial class TestSceneFreeModSelectOverlay : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private FreeModSelectOverlay freeModSelectOverlay;
|
private FreeModSelectOverlay freeModSelectOverlay = null!;
|
||||||
private FooterButtonFreeMods footerButtonFreeMods;
|
private FooterButtonFreeMods footerButtonFreeMods = null!;
|
||||||
private ScreenFooter footer;
|
private ScreenFooter footer = null!;
|
||||||
private readonly Bindable<Dictionary<ModType, IReadOnlyList<Mod>>> availableMods = new Bindable<Dictionary<ModType, IReadOnlyList<Mod>>>();
|
private readonly Bindable<Dictionary<ModType, IReadOnlyList<Mod>>> availableMods = new Bindable<Dictionary<ModType, IReadOnlyList<Mod>>>();
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
@ -49,7 +47,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddToggleStep("toggle visibility", visible =>
|
AddToggleStep("toggle visibility", visible =>
|
||||||
{
|
{
|
||||||
if (freeModSelectOverlay != null)
|
|
||||||
freeModSelectOverlay.State.Value = visible ? Visibility.Visible : Visibility.Hidden;
|
freeModSelectOverlay.State.Value = visible ? Visibility.Visible : Visibility.Hidden;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Moq;
|
using Moq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -20,7 +18,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneGameplayChatDisplay : OsuManualInputManagerTestScene
|
public partial class TestSceneGameplayChatDisplay : OsuManualInputManagerTestScene
|
||||||
{
|
{
|
||||||
private GameplayChatDisplay chatDisplay;
|
private GameplayChatDisplay chatDisplay = null!;
|
||||||
|
|
||||||
[Cached(typeof(ILocalUserPlayInfo))]
|
[Cached(typeof(ILocalUserPlayInfo))]
|
||||||
private ILocalUserPlayInfo localUserInfo;
|
private ILocalUserPlayInfo localUserInfo;
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -46,7 +44,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
QueueMode = QueueMode.AllPlayers
|
QueueMode = QueueMode.AllPlayers
|
||||||
}).WaitSafely());
|
}).WaitSafely());
|
||||||
|
|
||||||
AddUntilStep("api room updated", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == QueueMode.AllPlayers);
|
AddUntilStep("api room updated", () => MultiplayerClient.ClientAPIRoom?.QueueMode == QueueMode.AllPlayers);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -70,13 +68,13 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
RunGameplay();
|
RunGameplay();
|
||||||
|
|
||||||
IBeatmapInfo firstBeatmap = null;
|
IBeatmapInfo firstBeatmap = null!;
|
||||||
AddStep("get first playlist item beatmap", () => firstBeatmap = MultiplayerClient.ServerAPIRoom?.Playlist[0].Beatmap);
|
AddStep("get first playlist item beatmap", () => firstBeatmap = MultiplayerClient.ServerAPIRoom!.Playlist[0].Beatmap);
|
||||||
|
|
||||||
selectNewItem(() => OtherBeatmap);
|
selectNewItem(() => OtherBeatmap);
|
||||||
|
|
||||||
AddUntilStep("first playlist item hasn't changed", () => MultiplayerClient.ServerAPIRoom?.Playlist[0].Beatmap == firstBeatmap);
|
AddUntilStep("first playlist item hasn't changed", () => MultiplayerClient.ServerAPIRoom!.Playlist[0].Beatmap == firstBeatmap);
|
||||||
AddUntilStep("second playlist item changed", () => MultiplayerClient.ClientAPIRoom?.Playlist[1].Beatmap != firstBeatmap);
|
AddUntilStep("second playlist item changed", () => MultiplayerClient.ClientAPIRoom!.Playlist[1].Beatmap != firstBeatmap);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -103,7 +101,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddUntilStep("wait for song select", () => CurrentSubScreen is Screens.Select.SongSelect select && select.BeatmapSetsLoaded);
|
AddUntilStep("wait for song select", () => CurrentSubScreen is Screens.Select.SongSelect select && select.BeatmapSetsLoaded);
|
||||||
|
|
||||||
BeatmapInfo otherBeatmap = null;
|
BeatmapInfo otherBeatmap = null!;
|
||||||
AddStep("select other beatmap", () => ((Screens.Select.SongSelect)CurrentSubScreen).FinaliseSelection(otherBeatmap = beatmap()));
|
AddStep("select other beatmap", () => ((Screens.Select.SongSelect)CurrentSubScreen).FinaliseSelection(otherBeatmap = beatmap()));
|
||||||
|
|
||||||
AddUntilStep("wait for return to match", () => CurrentSubScreen is MultiplayerMatchSubScreen);
|
AddUntilStep("wait for return to match", () => CurrentSubScreen is MultiplayerMatchSubScreen);
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -23,7 +21,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
protected new TestRoomManager RoomManager => (TestRoomManager)base.RoomManager;
|
protected new TestRoomManager RoomManager => (TestRoomManager)base.RoomManager;
|
||||||
|
|
||||||
private RoomsContainer container;
|
private RoomsContainer container = null!;
|
||||||
|
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
{
|
{
|
||||||
@ -55,20 +53,20 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddAssert("has 5 rooms", () => container.Rooms.Count == 5);
|
AddAssert("has 5 rooms", () => container.Rooms.Count == 5);
|
||||||
|
|
||||||
AddAssert("all spotlights at top", () => container.Rooms
|
AddAssert("all spotlights at top", () => container.Rooms
|
||||||
.SkipWhile(r => r.Room.Category.Value == RoomCategory.Spotlight)
|
.SkipWhile(r => r.Room.Category == RoomCategory.Spotlight)
|
||||||
.All(r => r.Room.Category.Value == RoomCategory.Normal));
|
.All(r => r.Room.Category == RoomCategory.Normal));
|
||||||
|
|
||||||
AddStep("remove first room", () => RoomManager.RemoveRoom(RoomManager.Rooms.First(r => r.RoomID.Value == 0)));
|
AddStep("remove first room", () => RoomManager.RemoveRoom(RoomManager.Rooms.First(r => r.RoomID == 0)));
|
||||||
AddAssert("has 4 rooms", () => container.Rooms.Count == 4);
|
AddAssert("has 4 rooms", () => container.Rooms.Count == 4);
|
||||||
AddAssert("first room removed", () => container.Rooms.All(r => r.Room.RoomID.Value != 0));
|
AddAssert("first room removed", () => container.Rooms.All(r => r.Room.RoomID != 0));
|
||||||
|
|
||||||
AddStep("select first room", () => container.Rooms.First().TriggerClick());
|
AddStep("select first room", () => container.Rooms.First().TriggerClick());
|
||||||
AddAssert("first spotlight selected", () => checkRoomSelected(RoomManager.Rooms.First(r => r.Category.Value == RoomCategory.Spotlight)));
|
AddAssert("first spotlight selected", () => checkRoomSelected(RoomManager.Rooms.First(r => r.Category == RoomCategory.Spotlight)));
|
||||||
|
|
||||||
AddStep("remove last room", () => RoomManager.RemoveRoom(RoomManager.Rooms.MinBy(r => r.RoomID?.Value)));
|
AddStep("remove last room", () => RoomManager.RemoveRoom(RoomManager.Rooms.MinBy(r => r.RoomID)!));
|
||||||
AddAssert("first spotlight still selected", () => checkRoomSelected(RoomManager.Rooms.First(r => r.Category.Value == RoomCategory.Spotlight)));
|
AddAssert("first spotlight still selected", () => checkRoomSelected(RoomManager.Rooms.First(r => r.Category == RoomCategory.Spotlight)));
|
||||||
|
|
||||||
AddStep("remove spotlight room", () => RoomManager.RemoveRoom(RoomManager.Rooms.Single(r => r.Category.Value == RoomCategory.Spotlight)));
|
AddStep("remove spotlight room", () => RoomManager.RemoveRoom(RoomManager.Rooms.Single(r => r.Category == RoomCategory.Spotlight)));
|
||||||
AddAssert("selection vacated", () => checkRoomSelected(null));
|
AddAssert("selection vacated", () => checkRoomSelected(null));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +155,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("add rooms", () => RoomManager.AddRooms(3, new CatchRuleset().RulesetInfo));
|
AddStep("add rooms", () => RoomManager.AddRooms(3, new CatchRuleset().RulesetInfo));
|
||||||
|
|
||||||
// Todo: What even is this case...?
|
// Todo: What even is this case...?
|
||||||
AddStep("set empty filter criteria", () => container.Filter.Value = null);
|
AddStep("set empty filter criteria", () => container.Filter.Value = new FilterCriteria());
|
||||||
AddUntilStep("5 rooms visible", () => container.Rooms.Count(r => r.IsPresent) == 5);
|
AddUntilStep("5 rooms visible", () => container.Rooms.Count(r => r.IsPresent) == 5);
|
||||||
|
|
||||||
AddStep("filter osu! rooms", () => container.Filter.Value = new FilterCriteria { Ruleset = new OsuRuleset().RulesetInfo });
|
AddStep("filter osu! rooms", () => container.Filter.Value = new FilterCriteria { Ruleset = new OsuRuleset().RulesetInfo });
|
||||||
@ -182,11 +180,11 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("filter public rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Public });
|
AddStep("filter public rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Public });
|
||||||
|
|
||||||
AddUntilStep("private room hidden", () => container.Rooms.All(r => !r.Room.HasPassword.Value));
|
AddUntilStep("private room hidden", () => container.Rooms.All(r => !r.Room.HasPassword));
|
||||||
|
|
||||||
AddStep("filter private rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Private });
|
AddStep("filter private rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Private });
|
||||||
|
|
||||||
AddUntilStep("public room hidden", () => container.Rooms.All(r => r.Room.HasPassword.Value));
|
AddUntilStep("public room hidden", () => container.Rooms.All(r => r.Room.HasPassword));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -195,9 +193,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("add rooms", () => RoomManager.AddRooms(3, withPassword: true));
|
AddStep("add rooms", () => RoomManager.AddRooms(3, withPassword: true));
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool checkRoomSelected(Room room) => SelectedRoom.Value == room;
|
private bool checkRoomSelected(Room? room) => SelectedRoom.Value == room;
|
||||||
|
|
||||||
private Room getRoomInFlow(int index) =>
|
private Room? getRoomInFlow(int index) =>
|
||||||
(container.ChildrenOfType<FillFlowContainer<DrawableLoungeRoom>>().First().FlowingChildren.ElementAt(index) as DrawableRoom)?.Room;
|
(container.ChildrenOfType<FillFlowContainer<DrawableLoungeRoom>>().First().FlowingChildren.ElementAt(index) as DrawableRoom)?.Room;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Game.Online.API;
|
using osu.Game.Online.API;
|
||||||
using osu.Game.Online.Rooms;
|
using osu.Game.Online.Rooms;
|
||||||
@ -23,7 +24,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room();
|
SelectedRoom.Value = new Room();
|
||||||
|
|
||||||
Child = new MatchBeatmapDetailArea
|
Child = new MatchBeatmapDetailArea(SelectedRoom.Value)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
@ -35,7 +36,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
private void createNewItem()
|
private void createNewItem()
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist = SelectedRoom.Value.Playlist.Append(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
ID = SelectedRoom.Value.Playlist.Count,
|
ID = SelectedRoom.Value.Playlist.Count,
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
@ -45,7 +46,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
new APIMod(new OsuModDoubleTime()),
|
new APIMod(new OsuModDoubleTime()),
|
||||||
new APIMod(new OsuModAutoplay())
|
new APIMod(new OsuModAutoplay())
|
||||||
}
|
}
|
||||||
});
|
}).ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -61,9 +61,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("create leaderboard", () =>
|
AddStep("create leaderboard", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room { RoomID = { Value = 3 } };
|
SelectedRoom.Value = new Room { RoomID = 3 };
|
||||||
|
|
||||||
Child = new MatchLeaderboard
|
Child = new MatchLeaderboard(SelectedRoom.Value)
|
||||||
{
|
{
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
|
@ -43,12 +43,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
private OsuButton readyButton => control.ChildrenOfType<OsuButton>().Single();
|
private OsuButton readyButton => control.ChildrenOfType<OsuButton>().Single();
|
||||||
|
|
||||||
[Cached(typeof(IBindable<PlaylistItem>))]
|
|
||||||
private readonly Bindable<PlaylistItem> currentItem = new Bindable<PlaylistItem>();
|
|
||||||
|
|
||||||
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent) =>
|
|
||||||
new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent)) { Model = { BindTarget = room } };
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load()
|
private void load()
|
||||||
{
|
{
|
||||||
@ -107,31 +101,33 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[SetUpSteps]
|
[SetUpSteps]
|
||||||
public void SetUpSteps()
|
public void SetUpSteps()
|
||||||
{
|
{
|
||||||
|
PlaylistItem item = null!;
|
||||||
|
|
||||||
AddStep("reset state", () =>
|
AddStep("reset state", () =>
|
||||||
{
|
{
|
||||||
multiplayerClient.Invocations.Clear();
|
multiplayerClient.Invocations.Clear();
|
||||||
|
|
||||||
beatmapAvailability.Value = BeatmapAvailability.LocallyAvailable();
|
beatmapAvailability.Value = BeatmapAvailability.LocallyAvailable();
|
||||||
|
|
||||||
currentItem.Value = new PlaylistItem(Beatmap.Value.BeatmapInfo)
|
item = new PlaylistItem(Beatmap.Value.BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = Beatmap.Value.BeatmapInfo.Ruleset.OnlineID
|
RulesetID = Beatmap.Value.BeatmapInfo.Ruleset.OnlineID
|
||||||
};
|
};
|
||||||
|
|
||||||
room.Value = new Room
|
room.Value = new Room
|
||||||
{
|
{
|
||||||
Playlist = { currentItem.Value },
|
Playlist = [item],
|
||||||
CurrentPlaylistItem = { BindTarget = currentItem }
|
CurrentPlaylistItem = item
|
||||||
};
|
};
|
||||||
|
|
||||||
localUser = new MultiplayerRoomUser(API.LocalUser.Value.Id) { User = API.LocalUser.Value };
|
localUser = new MultiplayerRoomUser(API.LocalUser.Value.Id)
|
||||||
|
{
|
||||||
|
User = API.LocalUser.Value
|
||||||
|
};
|
||||||
|
|
||||||
multiplayerRoom = new MultiplayerRoom(0)
|
multiplayerRoom = new MultiplayerRoom(0)
|
||||||
{
|
{
|
||||||
Playlist =
|
Playlist = { TestMultiplayerClient.CreateMultiplayerPlaylistItem(item) },
|
||||||
{
|
|
||||||
TestMultiplayerClient.CreateMultiplayerPlaylistItem(currentItem.Value),
|
|
||||||
},
|
|
||||||
Users = { localUser },
|
Users = { localUser },
|
||||||
Host = localUser,
|
Host = localUser,
|
||||||
};
|
};
|
||||||
@ -144,6 +140,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Size = new Vector2(250, 50),
|
Size = new Vector2(250, 50),
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>(item)
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -18,8 +16,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiSpectatorLeaderboard : MultiplayerTestScene
|
public partial class TestSceneMultiSpectatorLeaderboard : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private Dictionary<int, ManualClock> clocks;
|
private Dictionary<int, ManualClock> clocks = null!;
|
||||||
private MultiSpectatorLeaderboard leaderboard;
|
private MultiSpectatorLeaderboard? leaderboard;
|
||||||
|
|
||||||
[SetUpSteps]
|
[SetUpSteps]
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
@ -55,13 +53,13 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}, Add);
|
}, Add);
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("wait for load", () => leaderboard.IsLoaded);
|
AddUntilStep("wait for load", () => leaderboard!.IsLoaded);
|
||||||
AddUntilStep("wait for user population", () => leaderboard.ChildrenOfType<GameplayLeaderboardScore>().Count() == 2);
|
AddUntilStep("wait for user population", () => leaderboard.ChildrenOfType<GameplayLeaderboardScore>().Count() == 2);
|
||||||
|
|
||||||
AddStep("add clock sources", () =>
|
AddStep("add clock sources", () =>
|
||||||
{
|
{
|
||||||
foreach ((int userId, var clock) in clocks)
|
foreach ((int userId, var clock) in clocks)
|
||||||
leaderboard.AddClock(userId, clock);
|
leaderboard!.AddClock(userId, clock);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -455,7 +455,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
applyToBeatmap?.Invoke(Beatmap.Value);
|
applyToBeatmap?.Invoke(Beatmap.Value);
|
||||||
|
|
||||||
LoadScreen(spectatorScreen = new MultiSpectatorScreen(SelectedRoom.Value, playingUsers.ToArray()));
|
LoadScreen(spectatorScreen = new MultiSpectatorScreen(SelectedRoom.Value!, playingUsers.ToArray()));
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("wait for screen load", () => spectatorScreen.LoadState == LoadState.Loaded && (!waitForPlayerLoad || spectatorScreen.AllPlayersLoaded));
|
AddUntilStep("wait for screen load", () => spectatorScreen.LoadState == LoadState.Loaded && (!waitForPlayerLoad || spectatorScreen.AllPlayersLoaded));
|
||||||
|
@ -103,14 +103,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddRepeatStep("random stuff happens", performRandomAction, 30);
|
AddRepeatStep("random stuff happens", performRandomAction, 30);
|
||||||
@ -238,17 +238,17 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("Check participant count correct", () => multiplayerClient.ClientAPIRoom?.ParticipantCount.Value == 1);
|
AddUntilStep("Check participant count correct", () => multiplayerClient.ClientAPIRoom?.ParticipantCount == 1);
|
||||||
AddUntilStep("Check participant list contains user", () => multiplayerClient.ClientAPIRoom?.RecentParticipants.Count(u => u.Id == API.LocalUser.Value.Id) == 1);
|
AddUntilStep("Check participant list contains user", () => multiplayerClient.ClientAPIRoom?.RecentParticipants.Count(u => u.Id == API.LocalUser.Value.Id) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,14 +259,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
roomManager.AddServerSideRoom(new Room
|
roomManager.AddServerSideRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}, API.LocalUser.Value);
|
}, API.LocalUser.Value);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -288,14 +288,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
roomManager.AddServerSideRoom(new Room
|
roomManager.AddServerSideRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}, API.LocalUser.Value);
|
}, API.LocalUser.Value);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -308,7 +308,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddUntilStep("wait for room open", () => this.ChildrenOfType<MultiplayerMatchSubScreen>().FirstOrDefault()?.IsLoaded == true);
|
AddUntilStep("wait for room open", () => this.ChildrenOfType<MultiplayerMatchSubScreen>().FirstOrDefault()?.IsLoaded == true);
|
||||||
AddUntilStep("wait for join", () => multiplayerClient.RoomJoined);
|
AddUntilStep("wait for join", () => multiplayerClient.RoomJoined);
|
||||||
|
|
||||||
AddUntilStep("Check participant count correct", () => multiplayerClient.ClientAPIRoom?.ParticipantCount.Value == 1);
|
AddUntilStep("Check participant count correct", () => multiplayerClient.ClientAPIRoom?.ParticipantCount == 1);
|
||||||
AddUntilStep("Check participant list contains user", () => multiplayerClient.ClientAPIRoom?.RecentParticipants.Count(u => u.Id == API.LocalUser.Value.Id) == 1);
|
AddUntilStep("Check participant list contains user", () => multiplayerClient.ClientAPIRoom?.RecentParticipants.Count(u => u.Id == API.LocalUser.Value.Id) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -317,18 +317,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Password = { Value = "password" },
|
Password = "password",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("room has password", () => multiplayerClient.ClientAPIRoom?.Password.Value == "password");
|
AddUntilStep("room has password", () => multiplayerClient.ClientAPIRoom?.Password == "password");
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -338,15 +338,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
roomManager.AddServerSideRoom(new Room
|
roomManager.AddServerSideRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Password = { Value = "password" },
|
Password = "password",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}, API.LocalUser.Value);
|
}, API.LocalUser.Value);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -370,19 +370,19 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Password = { Value = "password" },
|
Password = "password",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("change password", () => multiplayerClient.ChangeSettings(password: "password2"));
|
AddStep("change password", () => multiplayerClient.ChangeSettings(password: "password2"));
|
||||||
AddUntilStep("local password changed", () => multiplayerClient.ClientAPIRoom?.Password.Value == "password2");
|
AddUntilStep("local password changed", () => multiplayerClient.ClientAPIRoom?.Password == "password2");
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -401,14 +401,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
pressReadyButton();
|
pressReadyButton();
|
||||||
@ -430,8 +430,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
};
|
};
|
||||||
return new Room
|
return new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist = { item }
|
Playlist = [item]
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -471,8 +471,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
};
|
};
|
||||||
return new Room
|
return new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist = { item }
|
Playlist = [item]
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -512,8 +512,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
};
|
};
|
||||||
return new Room
|
return new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist = { item }
|
Playlist = [item]
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -548,14 +548,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("join other user (ready, host)", () =>
|
AddStep("join other user (ready, host)", () =>
|
||||||
@ -581,14 +581,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("delete beatmap", () => beatmaps.Delete(importedSet));
|
AddStep("delete beatmap", () => beatmaps.Delete(importedSet));
|
||||||
@ -620,14 +620,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("disconnect", () => multiplayerClient.Disconnect());
|
AddStep("disconnect", () => multiplayerClient.Disconnect());
|
||||||
@ -639,15 +639,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
AllowedMods = new[] { new APIMod(new OsuModHidden()) }
|
AllowedMods = new[] { new APIMod(new OsuModHidden()) }
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("open mod overlay", () => this.ChildrenOfType<UserModSelectButton>().Single().TriggerClick());
|
AddStep("open mod overlay", () => this.ChildrenOfType<UserModSelectButton>().Single().TriggerClick());
|
||||||
@ -679,14 +679,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
enterGameplay();
|
enterGameplay();
|
||||||
@ -724,14 +724,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
enterGameplay();
|
enterGameplay();
|
||||||
@ -754,14 +754,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
pressReadyButton();
|
pressReadyButton();
|
||||||
@ -791,15 +791,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
roomManager.AddServerSideRoom(new Room
|
roomManager.AddServerSideRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}, API.LocalUser.Value);
|
}, API.LocalUser.Value);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -810,12 +810,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("disable polling", () => this.ChildrenOfType<ListingPollingComponent>().Single().TimeBetweenPolls.Value = 0);
|
AddStep("disable polling", () => this.ChildrenOfType<ListingPollingComponent>().Single().TimeBetweenPolls.Value = 0);
|
||||||
AddStep("change server-side settings", () =>
|
AddStep("change server-side settings", () =>
|
||||||
{
|
{
|
||||||
roomManager.ServerSideRooms[0].Name.Value = "New name";
|
roomManager.ServerSideRooms[0].Name = "New name";
|
||||||
roomManager.ServerSideRooms[0].Playlist.Add(new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
roomManager.ServerSideRooms[0].Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
ID = 2,
|
ID = 2,
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("join room", () => InputManager.Key(Key.Enter));
|
AddStep("join room", () => InputManager.Key(Key.Enter));
|
||||||
@ -825,8 +828,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddAssert("local room has correct settings", () =>
|
AddAssert("local room has correct settings", () =>
|
||||||
{
|
{
|
||||||
var localRoom = this.ChildrenOfType<MultiplayerMatchSubScreen>().Single().Room;
|
var localRoom = this.ChildrenOfType<MultiplayerMatchSubScreen>().Single().Room;
|
||||||
return localRoom.Name.Value == roomManager.ServerSideRooms[0].Name.Value
|
return localRoom.Name == roomManager.ServerSideRooms[0].Name && localRoom.Playlist.Single().ID == 2;
|
||||||
&& localRoom.Playlist.SequenceEqual(roomManager.ServerSideRooms[0].Playlist);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -836,15 +838,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("set spectating state", () => multiplayerClient.ChangeUserState(API.LocalUser.Value.OnlineID, MultiplayerUserState.Spectating));
|
AddStep("set spectating state", () => multiplayerClient.ChangeUserState(API.LocalUser.Value.OnlineID, MultiplayerUserState.Spectating));
|
||||||
@ -872,15 +874,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("set spectating state", () => multiplayerClient.ChangeUserState(API.LocalUser.Value.OnlineID, MultiplayerUserState.Spectating));
|
AddStep("set spectating state", () => multiplayerClient.ChangeUserState(API.LocalUser.Value.OnlineID, MultiplayerUserState.Spectating));
|
||||||
@ -911,15 +913,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
enterGameplay();
|
enterGameplay();
|
||||||
@ -942,15 +944,15 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
enterGameplay();
|
enterGameplay();
|
||||||
@ -976,14 +978,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("join other user and make host", () =>
|
AddStep("join other user and make host", () =>
|
||||||
@ -1022,10 +1024,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
createRoom(() => new Room
|
createRoom(() => new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "Test Room" },
|
Name = "Test Room",
|
||||||
QueueMode = { Value = QueueMode.AllPlayers },
|
QueueMode = QueueMode.AllPlayers,
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
@ -1036,7 +1038,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
RulesetID = new TaikoRuleset().RulesetInfo.OnlineID,
|
RulesetID = new TaikoRuleset().RulesetInfo.OnlineID,
|
||||||
AllowedMods = new[] { new APIMod { Acronym = "HD" } },
|
AllowedMods = new[] { new APIMod { Acronym = "HD" } },
|
||||||
},
|
},
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("select hidden", () => multiplayerClient.ChangeUserMods(new[] { new APIMod { Acronym = "HD" } }));
|
AddStep("select hidden", () => multiplayerClient.ChangeUserMods(new[] { new APIMod { Acronym = "HD" } }));
|
||||||
|
@ -37,10 +37,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestPerUserMods()
|
public void TestPerUserMods()
|
||||||
{
|
{
|
||||||
AddStep("first user has no mods", () => Assert.That(((TestLeaderboard)Leaderboard).UserMods[0], Is.Empty));
|
AddStep("first user has no mods", () => Assert.That(((TestLeaderboard)Leaderboard!).UserMods[0], Is.Empty));
|
||||||
AddStep("last user has NF mod", () =>
|
AddStep("last user has NF mod", () =>
|
||||||
{
|
{
|
||||||
Assert.That(((TestLeaderboard)Leaderboard).UserMods[TOTAL_USERS - 1], Has.One.Items);
|
Assert.That(((TestLeaderboard)Leaderboard!).UserMods[TOTAL_USERS - 1], Has.One.Items);
|
||||||
Assert.That(((TestLeaderboard)Leaderboard).UserMods[TOTAL_USERS - 1].Single(), Is.TypeOf<OsuModNoFail>());
|
Assert.That(((TestLeaderboard)Leaderboard).UserMods[TOTAL_USERS - 1].Single(), Is.TypeOf<OsuModNoFail>());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
LoadComponentAsync(new MatchScoreDisplay
|
LoadComponentAsync(new MatchScoreDisplay
|
||||||
{
|
{
|
||||||
Team1Score = { BindTarget = Leaderboard.TeamScores[0] },
|
Team1Score = { BindTarget = Leaderboard!.TeamScores[0] },
|
||||||
Team2Score = { BindTarget = Leaderboard.TeamScores[1] }
|
Team2Score = { BindTarget = Leaderboard.TeamScores[1] }
|
||||||
}, Add);
|
}, Add);
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
@ -22,10 +20,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
protected new TestRoomManager RoomManager => (TestRoomManager)base.RoomManager;
|
protected new TestRoomManager RoomManager => (TestRoomManager)base.RoomManager;
|
||||||
|
|
||||||
private LoungeSubScreen loungeScreen;
|
private LoungeSubScreen loungeScreen = null!;
|
||||||
|
private Room? lastJoinedRoom;
|
||||||
private Room lastJoinedRoom;
|
private string? lastJoinedPassword;
|
||||||
private string lastJoinedPassword;
|
|
||||||
|
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
{
|
{
|
||||||
@ -87,7 +84,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestJoinRoomWithIncorrectPasswordViaButton()
|
public void TestJoinRoomWithIncorrectPasswordViaButton()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover passwordEntryPopover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? passwordEntryPopover = null;
|
||||||
|
|
||||||
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
||||||
AddStep("select room", () => InputManager.Key(Key.Down));
|
AddStep("select room", () => InputManager.Key(Key.Down));
|
||||||
@ -97,14 +94,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("press join room button", () => passwordEntryPopover.ChildrenOfType<OsuButton>().First().TriggerClick());
|
AddStep("press join room button", () => passwordEntryPopover.ChildrenOfType<OsuButton>().First().TriggerClick());
|
||||||
|
|
||||||
AddAssert("room not joined", () => loungeScreen.IsCurrentScreen());
|
AddAssert("room not joined", () => loungeScreen.IsCurrentScreen());
|
||||||
AddUntilStep("password prompt still visible", () => passwordEntryPopover.State.Value == Visibility.Visible);
|
AddUntilStep("password prompt still visible", () => passwordEntryPopover!.State.Value == Visibility.Visible);
|
||||||
AddAssert("textbox still focused", () => InputManager.FocusedDrawable is OsuPasswordTextBox);
|
AddAssert("textbox still focused", () => InputManager.FocusedDrawable is OsuPasswordTextBox);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestJoinRoomWithIncorrectPasswordViaEnter()
|
public void TestJoinRoomWithIncorrectPasswordViaEnter()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover passwordEntryPopover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? passwordEntryPopover = null;
|
||||||
|
|
||||||
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
||||||
AddStep("select room", () => InputManager.Key(Key.Down));
|
AddStep("select room", () => InputManager.Key(Key.Down));
|
||||||
@ -114,14 +111,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddStep("press enter", () => InputManager.Key(Key.Enter));
|
AddStep("press enter", () => InputManager.Key(Key.Enter));
|
||||||
|
|
||||||
AddAssert("room not joined", () => loungeScreen.IsCurrentScreen());
|
AddAssert("room not joined", () => loungeScreen.IsCurrentScreen());
|
||||||
AddUntilStep("password prompt still visible", () => passwordEntryPopover.State.Value == Visibility.Visible);
|
AddUntilStep("password prompt still visible", () => passwordEntryPopover!.State.Value == Visibility.Visible);
|
||||||
AddAssert("textbox still focused", () => InputManager.FocusedDrawable is OsuPasswordTextBox);
|
AddAssert("textbox still focused", () => InputManager.FocusedDrawable is OsuPasswordTextBox);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestJoinRoomWithCorrectPassword()
|
public void TestJoinRoomWithCorrectPassword()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover passwordEntryPopover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? passwordEntryPopover = null;
|
||||||
|
|
||||||
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
||||||
AddStep("select room", () => InputManager.Key(Key.Down));
|
AddStep("select room", () => InputManager.Key(Key.Down));
|
||||||
@ -137,7 +134,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestJoinRoomWithPasswordViaKeyboardOnly()
|
public void TestJoinRoomWithPasswordViaKeyboardOnly()
|
||||||
{
|
{
|
||||||
DrawableLoungeRoom.PasswordEntryPopover passwordEntryPopover = null;
|
DrawableLoungeRoom.PasswordEntryPopover? passwordEntryPopover = null;
|
||||||
|
|
||||||
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
AddStep("add room", () => RoomManager.AddRooms(1, withPassword: true));
|
||||||
AddStep("select room", () => InputManager.Key(Key.Down));
|
AddStep("select room", () => InputManager.Key(Key.Down));
|
||||||
@ -150,7 +147,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddAssert("room join password correct", () => lastJoinedPassword == "password");
|
AddAssert("room join password correct", () => lastJoinedPassword == "password");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onRoomJoined(Room room, string password)
|
private void onRoomJoined(Room room, string? password)
|
||||||
{
|
{
|
||||||
lastJoinedRoom = room;
|
lastJoinedRoom = room;
|
||||||
lastJoinedPassword = password;
|
lastJoinedPassword = password;
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
@ -13,9 +12,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerMatchFooter : MultiplayerTestScene
|
public partial class TestSceneMultiplayerMatchFooter : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
[Cached(typeof(IBindable<PlaylistItem>))]
|
|
||||||
private readonly Bindable<PlaylistItem> currentItem = new Bindable<PlaylistItem>();
|
|
||||||
|
|
||||||
public override void SetUpSteps()
|
public override void SetUpSteps()
|
||||||
{
|
{
|
||||||
base.SetUpSteps();
|
base.SetUpSteps();
|
||||||
@ -33,7 +29,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
RelativeSizeAxes = Axes.X,
|
RelativeSizeAxes = Axes.X,
|
||||||
Height = 50,
|
Height = 50,
|
||||||
Child = new MultiplayerMatchFooter()
|
Child = new MultiplayerMatchFooter
|
||||||
|
{
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
@ -1,12 +1,9 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using JetBrains.Annotations;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Audio;
|
using osu.Framework.Audio;
|
||||||
@ -35,17 +32,16 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerMatchSongSelect : MultiplayerTestScene
|
public partial class TestSceneMultiplayerMatchSongSelect : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private BeatmapManager manager;
|
private BeatmapManager manager = null!;
|
||||||
private RulesetStore rulesets;
|
private RulesetStore rulesets = null!;
|
||||||
|
|
||||||
private IList<BeatmapInfo> beatmaps => importedBeatmapSet?.PerformRead(s => s.Beatmaps) ?? new List<BeatmapInfo>();
|
private IList<BeatmapInfo> beatmaps => importedBeatmapSet.PerformRead(s => s.Beatmaps);
|
||||||
|
|
||||||
private TestMultiplayerMatchSongSelect songSelect;
|
private TestMultiplayerMatchSongSelect songSelect = null!;
|
||||||
|
private Live<BeatmapSetInfo> importedBeatmapSet = null!;
|
||||||
private Live<BeatmapSetInfo> importedBeatmapSet;
|
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private OsuConfigManager configManager { get; set; }
|
private OsuConfigManager configManager { get; set; } = null!;
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(GameHost host, AudioManager audio)
|
private void load(GameHost host, AudioManager audio)
|
||||||
@ -57,7 +53,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
Dependencies.Cache(detachedBeatmapStore = new DetachedBeatmapStore());
|
Dependencies.Cache(detachedBeatmapStore = new DetachedBeatmapStore());
|
||||||
Dependencies.Cache(Realm);
|
Dependencies.Cache(Realm);
|
||||||
|
|
||||||
importedBeatmapSet = manager.Import(TestResources.CreateTestBeatmapSetInfo(8, rulesets.AvailableRulesets.ToArray()));
|
importedBeatmapSet = manager.Import(TestResources.CreateTestBeatmapSetInfo(8, rulesets.AvailableRulesets.ToArray()))!;
|
||||||
|
|
||||||
Add(detachedBeatmapStore);
|
Add(detachedBeatmapStore);
|
||||||
}
|
}
|
||||||
@ -71,7 +67,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
SelectedMods.SetDefault();
|
SelectedMods.SetDefault();
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("create song select", () => LoadScreen(songSelect = new TestMultiplayerMatchSongSelect(SelectedRoom.Value)));
|
AddStep("create song select", () => LoadScreen(songSelect = new TestMultiplayerMatchSongSelect(SelectedRoom.Value!)));
|
||||||
AddUntilStep("wait for present", () => songSelect.IsCurrentScreen() && songSelect.BeatmapSetsLoaded);
|
AddUntilStep("wait for present", () => songSelect.IsCurrentScreen() && songSelect.BeatmapSetsLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -88,7 +84,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestBeatmapConfirmed()
|
public void TestBeatmapConfirmed()
|
||||||
{
|
{
|
||||||
BeatmapInfo selectedBeatmap = null;
|
BeatmapInfo selectedBeatmap = null!;
|
||||||
|
|
||||||
setUp();
|
setUp();
|
||||||
|
|
||||||
@ -117,8 +113,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
setUp();
|
setUp();
|
||||||
|
|
||||||
AddStep("change ruleset", () => Ruleset.Value = new OsuRuleset().RulesetInfo);
|
AddStep("change ruleset", () => Ruleset.Value = new OsuRuleset().RulesetInfo);
|
||||||
AddStep($"select {allowedMod.ReadableName()} as allowed", () => songSelect.FreeMods.Value = new[] { (Mod)Activator.CreateInstance(allowedMod) });
|
AddStep($"select {allowedMod.ReadableName()} as allowed", () => songSelect.FreeMods.Value = new[] { (Mod)Activator.CreateInstance(allowedMod)! });
|
||||||
AddStep($"select {requiredMod.ReadableName()} as required", () => songSelect.Mods.Value = new[] { (Mod)Activator.CreateInstance(requiredMod) });
|
AddStep($"select {requiredMod.ReadableName()} as required", () => songSelect.Mods.Value = new[] { (Mod)Activator.CreateInstance(requiredMod)! });
|
||||||
|
|
||||||
AddAssert("freemods empty", () => songSelect.FreeMods.Value.Count == 0);
|
AddAssert("freemods empty", () => songSelect.FreeMods.Value.Count == 0);
|
||||||
|
|
||||||
@ -141,7 +137,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("create song select", () =>
|
AddStep("create song select", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Single().RulesetID = 2;
|
SelectedRoom.Value!.Playlist.Single().RulesetID = 2;
|
||||||
songSelect = new TestMultiplayerMatchSongSelect(SelectedRoom.Value, SelectedRoom.Value.Playlist.Single());
|
songSelect = new TestMultiplayerMatchSongSelect(SelectedRoom.Value, SelectedRoom.Value.Playlist.Single());
|
||||||
songSelect.OnLoadComplete += _ => Ruleset.Value = new TaikoRuleset().RulesetInfo;
|
songSelect.OnLoadComplete += _ => Ruleset.Value = new TaikoRuleset().RulesetInfo;
|
||||||
LoadScreen(songSelect);
|
LoadScreen(songSelect);
|
||||||
@ -171,7 +167,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
public new BeatmapCarousel Carousel => base.Carousel;
|
public new BeatmapCarousel Carousel => base.Carousel;
|
||||||
|
|
||||||
public TestMultiplayerMatchSongSelect(Room room, [CanBeNull] PlaylistItem itemToEdit = null)
|
public TestMultiplayerMatchSongSelect(Room room, PlaylistItem? itemToEdit = null)
|
||||||
: base(room, itemToEdit)
|
: base(room, itemToEdit)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,7 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using JetBrains.Annotations;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Audio;
|
using osu.Framework.Audio;
|
||||||
@ -42,10 +39,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerMatchSubScreen : MultiplayerTestScene
|
public partial class TestSceneMultiplayerMatchSubScreen : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private MultiplayerMatchSubScreen screen;
|
private MultiplayerMatchSubScreen screen = null!;
|
||||||
|
private BeatmapManager beatmaps = null!;
|
||||||
private BeatmapManager beatmaps;
|
private BeatmapSetInfo importedSet = null!;
|
||||||
private BeatmapSetInfo importedSet;
|
|
||||||
|
|
||||||
public TestSceneMultiplayerMatchSubScreen()
|
public TestSceneMultiplayerMatchSubScreen()
|
||||||
: base(false)
|
: base(false)
|
||||||
@ -69,41 +65,25 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
AddStep("load match", () =>
|
AddStep("load match", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room { Name = { Value = "Test Room" } };
|
SelectedRoom.Value = new Room { Name = "Test Room" };
|
||||||
LoadScreen(screen = new TestMultiplayerMatchSubScreen(SelectedRoom.Value));
|
LoadScreen(screen = new TestMultiplayerMatchSubScreen(SelectedRoom.Value!));
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("wait for load", () => screen.IsCurrentScreen());
|
AddUntilStep("wait for load", () => screen.IsCurrentScreen());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest]
|
|
||||||
/*
|
|
||||||
* Fail rate around 1.5%
|
|
||||||
*
|
|
||||||
* TearDown : System.AggregateException : One or more errors occurred. (Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index'))
|
|
||||||
----> System.ArgumentOutOfRangeException : Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index')
|
|
||||||
* --TearDown
|
|
||||||
* at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledExceptions)
|
|
||||||
* at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
|
|
||||||
* at osu.Framework.Extensions.TaskExtensions.WaitSafely(Task task)
|
|
||||||
* at osu.Framework.Testing.TestScene.checkForErrors()
|
|
||||||
* at osu.Framework.Testing.TestScene.RunTestsFromNUnit()
|
|
||||||
*--ArgumentOutOfRangeException
|
|
||||||
* at osu.Framework.Bindables.BindableList`1.removeAt(Int32 index, BindableList`1 caller)
|
|
||||||
* at osu.Framework.Bindables.BindableList`1.removeAt(Int32 index, BindableList`1 caller)
|
|
||||||
* at osu.Framework.Bindables.BindableList`1.removeAt(Int32 index, BindableList`1 caller)
|
|
||||||
* at osu.Game.Online.Multiplayer.MultiplayerClient.<>c__DisplayClass106_0.<PlaylistItemChanged>b__0() in C:\BuildAgent\work\ecd860037212ac52\osu.Game\Online\Multiplayer\MultiplayerClient .cs:line 702
|
|
||||||
* at osu.Framework.Threading.ScheduledDelegate.RunTaskInternal()
|
|
||||||
*/
|
|
||||||
public void TestCreatedRoom()
|
public void TestCreatedRoom()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item", () =>
|
AddStep("add playlist item", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -112,16 +92,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestTaikoOnlyMod()
|
public void TestTaikoOnlyMod()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item", () =>
|
AddStep("add playlist item", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new TaikoRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new TaikoRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new TaikoRuleset().RulesetInfo.OnlineID,
|
RulesetID = new TaikoRuleset().RulesetInfo.OnlineID,
|
||||||
AllowedMods = new[] { new APIMod(new TaikoModSwap()) }
|
AllowedMods = new[] { new APIMod(new TaikoModSwap()) }
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -133,32 +115,36 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestSettingValidity()
|
public void TestSettingValidity()
|
||||||
{
|
{
|
||||||
AddAssert("create button not enabled", () => !this.ChildrenOfType<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>().Single().Enabled.Value);
|
AddAssert("create button not enabled", () => !this.ChildrenOfType<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>().Single().Enabled.Value);
|
||||||
|
|
||||||
AddStep("set playlist", () =>
|
AddStep("set playlist", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
AddAssert("create button enabled", () => this.ChildrenOfType<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>().Single().Enabled.Value);
|
AddAssert("create button enabled", () => this.ChildrenOfType<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>().Single().Enabled.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestStartMatchWhileSpectating()
|
public void TestStartMatchWhileSpectating()
|
||||||
{
|
{
|
||||||
AddStep("set playlist", () =>
|
AddStep("set playlist", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First()).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First()).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -179,16 +165,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestFreeModSelectionHasAllowedMods()
|
public void TestFreeModSelectionHasAllowedMods()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item with allowed mod", () =>
|
AddStep("add playlist item with allowed mod", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
AllowedMods = new[] { new APIMod(new OsuModDoubleTime()) }
|
AllowedMods = new[] { new APIMod(new OsuModDoubleTime()) }
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -206,16 +194,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestModSelectKeyWithAllowedMods()
|
public void TestModSelectKeyWithAllowedMods()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item with allowed mod", () =>
|
AddStep("add playlist item with allowed mod", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
AllowedMods = new[] { new APIMod(new OsuModDoubleTime()) }
|
AllowedMods = new[] { new APIMod(new OsuModDoubleTime()) }
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -228,15 +218,17 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestModSelectKeyWithNoAllowedMods()
|
public void TestModSelectKeyWithNoAllowedMods()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item with no allowed mods", () =>
|
AddStep("add playlist item with no allowed mods", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
|
|
||||||
@ -249,13 +241,12 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestNextPlaylistItemSelectedAfterCompletion()
|
public void TestNextPlaylistItemSelectedAfterCompletion()
|
||||||
{
|
{
|
||||||
AddStep("add two playlist items", () =>
|
AddStep("add two playlist items", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.AddRange(new[]
|
SelectedRoom.Value!.Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First()).BeatmapInfo)
|
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First()).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
@ -264,7 +255,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID
|
||||||
}
|
}
|
||||||
});
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
@ -286,12 +277,13 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
[FlakyTest] // See above
|
|
||||||
public void TestModSelectOverlay()
|
public void TestModSelectOverlay()
|
||||||
{
|
{
|
||||||
AddStep("add playlist item", () =>
|
AddStep("add playlist item", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.Add(new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
SelectedRoom.Value!.Playlist =
|
||||||
|
[
|
||||||
|
new PlaylistItem(new TestBeatmap(new OsuRuleset().RulesetInfo).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
RulesetID = new OsuRuleset().RulesetInfo.OnlineID,
|
||||||
RequiredMods = new[]
|
RequiredMods = new[]
|
||||||
@ -303,7 +295,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
new APIMod(new OsuModFlashlight()),
|
new APIMod(new OsuModFlashlight()),
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
];
|
||||||
});
|
});
|
||||||
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
ClickButtonWhenEnabled<MultiplayerMatchSettingsOverlay.CreateOrUpdateButton>();
|
||||||
|
|
||||||
@ -323,8 +316,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
private partial class TestMultiplayerMatchSubScreen : MultiplayerMatchSubScreen
|
private partial class TestMultiplayerMatchSubScreen : MultiplayerMatchSubScreen
|
||||||
{
|
{
|
||||||
[Resolved(canBeNull: true)]
|
[Resolved(canBeNull: true)]
|
||||||
[CanBeNull]
|
private IDialogOverlay? dialogOverlay { get; set; }
|
||||||
private IDialogOverlay dialogOverlay { get; set; }
|
|
||||||
|
|
||||||
public TestMultiplayerMatchSubScreen(Room room)
|
public TestMultiplayerMatchSubScreen(Room room)
|
||||||
: base(room)
|
: base(room)
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -22,7 +20,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerPlayer : MultiplayerTestScene
|
public partial class TestSceneMultiplayerPlayer : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private MultiplayerPlayer player;
|
private MultiplayerPlayer player = null!;
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestGameplay()
|
public void TestGameplay()
|
||||||
@ -49,7 +47,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
AddUntilStep("score changed", () => player.GameplayState.ScoreProcessor.TotalScore.Value > 0);
|
AddUntilStep("score changed", () => player.GameplayState.ScoreProcessor.TotalScore.Value > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setup(Func<IReadOnlyList<Mod>> mods = null)
|
private void setup(Func<IReadOnlyList<Mod>>? mods = null)
|
||||||
{
|
{
|
||||||
AddStep("set beatmap", () =>
|
AddStep("set beatmap", () =>
|
||||||
{
|
{
|
||||||
@ -64,10 +62,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("initialise gameplay", () =>
|
AddStep("initialise gameplay", () =>
|
||||||
{
|
{
|
||||||
Stack.Push(player = new MultiplayerPlayer(MultiplayerClient.ServerAPIRoom, new PlaylistItem(Beatmap.Value.BeatmapInfo)
|
Stack.Push(player = new MultiplayerPlayer(MultiplayerClient.ServerAPIRoom!, new PlaylistItem(Beatmap.Value.BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = Beatmap.Value.BeatmapInfo.Ruleset.OnlineID,
|
RulesetID = Beatmap.Value.BeatmapInfo.Ruleset.OnlineID,
|
||||||
}, MultiplayerClient.ServerRoom?.Users.ToArray()));
|
}, MultiplayerClient.ServerRoom!.Users.ToArray()));
|
||||||
});
|
});
|
||||||
|
|
||||||
AddUntilStep("wait for player to be current", () => player.IsCurrentScreen() && player.IsLoaded);
|
AddUntilStep("wait for player to be current", () => player.IsCurrentScreen() && player.IsLoaded);
|
||||||
|
@ -28,9 +28,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerPlaylist : MultiplayerTestScene
|
public partial class TestSceneMultiplayerPlaylist : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
[Cached(typeof(IBindable<PlaylistItem>))]
|
|
||||||
private readonly Bindable<PlaylistItem> currentItem = new Bindable<PlaylistItem>();
|
|
||||||
|
|
||||||
private MultiplayerPlaylist list = null!;
|
private MultiplayerPlaylist list = null!;
|
||||||
private BeatmapManager beatmaps = null!;
|
private BeatmapManager beatmaps = null!;
|
||||||
private BeatmapSetInfo importedSet = null!;
|
private BeatmapSetInfo importedSet = null!;
|
||||||
@ -51,12 +48,13 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("create list", () =>
|
AddStep("create list", () =>
|
||||||
{
|
{
|
||||||
Child = list = new MultiplayerPlaylist
|
Child = list = new MultiplayerPlaylist(SelectedRoom.Value!)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Size = new Vector2(0.4f, 0.8f)
|
Size = new Vector2(0.4f, 0.8f),
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>()
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -166,9 +164,9 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
RoomManager.CreateRoom(new Room
|
RoomManager.CreateRoom(new Room
|
||||||
{
|
{
|
||||||
Name = { Value = "test name" },
|
Name = "test name",
|
||||||
Playlist =
|
Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(new TestBeatmap(Ruleset.Value).BeatmapInfo)
|
new PlaylistItem(new TestBeatmap(Ruleset.Value).BeatmapInfo)
|
||||||
{
|
{
|
||||||
RulesetID = Ruleset.Value.OnlineID
|
RulesetID = Ruleset.Value.OnlineID
|
||||||
@ -178,7 +176,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
RulesetID = Ruleset.Value.OnlineID,
|
RulesetID = Ruleset.Value.OnlineID,
|
||||||
Expired = true
|
Expired = true
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -27,10 +25,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerQueueList : MultiplayerTestScene
|
public partial class TestSceneMultiplayerQueueList : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
private MultiplayerQueueList playlist;
|
private MultiplayerQueueList playlist = null!;
|
||||||
private BeatmapManager beatmaps;
|
private BeatmapManager beatmaps = null!;
|
||||||
private BeatmapSetInfo importedSet;
|
private BeatmapSetInfo importedSet = null!;
|
||||||
private BeatmapInfo importedBeatmap;
|
private BeatmapInfo importedBeatmap = null!;
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(GameHost host, AudioManager audio)
|
private void load(GameHost host, AudioManager audio)
|
||||||
@ -46,12 +44,17 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("create playlist", () =>
|
AddStep("create playlist", () =>
|
||||||
{
|
{
|
||||||
Child = playlist = new MultiplayerQueueList
|
Child = playlist = new MultiplayerQueueList(SelectedRoom.Value!)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Size = new Vector2(500, 300),
|
Size = new Vector2(500, 300),
|
||||||
Items = { BindTarget = MultiplayerClient.ClientAPIRoom!.Playlist }
|
};
|
||||||
|
|
||||||
|
MultiplayerClient.ClientAPIRoom!.PropertyChanged += (_, e) =>
|
||||||
|
{
|
||||||
|
if (e.PropertyName == nameof(Room.Playlist))
|
||||||
|
playlist.Items.ReplaceRange(0, playlist.Items.Count, MultiplayerClient.ClientAPIRoom.Playlist);
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -69,7 +72,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestDeleteButtonAlwaysVisibleForHost()
|
public void TestDeleteButtonAlwaysVisibleForHost()
|
||||||
{
|
{
|
||||||
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
||||||
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == QueueMode.AllPlayers);
|
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode == QueueMode.AllPlayers);
|
||||||
|
|
||||||
addPlaylistItem(() => API.LocalUser.Value.OnlineID);
|
addPlaylistItem(() => API.LocalUser.Value.OnlineID);
|
||||||
assertDeleteButtonVisibility(1, true);
|
assertDeleteButtonVisibility(1, true);
|
||||||
@ -81,7 +84,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestDeleteButtonOnlyVisibleForItemOwnerIfNotHost()
|
public void TestDeleteButtonOnlyVisibleForItemOwnerIfNotHost()
|
||||||
{
|
{
|
||||||
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
||||||
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == QueueMode.AllPlayers);
|
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode == QueueMode.AllPlayers);
|
||||||
|
|
||||||
AddStep("join other user", () => MultiplayerClient.AddUser(new APIUser { Id = 1234 }));
|
AddStep("join other user", () => MultiplayerClient.AddUser(new APIUser { Id = 1234 }));
|
||||||
AddStep("set other user as host", () => MultiplayerClient.TransferHost(1234));
|
AddStep("set other user as host", () => MultiplayerClient.TransferHost(1234));
|
||||||
@ -100,7 +103,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestSingleItemDoesNotHaveDeleteButton()
|
public void TestSingleItemDoesNotHaveDeleteButton()
|
||||||
{
|
{
|
||||||
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
||||||
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == QueueMode.AllPlayers);
|
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode == QueueMode.AllPlayers);
|
||||||
|
|
||||||
assertDeleteButtonVisibility(0, false);
|
assertDeleteButtonVisibility(0, false);
|
||||||
}
|
}
|
||||||
@ -109,7 +112,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestCurrentItemHasDeleteButtonIfNotSingle()
|
public void TestCurrentItemHasDeleteButtonIfNotSingle()
|
||||||
{
|
{
|
||||||
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
AddStep("set all players queue mode", () => MultiplayerClient.ChangeSettings(new MultiplayerRoomSettings { QueueMode = QueueMode.AllPlayers }).WaitSafely());
|
||||||
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode.Value == QueueMode.AllPlayers);
|
AddUntilStep("wait for queue mode change", () => MultiplayerClient.ClientAPIRoom?.QueueMode == QueueMode.AllPlayers);
|
||||||
|
|
||||||
addPlaylistItem(() => API.LocalUser.Value.OnlineID);
|
addPlaylistItem(() => API.LocalUser.Value.OnlineID);
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Game.Online.Rooms;
|
using osu.Game.Online.Rooms;
|
||||||
using osu.Game.Rulesets.Osu;
|
using osu.Game.Rulesets.Osu;
|
||||||
@ -16,7 +14,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestDisplayResults()
|
public void TestDisplayResults()
|
||||||
{
|
{
|
||||||
MultiplayerResultsScreen screen = null;
|
MultiplayerResultsScreen screen = null!;
|
||||||
|
|
||||||
AddStep("show results screen", () =>
|
AddStep("show results screen", () =>
|
||||||
{
|
{
|
||||||
|
@ -26,9 +26,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerSpectateButton : MultiplayerTestScene
|
public partial class TestSceneMultiplayerSpectateButton : MultiplayerTestScene
|
||||||
{
|
{
|
||||||
[Cached(typeof(IBindable<PlaylistItem>))]
|
|
||||||
private readonly Bindable<PlaylistItem> currentItem = new Bindable<PlaylistItem>();
|
|
||||||
|
|
||||||
private MultiplayerSpectateButton spectateButton = null!;
|
private MultiplayerSpectateButton spectateButton = null!;
|
||||||
private MatchStartControl startControl = null!;
|
private MatchStartControl startControl = null!;
|
||||||
|
|
||||||
@ -51,13 +48,13 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
|
|
||||||
AddStep("create button", () =>
|
AddStep("create button", () =>
|
||||||
{
|
{
|
||||||
AvailabilityTracker.SelectedItem.BindTo(currentItem);
|
PlaylistItem item = SelectedRoom.Value!.Playlist.First();
|
||||||
|
|
||||||
|
AvailabilityTracker.SelectedItem.Value = item;
|
||||||
|
|
||||||
importedSet = beatmaps.GetAllUsableBeatmapSets().First();
|
importedSet = beatmaps.GetAllUsableBeatmapSets().First();
|
||||||
Beatmap.Value = beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First());
|
Beatmap.Value = beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First());
|
||||||
|
|
||||||
currentItem.Value = SelectedRoom.Value.Playlist.First();
|
|
||||||
|
|
||||||
Child = new PopoverContainer
|
Child = new PopoverContainer
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
@ -72,12 +69,14 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Size = new Vector2(200, 50),
|
Size = new Vector2(200, 50),
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>(item)
|
||||||
},
|
},
|
||||||
startControl = new MatchStartControl
|
startControl = new MatchStartControl
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Size = new Vector2(200, 50),
|
Size = new Vector2(200, 50),
|
||||||
|
SelectedItem = new Bindable<PlaylistItem?>(item)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -16,7 +14,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestSceneMultiplayerSpectatorPlayerGrid : OsuManualInputManagerTestScene
|
public partial class TestSceneMultiplayerSpectatorPlayerGrid : OsuManualInputManagerTestScene
|
||||||
{
|
{
|
||||||
private PlayerGrid grid;
|
private PlayerGrid grid = null!;
|
||||||
|
|
||||||
[SetUp]
|
[SetUp]
|
||||||
public void Setup() => Schedule(() =>
|
public void Setup() => Schedule(() =>
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
@ -32,7 +30,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[TestCase(1048576, 1048576)]
|
[TestCase(1048576, 1048576)]
|
||||||
public void TestDisplayTeamResults(int team1Score, int team2Score)
|
public void TestDisplayTeamResults(int team1Score, int team2Score)
|
||||||
{
|
{
|
||||||
MultiplayerResultsScreen screen = null;
|
MultiplayerResultsScreen screen = null!;
|
||||||
|
|
||||||
AddStep("show results screen", () =>
|
AddStep("show results screen", () =>
|
||||||
{
|
{
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -28,18 +26,18 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestScenePlaylistsRoomSettingsPlaylist : OnlinePlayTestScene
|
public partial class TestScenePlaylistsRoomSettingsPlaylist : OnlinePlayTestScene
|
||||||
{
|
{
|
||||||
private TestPlaylist playlist;
|
private TestPlaylist playlist = null!;
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestItemRemovedOnDeletion()
|
public void TestItemRemovedOnDeletion()
|
||||||
{
|
{
|
||||||
PlaylistItem selectedItem = null;
|
PlaylistItem selectedItem = null!;
|
||||||
|
|
||||||
createPlaylist();
|
createPlaylist();
|
||||||
|
|
||||||
moveToItem(0);
|
moveToItem(0);
|
||||||
AddStep("click", () => InputManager.Click(MouseButton.Left));
|
AddStep("click", () => InputManager.Click(MouseButton.Left));
|
||||||
AddStep("retrieve selection", () => selectedItem = playlist.SelectedItem.Value);
|
AddStep("retrieve selection", () => selectedItem = playlist.SelectedItem.Value!);
|
||||||
|
|
||||||
moveToDeleteButton(0);
|
moveToDeleteButton(0);
|
||||||
AddStep("click delete button", () => InputManager.Click(MouseButton.Left));
|
AddStep("click delete button", () => InputManager.Click(MouseButton.Left));
|
||||||
@ -122,7 +120,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
InputManager.MoveMouseTo(item.ChildrenOfType<DrawableRoomPlaylistItem.PlaylistRemoveButton>().ElementAt(0), offset);
|
InputManager.MoveMouseTo(item.ChildrenOfType<DrawableRoomPlaylistItem.PlaylistRemoveButton>().ElementAt(0), offset);
|
||||||
});
|
});
|
||||||
|
|
||||||
private void createPlaylist(Action<TestPlaylist> setupPlaylist = null)
|
private void createPlaylist(Action<TestPlaylist>? setupPlaylist = null)
|
||||||
{
|
{
|
||||||
AddStep("create playlist", () =>
|
AddStep("create playlist", () =>
|
||||||
{
|
{
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
@ -27,9 +25,8 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
public partial class TestScenePlaylistsSongSelect : OnlinePlayTestScene
|
public partial class TestScenePlaylistsSongSelect : OnlinePlayTestScene
|
||||||
{
|
{
|
||||||
private BeatmapManager manager;
|
private BeatmapManager manager = null!;
|
||||||
|
private TestPlaylistsSongSelect songSelect = null!;
|
||||||
private TestPlaylistsSongSelect songSelect;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(GameHost host, AudioManager audio)
|
private void load(GameHost host, AudioManager audio)
|
||||||
@ -60,7 +57,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
SelectedMods.Value = Array.Empty<Mod>();
|
SelectedMods.Value = Array.Empty<Mod>();
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("create song select", () => LoadScreen(songSelect = new TestPlaylistsSongSelect(SelectedRoom.Value)));
|
AddStep("create song select", () => LoadScreen(songSelect = new TestPlaylistsSongSelect(SelectedRoom.Value!)));
|
||||||
AddUntilStep("wait for present", () => songSelect.IsCurrentScreen() && songSelect.BeatmapSetsLoaded);
|
AddUntilStep("wait for present", () => songSelect.IsCurrentScreen() && songSelect.BeatmapSetsLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,46 +65,41 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestItemAddedIfEmptyOnStart()
|
public void TestItemAddedIfEmptyOnStart()
|
||||||
{
|
{
|
||||||
AddStep("finalise selection", () => songSelect.FinaliseSelection());
|
AddStep("finalise selection", () => songSelect.FinaliseSelection());
|
||||||
AddAssert("playlist has 1 item", () => SelectedRoom.Value.Playlist.Count == 1);
|
AddAssert("playlist has 1 item", () => SelectedRoom.Value!.Playlist.Count == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestItemAddedWhenCreateNewItemClicked()
|
public void TestItemAddedWhenCreateNewItemClicked()
|
||||||
{
|
{
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddAssert("playlist has 1 item", () => SelectedRoom.Value.Playlist.Count == 1);
|
AddAssert("playlist has 1 item", () => SelectedRoom.Value!.Playlist.Count == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestItemNotAddedIfExistingOnStart()
|
public void TestItemNotAddedIfExistingOnStart()
|
||||||
{
|
{
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddStep("finalise selection", () => songSelect.FinaliseSelection());
|
AddStep("finalise selection", () => songSelect.FinaliseSelection());
|
||||||
AddAssert("playlist has 1 item", () => SelectedRoom.Value.Playlist.Count == 1);
|
AddAssert("playlist has 1 item", () => SelectedRoom.Value!.Playlist.Count == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestAddSameItemMultipleTimes()
|
public void TestAddSameItemMultipleTimes()
|
||||||
{
|
{
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddAssert("playlist has 2 items", () => SelectedRoom.Value.Playlist.Count == 2);
|
AddAssert("playlist has 2 items", () => SelectedRoom.Value!.Playlist.Count == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestAddItemAfterRearrangement()
|
public void TestAddItemAfterRearrangement()
|
||||||
{
|
{
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddStep("rearrange", () =>
|
AddStep("rearrange", () => SelectedRoom.Value!.Playlist = SelectedRoom.Value!.Playlist.Skip(1).Append(SelectedRoom.Value!.Playlist[0]).ToArray());
|
||||||
{
|
|
||||||
var item = SelectedRoom.Value.Playlist[0];
|
|
||||||
SelectedRoom.Value.Playlist.RemoveAt(0);
|
|
||||||
SelectedRoom.Value.Playlist.Add(item);
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create new item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddAssert("new item has id 2", () => SelectedRoom.Value.Playlist.Last().ID == 2);
|
AddAssert("new item has id 2", () => SelectedRoom.Value!.Playlist.Last().ID == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -117,19 +109,19 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
public void TestNewItemHasNewModInstances()
|
public void TestNewItemHasNewModInstances()
|
||||||
{
|
{
|
||||||
AddStep("set dt mod", () => SelectedMods.Value = new[] { new OsuModDoubleTime() });
|
AddStep("set dt mod", () => SelectedMods.Value = new[] { new OsuModDoubleTime() });
|
||||||
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
AddStep("change mod rate", () => ((OsuModDoubleTime)SelectedMods.Value[0]).SpeedChange.Value = 2);
|
AddStep("change mod rate", () => ((OsuModDoubleTime)SelectedMods.Value[0]).SpeedChange.Value = 2);
|
||||||
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
|
|
||||||
AddAssert("item 1 has rate 1.5", () =>
|
AddAssert("item 1 has rate 1.5", () =>
|
||||||
{
|
{
|
||||||
var mod = (OsuModDoubleTime)SelectedRoom.Value.Playlist.First().RequiredMods[0].ToMod(new OsuRuleset());
|
var mod = (OsuModDoubleTime)SelectedRoom.Value!.Playlist.First().RequiredMods[0].ToMod(new OsuRuleset());
|
||||||
return Precision.AlmostEquals(1.5, mod.SpeedChange.Value);
|
return Precision.AlmostEquals(1.5, mod.SpeedChange.Value);
|
||||||
});
|
});
|
||||||
|
|
||||||
AddAssert("item 2 has rate 2", () =>
|
AddAssert("item 2 has rate 2", () =>
|
||||||
{
|
{
|
||||||
var mod = (OsuModDoubleTime)SelectedRoom.Value.Playlist.Last().RequiredMods[0].ToMod(new OsuRuleset());
|
var mod = (OsuModDoubleTime)SelectedRoom.Value!.Playlist.Last().RequiredMods[0].ToMod(new OsuRuleset());
|
||||||
return Precision.AlmostEquals(2, mod.SpeedChange.Value);
|
return Precision.AlmostEquals(2, mod.SpeedChange.Value);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -140,7 +132,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestGlobalModInstancesNotRetained()
|
public void TestGlobalModInstancesNotRetained()
|
||||||
{
|
{
|
||||||
OsuModDoubleTime mod = null;
|
OsuModDoubleTime mod = null!;
|
||||||
|
|
||||||
AddStep("set dt mod and store", () =>
|
AddStep("set dt mod and store", () =>
|
||||||
{
|
{
|
||||||
@ -150,12 +142,12 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
mod = (OsuModDoubleTime)SelectedMods.Value[0];
|
mod = (OsuModDoubleTime)SelectedMods.Value[0];
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem());
|
AddStep("create item", () => songSelect.BeatmapDetails.CreateNewItem!());
|
||||||
|
|
||||||
AddStep("change stored mod rate", () => mod.SpeedChange.Value = 2);
|
AddStep("change stored mod rate", () => mod.SpeedChange.Value = 2);
|
||||||
AddAssert("item has rate 1.5", () =>
|
AddAssert("item has rate 1.5", () =>
|
||||||
{
|
{
|
||||||
var m = (OsuModDoubleTime)SelectedRoom.Value.Playlist.First().RequiredMods[0].ToMod(new OsuRuleset());
|
var m = (OsuModDoubleTime)SelectedRoom.Value!.Playlist.First().RequiredMods[0].ToMod(new OsuRuleset());
|
||||||
return Precision.AlmostEquals(1.5, m.SpeedChange.Value);
|
return Precision.AlmostEquals(1.5, m.SpeedChange.Value);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,6 @@ using osu.Framework.Allocation;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Game.Online.API.Requests.Responses;
|
using osu.Game.Online.API.Requests.Responses;
|
||||||
using osu.Game.Online.Multiplayer;
|
using osu.Game.Online.Multiplayer;
|
||||||
using osu.Game.Online.Rooms;
|
|
||||||
using osu.Game.Screens.OnlinePlay.Lounge.Components;
|
using osu.Game.Screens.OnlinePlay.Lounge.Components;
|
||||||
|
|
||||||
namespace osu.Game.Tests.Visual.Multiplayer
|
namespace osu.Game.Tests.Visual.Multiplayer
|
||||||
@ -18,10 +17,6 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
private readonly Mock<MultiplayerClient> multiplayerClient = new Mock<MultiplayerClient>();
|
private readonly Mock<MultiplayerClient> multiplayerClient = new Mock<MultiplayerClient>();
|
||||||
|
|
||||||
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent) =>
|
|
||||||
// not used directly in component, but required due to it inheriting from OnlinePlayComposite.
|
|
||||||
new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent));
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load()
|
private void load()
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room();
|
SelectedRoom.Value = new Room();
|
||||||
|
|
||||||
Child = new StarRatingRangeDisplay
|
Child = new StarRatingRangeDisplay(SelectedRoom.Value)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre
|
Origin = Anchor.Centre
|
||||||
@ -33,11 +33,11 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
AddStep("set playlist", () =>
|
AddStep("set playlist", () =>
|
||||||
{
|
{
|
||||||
SelectedRoom.Value.Playlist.AddRange(new[]
|
SelectedRoom.Value!.Playlist =
|
||||||
{
|
[
|
||||||
new PlaylistItem(new BeatmapInfo { StarRating = min }),
|
new PlaylistItem(new BeatmapInfo { StarRating = min }),
|
||||||
new PlaylistItem(new BeatmapInfo { StarRating = max }),
|
new PlaylistItem(new BeatmapInfo { StarRating = max }),
|
||||||
});
|
];
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user