- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我从 DAO 测试了以下 2 种方法:
public List<T> findAll() {
if (logger.isDebugEnabled()) {
logger.debug("findAll");
}
return currentSession().createCriteria(getPersistentClass()).list();
}
public int count() {
if (logger.isDebugEnabled()) {
logger.debug("count");
}
return ((Number) currentSession().createCriteria(getPersistentClass()).
setProjection(Projections.rowCount()).
uniqueResult()).intValue();
}
测试片段:
@Test
@Transactional(isolation = Isolation.SERIALIZABLE)
public void testFindAll(){
Assert.assertEquals(2566, this.employeeHibernateDAO.findAll().size());
}
@Test
@Transactional(isolation = Isolation.SERIALIZABLE)
public void testCount(){
Assert.assertEquals(2566, this.employeeHibernateDAO.count());
}
表中共有 2566 个条目,count
成功返回其计数,但 findAll
没有。
错误:
java.lang.AssertionError:
Expected :2566
Actual :0
at org.junit.Assert.fail(Assert.java:91)
at org.junit.Assert.failNotEquals(Assert.java:645)
at org.junit.Assert.assertEquals(Assert.java:126)
at org.junit.Assert.assertEquals(Assert.java:470)
at org.junit.Assert.assertEquals(Assert.java:454)
at com.develop.test.data.dao.EmployeeDAOTest.testFindAll(EmployeeDAOTest.java:53)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:82)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:240)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:49)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
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:236)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:180)
at org.junit.runner.JUnitCore.run(JUnitCore.java:157)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:71)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:199)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:62)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
鉴于该错误,它实际上在该特定方法上返回 0。我不明白为什么考虑计数是成功的。有帮助吗?
编辑:count()
的 SQL:
09:56:15.180 [main] DEBUG org.hibernate.SQL -
select
count(*) as y0_
from
EMPLOYEE this_
Hibernate:
select
count(*) as y0_
from
EMPLOYEE this_
findAll()
的 SQL(employee3 指的是 Updated-By 字段):
09:56:15.243 [main] DEBUG org.hibernate.SQL -
select
this_.EMP_ID as EMP1_5_2_,
this_.ISACTIVE as ISACTIVE5_2_,
this_.COMPANY_CODE as COMPANY12_5_2_,
this_.CORP_TITLE as CORP3_5_2_,
this_.DEPT_CODE as DEPT13_5_2_,
this_.E_MAIL as E4_5_2_,
this_.EMP_FIRST_NAME as EMP5_5_2_,
this_.HIRE_DATE as HIRE6_5_2_,
this_.JOB_CODE as JOB7_5_2_,
this_.JOB_TITLE_DESC as JOB8_5_2_,
this_.EMP_LAST_NAME as EMP9_5_2_,
this_.MANAGER_ID as MANAGER14_5_2_,
this_.MANAGER_INDC as MANAGER10_5_2_,
this_.EMP_MIDDLE_NAME as EMP11_5_2_,
preference2_.EMP_ID as EMP1_13_0_,
preference2_.UPDATED_BY as UPDATED4_13_0_,
preference2_.UPDATED_DATE as UPDATED2_13_0_,
preference2_.LANGUAGE as LANGUAGE13_0_,
employee3_.EMP_ID as EMP1_5_1_,
employee3_.ISACTIVE as ISACTIVE5_1_,
employee3_.COMPANY_CODE as COMPANY12_5_1_,
employee3_.CORP_TITLE as CORP3_5_1_,
employee3_.DEPT_CODE as DEPT13_5_1_,
employee3_.E_MAIL as E4_5_1_,
employee3_.EMP_FIRST_NAME as EMP5_5_1_,
employee3_.HIRE_DATE as HIRE6_5_1_,
employee3_.JOB_CODE as JOB7_5_1_,
employee3_.JOB_TITLE_DESC as JOB8_5_1_,
employee3_.EMP_LAST_NAME as EMP9_5_1_,
employee3_.MANAGER_ID as MANAGER14_5_1_,
employee3_.MANAGER_INDC as MANAGER10_5_1_,
employee3_.EMP_MIDDLE_NAME as EMP11_5_1_
from
EMPLOYEE this_
inner join
PREFERENCE preference2_
on this_.EMP_ID=preference2_.EMP_ID
left outer join
EMPLOYEE employee3_
on preference2_.UPDATED_BY=employee3_.EMP_ID
Hibernate:
select
this_.EMP_ID as EMP1_5_2_,
this_.ISACTIVE as ISACTIVE5_2_,
this_.COMPANY_CODE as COMPANY12_5_2_,
this_.CORP_TITLE as CORP3_5_2_,
this_.DEPT_CODE as DEPT13_5_2_,
this_.E_MAIL as E4_5_2_,
this_.EMP_FIRST_NAME as EMP5_5_2_,
this_.HIRE_DATE as HIRE6_5_2_,
this_.JOB_CODE as JOB7_5_2_,
this_.JOB_TITLE_DESC as JOB8_5_2_,
this_.EMP_LAST_NAME as EMP9_5_2_,
this_.MANAGER_ID as MANAGER14_5_2_,
this_.MANAGER_INDC as MANAGER10_5_2_,
this_.EMP_MIDDLE_NAME as EMP11_5_2_,
preference2_.EMP_ID as EMP1_13_0_,
preference2_.UPDATED_BY as UPDATED4_13_0_,
preference2_.UPDATED_DATE as UPDATED2_13_0_,
preference2_.LANGUAGE as LANGUAGE13_0_,
employee3_.EMP_ID as EMP1_5_1_,
employee3_.ISACTIVE as ISACTIVE5_1_,
employee3_.COMPANY_CODE as COMPANY12_5_1_,
employee3_.CORP_TITLE as CORP3_5_1_,
employee3_.DEPT_CODE as DEPT13_5_1_,
employee3_.E_MAIL as E4_5_1_,
employee3_.EMP_FIRST_NAME as EMP5_5_1_,
employee3_.HIRE_DATE as HIRE6_5_1_,
employee3_.JOB_CODE as JOB7_5_1_,
employee3_.JOB_TITLE_DESC as JOB8_5_1_,
employee3_.EMP_LAST_NAME as EMP9_5_1_,
employee3_.MANAGER_ID as MANAGER14_5_1_,
employee3_.MANAGER_INDC as MANAGER10_5_1_,
employee3_.EMP_MIDDLE_NAME as EMP11_5_1_
from
EMPLOYEE this_
inner join
PREFERENCE preference2_
on this_.EMP_ID=preference2_.EMP_ID
left outer join
EMPLOYEE employee3_
on preference2_.UPDATED_BY=employee3_.EMP_ID
最佳答案
是否无法想象您实际上有零行用于连接查询?加入 PREFERENCE
是否成功?
关于java.lang.AssertionError : one method tests correctly but a similar one does not 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9069652/
在 Tomcat 6/Ubuntu 12.04 上启动 Grails 2.1.0 应用程序时出现以下错误。 Error 500 - Internal Server Error. groovy.lang
在运行 Storm 拓扑时,我收到此错误。拓扑完美运行 5 分钟,没有任何错误,然后失败。我正在使用 Config.TOPOLOGY_TICK_TUPLE_FREQ_SECS as 300 sec i
我有一个 jsp 代码在其中一台机器上运行良好。但是当我复制到另一台机器时,我得到了这个 no such method found 异常。我是 Spring 的新手。有人可以解释我错过了什么吗? 以下
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我的代码在下面给出了一个错误; Exception in thread "main" java.lang.NoSuchMethodError: com/myApp/Client.cypherCBC(L
我正在尝试一个 Restful web 服务示例,所以当我要访问 url 时,我遇到了异常 java.lang.NoSuchMethodError: jersey.repackaged.com.goo
我正在将一个 Spring web 项目转换为一个 Maven 项目,但我收到了这个错误: java.lang.NoSuchMethodError: org.jboss.logging.Logger.
在我的项目中,我有一个像这样的枚举: public enum MyEnum { FIRST(1), SECOND(2); private int value; private MyEnum(int v
我创建了这个简单的示例,用于读取 Linux 正常运行时间: public String getMachineUptime() throws IOException { String[] di
我正在使用 Eclipse,并且正在使用 Java。我的目标是使用 bogoSort 方法对 vector 进行排序在一个 vector (vectorExample)中适应我的 vector 类型,
我正在运行以下查询。它显示一条错误消息。如何解决这个错误? ListrouteList=null; List companyList = session.createS
我有以下模型类: @Entity @Table(name="user_content") @org.hibernate.annotations.NamedQueries({ @org.
我有那个错误。这是我的代码: GmailSettingsService service = new GmailSettingsService(APPLICATION_NAME, DOMAIN_NAME
实际上我在执行我的java程序时遇到了下面提到的错误 Exception in thread "pool-1-thread-1" java.lang.ClassCastException: jav
java.lang.ClassCastException: java.lang.Float cannot be cast to java.lang.String 我在以下代码中遇到此异常: Strin
我正在尝试从 linkedhashset 中检索随机元素。下面是我的代码,但它每次都给我异常。 private static void generateRandomUserId(Set userIds
我已经完成了 Android 中的代码: List spinnerArray = new ArrayList(); for (int i = 0; i item = (LinkedTreeMap)
这个问题已经有答案了: Explanation of ClassCastException in Java (12 个回答) 已关闭 6 年前。 我已经编写了 java 到 Json 的代码,同时从页
这个问题在这里已经有了答案: ClassCastException java.lang.Long cannot be cast to clojure.lang.IFn (4 个答案) 关闭 6 年前
我在运行时遇到问题来编译这段代码,这给我一个错误,java.lang.Integer 无法转换为 Java.lang.Double。如果有人帮助我更正此代码,我将非常高兴 double x; pu
我是一名优秀的程序员,十分优秀!