Интеграционные тесты Roo и Failsafe: проблема BeanConfigurerSupport

case: приложение Roo с автоматически интегрированными тестами.

нужно: использовать PGSQL для развертывания, HSQLDB для интеграционных тестов.

Выбор: Spring-Agent/ Spring-Instrument & aspectjweaver в argLine в конфигурации maven-failsafe-plugin, чтобы не быть связанным с определенной установкой tomcat (которая должна иметь необходимые jar-файлы и конфигурацию Context)

результат:

BeanConfigurerSupport - BeanFactory не был установлен для BeanConfigurerSupport: убедитесь, что этот конфигуратор работает в контейнере Spring. Невозможно настроить bean-компонент типа [com.model.UserIntegrationTest]. Приступ без инъекций.

Я заметил, что он использует classloader: WebappClassLoader

Я также попытался изменить подход к конфигурации tomcat и добавить необходимые jar-файлы в его библиотеки, но не смог заставить отказоустойчивый плагин сотрудничать с удаленным tomcat.

Любая идея?

Ниже приведены фрагменты кода, связанные с этой проблемой. Самый простой способ получить SSCCE - это получить пример весенней директории и попытаться выполнить директорию *IntegrationTest, сгенерированную как интеграционные тесты, с отказоустойчивым использованием hsqldb для тестирования и некоторых других БД для развертывания.

Часть pom.xml:

<properties>
    ...........
    <aspectj.version>1.8.2</aspectj.version>
<properties>

<plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>aspectj-maven-plugin</artifactId>
    <version>1.7</version>
    <configuration>
        <outxml>true</outxml>
        <complianceLevel>1.7</complianceLevel>
        <source>1.7</source>
        <target>1.7</target>
        <weaveWithAspectsInMainSourceFolder>true</weaveWithAspectsInMainSourceFolder>
        <aspectLibraries>
            <aspectLibrary>
                <groupId>org.springframework</groupId>
                <artifactId>spring-aspects</artifactId>
            </aspectLibrary>
        </aspectLibraries>
    </configuration>
    <executions>
        <execution>
            <phase>process-sources</phase>
            <goals>
                <goal>compile</goal>
                <!-- use this goal to weave all your main classes -->
                <goal>test-compile</goal>
                <!-- use this goal to weave all your test classes -->
            </goals>
        </execution>
    </executions>
</plugin>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <version>2.17</version>
    <configuration>
        <junitArtifactName>org.junit:com.springsource.org.junit</junitArtifactName>
        <!--see: https://issuetracker.springsource.com/browse/EBR-220-->
        <printSummary>false</printSummary>
        <redirectTestOutputToFile>true</redirectTestOutputToFile>
        <excludes>
            <exclude>${roo.aspect.test.files}</exclude>
            <exclude>${integration.test.files}</exclude>
        </excludes>
        <reuseForks>false</reuseForks>
        <forkCount>1</forkCount>
        <argLine>-javaagent:${settings.localRepository}/org/springframework/spring-agent/2.5.6.SEC03/spring-agent-2.5.6.SEC03.jar -javaagent:${settings.localRepository}/org/aspectj/aspectjweaver/1.8.2/aspectjweaver-1.8.2.jar -javaagent:${settings.localRepository}/org/springframework/spring-instrument/${spring.version}/spring-instrument-${spring.version}.jar</argLine>
    </configuration>
</plugin>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-failsafe-plugin</artifactId>
    <version>2.17</version>
    <configuration>
        <systemPropertyVariables>
            <integration-test.url>http://localhost:8080/${project.build.finalName}/</integration-test.url>
        </systemPropertyVariables>
        <junitArtifactName>org.junit:com.springsource.org.junit</junitArtifactName>
        <includes>
            <include>${integration.test.files}</include>
        </includes>
        <excludes>
            <exclude>${roo.aspect.test.files}</exclude>
        </excludes>
        <reuseForks>false</reuseForks>
        <forkCount>1</forkCount>
        <argLine>-javaagent:${settings.localRepository}/org/springframework/spring-agent/2.5.6.SEC03/spring-agent-2.5.6.SEC03.jar -javaagent:${settings.localRepository}/org/aspectj/aspectjweaver/1.8.2/aspectjweaver-1.8.2.jar -javaagent:${settings.localRepository}/org/springframework/spring-instrument/${spring.version}/spring-instrument-${spring.version}.jar</argLine>
    </configuration>
    <executions>
        <execution>
            <id>integration-test</id>
            <goals>
                <goal>integration-test</goal>
            </goals>
        </execution>
        <execution>
            <id>verify</id>
            <goals>
                <goal>verify</goal>
            </goals>
        </execution>
    </executions>
</plugin>
<plugin>
    <groupId>org.apache.tomcat.maven</groupId>
    <artifactId>tomcat7-maven-plugin</artifactId>
    <version>2.2</version>
    <configuration>
        <url>${server.url}/manager/text</url>
        <server>TomcatServer</server>
        <path>/${project.name}</path>
    </configuration>
    <executions>
        <execution>
            <id>start-tomcat</id>
            <phase>pre-integration-test</phase>
            <goals>
                <goal>run</goal>
            </goals>
            <configuration>
                <fork>true</fork>
            </configuration>
        </execution>
        <execution>
            <id>stop-tomcat</id>
            <phase>post-integration-test</phase>
            <goals>
                <goal>shutdown</goal>
            </goals>
        </execution>
    </executions>
</plugin> 

Часть applicationContext.xml, где определен профиль для ИТ:

<beans profile="integrationTests">

     <bean class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"
        id="itdataSource"> <property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
        <property name="url" value="jdbc:hsqldb:mem:ittests;shutdown=true"/> <property
        name="username" value="sa"/> <property name="password" value=""/> <property
        name="testOnBorrow" value="true"/> <property name="testOnReturn" value="true"/>
        <property name="testWhileIdle" value="true"/> <property name="timeBetweenEvictionRunsMillis"
        value="1800000"/> <property name="numTestsPerEvictionRun" value="3"/> <property
        name="minEvictableIdleTimeMillis" value="1800000"/> </bean>

    <!--<jdbc:embedded-database id="itdataSource" type="HSQL" />-->
    <bean
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
        id="entityManagerFactory">
        <property name="persistenceUnitName" value="persistenceUnitForIntegrationTests" />
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                <property name="database" value="HSQL" />
                <property name="showSql" value="true" />
            </bean>
        </property>
        <property name="dataSource" ref="itdataSource" />
    </bean>
</beans>     

После обновления aspectj-maven-plugin до 1.7 вместо сообщений, которые я публиковал изначально, я получаю

[WARNING] advice defined in org.springframework.mock.staticmock.AbstractMethodMockingControl has not been applied [Xlint:adviceDidNotMatch]
    C:\Users\ckorakidis\.m2\repository\org\springframework\spring-aspects\3.2.6.RELEASE\spring-aspects-3.2.6.RELEASE.jar!org\springframework\mock\staticmock\AbstractMethodMockingControl.class:167

.......

[WARNING] this affected type is not exposed to the weaver: com.mbplc.cborms.db.UserRepository [Xlint:typeNotExposedToWeaver]
C:\workspace\poc\com\db\UserRepository_Roo_Jpa_Repository.aj:16

.....

[AppClassLoader@3972aa3f] warning javax.* types are not being woven because the weaver option '-Xset:weaveJavaxPackages=true' has not been specified
2014-09-16 23:35:33,389 [main] DEBUG org.springframework.beans.factory.wiring.BeanConfigurerSupport - BeanFactory has not been set on BeanConfigurerSupport: Make sure this configurer runs in a Spring container. Unable to configure bean of type [com.model.UserIntegrationTest]. Proceeding without injection.

......

    classloader: WebappClassLoader
  context: /poc
  delegate: false
  repositories:
    /WEB-INF/classes/
----------> Parent Classloader:
ClassRealm[plugin>org.apache.tomcat.maven:tomcat7-maven-plugin:2.2, parent: sun.misc.Launcher$AppClassLoader@65450f1f]

    excludeUnlistedClasses: false
    JTA datasource: null
    Non JTA datasource: org.apache.commons.dbcp.BasicDataSource@70a3b90
    Transaction type: RESOURCE_LOCAL

1 ответ

Решение

Я обнаружил аналогичную проблему при попытке использовать профили Spring в проекте Roo.

Если вам действительно нужно запустить тест с другими конфигурациями БД, как насчет использования профилей Maven?

К примеру:

  1. Изменить вас applicationContext.xml создавать BasicDataSource с помощью database.properties значения (и удалить тег профиля)
  2. Объявить два профиля Maven на pom.xml: один для теста, а другой с окончательной конфигурацией БД.
  3. конфигурировать resources пометить на pom.xml фильтровать database.properties
  4. изменять database.properties и установите значения в свойствах pom

Таким образом, вы можете запустить интеграционный тест с HSQLB, используя тестовый профиль и другой профиль, чтобы упаковать / запустить ваше приложение с реальной БД без использования профилей Spring.

Удачи!

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