Merge pull request #1623 from peppy/load-player-test-async

Load Player-based TestCases asynchronously
This commit is contained in:
Dan Balasescu 2017-11-29 17:47:58 +09:00 committed by GitHub
commit fbddaccaf5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 4 deletions

@ -1 +1 @@
Subproject commit d92cec764538da2e7ed95bfb566f6bc81a9667c8
Subproject commit 4fc866eee3803f88b155150e32e021b9c21e647f

View File

@ -50,7 +50,11 @@ namespace osu.Game.Tests.Visual
string instantiation = ruleset?.AssemblyQualifiedName;
foreach (var r in rulesets.AvailableRulesets.Where(rs => instantiation == null || rs.InstantiationInfo == instantiation))
AddStep(r.Name, () => loadPlayerFor(r));
{
Player p = null;
AddStep(r.Name, () => p = loadPlayerFor(r));
AddUntilStep(() => p.IsLoaded);
}
}
protected virtual Beatmap CreateBeatmap()
@ -64,7 +68,7 @@ namespace osu.Game.Tests.Visual
return beatmap;
}
private void loadPlayerFor(RulesetInfo r)
private Player loadPlayerFor(RulesetInfo r)
{
var beatmap = CreateBeatmap();
@ -78,7 +82,11 @@ namespace osu.Game.Tests.Visual
if (Player != null)
Remove(Player);
LoadScreen(CreatePlayer(working, instance));
var player = CreatePlayer(working, instance);
LoadComponentAsync(player, LoadScreen);
return player;
}
protected virtual Player CreatePlayer(WorkingBeatmap beatmap, Ruleset ruleset) => new Player