Unitils - Dbunit ExpectedDataSet не работает / заблокирован - PullRequest
0 голосов
/ 01 марта 2012

Я создаю веб-приложение с Spring 3.1.0.RELEASE и JPA 2 с провайдером Hibernate. Я делаю тест с junit 4.10, dbunit 2.4.8, unitils 3.3, hsqldb 2.2.8.

Я пытаюсь проверить сервисный уровень, операцию создания. В моем DAO у меня есть этот метод:

@Override
    @Transactional
    public void createQuestion(Question question) {
        logger.debug("createQuestion");

        entityManager.persist(question);
        logger.info("New question created  [id] {}", question.getId());

    }

Мой тестовый класс QuestionServiceTest:

@SpringApplicationContext("test-applicationContext.xml")
public class QuestionServiceTest extends UnitilsJUnit4 {

    @SpringBeanByName
    private QuestionService questionService;

    @SpringBeanByName
    private ThemeService themeService;

    @Test
    @DataSet("QuestionServiceTest.testCreateQuestion.xml")
    @ExpectedDataSet("QuestionServiceTest.testCreateQuestion-result.xml")
    public void testCreateQuestion() {
        final Question newQuestion = new Question();
        newQuestion.setCountryCode("FR");
        newQuestion.setEmail("test@mytest.com");
        newQuestion.setFirstName("FirstTest");
        newQuestion.setLastName("LastTest");
        newQuestion.setOriginalLang(LanguageEnum.FR);
        newQuestion.setOriginalQuestion("This is the original question");
        final Calendar calendar = Calendar.getInstance();
        calendar.set(2012, 5, 12);
        newQuestion.setCreationDate(calendar.getTime());
        final Theme theme = themeService.findThemeById(new Integer(1));
        newQuestion.setTheme(theme);
        questionService.createQuestion(newQuestion);
    }
}

Я использую свойство hibernate.hbm2ddl.auto = create-drop для генерации схемы, таблица вопросов:

create table question (
        id integer generated by default as identity (start with 1),
        country_code varchar(10) not null,
        creation_date timestamp not null,
        email varchar(255) not null,
        firstname varchar(100) not null,
        lastname varchar(100) not null,
        original_lang varchar(255) not null,
        original_question clob not null,
        theme_id integer not null,
        primary key (id)
    )

theme_id - это внешний ключ к теме таблицы.

Когда я запускаю тест с ExpectedDataSet, вставка работает, но тест никогда не заканчивается. Тестовый блок на:

DEBUG: org.dbunit.database.AbstractResultSetTable - Запрос: выберите "ID", "COUNTRY_CODE", "CREATION_DATE", "EMAIL", "FIRSTNAME", "LASTNAME", "ORIGINAL_LANG", "ORIGINAL_QUESTION", "THEME_ID" из "PUBLIC". "QUESTION" заказ по "ID"

Это последняя строка при отладке.

Мои объекты unitils.properties:

# Defaults and other keys with explanations can be found there: http://unitils.org/unitils-default.properties
database.driverClassName=org.hsqldb.jdbcDriver
database.url=jdbc:hsqldb:mem:testOpen
database.userName=sa
database.password=
database.dialect=hsqldb

#  This schema is the initial schema when a new session is started in HSQLDB, don't change it or test won't works !
database.schemaNames=PUBLIC

dbUnit.datasetresolver.prefixWithPackageName=false
dbUnit.datasetresolver.pathPrefix=dataSets

My persistence.xml:

<persistence-unit name="OpenTestPU" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>

        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.format_sql" value="true" />
            <property name="hibernate.connection.driver_class" value="org.hsqldb.jdbcDriver" />
            <property name="hibernate.connection.username" value="sa" />
            <property name="hibernate.connection.password" value="" />
            <property name="hibernate.connection.url" value="jdbc:hsqldb:mem:testOpen" />
            <property name="hibernate.hbm2ddl.auto" value="create-drop" />
        </properties>
    </persistence-unit>

Что мне делать? Я уже пробовал предыдущий выпуск dbunit или unitils, но это ничего не меняет. Ожидаемый набор данных - действительно классная функция.

Спасибо.

1 Ответ

0 голосов
/ 20 сентября 2012

У меня была такая же проблема, и я не смог ее решить.Затем я попробовал spring-test-dbunit, и эта библиотека работала без сбоев.

...