java – 没有通过单元测试执行的AspectJ建议

前端之家收集整理的这篇文章主要介绍了java – 没有通过单元测试执行的AspectJ建议前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我很难过.我正在尝试测试一个AspectJ类.当我运行我的应用程序时,我的Aspect类被完美地拾取.但是,我似乎无法让任何Aspect类拦截测试中的任何方法.

我使用的是Spring 3.2.2,AspectJ 1.7.2和Maven 4.

这是我正在使用的简单测试:

测试AspectJ类

package my.package.path.config;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Aspect
public class TestAOP {
    private String message;

    public TestAOP() {
    }

    @Pointcut("execution(* my.package.path.TestAOPClient.relayMessage(..))")
    public void aopPointcut() {
    }

    @Around("aopPointcut()")
    public String monitor(ProceedingJoinPoint pjp) throws Throwable {
        String msg = (String)pjp.proceed();
        this.setMessage(msg);
        return msg;
    }

}

正在拦截方法的类

package my.package.path.config;

public class TestAOPClient {
    public String relayMessage(String msg) {
        return msg;
    }
}

测试类

package my.package.path.config;

import static org.hamcrest.Matchers.equalTo;
import static org.junit.Assert.assertThat;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;

@Configuration
@ContextConfiguration(classes={WebConfig.class})
@RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration("src/main/java")
public class AopConfigTest extends AbstractJUnit4SpringContextTests {

     @Bean
     public TestAOP testAop() throws Exception {
        return new TestAOP();
     }

     @Test
     public void assertTestConfigIsActive() {
        TestAOPClient client = new TestAOPClient();
        client.relayMessage("hello");
        assertThat(((TestAOP)applicationContext.getBean("testAop")).getMessage(),equalTo("hello"));

    }
}

WebConfig文件

package my.package.path.web.context;
@Configuration
@EnableWebMvc
@EnableAspectJAutoProxy(proxyTargetClass=false)
@ComponentScan(value={"my.package.path.config","my.package.path.web"})
public class WebConfig {

}

总是,我会得到断言错误

Expected: "hello" but: was null

我的WebApplicationContext似乎被选中,因为在运行时,如果我指定一个不存在我的Aspect切入点的类,我将得到一个ApplicationContext无法加载错误.

我错过了什么?

解决方法

您将单元测试也用作@Configuration源是有点奇怪.

您应该从单元测试中删除@Configuration批注,并将testAOP()bean定义移动到WebConfig.但最重要的是,建议使用的bean不能手动创建,而是由Spring创建:

@ContextConfiguration(classes={WebConfig.class})
@WebAppConfiguration("src/main/java")
public class AopConfigTest extends AbstractJUnit4SpringContextTests {

     @Autowired
     private TestAOP testAop;

     @Autowired
     private TestAOPClient client;

     @Test
     public void assertTestConfigIsActive() {
        client.relayMessage("hello");
        assertThat(((TestAOP)applicationContext.getBean("testAop")).getMessage(),equalTo("hello"));
    }

}

使用bean定义更新了配置:

@Configuration
@EnableWebMvc
@EnableAspectJAutoProxy(proxyTargetClass=false)
@ComponentScan(value={"my.package.path.config","my.package.path.web"})
public class WebConfig {

    @Bean
    public TestAOP testAop() throws Exception {
        return new TestAOP();
    }

    @Bean
    public TestAOPClient testAopClient() throws Exception {
        return new TestAOPClient();
    }

}

如果您的目标是测试AOP配置是否正常并且TestAOP确实是测试bean(不仅仅是此问题的虚拟名称),您可以创建一个特殊的TestConfig配置类,在那里移动bean定义并从测试@中使用它ContextConfiguration(类= {WebConfig.class,TestConfig.class}).

猜你在找的Java相关文章