1

setUp()私は3つのテストの方法でほぼ同じコードを持っています。個別に実行すると、すべてのテストが機能しますが、完全なテスト セットの一部として実行すると、最後のテストが失敗します。

「問題のある」コードは次のとおりです。

@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 があります。前に述べたように、前の 2 つのテストでは問題なく動作しましたが、ここでは失敗しました。

何か案は?

事前に乾杯

編集:

これは、tearDownこのテストの私のものです:

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

他の 2 つのテストをコメントアウトしましたが、これはまだ失敗しますが、多くのテストのうちの 1 つとして実行された場合にのみ実行されます。

編集2:

次の行をコメントアウトすると、ドライバーの問題の一部をなんとか乗り越えることができました。

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

これがニシンであるかどうかはわかりませんが、テストのために、コンテキストクラスに使用するより良いクラスはありますか?

4

1 に答える 1

1

他の2つのテストで何をしているのかわからないので、以下の理由を推測することしかできません

2 番目のテストには、セッションを使用不可にする何らかのメソッドが存在する可能性があります。これは、最初のテストで挿入したデータが原因である可能性があります。セッション状態を台無しにし、例外がコンソールに表示されるように適切にキャッチされていないため、(主キーが既に存在するなどの理由で) 失敗しています。

于 2012-10-29T11:46:21.030 に答える