thingsboard-developers

Details

dao/pom.xml 5(+5 -0)

diff --git a/dao/pom.xml b/dao/pom.xml
index 4cddf8b..7686f10 100644
--- a/dao/pom.xml
+++ b/dao/pom.xml
@@ -174,6 +174,11 @@
             <artifactId>h2</artifactId>
             <scope>test</scope>
         </dependency>
+        <dependency>
+            <groupId>ru.yandex.qatools.embed</groupId>
+            <artifactId>postgresql-embedded</artifactId>
+            <scope>test</scope>
+        </dependency>
     </dependencies>
     <build>
         <plugins>
diff --git a/dao/src/test/java/org/thingsboard/server/dao/CustomPostgresUnit.java b/dao/src/test/java/org/thingsboard/server/dao/CustomPostgresUnit.java
new file mode 100644
index 0000000..c0025ce
--- /dev/null
+++ b/dao/src/test/java/org/thingsboard/server/dao/CustomPostgresUnit.java
@@ -0,0 +1,109 @@
+/**
+ * Copyright © 2016-2017 The Thingsboard Authors
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.thingsboard.server.dao;
+
+import com.google.common.base.Charsets;
+import com.google.common.io.Resources;
+import lombok.extern.slf4j.Slf4j;
+import org.junit.Before;
+import org.junit.rules.ExternalResource;
+import org.junit.rules.TestRule;
+import org.junit.runner.Description;
+import org.junit.runners.model.Statement;
+import ru.yandex.qatools.embed.postgresql.EmbeddedPostgres;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+import java.sql.Connection;
+import java.sql.DriverManager;
+import java.sql.SQLException;
+import java.util.List;
+import java.util.Properties;
+
+import static ru.yandex.qatools.embed.postgresql.distribution.Version.Main.V9_6;
+
+/**
+ * Created by Valerii Sosliuk on 6/24/2017.
+ */
+@Slf4j
+public class CustomPostgresUnit extends ExternalResource {
+
+    private static final String HOST = "host";
+    private static final String PORT = "port";
+    private static final String DATABASE = "database";
+    private static final String USERNAME = "username";
+    private static final String PASSWORD = "password";
+
+    private List<String> sqlFiles;
+    private Properties properties;
+
+    private EmbeddedPostgres postgres;
+
+    public CustomPostgresUnit(List<String> sqlFiles, String configurationFileName) {
+        this.sqlFiles = sqlFiles;
+        this.properties = loadProperties(configurationFileName);
+    }
+
+    @Override
+    public void before() {
+        postgres = new EmbeddedPostgres(V9_6);
+        load();
+    }
+
+    @Override
+    public void after() {
+        postgres.stop();
+    }
+
+    private void load() {
+        Connection conn = null;
+        try {
+            String url = postgres.start(properties.getProperty(HOST),
+                                        Integer.parseInt(properties.getProperty(PORT)),
+                                        properties.getProperty(DATABASE),
+                                        properties.getProperty(USERNAME),
+                                        properties.getProperty(PASSWORD));
+
+            conn = DriverManager.getConnection(url);
+            for (String sqlFile : sqlFiles) {
+                URL sqlFileUrl = Resources.getResource(sqlFile);
+                String sql = Resources.toString(sqlFileUrl, Charsets.UTF_8);
+                conn.createStatement().execute(sql);
+            }
+        } catch (IOException | SQLException e) {
+            throw new RuntimeException("Unable to start embedded postgres. Reason: " + e.getMessage(), e);
+        } finally {
+            if (conn != null) {
+                try {
+                    conn.close();
+                } catch (SQLException e) {
+                    log.error(e.getMessage(), e);
+                }
+            }
+        }
+    }
+
+    private Properties loadProperties(String fileName) {
+        final Properties properties = new Properties();
+        try (final InputStream stream = this.getClass().getClassLoader().getResourceAsStream(fileName)) {
+            properties.load(stream);
+            return properties;
+        } catch (IOException e) {
+            throw new RuntimeException(e.getMessage(), e);
+        }
+    }
+}
diff --git a/dao/src/test/java/org/thingsboard/server/dao/DaoTestSuite.java b/dao/src/test/java/org/thingsboard/server/dao/DaoTestSuite.java
index 845c4c6..9d2b38e 100644
--- a/dao/src/test/java/org/thingsboard/server/dao/DaoTestSuite.java
+++ b/dao/src/test/java/org/thingsboard/server/dao/DaoTestSuite.java
@@ -20,9 +20,16 @@ import org.junit.ClassRule;
 import org.junit.extensions.cpsuite.ClasspathSuite;
 import org.junit.extensions.cpsuite.ClasspathSuite.ClassnameFilters;
 import org.junit.runner.RunWith;
+import ru.yandex.qatools.embed.postgresql.EmbeddedPostgres;
 
+import java.io.IOException;
+import java.sql.Connection;
+import java.sql.DriverManager;
+import java.sql.SQLException;
 import java.util.Arrays;
 
+import static ru.yandex.qatools.embed.postgresql.distribution.Version.Main.V9_6;
+
 @RunWith(ClasspathSuite.class)
 @ClassnameFilters({
         "org.thingsboard.server.dao.service.*Test",
@@ -41,4 +48,10 @@ public class DaoTestSuite {
                             new ClassPathCQLDataSet("cassandra/system-data.cql", false, false),
                             new ClassPathCQLDataSet("system-test.cql", false, false)),
                     "cassandra-test.yaml", 30000l);
+
+    @ClassRule
+    public static CustomPostgresUnit postgresUnit = new CustomPostgresUnit(
+                    Arrays.asList("postgres/schema.sql", "postgres/system-data.sql"),
+                    "postgres-embedded-test.properties");
+
 }
diff --git a/dao/src/test/resources/jpa-test.properties b/dao/src/test/resources/jpa-test.properties
index 80ae6ff..f2ce4b2 100644
--- a/dao/src/test/resources/jpa-test.properties
+++ b/dao/src/test/resources/jpa-test.properties
@@ -5,7 +5,7 @@ sql.enabled=true
 spring.jpa.show-sql=false
 spring.jpa.hibernate.ddl-auto=validate
 
-spring.datasource.url=jdbc:postgresql://localhost:5432/thingsboard
+spring.datasource.url=jdbc:postgresql://localhost:5433/thingsboard
 spring.datasource.username=postgres
 spring.datasource.password=postgres
 
diff --git a/dao/src/test/resources/postgres-embedded-test.properties b/dao/src/test/resources/postgres-embedded-test.properties
new file mode 100644
index 0000000..557aad5
--- /dev/null
+++ b/dao/src/test/resources/postgres-embedded-test.properties
@@ -0,0 +1,5 @@
+host: localhost
+port: 5433
+database: thingsboard
+username: postgres
+password: postgres
\ No newline at end of file

pom.xml 7(+7 -0)

diff --git a/pom.xml b/pom.xml
index d09e4ca..393fbba 100755
--- a/pom.xml
+++ b/pom.xml
@@ -745,6 +745,13 @@
                 <groupId>com.h2database</groupId>
                 <artifactId>h2</artifactId>
                 <version>${h2.version}</version>
+                <scope>test</scope>
+            </dependency>
+            <dependency>
+                <groupId>ru.yandex.qatools.embed</groupId>
+                <artifactId>postgresql-embedded</artifactId>
+                <version>2.2</version>
+                <scope>test</scope>
             </dependency>
             <dependency>
                 <groupId>com.sun.winsw</groupId>