mirror of https://github.com/apache/nifi.git
NIFI-1613: ConvertJSONToSQL truncates numeric value wrongly.
- Changed boolean value conversion to use Boolean.valueOf. - Updated comments in source code to reflect current situation more clearly. - Updated tests those have been added since the original commits were made.
This commit is contained in:
parent
3b2e43b75c
commit
3844a821f1
|
@ -514,19 +514,10 @@ public class ConvertJSONToSQL extends AbstractProcessor {
|
||||||
|
|
||||||
// only "true" is considered true, everything else is false
|
// only "true" is considered true, everything else is false
|
||||||
case Types.BOOLEAN:
|
case Types.BOOLEAN:
|
||||||
switch (fieldValue==null?"":fieldValue) {
|
fieldValue = Boolean.valueOf(fieldValue).toString();
|
||||||
case "true":
|
|
||||||
fieldValue = "true";
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
fieldValue = "false";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Don't truncate numeric types.
|
// Don't truncate numeric types.
|
||||||
// Should we check value is indeed number and throw error if not?
|
|
||||||
case Types.TINYINT:
|
case Types.TINYINT:
|
||||||
case Types.SMALLINT:
|
case Types.SMALLINT:
|
||||||
case Types.INTEGER:
|
case Types.INTEGER:
|
||||||
|
@ -538,11 +529,11 @@ public class ConvertJSONToSQL extends AbstractProcessor {
|
||||||
case Types.NUMERIC:
|
case Types.NUMERIC:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Don't truncate date and time types.
|
// Don't truncate DATE, TIME and TIMESTAMP types. We assume date and time is already correct in long representation.
|
||||||
// Should we check value is indeed correct date and/or time and throw error if not?
|
// Specifically, milliseconds since January 1, 1970, 00:00:00 GMT
|
||||||
// We assume date and time is already correct, but because ConvertJSONToSQL is often used together with PutSQL
|
// However, for TIMESTAMP, PutSQL accepts optional timestamp format via FlowFile attribute.
|
||||||
// maybe we should assure PutSQL correctly understands date and time values.
|
// See PutSQL.setParameter method and NIFI-3430 for detail.
|
||||||
// Currently PutSQL expect Long numeric values. But JSON usually uses ISO 8601, for example: 2012-04-23T18:25:43.511Z for dates.
|
// Alternatively, user can use JSONTreeReader and PutDatabaseRecord to handle date format more efficiently.
|
||||||
case Types.DATE:
|
case Types.DATE:
|
||||||
case Types.TIME:
|
case Types.TIME:
|
||||||
case Types.TIMESTAMP:
|
case Types.TIMESTAMP:
|
||||||
|
|
|
@ -106,18 +106,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testInsertQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testInsertQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
||||||
|
@ -143,18 +134,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testInsertQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testInsertQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
||||||
|
@ -234,18 +216,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testUpdateQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
||||||
|
@ -297,18 +270,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testMultipleInsertsQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testMultipleInsertsQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "INSERT");
|
||||||
|
@ -359,18 +323,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateBasedOnPrimaryKeyQuotedIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testUpdateBasedOnPrimaryKeyQuotedIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
||||||
|
@ -449,18 +404,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateBasedOnUpdateKeyQuotedIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testUpdateBasedOnUpdateKeyQuotedIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "UPDATE");
|
||||||
|
@ -796,18 +742,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testDelete() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testDelete() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
||||||
|
@ -831,18 +768,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testDeleteQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testDeleteQuotedIdentifiers() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
||||||
|
@ -868,18 +796,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testDeleteQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testDeleteQuotedTableIdentifier() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
||||||
|
@ -905,18 +824,9 @@ public class TestConvertJSONToSQL {
|
||||||
@Test
|
@Test
|
||||||
public void testDeleteWithNullValue() throws InitializationException, ProcessException, SQLException, IOException {
|
public void testDeleteWithNullValue() throws InitializationException, ProcessException, SQLException, IOException {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
final TestRunner runner = TestRunners.newTestRunner(ConvertJSONToSQL.class);
|
||||||
final File tempDir = folder.getRoot();
|
|
||||||
final File dbDir = new File(tempDir, "db");
|
|
||||||
final DBCPService service = new MockDBCPService(dbDir.getAbsolutePath());
|
|
||||||
runner.addControllerService("dbcp", service);
|
runner.addControllerService("dbcp", service);
|
||||||
runner.enableControllerService(service);
|
runner.enableControllerService(service);
|
||||||
|
|
||||||
try (final Connection conn = service.getConnection()) {
|
|
||||||
try (final Statement stmt = conn.createStatement()) {
|
|
||||||
stmt.executeUpdate(createPersons);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
runner.setProperty(ConvertJSONToSQL.CONNECTION_POOL, "dbcp");
|
||||||
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
runner.setProperty(ConvertJSONToSQL.TABLE_NAME, "PERSONS");
|
||||||
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
runner.setProperty(ConvertJSONToSQL.STATEMENT_TYPE, "DELETE");
|
||||||
|
|
Loading…
Reference in New Issue