0

我正在使用 spring-boot (1.1.8.RELEASE)、spring-data-neo4j (3.2.0.RELEASE) 构建应用程序,以便通过 rest api 连接到独立的 neo4j 服务器。我正在使用 spring-test 来测试应用程序。

我想在运行单元测试之前清理数据库。我创建了一个方法 cleanDb 在开始事务之前执行。但是当运行 AppTests 中的 cleanDb 方法时,我会遇到 NullPointerException。

仅供参考,当我删除此方法时,所有单元测试都通过了。

谢谢您的帮助

在我的弹簧配置下面找到

@Configuration
@ComponentScan
@EnableTransactionManagement
@EnableAutoConfiguration
public class AppConfig extends Neo4jConfiguration {

public AppConfig() {
    setBasePackage("demo");
}

@Bean
public GraphDatabaseService graphDatabaseService(Environment environment) {
    return new SpringRestGraphDatabase("http://localhost:7474/db/data");
}

}

在我的测试课下面找到

@SuppressWarnings("deprecation")
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = AppConfig.class)
@Transactional
public class AppTests {

@Autowired
private Neo4jTemplate template;

@Rollback(false)
@BeforeTransaction
public void cleanDb() {
Neo4jHelper.cleanDb(template);
}

@Test
public void templateTest() {

    Person person = new Person();
    person.setName("Benoit");
    person.setBorn(1986);

    Person newPerson = template.save(person);

    Person retrievedPerson = template.findOne(newPerson.getNodeId(),Person.class);

    Assert.assertEquals("Benoit", retrievedPerson.getName());
}

}

当我执行单元测试时,在故障跟踪下面找到:

org.springframework.data.neo4j.core.UncategorizedGraphStoreException: Error cleaning database ; nested exception is java.lang.NullPointerException
at org.springframework.data.neo4j.support.node.Neo4jHelper.cleanDb(Neo4jHelper.java:78)
at org.springframework.data.neo4j.support.node.Neo4jHelper.cleanDb(Neo4jHelper.java:67)
at org.springframework.data.neo4j.support.node.Neo4jHelper.cleanDb(Neo4jHelper.java:38)
at demo.AppTests.cleanDb(AppTests.java:46)
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:606)
at org.springframework.test.context.transaction.TransactionalTestExecutionListener.runBeforeTransactionMethods(TransactionalTestExecutionListener.java:213)
at org.springframework.test.context.transaction.TransactionalTestExecutionListener.beforeTestMethod(TransactionalTestExecutionListener.java:167)
at org.springframework.test.context.TestContextManager.beforeTestMethod(TestContextManager.java:368)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:73)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:233)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:87)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:176)
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)
Caused by: java.lang.NullPointerException
at org.neo4j.tooling.GlobalGraphOperations.assertInTransaction(GlobalGraphOperations.java:236)
at org.neo4j.tooling.GlobalGraphOperations.getAllNodes(GlobalGraphOperations.java:82)
at org.springframework.data.neo4j.support.node.Neo4jHelper.removeNodes(Neo4jHelper.java:88)
at org.springframework.data.neo4j.support.node.Neo4jHelper.cleanDb(Neo4jHelper.java:74)
... 30 more

)

谢谢

问候

4

1 回答 1

1

rest-graph 数据库只是一个假包装器。

它不支持 cleanDB 使用的方法。

您可以通过运行如下 Cypher 语句来清理数据库:

MATCH (n)
OPTIONAL MATCH (n)-[r]-()
DELETE n,r
于 2014-11-01T05:22:17.607 回答