Howto: дерби в памяти дБ со стеклянной рыбой

Мне нужно запустить тесты arquillian+junit на удаленном сервере Glassfish 4.1. Таблицы базы данных для этих тестов должны быть
(1) создано в памяти,
(2) со встроенной JavaDB и
(3) упал после выполнения теста.

Будет ли работать следующий glassfish-resources.xml?

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE resources PUBLIC
    "-//GlassFish.org//DTD GlassFish Application Server 3.1 Resource Definitions//EN"
    "http://glassfish.org/dtds/glassfish-resources_1_5.dtd">
<resources>
    <jdbc-resource pool-name="ArquillianEmbeddedDerbyPool"
                   jndi-name="java:app/jdbc/chapter2" />
    <jdbc-connection-pool name="ArquillianEmbeddedDerbyPool"
                          res-type="javax.sql.DataSource"
                          datasource-classname="org.apache.derby.jdbc.EmbeddedDataSource"
                          is-isolation-level-guaranteed="false">
        <property name="databaseName" value="memory:action-bazaar-db"/>
        <property name="createDatabase" value="create"/>
    </jdbc-connection-pool>
</resources>

Я попробовал, но не уверен, что база данных создана в памяти. Я продолжаю получать ошибку ниже каждый раз, когда я запускаю тесты. Как избавиться от этой ошибки?

PER01000: получен оператор выполнения SQLException "CREATE TABLE SEQUENCE (SEQ_NAME VARCHAR(50) NOT NULL, SEQ_COUNT DECIMAL(15), PRIMARY KEY (SEQ_NAME))": java.sql.SQLException: таблица / представление "SEQUENCE" уже существует в схеме ПРИЛОЖЕНИЕ'

1 ответ

Если вы используете Maven для своей сборки, вы можете использовать плагин derby-maven-plugin, который я написал и который доступен на GitHub и через Maven Central.

Вы можете проверить здесь мой ответ на аналогичный вопрос.

Другие вопросы по тегам