1

我在setUp()三个测试的方法中有几乎相同的代码。当单独运行时,测试全部工作,但是当我将它们作为完整测试集的一部分运行时,最后一个失败。

“违规”代码是:

@Before
public void setUp() throws Exception {
    AnnotationConfiguration configuration = new AnnotationConfiguration();

    configuration.addAnnotatedClass(User.class);
    configuration.setProperty("hibernate.dialect", "org.hibernate.dialect.H2Dialect");
    configuration.setProperty("hibernate.connection.driver_class", "org.h2.Driver");
    configuration.setProperty("hibernate.connection.url", "jdbc:h2:mem");
    configuration.setProperty("hibernate.hbm2ddl.auto", "create");
    configuration.setProperty("hibernate.current_session_context_class", "org.hibernate.context.ThreadLocalSessionContext");

    sessionFactory = configuration.buildSessionFactory();

    sessionFactory.openSession();

    // This is where it dies:
    sessionFactory.getCurrentSession().beginTransaction();

    User user = new User();
    user.setUsername("emanymton");
    user.setPassword(passwordEncoder.encodePassword("password", null));
    user.setAccess(1);

    sessionFactory.getCurrentSession().save(user);
    sessionFactory.getCurrentSession().getTransaction().commit();
}

堆栈跟踪是:

1    [main] ERROR org.hibernate.tool.hbm2ddl.SchemaExport  - schema export unsuccessful ava.sql.SQLException: No suitable driver found for jdbc:h2:mem
    at java.sql.DriverManager.getConnection(DriverManager.java:604)
    at java.sql.DriverManager.getConnection(DriverManager.java:190)
    at org.hibernate.connection.DriverManagerConnectionProvider.getConnection(DriverManagerConnectionProvider.java:133)
    at org.hibernate.tool.hbm2ddl.SuppliedConnectionProviderConnectionHelper.prepare(SuppliedConnectionProviderConnectionHelper.java:51)
    at org.hibernate.tool.hbm2ddl.SchemaExport.execute(SchemaExport.java:252)
    at org.hibernate.tool.hbm2ddl.SchemaExport.create(SchemaExport.java:211)
    at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:383)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1385)
    at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:954)
    at [MYPROJECT].security.authentication.manager.CustomAuthenticationManagerTest.setUp(CustomAuthenticationManagerTest.java:73)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:30)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:30)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:300)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
7    [main] ERROR org.hibernate.util.JDBCExceptionReporter  - No suitable driver found for jdbc:h2:mem

我将 Maven 用于依赖项,并在我的类路径中有依赖项 com.h2database.h2,版本 1.3.168。如前所述,它在前两个测试中运行良好,只是在这里失败了。

有任何想法吗?

提前喝彩

编辑:

这是我tearDown的测试:

@After
public void tearDown() throws Exception {
    try {
        sessionFactory.getCurrentSession().getTransaction().rollback();
    } catch (Exception e) {
        //
    }
    sessionFactory.close();
}

我已经注释掉了其他两个测试,而这个仍然失败,但只有当它作为众多测试之一运行时,它才能运行 Fine wen 自己运行。

编辑2:

当我注释掉这条线时,我设法解决了一些驱动程序问题:

    configuration.setProperty("hibernate.current_session_context_class", "org.hibernate.context.ThreadLocalSessionContext");

不确定这是一个红鲱鱼,但对于测试,是否有更好的类用于上下文类?

4

1 回答 1

1

不确定您在其他两个测试中在做什么,我只能推测以下原因

第二次测试中可能有一些方法使会话不可用,这可能是由于您在第一次测试中插入的一些数据造成的。由于它单独运行良好,第二次测试中的一些持久方法是失败(因为诸如主键之类的东西已经存在)弄乱了会话状态,并且没有正确捕获异常以显示在控制台中。

于 2012-10-29T11:46:21.030 回答