forked from crawshaw/sqlitejdbc
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathRSMetaDataTest.java
More file actions
79 lines (67 loc) · 2.9 KB
/
RSMetaDataTest.java
File metadata and controls
79 lines (67 loc) · 2.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package test;
import java.sql.*;
import org.junit.*;
import static org.junit.Assert.*;
public class RSMetaDataTest
{
private Connection conn;
private Statement stat;
private ResultSetMetaData meta;
@BeforeClass public static void forName() throws Exception {
Class.forName("org.sqlite.JDBC");
}
@Before public void connect() throws Exception {
conn = DriverManager.getConnection("jdbc:sqlite:");
stat = conn.createStatement();
stat.executeUpdate(
"create table People (pid integer primary key autoincrement, "
+ " firstname string, surname string, dob date);");
stat.executeUpdate(
"insert into people values (null, 'Mohandas', 'Gandhi', "
+ " '1869-10-02');");
meta = stat.executeQuery(
"select pid, firstname, surname from people;").getMetaData();
}
@After public void close() throws SQLException {
stat.executeUpdate("drop table people;");
stat.close();
conn.close();
}
@Test public void catalogName() throws SQLException {
assertEquals(meta.getCatalogName(1), "People");
}
@Test public void columns() throws SQLException {
assertEquals(meta.getColumnCount(), 3);
assertEquals(meta.getColumnName(1), "pid");
assertEquals(meta.getColumnName(2), "firstname");
assertEquals(meta.getColumnName(3), "surname");
assertEquals(meta.getColumnType(1), Types.INTEGER);
assertEquals(meta.getColumnType(2), Types.VARCHAR);
assertEquals(meta.getColumnType(3), Types.VARCHAR);
assertEquals(meta.getColumnTypeName(1), "integer");
assertEquals(meta.getColumnTypeName(2), "text");
assertEquals(meta.getColumnTypeName(3), "text");
assertTrue(meta.isAutoIncrement(1));
assertFalse(meta.isAutoIncrement(2));
assertFalse(meta.isAutoIncrement(3));
assertEquals(meta.isNullable(1), meta.columnNoNulls);
assertEquals(meta.isNullable(2), meta.columnNullable);
assertEquals(meta.isNullable(3), meta.columnNullable);
}
@Test public void differentRS() throws SQLException {
meta = stat.executeQuery("select * from people;").getMetaData();
assertEquals(meta.getColumnCount(), 4);
assertEquals(meta.getColumnName(1), "pid");
assertEquals(meta.getColumnName(2), "firstname");
assertEquals(meta.getColumnName(3), "surname");
assertEquals(meta.getColumnName(4), "dob");
}
@Test public void nullable() throws SQLException {
meta = stat.executeQuery("select null;").getMetaData();
assertEquals(meta.isNullable(1), ResultSetMetaData.columnNullable);
}
@Test(expected= SQLException.class)
public void badCatalogIndex() throws SQLException { meta.getCatalogName(4);}
@Test(expected= SQLException.class)
public void badColumnIndex() throws SQLException { meta.getColumnName(4); }
}