From c0c9c358e8703c1af917d7270adbb04160ad34b3 Mon Sep 17 00:00:00 2001 From: Trygve Laugstøl Date: Sun, 4 Aug 2013 10:24:43 +0200 Subject: wip --- .../io/trygvis/persistence/EntityMirrorTest.java | 66 +++++++++++++++++++++- 1 file changed, 64 insertions(+), 2 deletions(-) (limited to 'container-compiler-plugin/src/test') diff --git a/container-compiler-plugin/src/test/java/io/trygvis/persistence/EntityMirrorTest.java b/container-compiler-plugin/src/test/java/io/trygvis/persistence/EntityMirrorTest.java index 9d90eef..3f0f345 100644 --- a/container-compiler-plugin/src/test/java/io/trygvis/persistence/EntityMirrorTest.java +++ b/container-compiler-plugin/src/test/java/io/trygvis/persistence/EntityMirrorTest.java @@ -1,10 +1,15 @@ package io.trygvis.persistence; import io.trygvis.container.compiler.SqlUnitModel; +import io.trygvis.container.compiler.model.Imports; +import io.trygvis.container.compiler.model.MethodRef; import io.trygvis.container.compiler.model.TypeRef; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; +import java.io.CharArrayWriter; +import java.io.PrintWriter; + import static io.trygvis.persistence.FieldMirror.PrimitiveFieldMirror; import static java.lang.String.format; import static org.testng.Assert.assertEquals; @@ -15,6 +20,7 @@ public class EntityMirrorTest { static FieldMirror idLong = new PrimitiveFieldMirror(new TypeRef(Long.class), "id", "id", true, false, true); static FieldMirror idString = new PrimitiveFieldMirror(new TypeRef(String.class), "id", "id", true, false, true); static FieldMirror name = new PrimitiveFieldMirror(new TypeRef(String.class), "name", "name", false, false, false); + static FieldMirror age = new PrimitiveFieldMirror(new TypeRef(Integer.class), "age", "age", false, true, false); static FieldMirror ref = new FieldMirror.ReferenceFieldMirror(entityType, "parent", "parent", false, false); @DataProvider(name = "insertIntoSql", parallel = true) @@ -60,11 +66,67 @@ public class EntityMirrorTest { myTable.add(field); } - SqlUnitModel unit = new SqlUnitModel(); - unit.add(myTable); + SqlUnitModel unit = new SqlUnitModel().add(myTable); assertEquals(myTable.insertIntoSql(), insert); assertEquals(myTable.deleteFromSql(), delete); assertEquals(myTable.createTableSql(unit), create); } + + @Test + public void testInsertIntoMethod() { + eq(insertInto(idString), + "try(java.sql.PreparedStatement stmt = con.prepareStatement(insertIntoSql)) {", + " java.lang.String id = o.id;", + " if(id == null) {", + " stmt.setNull(1, java.sql.Types.VARCHAR);", + " } else {", + " stmt.setString(1, o.id);", + " }", + " stmt.executeUpdate();", + "}"); + + eq(insertInto(age), + "try(java.sql.PreparedStatement stmt = con.prepareStatement(insertIntoSql)) {", + " stmt.setInt(1, o.age);", + " stmt.executeUpdate();", + "}"); + } + + @Test + public void testFromResultSet() { + eq(fromResultSet(age), + "java.lang.Integer age = rs.getInt(1);", + "return new Wat(age);"); + } + + private MethodRef insertInto(FieldMirror... fields) { + EntityMirror myTable = new EntityMirror(new GeneratorConfiguration(), entityType, "my_table"); + myTable.add(fields); + SqlUnitModel unit = new SqlUnitModel().add(myTable); + return myTable.insertInto(unit, new Imports()); + } + + private MethodRef fromResultSet(FieldMirror... fields) { + EntityMirror myTable = new EntityMirror(new GeneratorConfiguration(), entityType, "my_table"); + myTable.add(fields); + SqlUnitModel unit = new SqlUnitModel().add(myTable); + return myTable.fromResultSet(unit, new Imports()); + } + + private void eq(MethodRef m, String... expected) { + CharArrayWriter actual = new CharArrayWriter(); + PrintWriter w = new PrintWriter(actual); + for (String s : m.body) { + w.println(s); + } + + CharArrayWriter e = new CharArrayWriter(); + w = new PrintWriter(e); + for (String s : expected) { + w.println(s); + } + + assertEquals(actual.toString(), e.toString()); + } } -- cgit v1.2.3