diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java | 91 | ||||
-rw-r--r-- | test/src/java/com/healthmarketscience/jackcess/TableTest.java | 3 |
2 files changed, 90 insertions, 4 deletions
diff --git a/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java b/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java index 18d3b47..ccefd0f 100644 --- a/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java +++ b/test/src/java/com/healthmarketscience/jackcess/DatabaseTest.java @@ -9,6 +9,7 @@ import java.math.BigDecimal; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; +import java.util.Collections; import java.util.Date; import java.util.HashMap; import java.util.List; @@ -35,6 +36,63 @@ public class DatabaseTest extends TestCase { return Database.create(tmp); } + public void testInvalidTableDefs() throws Exception { + Database db = create(); + + try { + db.createTable("test", Collections.<Column>emptyList()); + fail("created table with no columns?"); + } catch(IllegalArgumentException e) { + // success + } + + List<Column> columns = new ArrayList<Column>(); + Column col = new Column(); + col.setName("A"); + col.setType(DataType.TEXT); + columns.add(col); + col = new Column(); + col.setName("a"); + col.setType(DataType.MEMO); + columns.add(col); + + try { + db.createTable("test", columns); + fail("created table with duplicate column names?"); + } catch(IllegalArgumentException e) { + // success + } + + columns = new ArrayList<Column>(); + col = new Column(); + col.setName("A"); + col.setType(DataType.TEXT); + col.setLength((short)(352 * 2)); + columns.add(col); + + try { + db.createTable("test", columns); + fail("created table with invalid column length?"); + } catch(IllegalArgumentException e) { + // success + } + + columns = new ArrayList<Column>(); + col = new Column(); + col.setName("A"); + col.setType(DataType.TEXT); + columns.add(col); + db.createTable("test", columns); + + try { + db.createTable("Test", columns); + fail("create duplicate tables?"); + } catch(IllegalArgumentException e) { + // success + } + + } + public void testReadDeletedRows() throws Exception { Table table = Database.open(new File("test/data/delTest.mdb")).getTable("Table"); int rows = 0; @@ -153,10 +211,33 @@ public class DatabaseTest extends TestCase { } public void testDeleteCurrentRow() throws Exception { + + // make sure correct row is deleted Database db = create(); createTestTable(db); - Object[] row = createTestRow(); + Object[] row1 = createTestRow("Tim1"); + Object[] row2 = createTestRow("Tim2"); + Object[] row3 = createTestRow("Tim3"); Table table = db.getTable("Test"); + table.addRows(Arrays.asList(row1, row2, row3)); + + table.reset(); + table.getNextRow(); + table.getNextRow(); + table.deleteCurrentRow(); + + table.reset(); + + Map<String, Object> outRow = table.getNextRow(); + assertEquals("Tim1", outRow.get("A")); + outRow = table.getNextRow(); + assertEquals("Tim3", outRow.get("A")); + + // test multi row delete/add + db = create(); + createTestTable(db); + Object[] row = createTestRow(); + table = db.getTable("Test"); for (int i = 0; i < 10; i++) { row[3] = i; table.addRow(row); @@ -445,10 +526,14 @@ public class DatabaseTest extends TestCase { assertEquals(89, columns.size()); } - private Object[] createTestRow() { - return new Object[] {"Tim", "R", "McCune", 1234, (byte) 0xad, 555.66d, + private Object[] createTestRow(String col1Val) { + return new Object[] {col1Val, "R", "McCune", 1234, (byte) 0xad, 555.66d, 777.88f, (short) 999, new Date()}; } + + private Object[] createTestRow() { + return createTestRow("Tim"); + } private void createTestTable(Database db) throws Exception { List<Column> columns = new ArrayList<Column>(); diff --git a/test/src/java/com/healthmarketscience/jackcess/TableTest.java b/test/src/java/com/healthmarketscience/jackcess/TableTest.java index ecb02e8..29178f9 100644 --- a/test/src/java/com/healthmarketscience/jackcess/TableTest.java +++ b/test/src/java/com/healthmarketscience/jackcess/TableTest.java @@ -18,6 +18,7 @@ public class TableTest extends TestCase { } public void testCreateRow() throws Exception { + JetFormat format = JetFormat.VERSION_4; Table table = new Table(); List<Column> columns = new ArrayList<Column>(); Column col = new Column(); @@ -33,7 +34,7 @@ public class TableTest extends TestCase { row[0] = new Short((short) 9); row[1] = "Tim"; row[2] = "McCune"; - ByteBuffer buffer = table.createRow(row); + ByteBuffer buffer = table.createRow(row, format.MAX_ROW_SIZE); assertEquals((short) colCount, buffer.getShort()); assertEquals((short) 9, buffer.getShort()); assertEquals((byte) 'T', buffer.get()); |