Exemple #1
0
        public void TestExtractFileName()
        {
            string stackTrace = "LunarPlugin.Cmd_echo:Execute(String[]) (at Assets/Plugins/LunarPlugin/Console/CConsole_common.cs:329)\n" +
                                "LunarPlugin.CCommand:ExecuteGuarded(List`1, String) (at Assets/Plugins/LunarPlugin/Console/CCommand.cs:147)\n" +
                                "LunarPlugin.CCommand:ExecuteTokens(List`1, String) (at Assets/Plugins/LunarPlugin/Console/CCommand.cs:75)\n" +
                                "LunarPlugin.CommandProcessor:TryExecute(String) (at Assets/Plugins/LunarPlugin/Console/CommandProcessor.cs:35)\n" +
                                "LunarPlugin.App:ExecCommand(String) (at Assets/Plugins/LunarPlugin/App.cs:273)\n" +
                                "TerminalWindow:<CreateUI>m__2(TextField, KeyCode, Boolean) (at Assets/Editor/TerminalWindow.cs:48)\n" +
                                "LunarPlugin.TextField:OnGUI() (at Assets/Plugins/LunarPlugin/UI/TextField.cs:69)\n" +
                                "LunarPlugin.View:DrawChildren(Boolean) (at Assets/Plugins/LunarPlugin/UI/View.cs:392)\n" +
                                "LunarPlugin.View:DrawGUI() (at Assets/Plugins/LunarPlugin/UI/View.cs:70)\n" +
                                "LunarPlugin.View:OnGUI() (at Assets/Plugins/LunarPlugin/UI/View.cs:62)\n" +
                                "Window:OnGUI() (at Assets/Editor/Window.cs:37)\n" +
                                "System.Reflection.MonoMethod:InternalInvoke(Object, Object[], Exception&)\n" +
                                "System.Reflection.MonoMethod:Invoke(Object, BindingFlags, Binder, Object[], CultureInfo) (at /Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/MonoMethod.cs:222)\n" +
                                "System.Reflection.MethodBase:Invoke(Object, Object[]) (at /Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/MethodBase.cs:115)\n" +
                                "UnityEditor.HostView:Invoke(String, Object)\n" +
                                "UnityEditor.HostView:Invoke(String)\n" +
                                "UnityEditor.DockArea:OnGUI()";

            string expected = "CConsole_common.cs";

            string actual = EditorStackTrace.ExtractFileName(stackTrace);

            Assert.AreEqual(expected, actual);
        }
Exemple #2
0
        public void TestParsingCompilerWarningSourceEntries()
        {
            string line = "[E]: Assets/Editor/Console/ConsoleView.cs(637,18): error CS1525: Unexpected symbol `if', expecting `)', `,', `;', `[', or `='";

            SourcePathEntry expected = new SourcePathEntry("Assets/Editor/Console/ConsoleView.cs", 637);
            SourcePathEntry actual;
            bool            succeed = EditorStackTrace.TryParseCompilerMessage(line, out actual);

            Assert.IsTrue(succeed);

            Assert.AreEqual(expected.IsValid, actual.IsValid);
            Assert.AreEqual(expected.sourcePath, actual.sourcePath);
            Assert.AreEqual(expected.lineNumber, actual.lineNumber);
        }
Exemple #3
0
        public void TestOptimize()
        {
            string stackTrace = "  at System.Reflection.MonoMethod.Invoke (System.Object obj, BindingFlags invokeAttr, System.Reflection.Binder binder, System.Object[] parameters, System.Globalization.CultureInfo culture) [0x000eb] in /Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/MonoMethod.cs:232 \n" +
                                "  at System.Reflection.MethodBase.Invoke (System.Object obj, System.Object[] parameters) [0x00000]\n" +
                                "  at System.Reflection.MethodBase.Invoke (System.Object obj)\n" +
                                "  at Test.<OnGUIHelper>m__4 () [0x00013] in /Users/alementuev/dev/my/unity-debug-kit/Project/Assets/Test.cs:100 \n" +
                                "  at LunarPlugin.Timer.DefaultTimerCallback (LunarPlugin.Timer timer) [0x00000] in /Users/alementuev/dev/my/unity-debug-kit/Project/Assets/Plugins/LunarPlugin/Core/Timer.cs:76 \n" +
                                "  at LunarPlugin.Timer.Fire () [0x00008] in /Users/alementuev/dev/my/unity-debug-kit/Project/Assets/Plugins/LunarPlugin/Core/Timer.cs:51 ";

            StackTraceLine[] expected =
            {
                new StackTraceLine("System.Reflection.MonoMethod.Invoke(Object, BindingFlags, Binder, Object[], CultureInfo) (at /Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/MonoMethod.cs:232)", "/Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/MonoMethod.cs", 232),
                new StackTraceLine("System.Reflection.MethodBase.Invoke(Object, Object[])"),
                new StackTraceLine("System.Reflection.MethodBase.Invoke(Object)"),
                new StackTraceLine("Test.<OnGUIHelper>m__4() (at Assets/Test.cs:100)",                                                                                                                                                                "Assets/Test.cs",                                                                                                100),
                new StackTraceLine("LunarPlugin.Timer.DefaultTimerCallback(Timer) (at Assets/Plugins/LunarPlugin/Core/Timer.cs:76)",                                                                                                                  "Assets/Plugins/LunarPlugin/Core/Timer.cs",                                                                       76),
                new StackTraceLine("LunarPlugin.Timer.Fire() (at Assets/Plugins/LunarPlugin/Core/Timer.cs:51)",                                                                                                                                       "Assets/Plugins/LunarPlugin/Core/Timer.cs", 51)
            };

            StackTraceLine[] actual = EditorStackTrace.ParseStackTrace(stackTrace);
            Assert.AreEqual(expected, actual);
        }
Exemple #4
0
        public void TestOptimizeAlreadyOptimized()
        {
            string stackTrace = "Test.foo(String, Timer, Boolean[]) (at Assets/Test.cs:120)\n" +
                                "Test.<OnGUIHelper>m__4() (at Assets/Test.cs:98)\n" +
                                "LunarPlugin.Timer.DefaultTimerCallback(Timer) (at Assets/Plugins/LunarPlugin/Core/Timer.cs:76)\n" +
                                "LunarPlugin.Timer.Fire() (at Assets/Plugins/LunarPlugin/Core/Timer.cs:51)\n" +
                                "UnityEditor.HostView:Invoke(String, Object)\n" +
                                "UnityEditor.HostView:Invoke(String)\n" +
                                "UnityEditor.DockArea:OnGUI()";

            StackTraceLine[] expected =
            {
                new StackTraceLine("Test.foo(String, Timer, Boolean[]) (at Assets/Test.cs:120)",                                     "Assets/Test.cs",                           120),
                new StackTraceLine("Test.<OnGUIHelper>m__4() (at Assets/Test.cs:98)",                                                "Assets/Test.cs",                            98),
                new StackTraceLine("LunarPlugin.Timer.DefaultTimerCallback(Timer) (at Assets/Plugins/LunarPlugin/Core/Timer.cs:76)", "Assets/Plugins/LunarPlugin/Core/Timer.cs",  76),
                new StackTraceLine("LunarPlugin.Timer.Fire() (at Assets/Plugins/LunarPlugin/Core/Timer.cs:51)",                      "Assets/Plugins/LunarPlugin/Core/Timer.cs",  51),
                new StackTraceLine("UnityEditor.HostView:Invoke(String, Object)"),
                new StackTraceLine("UnityEditor.HostView:Invoke(String)"),
                new StackTraceLine("UnityEditor.DockArea:OnGUI()")
            };

            StackTraceLine[] actual = EditorStackTrace.ParseStackTrace(stackTrace);
            Assert.AreEqual(expected, actual);
        }