2.设置连接数据库的信息。
在这步里,JBuilder提供了大部分数据库驱动程序的选择和连接信息设置,其对话框如下所示:
 图 错误!文档中没有指定样式的文字。指定数据库连接信息 | ·Driver:选择borland.databstore.jdbc.DataStoreDriver类。JDBC测试固件提供了对大多数数据库的支持。其中下拉框中暂不可用的数据库驱动器类显示为红色,你可以通过配置工程扩展类库使它们可用。
·URL:点击其后的…按钮,弹出Create URL for DataStore对话框,如下图所示:
 图 错误!文档中没有指定样式的文字。构造DataStore数据连接URL的对话框 | 该对话框的设置内容会随着数据库类型的不同而变化。对于JDataStore数据库,该对话框提供了两个选项,如果数据库文件放在本机上时用第一个设置项,否则用第二个设置项。我们选择第一种选项,点击其后的…按钮,导航到<chapter25工程目录>/db/hr.jds并选择之,按OK返回向导主对话框窗口。
·User name:sysdba。
·Password:123456。
按对话框下的Test Connection测试连接,应该会返回一个Success信息报告连接测试成功。按Finish创建JDBC 测试固件,其代码如下所示:
代码清单 错误!文档中没有指定样式的文字。HrJdbcFixture.java
1. package fixture; 2. import java.sql.*; 3. import java.io.*; 4. import com.borland.jbuilder.unittest.JdbcFixture; 5. public class HrJdbcFixture 6. extends JdbcFixture 7. { 8. public HrJdbcFixture(Object obj) { 9. super(); 10. super.setUrl("jdbc:borland:dslocal:D:/JTJB2005/chapter25/db/hr.jds"); 11. super.setDriver("com.borland.datastore.jdbc.DataStoreDriver"); 12. super.setUsername("sysdba"); 13. super.setPassword("123456"); 14. } 15. 16. public void setUp() { 17. super.setUp(); 18. } 19. 20. public void tearDown() { 21. super.tearDown(); 22. } 23. } | JDBC测试固件承继了com.borland.jbuilder.unittest.JdbcFixture,这个类的重要方法包括:
·dumpResultSet():将一个ResultSet导到一个Writer中,该方法接受两个参数,一个是ResultSet另一个是Writer。
·getConnection():获取一个数据连接。
·runSqlBuffer():执行缓存于StringBuffer对象中的SQL语句。
·runSqlFile():执行保存在文件中的SQL语句,通过入参指定SQL文件的地址。
·setDriver():设置JDBC驱动器。
·setUrl():设置数据连接的URL。
·setUsername():设置用户名。
·setPassword():设置密码。
提示:
通过向导创建JDataStore的JDBC测试固件,虽然可以直接在对话框中选择com.borland.datastore.jdbc.DataStoreDriver驱动器,但运行这个JDBC测试固件时,JBuilder却报这样的错误信息:java.lang.ClassNotFoundException: com.borland.datastore.jdbc.DataStoreDriver。原来是JBuilder通过向导创建JDBC测试固件时,并没有直接将驱动器类加载到工程类库中,所以你需要手工通过Project->Project Properties...->Paths中,将JBuilder类库中名为JDataStore类库项加到工程类库中。 由于EMPLOYEE表的数据可能会随着测试的进行不断更改,这样在测试时测试规则就很难制定,因为规则的制定必须基于一个假设的环境。举个例子,我们现在要测试findById()方法,就必须知道EMPLOYEE表中有哪些数据,所以在测试开始时就必须创建好一些特定的数据。由于JDBC固件可以执行保存在外部文件中的SQL,所以我们创建一个insert.sql文件,将其放置在<chapter25工程目录>/db/insert.sql下,文件的内容如下:
| delete from employee;insert into employee values('0004','大山',23);insert into employee values('0005','英华',30);insert into employee values('0006','柯明',31); | 运行这个SQL语句时,先清空EMPLOYEE表中的数据,然后再插入3条特定的记录。下面,我们来创建应用JDBC测试固件的TestEmployeeDAO测试用例类。
1.在编辑器中激活EmployeeDAO。
2.File->New...->Test->双击Test Case图标启动创建测试用例的向导,在向导第1、2步为EmployeeDAO的创建一个名为TestEmployeeDAO的测试用例,这个测试用例对EmployeeDAO的findById()方法进行功能测试。
3.在向导的第3步选择测试固件,在向导对话框中我们前面创建的HrJdbcFixture已经出现在列表中。你也可以通过对话框的Add...和Remove选择不同的测试固件。
 图 错误!文档中没有指定样式的文字。选择测试固件 | 按Finish直接创建TestEmployeeDAO的测试用例,其代码如下所示:
代码清单 错误!文档中没有指定样式的文字。TestEmployeeDAO.java,向导创建的测试用例类
1. package chapter25.db; 2. import junit.framework.*; 3. import fixture.*; 4. import java.sql.*; 5. public class TestEmployeeDAO extends TestCase { 6. private EmployeeDAO employeeDAO = null; 7. HrJdbcFixture hrJdbcFixture; 8. protected void setUp() throws Exception { 9. super.setUp(); 10. /**@todo verify the constructors*/ 11. employeeDAO = new EmployeeDAO(null); 12. hrJdbcFixture = new HrJdbcFixture(this); 13. hrJdbcFixture.setUp(); 14. } 15. 16. protected void tearDown() throws Exception { 17. employeeDAO = null; 18. hrJdbcFixture.tearDown(); 19. hrJdbcFixture = null; 20. super.tearDown(); 21. } 22. 23. public void testFindById() throws SQLException { 24. String id = ""; 25. Employee expectedReturn = null; 26. Employee actualReturn = employeeDAO.findById(id); 27. assertEquals("return value", expectedReturn, actualReturn); 28. /**@todo fill in the test code*/ 29. } 30. } | 测试用例在setUp()方法中实例化HrJdbcFixture对象,并调用其setUp()方法初始化环境。只有JDBC测试固件的setUp()方法执行后(第13),才可调用JDBC测试固件的其他方法,如getConnection()等,所以JDBC测试固件的setUp()是其初始化方法。下面我们对这个TestEmployeeDAO进行改造,改造的代码如下粗体代码所示:
代码清单 错误!文档中没有指定样式的文字。改造后的TestEmployeeDAO类
1. … 2. public class TestEmployeeDAO extends TestCase { 3. … 4. protected void setUp() throws Exception { 5. super.setUp(); 6. hrJdbcFixture = new HrJdbcFixture(this); 7. hrJdbcFixture.setUp(); 8. employeeDAO = new EmployeeDAO(hrJdbcFixture.getConnection()); 9. hrJdbcFixture.runSqlFile("D:/JTJB2005/chapter25/db/insert.sql",true); 10. } 11. … 12. public void testFindById() throws SQLException { 13. Employee expectEmp = new Employee("0004","大山",23); 14. Employee realEmp = employeeDAO.findById("0004"); 15. assertNotNull(realEmp); 16. assertEquals(expectEmp,realEmp); 17. } 18. } | 因为JDBC测试固件需要在setUp()方法调用后,其他方法才可用,所以在TestEmployeeDAO的setUp()方法中,我们将EmployeeDAO的实例化方法移到后面,以便实例化EmployeeDAO时可以通过hrJdbcFixture.getConnection()获取数据连接(第8行)。在第9行,执行insert.sql文件,清除表中原来的数据并插入3行测试数据。
在第13~14行,通过EmployeeDAO的findById()方法查找返回ID为0004的Employee对象,在第15~16行设定两个测试规则。
运行这个带JDBC测试固件的测试用例,HrJbdcFixture测试固件先准备好测试环境,然后再执行TestEmployeeDAO的testFindById()测试方法。
|
|