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.
Вы можете проверить здесь мой ответ на аналогичный вопрос.