TestHelpers.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. using Esprima.Ast;
  2. using Jint.Runtime.Debugger;
  3. namespace Jint.Tests.Runtime.Debugger
  4. {
  5. public static class TestHelpers
  6. {
  7. public static bool IsLiteral(this Node node, string requiredValue = null)
  8. {
  9. return node switch
  10. {
  11. Directive directive => requiredValue == null || directive.Value == requiredValue,
  12. ExpressionStatement expr => requiredValue == null || (expr.Expression is Literal literal && literal.StringValue == requiredValue),
  13. _ => false
  14. };
  15. }
  16. public static bool ReachedLiteral(this DebugInformation info, string requiredValue)
  17. {
  18. return info.CurrentNode.IsLiteral(requiredValue);
  19. }
  20. /// <summary>
  21. /// Initializes engine in debugmode and executes script until debugger statement,
  22. /// before calling stepHandler for assertions. Also asserts that a break was triggered.
  23. /// </summary>
  24. /// <param name="initialization">Action to initialize and execute scripts</param>
  25. /// <param name="breakHandler">Handler for assertions</param>
  26. public static void TestAtBreak(Action<Engine> initialization, Action<Engine, DebugInformation> breakHandler)
  27. {
  28. var engine = new Engine(options => options
  29. .DebugMode()
  30. .DebuggerStatementHandling(DebuggerStatementHandling.Script)
  31. );
  32. bool didBreak = false;
  33. engine.Debugger.Break += (sender, info) =>
  34. {
  35. didBreak = true;
  36. breakHandler(sender as Engine, info);
  37. return StepMode.None;
  38. };
  39. initialization(engine);
  40. Assert.True(didBreak, "Test script did not break (e.g. didn't reach debugger statement)");
  41. }
  42. /// <inheritdoc cref="TestAtBreak()"/>
  43. public static void TestAtBreak(Action<Engine> initialization, Action<DebugInformation> breakHandler)
  44. {
  45. TestAtBreak(engine => initialization(engine), (engine, info) => breakHandler(info));
  46. }
  47. /// <summary>
  48. /// Initializes engine in debugmode and executes script until debugger statement,
  49. /// before calling stepHandler for assertions. Also asserts that a break was triggered.
  50. /// </summary>
  51. /// <param name="script">Script that is basis for testing</param>
  52. /// <param name="breakHandler">Handler for assertions</param>
  53. public static void TestAtBreak(string script, Action<Engine, DebugInformation> breakHandler)
  54. {
  55. TestAtBreak(engine => engine.Execute(script), breakHandler);
  56. }
  57. /// <inheritdoc cref="TestAtBreak()"/>
  58. public static void TestAtBreak(string script, Action<DebugInformation> breakHandler)
  59. {
  60. TestAtBreak(script, (engine, info) => breakHandler(info));
  61. }
  62. }
  63. }