1

次のようなBeanを定義するjarがあります。

@Component(value="SHTTP")
public class SHTTPImpl{
}   

jar 内には、上記で定義された Bean を次のようにロードする別のクラスがあります。

public static xx getInstance() {
   getApplicationContext().getBean("SHTTP"); //Exception thrown here
}

関数 getApplicationContext() は次のように定義されます。

private static AnnotationConfigApplicationContext getApplicationContext() {
    if (appContext == null) {
        appContext = new AnnotationConfigApplicationContext(XXContext.class);
    }
    return appContext;
}

ここで、このjarファイルを別のプロジェクト内に追加しました。たとえば、独自のxmlアプリケーションコンテキストを持つ「プロジェクトB」です。関数を呼び出してBean「SHTTPImpl」を取得しようとするプロジェクトB内にクラスがあります

getInstance()

.

しかし、これは機能しないようです

この問題は、テストケースを実行したときにのみ発生します。アプリケーションをサーバーにデプロイして実行すると、Bean が見つからないという例外が発生しません。しかし、動作するテストケースを書くことは私にとって重要です。だから、私を助けてください

ありがとう

編集:これが私のテストケースです

@Test
public void testprocessRequestMessageType() throws Exception{
    ProcessIncomingTransactionsNoThreads processIncomingTransactionNoThreads = (ProcessIncomingTransactionsNoThreads)getBean("processTransactions");
    processIncomingTransactionNoThreads.processRequestMessageType(cm); //This method tries to load the bean from the jar file
}

public class BaseTest extends TestCase {
public static ApplicationContext getContext() {
    return new FileSystemXmlApplicationContext("/src/test/resources/test-service-context.xml");
}

public static Object getBean(String beanName) {
    return getContext().getBean(beanName);
}   
}

編集 2: jar ファイルでコンテキストのルートを定義する方法を追加する方がよいと思います。内容はこちら

XXContext.java ファイル:

  @Configuration
  @ComponentScan(basePackages = { "com.xxx.adapter.sms" }) //SHTTPImpl is in package com.xxx.adapter.sms.syn
  public class XXContext {
    @Bean
    ...
   }

プロジェクト内のファイル test-service-context.xml (これは jar 内にありません) は、問題に関連しない一連の Bean を定義します。

EDIT 3 test-service-context.xml コンテンツの追加 (関連部分のみ)

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans 
                       http://www.springframework.org/schema/beans/spring-beans.xsd
                       http://www.springframework.org/schema/context
                       http://www.springframework.org/schema/context/spring-context.xsd
                       http://www.springframework.org/schema/tx 
                       http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

  <bean id="processTransactions" class="com.XXX.batch.listener.ProcessIncomingTransactionsNoThreads" >
    <property name="batchDetailDAO" ref="batchDetailDAO"/>
    <property name="batchHeaderDAO" ref="batchHeaderDAO"/>
    <property name="batchTXDetailDAO" ref="batchTXDetailDAO"/>
    <property name="batchServiceUtil" ref="batchServiceUtil"/>
    <property name="batchMessageUtil" ref="batchMessageUtil"/>
</bean>

    <bean id="mBankingSessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource" /> 
    <property name="annotatedClasses">
        <list>
            <value>com.XXX.batch.common.model.BatchControlParam</value>
            <value>com.XXX.batch.common.model.BatchDetail</value>
            <value>com.XXX.batch.common.model.BatchFileStatusLookup</value>
            <value>com.XXX.batch.common.model.BatchHeader</value>
            <value>com.XXX.batch.common.model.BatchPartnerPriority</value>
            <value>com.XXX.batch.common.model.BatchTXDetail</value>
            <value>com.XXX.batch.common.model.BatchTXStatusLookup</value>
            <value>com.XXX.batch.common.model.Party</value>
            <value>com.XXX.batch.common.model.PartyAttributes</value>
            <value>com.XXX.batch.common.model.PartyAttributeValues</value>
            <value>com.XXX.batch.common.model.PartyType</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.jdbc.batch_size">10</prop>
        </props>
    </property>
</bean>
4

0 に答える 0