final StatementContext statementContext = ((StatementException) t.getCause()).getStatementContext();
final StatementContext statementContext = ((StatementException) t.getCause()).getStatementContext();
final StatementContext statementContext = ((StatementException) t.getCause()).getStatementContext();
@Override public String getMessage() { String base = super.getMessage(); StatementContext ctx = getStatementContext(); if (ctx == null) { return base; } else { return String.format("%s [statement:\"%s\", located:\"%s\", rewritten:\"%s\", arguments:%s]", base, ctx.getRawSql(), ctx.getLocatedSql(), ctx.getRewrittenSql(), ctx.getBinding()); } } }
@Override public String getMessage() { String base = super.getMessage(); StatementContext ctx = getStatementContext(); if (ctx == null) { return base; } else { return String.format("%s [statement:\"%s\", located:\"%s\", rewritten:\"%s\", arguments:%s]", base, ctx.getRawSql(), ctx.getLocatedSql(), ctx.getRewrittenSql(), ctx.getBinding()); } } }
@Test public void testFoo() throws Exception { Handle h = openHandle(); try { h.insert("WOOF", 7, "Tom"); } catch (StatementException e) { assertEquals(e.getStatementContext().getRawSql(), "WOOF"); } } }
@Test public void testFoo() throws Exception { Handle h = openHandle(); try { h.insert("WOOF", 7, "Tom"); } catch (StatementException e) { assertEquals(e.getStatementContext().getRawSql(), "WOOF"); } } }
@Test public void testScriptAsSetOfSeparateStatements() throws Exception { try { BasicHandle h = openHandle(); Script script = h.createScript("malformed-sql-script"); script.executeAsSeparateStatements(); fail("Should fail because the script is malformed"); } catch (StatementException e) { StatementContext context = e.getStatementContext(); assertEquals(context.getRawSql().trim(), "insert into something(id, name) values (2, eric)"); } } }
@Test public void testScriptAsSetOfSeparateStatements() throws Exception { try { BasicHandle h = openHandle(); Script script = h.createScript("malformed-sql-script"); script.executeAsSeparateStatements(); fail("Should fail because the script is malformed"); } catch (StatementException e) { StatementContext context = e.getStatementContext(); assertEquals(context.getRawSql().trim(), "insert into something(id, name) values (2, eric)"); } } }