Java Hibernate LazyInitializationException仅在仅使用JUnit运行时发生

Java Hibernate LazyInitializationException仅在仅使用JUnit运行时发生,java,spring-boot,hibernate,jpa,junit,Java,Spring Boot,Hibernate,Jpa,Junit,我正在为一个API项目使用Java+SpringBoot(2.1.16版)+Hibernate+JPA。 我有好几个模特,有好几段恋情。 我没有提到提取类型,但据我所知,根据我使用的Hibernate版本,它在默认情况下是急切的。 我在我的服务方法中也提到了@Transactional。 当我通过Postman(我接收所有字段,包括OneToMany)获得对API端点的数据调用时,一切都很好,没有任何例外。 但是,当我通过单元测试调用服务方法时,我得到以下异常 org.hibernate.Laz

我正在为一个API项目使用Java+SpringBoot(2.1.16版)+Hibernate+JPA。 我有好几个模特,有好几段恋情。 我没有提到提取类型,但据我所知,根据我使用的Hibernate版本,它在默认情况下是急切的。 我在我的服务方法中也提到了@Transactional。 当我通过Postman(我接收所有字段,包括OneToMany)获得对API端点的数据调用时,一切都很好,没有任何例外。 但是,当我通过单元测试调用服务方法时,我得到以下异常

org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: com.ccc.common.model.InstantiatedVnfInfo.vnfcInfo, could not initialize proxy - no Session

at org.hibernate.collection.internal.AbstractPersistentCollection.throwLazyInitializationException(AbstractPersistentCollection.java:602)
at org.hibernate.collection.internal.AbstractPersistentCollection.withTemporarySessionIfNeeded(AbstractPersistentCollection.java:217)
at org.hibernate.collection.internal.AbstractPersistentCollection.initialize(AbstractPersistentCollection.java:581)
at org.hibernate.collection.internal.AbstractPersistentCollection.read(AbstractPersistentCollection.java:148)
at org.hibernate.collection.internal.PersistentBag.toString(PersistentBag.java:624)
at java.base/java.lang.String.valueOf(String.java:3367)
at java.base/java.lang.StringBuilder.append(StringBuilder.java:167)
at org.junit.Assert.failNotNull(Assert.java:755)
at org.junit.Assert.assertNull(Assert.java:737)
at org.junit.Assert.assertNull(Assert.java:747)
at hms.vnfm.lcm.service.VnfInstancesServiceTest.testCreateVnfInstanceWithNullFields(VnfInstancesServiceTest.java:75)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:64)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:564)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestExecutionCallbacks.evaluate(RunBeforeTestExecutionCallbacks.java:74)
at org.springframework.test.context.junit4.statements.RunAfterTestExecutionCallbacks.evaluate(RunAfterTestExecutionCallbacks.java:84)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:251)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:97)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:190)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:220)
at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:53)

有什么问题吗?

我可以在添加后解决问题

@交易的


对于我的测试方法,我可以在添加

@交易的


对于我的测试方法来说,当您使用postman调用rest API时,它可以工作,因为Spring Boot提供了一个名为OpenSessionInViewFilter的功能,它可以为HTTP请求的当前会话打开一个hibernate会话。当您通过测试方法直接调用服务方法而不使用@Transactional注释时,由于没有打开hibernate会话,因此延迟获取不起作用。

当您使用postman调用rest API时,这是因为Spring Boot提供了一个名为OpenSessionInViewFilter的功能,它可以为HTTP请求的当前会话打开一个hibernate会话。当您通过测试方法直接调用服务方法而不使用@Transactional注释时,延迟获取不起作用,因为没有打开hibernate会话