Тестирование JPA / Hibernate сущностей с использованием DBUnit - PullRequest
3 голосов
/ 19 января 2012

У меня есть некоторые проблемы с некоторыми объектами, особенно с использованием JPA / Hibernate и DBUNIT.Я столкнулся с этой ошибкой, когда пытался построить проект.

Tests run: 2, Failures: 0, Errors: 2, Skipped: 0, Time elapsed: 2.221 sec <<< FAILURE!
readDocumentById(com.bt.msm.ds.facade.DataServicesFacadeTest)  Time elapsed: 2.043 sec  <<< ERROR!
org.dbunit.dataset.NoSuchColumnException: CONTENTDOCUMENT.ID -  (Non-uppercase input column: ID) in ColumnNameToIndexes cache map. Note that the map's column names are NOT case sensitive.
    at org.dbunit.dataset.AbstractTableMetaData.getColumnIndex(AbstractTableMetaData.java:128)
    at org.dbunit.operation.AbstractOperation.getOperationMetaData(AbstractOperation.java:89)
    at org.dbunit.operation.AbstractBatchOperation.execute(AbstractBatchOperation.java:140)
    at org.dbunit.operation.CompositeOperation.execute(CompositeOperation.java:79)

Ошибка исчезает, если свойства конфигурации имеют следующий вид

username : usera
password : usera
schema   : usera
dbunit version : 2.4.2

Ошибка возникает, если свойства конфигурации имеют следующий вид

username : usera
pasword : usera
schema :  schemab
dbunit version > 2.4.2 (e.g. 2.4.4)

Похоже,если имя shema совпадает с именем пользователя, а версия dbunit - 2.4.2, тогда это работает.Если имя схемы не совпадает с именем пользователя, а версия dbunit имеет версию, превышающую 2.4.2 (я пробовал 2.4.3 и 2.4.4), то возникает ошибка.

Вот некоторые подробности

Таблица DDL

CREATE TABLE CONTENTDOCUMENT (
  ID bigint(20) NOT NULL AUTO_INCREMENT,
  CONTENT varchar(255) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

Версия базы данных:

MySql 5.5.17 MySQL Community Server (GPL)

JPA / Hibernate Entity (резюме) -

@Entity
@Indexed
@Table(name="CONTENTDOCUMENT")

public class ContentDocument{
    @Id
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    @Column(name="ID")
    public Long getId() {
        return id;
    }

    @Column(name="CONTENT")
    public String getContent() {
        return content;
    }
}

Набор данных DBunit

<dataset>
    <CONTENTDOCUMENT ID="1" CONTENT="TestContent1"/>
    <CONTENTDOCUMENT ID="2" CONTENT="TestContent2" />   
</dataset>

Есть какие-нибудь подсказки?

1 Ответ

0 голосов
/ 13 июля 2013

Попробуйте указать файл dtd при вставке данных.

...