summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/server-side/com/vaadin/data/util/sqlcontainer/generator/SQLGeneratorsTest.java83
1 files changed, 83 insertions, 0 deletions
diff --git a/tests/server-side/com/vaadin/data/util/sqlcontainer/generator/SQLGeneratorsTest.java b/tests/server-side/com/vaadin/data/util/sqlcontainer/generator/SQLGeneratorsTest.java
index e62a06e6e1..b8df4b1799 100644
--- a/tests/server-side/com/vaadin/data/util/sqlcontainer/generator/SQLGeneratorsTest.java
+++ b/tests/server-side/com/vaadin/data/util/sqlcontainer/generator/SQLGeneratorsTest.java
@@ -5,6 +5,7 @@ import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
+import org.easymock.EasyMock;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
@@ -14,7 +15,9 @@ import com.vaadin.data.Container.Filter;
import com.vaadin.data.util.filter.Like;
import com.vaadin.data.util.filter.Or;
import com.vaadin.data.util.sqlcontainer.AllTests;
+import com.vaadin.data.util.sqlcontainer.ColumnProperty;
import com.vaadin.data.util.sqlcontainer.DataGenerator;
+import com.vaadin.data.util.sqlcontainer.RowId;
import com.vaadin.data.util.sqlcontainer.RowItem;
import com.vaadin.data.util.sqlcontainer.SQLContainer;
import com.vaadin.data.util.sqlcontainer.connection.JDBCConnectionPool;
@@ -148,6 +151,86 @@ public class SQLGeneratorsTest {
}
@Test
+ public void generateUpdateQuery_severalPrimKeys_shouldSucceed()
+ throws SQLException {
+ /*
+ * No need to run this for Oracle/MSSQL generators since the
+ * DefaultSQLGenerator method would be called anyway.
+ */
+ if (AllTests.sqlGen instanceof MSSQLGenerator
+ || AllTests.sqlGen instanceof OracleGenerator) {
+ return;
+ }
+
+ DefaultSQLGenerator sqlGen = new DefaultSQLGenerator();
+
+ // Create situation wihere PrimKey is a composite of two columns...
+ ColumnProperty cp1 = new ColumnProperty("FIRSTPK", false, true, false,
+ true, new Integer(1), Integer.class);
+ ColumnProperty cp2 = new ColumnProperty("SECONDPK", false, true, false,
+ true, "primKeyValue", String.class);
+ ColumnProperty cp3 = new ColumnProperty("NONPK", false, true, false,
+ false, new Integer(1), Integer.class);
+
+ SQLContainer container = EasyMock.createNiceMock(SQLContainer.class);
+
+ RowItem ri = new RowItem(container, new RowId(new Object[] { 0L }),
+ Arrays.asList(cp1, cp2, cp3));
+
+ StatementHelper generateUpdateQuery = sqlGen.generateUpdateQuery(
+ "testTable", ri);
+
+ String queryString = generateUpdateQuery.getQueryString();
+
+ // Assert that the WHERE-clause has both prim keys...
+ Assert.assertEquals(
+ "UPDATE testTable SET \"NONPK\" = ?, \"SECONDPK\" = ?, \"FIRSTPK\" = ? WHERE \"SECONDPK\" = ? AND \"FIRSTPK\" = ?",
+ queryString);
+ }
+
+ @Test
+ public void generateUpdateQuery_severalPrimKeysAndVersion_shouldSucceed()
+ throws SQLException {
+ /*
+ * No need to run this for Oracle/MSSQL generators since the
+ * DefaultSQLGenerator method would be called anyway.
+ */
+ if (AllTests.sqlGen instanceof MSSQLGenerator
+ || AllTests.sqlGen instanceof OracleGenerator) {
+ return;
+ }
+
+ DefaultSQLGenerator sqlGen = new DefaultSQLGenerator();
+
+ // Create situation wihere PrimKey is a composite of two columns...
+ ColumnProperty cp1 = new ColumnProperty("FIRSTPK", false, true, false,
+ true, new Integer(1), Integer.class);
+ ColumnProperty cp2 = new ColumnProperty("SECONDPK", false, true, false,
+ true, "primKeyValue", String.class);
+ ColumnProperty cp3 = new ColumnProperty("NONPK", false, true, false,
+ false, new Integer(1), Integer.class);
+ ColumnProperty cp4 = new ColumnProperty("VERSION", false, true, false,
+ false, new Integer(1), Integer.class);
+ cp4.setVersionColumn(true);
+
+ SQLContainer container = EasyMock.createNiceMock(SQLContainer.class);
+
+ RowItem ri = new RowItem(container, new RowId(new Object[] { 0L }),
+ Arrays.asList(cp1, cp2, cp3, cp4));
+
+ StatementHelper generateUpdateQuery = sqlGen.generateUpdateQuery(
+ "testTable", ri);
+
+ String queryString = generateUpdateQuery.getQueryString();
+
+ // Assert that the WHERE-clause has both prim keys and version...
+ // Version should not be in SET...
+ Assert.assertEquals(
+ "UPDATE testTable SET \"NONPK\" = ?, \"SECONDPK\" = ?, \"FIRSTPK\" = ? WHERE \"VERSION\" = ? AND \"SECONDPK\" = ? AND \"FIRSTPK\" = ?",
+ queryString);
+ }
+
+ @Test
public void generateInsertQuery_basicQuery_shouldSucceed()
throws SQLException {
/*