JBuilder2005单元测试之创建测试固件(2)

  ·Driver:选择borland.databstore.jdbc.DataStoreDriver类。JDBC测试固件提供了对大多数数据库的支持。其中下拉框中暂不可用的数据库驱动器类显示为红色,你可以通过配置工程扩展类库使它们可用。

  ·URL:点击其后的…按钮,弹出Create URL for DataStore对话框,如下图所示:

JBuilder2005单元测试之创建测试固件

  图 错误!文档中没有指定样式的文字。构造DataStore数据连接URL的对话框

  该对话框的设置内容会随着数据库类型的不同而变化。对于JDataStore数据库,该对话框提供了两个选项,如果数据库文件放在本机上时用第一个设置项,否则用第二个设置项。我们选择第一种选项,点击其后的…按钮,导航到/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文件,将其放置在/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选择不同的测试固件。

JBuilder2005单元测试之创建测试固件


  图 错误!文档中没有指定样式的文字。选择测试固件

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzxwwj.html