1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-23 17:33:09 +08:00

Fix multiplayer tests

This commit is contained in:
Dan Balasescu 2024-02-02 22:34:48 +09:00
parent 20ae88b0a0
commit 50f9c61029
No known key found for this signature in database

View File

@ -30,7 +30,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
/// <summary> /// <summary>
/// All dependencies required for online play components and screens. /// All dependencies required for online play components and screens.
/// </summary> /// </summary>
protected OnlinePlayTestSceneDependencies OnlinePlayDependencies => dependencies.OnlinePlayDependencies; protected OnlinePlayTestSceneDependencies OnlinePlayDependencies => dependencies.OnlinePlayDependencies!;
protected override Container<Drawable> Content => content; protected override Container<Drawable> Content => content;
@ -48,12 +48,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
} }
protected sealed override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent) protected sealed override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
{ => dependencies = new DelegatedDependencyContainer(base.CreateChildDependencies(parent));
return dependencies = new DelegatedDependencyContainer(base.CreateChildDependencies(parent))
{
OnlinePlayDependencies = initDependencies()
};
}
public override void SetUpSteps() public override void SetUpSteps()
{ {
@ -62,7 +57,9 @@ namespace osu.Game.Tests.Visual.OnlinePlay
AddStep("setup dependencies", () => AddStep("setup dependencies", () =>
{ {
// Reset the room dependencies to a fresh state. // Reset the room dependencies to a fresh state.
dependencies.OnlinePlayDependencies = initDependencies(); dependencies.OnlinePlayDependencies = CreateOnlinePlayDependencies();
drawableDependenciesContainer.Clear();
drawableDependenciesContainer.AddRange(dependencies.OnlinePlayDependencies.DrawableComponents);
var handler = OnlinePlayDependencies.RequestsHandler; var handler = OnlinePlayDependencies.RequestsHandler;
@ -88,14 +85,6 @@ namespace osu.Game.Tests.Visual.OnlinePlay
}); });
} }
private OnlinePlayTestSceneDependencies initDependencies()
{
var newDependencies = CreateOnlinePlayDependencies();
drawableDependenciesContainer.Clear();
drawableDependenciesContainer.AddRange(newDependencies.DrawableComponents);
return newDependencies;
}
/// <summary> /// <summary>
/// Creates the room dependencies. Called every <see cref="SetUpSteps"/>. /// Creates the room dependencies. Called every <see cref="SetUpSteps"/>.
/// </summary> /// </summary>
@ -112,7 +101,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
/// <summary> /// <summary>
/// The online play dependencies. /// The online play dependencies.
/// </summary> /// </summary>
public OnlinePlayTestSceneDependencies OnlinePlayDependencies { get; set; } = null!; public OnlinePlayTestSceneDependencies? OnlinePlayDependencies { get; set; }
private readonly IReadOnlyDependencyContainer parent; private readonly IReadOnlyDependencyContainer parent;
private readonly DependencyContainer injectableDependencies; private readonly DependencyContainer injectableDependencies;
@ -128,10 +117,10 @@ namespace osu.Game.Tests.Visual.OnlinePlay
} }
public object Get(Type type) public object Get(Type type)
=> OnlinePlayDependencies.Get(type) ?? parent.Get(type); => OnlinePlayDependencies?.Get(type) ?? parent.Get(type);
public object Get(Type type, CacheInfo info) public object Get(Type type, CacheInfo info)
=> OnlinePlayDependencies.Get(type, info) ?? parent.Get(type, info); => OnlinePlayDependencies?.Get(type, info) ?? parent.Get(type, info);
public void Inject<T>(T instance) public void Inject<T>(T instance)
where T : class, IDependencyInjectionCandidate where T : class, IDependencyInjectionCandidate