generated from giis-uniovi/samples-giis-template
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
a0a5f44
commit c0c3137
Showing
7 changed files
with
266 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
net/TdRulesTest/Translated/Test4giis.Tdrules.Store.Rdb.Sqlite/TestSqliteResultSet.cs
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
118 changes: 118 additions & 0 deletions
118
net/TdRulesTest/Translated/Test4giis.Tdrules.Store.Rdb/TestSqlserverResultSet.cs
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
2 changes: 1 addition & 1 deletion
2
net/TdRulesTest/Translated/Test4giis.Tdrules.Store.Rdb/TestSqlserverSchemaMetadata.cs
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
113 changes: 113 additions & 0 deletions
113
tdrules-store-rdb/src/test/java/test4giis/tdrules/store/rdb/TestSqlserverResultSet.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
package test4giis.tdrules.store.rdb; | ||
|
||
import static org.junit.Assert.assertEquals; | ||
import static org.junit.Assert.assertFalse; | ||
import static org.junit.Assert.assertNotNull; | ||
import static org.junit.Assert.assertTrue; | ||
|
||
import java.sql.Connection; | ||
import java.sql.ResultSet; | ||
import java.sql.SQLException; | ||
import java.util.Date; | ||
|
||
import org.junit.After; | ||
import org.junit.Before; | ||
import org.junit.Test; | ||
|
||
import giis.portable.util.JavaCs; | ||
|
||
/** | ||
* Reading basic data types from a ResultSet, check nullability and access by name or column number. | ||
* Intended to test the .net ResultSet wrapper implementation | ||
*/ | ||
public class TestSqlserverResultSet extends Base { | ||
protected Connection dbt; | ||
protected ResultSet rs; | ||
|
||
protected String sCreate1 = "create table tabrs1 (pk integer primary key not null, " | ||
+ "tint integer, tchar varchar(16), tdate date, tlong bigint)"; | ||
protected String sSelect1 = "select pk, tint, tchar, tdate, tlong from tabrs1"; | ||
|
||
@Before | ||
public void setUp() throws SQLException { | ||
super.setUp(); | ||
dbt = getConnection(TEST_DBNAME2); | ||
executeNotThrow(dbt, "drop table tabrs1"); | ||
execute(dbt, sCreate1); | ||
} | ||
|
||
@After | ||
public void tearDown() throws SQLException { | ||
if (rs != null) | ||
rs.close(); | ||
dbt.close(); | ||
} | ||
|
||
@Test | ||
public void testReadResultSet() throws SQLException { | ||
execute(dbt, "insert into tabrs1 (pk,tint,tchar,tdate,tlong) values(1, 2, null, '2023-01-02', null)"); | ||
execute(dbt, "insert into tabrs1 (pk,tint,tchar,tdate,tlong) values(2, null, 'chrchr', null, 55)"); | ||
|
||
// 1st round: even columns are not null/odd columns are null (except pk), | ||
// read by column number | ||
rs = query(dbt, sSelect1); | ||
assertTrue(rs.next()); | ||
assertEquals(1, rs.getInt(1)); | ||
|
||
int tint = rs.getInt(2); | ||
assertFalse(rs.wasNull()); | ||
assertEquals(2, tint); | ||
assertEquals("2", rs.getString(2)); | ||
|
||
String tchar = rs.getString(3); | ||
assertTrue(rs.wasNull()); | ||
assertEquals(null, tchar); | ||
|
||
Date tdate; | ||
if (!"sqlite".equals(dbmsname)) { // sqlite does not have native Date | ||
tdate = rs.getDate(4); | ||
assertFalse(rs.wasNull()); | ||
assertEquals("2023-01-02", dateString(tdate)); // normalize Date for .net compatibility | ||
assertNotNull(rs.getString(4)); // do not check value because is system/locale dependent | ||
} | ||
|
||
long tlong = rs.getLong(5); | ||
assertTrue(rs.wasNull()); | ||
assertEquals(0, tlong); | ||
|
||
// 2nd round: alternate nullability, read by column name | ||
assertTrue(rs.next()); | ||
assertEquals(2, rs.getInt("pk")); | ||
|
||
tint = rs.getInt("tint"); | ||
assertTrue(rs.wasNull()); | ||
assertEquals(0, tint); | ||
assertEquals(null, rs.getString("tint")); | ||
|
||
tchar = rs.getString("tchar"); | ||
assertFalse(rs.wasNull()); | ||
assertEquals("chrchr", tchar); | ||
|
||
if (!"sqlite".equals(dbmsname)) { | ||
tdate = rs.getDate("tdate"); | ||
assertTrue(rs.wasNull()); | ||
if ("java".equals(PLATFORM)) | ||
assertEquals(null, tdate); | ||
else // on .net, DateTime is no nullable, returns DateTime.MinValue | ||
assertEquals("0001-01-01", dateString(tdate)); | ||
assertEquals(null, rs.getString("tdate")); | ||
} | ||
|
||
tlong = rs.getLong("tlong"); | ||
assertFalse(rs.wasNull()); | ||
assertEquals(55, tlong); | ||
assertEquals("55", rs.getString("tlong")); | ||
|
||
// resultset end | ||
assertFalse(rs.next()); | ||
} | ||
|
||
private String dateString(Date dt) { | ||
return JavaCs.substring(JavaCs.getIsoDate(dt), 0, 10); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
11 changes: 11 additions & 0 deletions
11
tdrules-store-rdb/src/test/java/test4giis/tdrules/store/rdb/sqlite/TestSqliteResultSet.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package test4giis.tdrules.store.rdb.sqlite; | ||
|
||
import test4giis.tdrules.store.rdb.TestSqlserverResultSet; | ||
|
||
public class TestSqliteResultSet extends TestSqlserverResultSet { | ||
|
||
public TestSqliteResultSet() { | ||
this.dbmsname = "sqlite"; | ||
} | ||
|
||
} |