From 123e17fd8005f362d05185367b3c973fe266b11e Mon Sep 17 00:00:00 2001 From: Stephen Amar Date: Fri, 13 Dec 2024 21:00:22 -0800 Subject: [PATCH] Improve error messages in Materializer (#238) --- sjsonnet/src/sjsonnet/Materializer.scala | 11 ++++++----- .../test/src-jvm/sjsonnet/ErrorTestsJvmOnly.scala | 3 +++ sjsonnet/test/src/sjsonnet/EvaluatorTests.scala | 2 +- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/sjsonnet/src/sjsonnet/Materializer.scala b/sjsonnet/src/sjsonnet/Materializer.scala index e077e6b1..70e3299c 100644 --- a/sjsonnet/src/sjsonnet/Materializer.scala +++ b/sjsonnet/src/sjsonnet/Materializer.scala @@ -37,7 +37,8 @@ abstract class Materializer { ) if(sort) { if(prevKey != null && k.compareTo(prevKey) <= 0) - Error.fail(s"""Internal error: Unexpected key "$k" after "$prevKey" in sorted object materialization""") + Error.fail( + s"""Internal error: Unexpected key "$k" after "$prevKey" in sorted object materialization""", v.pos) prevKey = k } } @@ -56,14 +57,14 @@ abstract class Materializer { case Val.True(pos) => storePos(pos); visitor.visitTrue(-1) case Val.False(pos) => storePos(pos); visitor.visitFalse(-1) case Val.Null(pos) => storePos(pos); visitor.visitNull(-1) - case _: Val.Func => - Error.fail("Couldn't manifest function as JSON") + case s: Val.Func => + Error.fail("Couldn't manifest function with params [" + s.params.names.mkString(",") + "]", v.pos) case _ => - Error.fail("Unknown value type " + v.prettyName) + Error.fail("Unknown value type", v.pos) } } catch { case _: StackOverflowError => - Error.fail("Stackoverflow while materializing, possibly due to recursive value") + Error.fail("Stackoverflow while materializing, possibly due to recursive value", v.pos) } def reverse(pos: Position, v: ujson.Value): Val = v match{ diff --git a/sjsonnet/test/src-jvm/sjsonnet/ErrorTestsJvmOnly.scala b/sjsonnet/test/src-jvm/sjsonnet/ErrorTestsJvmOnly.scala index db9d6d2d..4242198c 100644 --- a/sjsonnet/test/src-jvm/sjsonnet/ErrorTestsJvmOnly.scala +++ b/sjsonnet/test/src-jvm/sjsonnet/ErrorTestsJvmOnly.scala @@ -23,14 +23,17 @@ object ErrorTestsJvmOnly extends TestSuite { val tests = Tests{ test("array_recursive_manifest") - check( """sjsonnet.Error: Stackoverflow while materializing, possibly due to recursive value + | at .(sjsonnet/test/resources/test_suite/error.array_recursive_manifest.jsonnet:17:12) |""".stripMargin ) test("obj_recursive") - check( """sjsonnet.Error: Stackoverflow while materializing, possibly due to recursive value + | at .(sjsonnet/test/resources/test_suite/error.obj_recursive.jsonnet:17:3) |""".stripMargin ) test("obj_recursive_manifest") - check( """sjsonnet.Error: Stackoverflow while materializing, possibly due to recursive value + | at .(sjsonnet/test/resources/test_suite/error.obj_recursive_manifest.jsonnet:17:3) |""".stripMargin ) } diff --git a/sjsonnet/test/src/sjsonnet/EvaluatorTests.scala b/sjsonnet/test/src/sjsonnet/EvaluatorTests.scala index 06022b6e..8c8958f5 100644 --- a/sjsonnet/test/src/sjsonnet/EvaluatorTests.scala +++ b/sjsonnet/test/src/sjsonnet/EvaluatorTests.scala @@ -30,7 +30,7 @@ object EvaluatorTests extends TestSuite{ eval("local f(x) = function() true; f(42)") ==> ujson.True eval("local f(x) = function() true; f(42) == true") ==> ujson.False eval("local f(x) = function() true; f(42)() == true") ==> ujson.True - assert(evalErr("{foo: function() true}").startsWith("sjsonnet.Error: Couldn't manifest function as JSON")) + assert(evalErr("{foo: function() true}").startsWith("sjsonnet.Error: Couldn't manifest function with params")) eval("{foo: (function() true)()}") ==> ujson.Obj{"foo" -> ujson.True} } test("members") {