From c2f7ee480a7a2f993a6480e99b62bd8fc2bda19f Mon Sep 17 00:00:00 2001 From: Koji Hasegawa Date: Sat, 2 Nov 2024 23:54:28 +0900 Subject: [PATCH 1/3] Fix terminate process --- Runtime/Autopilot.cs | 4 ++-- Runtime/Launcher.cs | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Runtime/Autopilot.cs b/Runtime/Autopilot.cs index c291d6e..70e60a0 100644 --- a/Runtime/Autopilot.cs +++ b/Runtime/Autopilot.cs @@ -145,10 +145,10 @@ public async UniTask TerminateAsync(ExitCode exitCode, string message = null, st JUnitReporter.Output(_state.settings.junitReportPath, (int)exitCode, message, stackTrace, time); } - DestroyImmediate(this.gameObject); + Destroy(this.gameObject); _logger.Log("Terminate Autopilot"); - await Launcher.TeardownLaunchAutopilotAsync(_state, _logger, exitCode, "Autopilot", token); + Launcher.TeardownLaunchAutopilotAsync(_state, _logger, exitCode, "Autopilot").Forget(); } [Obsolete("Use " + nameof(TerminateAsync))] diff --git a/Runtime/Launcher.cs b/Runtime/Launcher.cs index 88eee4a..0a9de3d 100644 --- a/Runtime/Launcher.cs +++ b/Runtime/Launcher.cs @@ -217,8 +217,8 @@ private static Dictionary> GetOrderedInitializeOnLaunchAut #endif } - internal static async UniTask TeardownLaunchAutopilotAsync(AutopilotState state, ILogger logger, - ExitCode exitCode, string caller, CancellationToken token = default) + internal static async UniTaskVoid TeardownLaunchAutopilotAsync(AutopilotState state, ILogger logger, + ExitCode exitCode, string caller) { state.settings = null; state.exitCode = exitCode; @@ -242,7 +242,7 @@ internal static async UniTask TeardownLaunchAutopilotAsync(AutopilotState state, // XXX: Avoid a problem that Editor stay playing despite isPlaying get assigned false. // SEE: https://github.com/DeNA/Anjin/issues/20 - await UniTask.NextFrame(token); + await UniTask.NextFrame(); #if UNITY_EDITOR EditorApplication.isPlaying = false; // Note: If launched from the command line, `DeNA.Anjin.Editor.Commandline.OnChangePlayModeState()` will be called, and the Unity editor will be terminated. From 8bfdd12df9f18e7f9dcd42abb2748cd8df787eb7 Mon Sep 17 00:00:00 2001 From: Koji Hasegawa Date: Sat, 2 Nov 2024 23:56:56 +0900 Subject: [PATCH 2/3] Fix using NUnit.Framework in runtime --- Runtime/Launcher.cs | 2 +- Runtime/Settings/AutopilotSettings.cs | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Runtime/Launcher.cs b/Runtime/Launcher.cs index 0a9de3d..6749fc4 100644 --- a/Runtime/Launcher.cs +++ b/Runtime/Launcher.cs @@ -11,8 +11,8 @@ using DeNA.Anjin.Attributes; using DeNA.Anjin.Settings; using DeNA.Anjin.Utilities; -using NUnit.Framework; using UnityEngine; +using Assert = UnityEngine.Assertions.Assert; using Object = UnityEngine.Object; #if UNITY_INCLUDE_TESTS using NUnit.Framework; diff --git a/Runtime/Settings/AutopilotSettings.cs b/Runtime/Settings/AutopilotSettings.cs index eb2680e..177d59c 100644 --- a/Runtime/Settings/AutopilotSettings.cs +++ b/Runtime/Settings/AutopilotSettings.cs @@ -8,8 +8,8 @@ using DeNA.Anjin.Attributes; using DeNA.Anjin.Loggers; using DeNA.Anjin.Reporters; -using NUnit.Framework; using UnityEngine; +using UnityEngine.Assertions; namespace DeNA.Anjin.Settings { @@ -241,7 +241,7 @@ public void OverrideByCommandLineArguments(Arguments args) private static void Initialize() { var settings = AutopilotState.Instance.settings; - Assert.NotNull(settings); + Assert.IsNotNull(settings); settings.ConvertLoggersFromObsoleteLogger(); // Note: before create default logger. settings.CreateDefaultLoggerIfNeeded(); From 808e9db1b19a285a2ca2882c3e4c91bf81107f08 Mon Sep 17 00:00:00 2001 From: Koji Hasegawa Date: Sun, 3 Nov 2024 00:22:00 +0900 Subject: [PATCH 3/3] Fix log exit code to integer value --- Editor/Commandline.cs | 2 +- Runtime/Launcher.cs | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Editor/Commandline.cs b/Editor/Commandline.cs index ebc35ee..32abfa2 100644 --- a/Editor/Commandline.cs +++ b/Editor/Commandline.cs @@ -119,7 +119,7 @@ private static void OnChangePlayModeState(PlayModeStateChange playModeStateChang // Exit Unity when returning from play mode to edit mode. // Because it may freeze when exiting without going through edit mode. var exitCode = (int)AutopilotState.Instance.exitCode; - Debug.Log($"Exit Unity-editor by autopilot, exit code={exitCode}"); + Debug.Log($"Exit Unity-editor by autopilot, exit code: {(int)exitCode}"); EditorApplication.Exit(exitCode); } } diff --git a/Runtime/Launcher.cs b/Runtime/Launcher.cs index 6749fc4..75f5f7f 100644 --- a/Runtime/Launcher.cs +++ b/Runtime/Launcher.cs @@ -229,7 +229,7 @@ internal static async UniTaskVoid TeardownLaunchAutopilotAsync(AutopilotState st // Play mode tests if (TestContext.CurrentContext != null && exitCode != ExitCode.Normally) { - throw new AssertionException($"{caller} failed with exit code {exitCode}"); + throw new AssertionException($"{caller} failed with exit code {(int)exitCode}"); } #endif return; // Only terminate autopilot run if starting from play mode. @@ -251,7 +251,7 @@ internal static async UniTaskVoid TeardownLaunchAutopilotAsync(AutopilotState st else { // Player build launch from commandline - logger.Log($"Exit Unity-player by {caller}, exit code={exitCode}"); + logger.Log($"Exit Unity-player by {caller}, exit code: {(int)exitCode}"); Application.Quit((int)exitCode); } }