Search in sources :

Example 1 with DriverDefEditorContent

use of org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent in project kie-wb-common by kiegroup.

the class DataSourceDefEditorServiceImpl method testConnection.

@Override
public TestResult testConnection(DataSourceDef dataSourceDef, Module module) {
    TestResult result = new TestResult(false);
    if (isEmpty(dataSourceDef.getConnectionURL())) {
        result.setMessage("A valid connection url is required");
        return result;
    }
    if (isEmpty(dataSourceDef.getUser()) || isEmpty(dataSourceDef.getPassword())) {
        result.setMessage("A valid user and password are required");
        return result;
    }
    DriverDefInfo driverDefInfo = null;
    if (isEmpty(dataSourceDef.getDriverUuid())) {
        result.setMessage("A valid driver is required");
        return result;
    }
    if (module != null) {
        driverDefInfo = dataSourceDefQueryService.findModuleDriver(dataSourceDef.getDriverUuid(), module.getRootPath());
    } else {
        driverDefInfo = dataSourceDefQueryService.findGlobalDriver(dataSourceDef.getDriverUuid());
    }
    if (driverDefInfo == null) {
        result.setMessage("Data source driver: " + dataSourceDef.getUuid() + " was not found");
        return result;
    }
    DriverDefEditorContent driverDefEditorContent = driverDefService.loadContent(driverDefInfo.getPath());
    DriverDef driverDef = driverDefEditorContent.getDef();
    URI uri;
    try {
        uri = artifactResolver.resolve(driverDef.getGroupId(), driverDef.getArtifactId(), driverDef.getVersion());
    } catch (Exception e) {
        result.setMessage("Connection could not be tested due to the following error: " + e.getMessage());
        return result;
    }
    if (uri == null) {
        result.setMessage("Driver artifact: " + driverDef.getGroupId() + ":" + driverDef.getArtifactId() + ":" + driverDef.getVersion() + " was not found");
        return result;
    }
    try {
        Properties properties = new Properties();
        properties.put("user", dataSourceDef.getUser());
        properties.put("password", dataSourceDef.getPassword());
        URLConnectionFactory connectionFactory = new URLConnectionFactory(uri.toURL(), driverDef.getDriverClass(), dataSourceDef.getConnectionURL(), properties);
        Connection conn = connectionFactory.createConnection();
        if (conn == null) {
            result.setMessage("It was not possible to open connection");
        } else {
            StringBuilder stringBuilder = new StringBuilder();
            stringBuilder.append("Connection was successfully obtained: " + conn);
            stringBuilder.append("\n");
            stringBuilder.append("*** DatabaseProductName: " + conn.getMetaData().getDatabaseProductName());
            stringBuilder.append("\n");
            stringBuilder.append("*** DatabaseProductVersion: " + conn.getMetaData().getDatabaseProductVersion());
            stringBuilder.append("\n");
            stringBuilder.append("*** DriverName: " + conn.getMetaData().getDriverName());
            stringBuilder.append("\n");
            stringBuilder.append("*** DriverVersion: " + conn.getMetaData().getDriverVersion());
            stringBuilder.append("\n");
            conn.close();
            stringBuilder.append("Connection was successfully released.");
            stringBuilder.append("\n");
            result.setTestPassed(true);
            result.setMessage(stringBuilder.toString());
        }
        return result;
    } catch (Exception e) {
        result.setMessage(e.getMessage());
        return result;
    }
}
Also used : URLConnectionFactory(org.kie.workbench.common.screens.datasource.management.util.URLConnectionFactory) DriverDefInfo(org.kie.workbench.common.screens.datasource.management.model.DriverDefInfo) DriverDefEditorContent(org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent) Connection(java.sql.Connection) TestResult(org.kie.workbench.common.screens.datasource.management.model.TestResult) DriverDef(org.kie.workbench.common.screens.datasource.management.model.DriverDef) Properties(java.util.Properties) URI(java.net.URI)

Example 2 with DriverDefEditorContent

use of org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent in project kie-wb-common by kiegroup.

the class DriverDefEditorTest method createContent.

private DriverDefEditorContent createContent() {
    DriverDefEditorContent content = new DriverDefEditorContent();
    content.setDef(new DriverDef());
    content.getDef().setUuid(DRIVER_UUID);
    content.getDef().setName(NAME);
    content.getDef().setGroupId(GROUP_ID);
    content.getDef().setArtifactId(ARTIFACT_ID);
    content.getDef().setVersion(VERSION);
    content.getDef().setDriverClass(DRIVER_CLASS);
    return content;
}
Also used : DriverDefEditorContent(org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent) DriverDef(org.kie.workbench.common.screens.datasource.management.model.DriverDef)

Example 3 with DriverDefEditorContent

use of org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent in project kie-wb-common by kiegroup.

the class DriverDefEditorServiceTest method setup.

@Before
public void setup() {
    super.setup();
    editorService = new DriverDefEditorServiceImpl(runtimeManager, serviceHelper, ioService, moduleService, optionsFactory, pathNamingService, artifactResolver, newDriverEvent, updateDriverEvent, deleteDriverEvent);
    driverDef = new DriverDef();
    driverDef.setUuid("uuid");
    driverDef.setName("driverName");
    driverDef.setDriverClass(TestDriver.class.getName());
    driverDef.setGroupId("groupId");
    driverDef.setArtifactId("artifactId");
    driverDef.setVersion("version");
    driverDefEditorContent = new DriverDefEditorContent();
    driverDefEditorContent.setDef(driverDef);
    driverDefEditorContent.setModule(module);
    originalDriverDef = new DriverDef();
    originalDriverDef.setUuid("uuid");
    originalDriverDef.setName("driverNameOriginal");
    originalDriverDef.setDriverClass(TestDriver.class.getName());
    originalDriverDef.setGroupId("groupIdOriginal");
    originalDriverDef.setArtifactId("artifactIdOriginal");
    originalDriverDef.setVersion("versionOriginal");
    try {
        URL resource = getClass().getClassLoader().getResource("DataSourceFiles");
        uri = resource.toURI();
        when(artifactResolver.resolve(driverDef.getGroupId(), driverDef.getArtifactId(), driverDef.getVersion())).thenReturn(uri);
    } catch (Exception e) {
        fail(e.getMessage());
    }
}
Also used : DriverDefEditorContent(org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent) DriverDef(org.kie.workbench.common.screens.datasource.management.model.DriverDef) URL(java.net.URL) Before(org.junit.Before)

Aggregations

DriverDef (org.kie.workbench.common.screens.datasource.management.model.DriverDef)3 DriverDefEditorContent (org.kie.workbench.common.screens.datasource.management.model.DriverDefEditorContent)3 URI (java.net.URI)1 URL (java.net.URL)1 Connection (java.sql.Connection)1 Properties (java.util.Properties)1 Before (org.junit.Before)1 DriverDefInfo (org.kie.workbench.common.screens.datasource.management.model.DriverDefInfo)1 TestResult (org.kie.workbench.common.screens.datasource.management.model.TestResult)1 URLConnectionFactory (org.kie.workbench.common.screens.datasource.management.util.URLConnectionFactory)1