Интеграционное тестирование Spring 3 - исключение инициализации sessionFactory - PullRequest
2 голосов
/ 20 января 2012

Когда я запускаю тест на весенний джунт, я получаю следующее сообщение об ошибке:

Caused by: 
java.lang.NoSuchMethodError: org/slf4j/impl/StaticLoggerBinder.getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;

....

java.lang.ClassFormatError: JVMCFRE074 no Code attribute specified; class=javax/persistence/PersistenceException, method=<init>()V, pc=0

Не могли бы вы помочь мне найти причину этого сообщения об ошибке? Кажется, у меня есть некоторые проблемы с зависимостями slf4j - но у меня они есть в проекте.

Класс испытаний:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"/businessApplicationContextTest.xml"})
@TransactionConfiguration(transactionManager="transactionManager", defaultRollback=true)
@Transactional
public class LogicHandlerTest {

    @SessionFactory
    SessionFactory sessionFactory;

@Before
public void setup() {System.out.println("@Before");}

@Test
public void testDummy() {
    System.out.println("testDummy");
    assert(true);
}
}

Конфигурация контекста пружинного теста:

<!-- DATASOURCE -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName"    value="org.hsqldb.jdbcDriver"/>       
    <property name="url"                value="jdbc:hsqldb:mem:test"/>        
    <property name="username"           value="sa"/>          
    <property name="password"           value=""/>  
</bean> 

<!-- SESSION FACTORY -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="packagesToScan" value="com.test.dummyproject.entity"/>
    <property name="hibernateProperties">
      <props>
            <prop key="hibernate.jdbc.batch_size">100</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.connection.autocommit">true</prop>
            <prop key="hibernate.dialect">org.hibernate.dialect.HSQLDialect</prop>
        </props>
    </property>
</bean>

<!-- TRANSACTION MANAGER -->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory"/>
</bean>

ЗАВИСИМОСТЬ (версии из POM.XML):

    hibernate                        3.2.3.ga
    hibernate-annotations            3.3.1.GA
    hibernate-commons-annotations    3.2.0.Final
    javaee-api                   6.0
    slf4j-api                        1.6.4
    slf4j-log4j12                    1.6.4

Ответы [ 2 ]

0 голосов
/ 24 января 2012

Причиной этого сообщения об ошибке был беспорядок в зависимостях maven - я удалил зависимость javaee 6 из моего проекта, и теперь все работает нормально.(Поскольку сервер websphere уже содержит библиотеку javaee 6).

0 голосов
/ 20 января 2012

Кажется, вы не вводите SessionFactory в свой тест,

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean" auto-wire="byName">

@Resource
SessionFactory sessionFactory

обновление: добавьте эти jar-файлы в ваш classpath

01.antlr-2.7.6
02.commons-collections-3.1
03.dom4j-1.6.1
04.hibernate3
05.database specific jar
06.javassist-3.4.GA
07.jta-1.1
08.slf4j-api-1.5.6
09.slf4j-simple-1.5.6
...