我正在编写运行保龄球游戏的webapp的代码。球员得分被保存在一个数据库中,因此前十名可以被检索到以便在主页上看到。问题是,我无法访问从从数据库中检索分数的方法返回的arraylist中的值。从arraylist访问元素从方法
这是一个JUnit测试方法:(CDR是顶级球员,应该认定为true)
<!-- language: c# -->
public class DatabaseTest {
ScoreDB sdbTest = new ScoreDB();
@Test
public void testTopPl(){
assertTrue(sdbTest.listTopPlayers().get(0).getName() == "CDR");
}
}
这是数据库检索代码:
public List<Player> listTopPlayers(){
Transaction trns = null;
Session session = HibernateUtil.getSessionFactory().openSession();
List<Player> topPlayers = new ArrayList<Player>();
try {
trns = session.beginTransaction();
List<Player> players = session.createQuery("FROM Player").list();
Collections.sort(players, new ScoreComparator());
for (int i=0; i<10; i++){
topPlayers.add(players.get(i));
}
// System.out.print(topPlayers.get(0).getName() + " test");
trns.commit();
trns = session.beginTransaction();
}catch (RuntimeException e) {
if(trns != null){
trns.rollback();
}
e.printStackTrace();
} finally{
session.flush();
session.close();
}
return topPlayers;
}
}
“无法访问”是什么意思?它会抛出一个错误吗?它是否返回错误的项目? – christopher 2013-05-07 12:05:02
它并没有出现错误,但是当我运行JUnit测试用例时,即使我检查了要返回的ArrayList,但在获得预期值的方法中,我也得到了失败的测试。 – jchoran 2013-05-07 12:07:54