TestsCallback.cs 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #if TEST_FRAMEWORK
  2. using System;
  3. using System.Text;
  4. using UnityEditor.TestTools.TestRunner.Api;
  5. using UnityEngine;
  6. namespace Packages.Rider.Editor.UnitTesting
  7. {
  8. public class TestsCallback : ScriptableObject, IErrorCallbacks
  9. {
  10. public void RunFinished(ITestResultAdaptor result)
  11. {
  12. CallbackData.instance.isRider = false;
  13. CallbackData.instance.events.Add(
  14. new TestEvent(EventType.RunFinished, "", "","", 0, ParseTestStatus(result.TestStatus), ""));
  15. CallbackData.instance.RaiseChangedEvent();
  16. }
  17. public void RunStarted(ITestAdaptor testsToRun)
  18. {
  19. CallbackData.instance.events.Add(
  20. new TestEvent(EventType.RunStarted, "", "","", 0, NUnit.Framework.Interfaces.TestStatus.Passed, ""));
  21. CallbackData.instance.RaiseChangedEvent();
  22. }
  23. public void TestStarted(ITestAdaptor result)
  24. {
  25. if (result.Method == null) return;
  26. CallbackData.instance.events.Add(
  27. new TestEvent(EventType.TestStarted, GetUniqueName(result), result.Method.TypeInfo.Assembly.GetName().Name, "", 0, NUnit.Framework.Interfaces.TestStatus.Passed, result.ParentFullName));
  28. CallbackData.instance.RaiseChangedEvent();
  29. }
  30. public void TestFinished(ITestResultAdaptor result)
  31. {
  32. if (result.Test.Method == null) return;
  33. CallbackData.instance.events.Add(
  34. new TestEvent(EventType.TestFinished, GetUniqueName(result.Test), result.Test.Method.TypeInfo.Assembly.GetName().Name, ExtractOutput(result), (result.EndTime-result.StartTime).Milliseconds, ParseTestStatus(result.TestStatus), result.Test.ParentFullName));
  35. CallbackData.instance.RaiseChangedEvent();
  36. }
  37. public void OnError(string message)
  38. {
  39. CallbackData.instance.isRider = false;
  40. CallbackData.instance.events.Add(
  41. new TestEvent(EventType.RunFinished, "", "",message, 0, NUnit.Framework.Interfaces.TestStatus.Failed, ""));
  42. CallbackData.instance.RaiseChangedEvent();
  43. }
  44. // todo: reimplement JetBrains.Rider.Unity.Editor.AfterUnity56.UnitTesting.TestEventsSender.GetUniqueName
  45. private static string GetUniqueName(ITestAdaptor test)
  46. {
  47. string str = test.FullName;
  48. return str;
  49. }
  50. private static NUnit.Framework.Interfaces.TestStatus ParseTestStatus(TestStatus testStatus)
  51. {
  52. return (NUnit.Framework.Interfaces.TestStatus)Enum.Parse(typeof(NUnit.Framework.Interfaces.TestStatus), testStatus.ToString());
  53. }
  54. private static string ExtractOutput(ITestResultAdaptor testResult)
  55. {
  56. var stringBuilder = new StringBuilder();
  57. if (testResult.Message != null)
  58. {
  59. stringBuilder.AppendLine("Message: ");
  60. stringBuilder.AppendLine(testResult.Message);
  61. }
  62. if (!string.IsNullOrEmpty(testResult.Output))
  63. {
  64. stringBuilder.AppendLine("Output: ");
  65. stringBuilder.AppendLine(testResult.Output);
  66. }
  67. if (!string.IsNullOrEmpty(testResult.StackTrace))
  68. {
  69. stringBuilder.AppendLine("Stacktrace: ");
  70. stringBuilder.AppendLine(testResult.StackTrace);
  71. }
  72. var result = stringBuilder.ToString();
  73. if (result.Length > 0)
  74. return result;
  75. return testResult.Output ?? string.Empty;
  76. }
  77. }
  78. }
  79. #endif