浅析PHP官方自动化测试方法(2)

发表于:2011-09-07来源:未知作者:领测软件测试网采编点击数: 标签:php;自动化测试
PHP : /home/user_dir/php-5.2.8/sapi/cli/php PHP_SAPI : cli PHP_VERSION : 5.2.8 ZEND_VERSION: 2.1.0 PHP_OS : Linux rhas05 2.6.9-55.ELhugemem #1 SMP Fri Apr 20 17:20:11 EDT 2007 i686 i686 i386 GNU/Linux

  PHP : /home/user_dir/php-5.2.8/sapi/cli/php

  PHP_SAPI : cli

  PHP_VERSION : 5.2.8

  ZEND_VERSION: 2.1.0

  PHP_OS : Linux rhas05 2.6.9-55.ELhugemem #1

  SMP Fri Apr 20 17:20:11 EDT 2007 i686 i686 i386 GNU/Linux

  INI actual :

  More .INIs :

  Extra dirs :

  =====================================================================

  Running selected tests.

  PASS Test version string [001.phpt]

  =====================================================================

  Number of tests : 1 1

  Tests skipped : 0 ( 0.0%) --------

  Tests warned : 0 ( 0.0%) ( 0.0%)

  Tests failed : 0 ( 0.0%) ( 0.0%)

  Tests passed : 1 (100.0%) (100.0%)

  ---------------------------------------------------------------------

  Time taken : 0 seconds

  =====================================================================

  如果该测试失败了,则除了屏幕输出失败结果外,当前运行目录下还会生成若干文件,以供用户分析测试失败的原因。生成的日志文件的种类是由环境变量 TEST_PHP_LOG_FORMAT 设定的,详见表 2 。如果设定的是 “ LEOD ” 则生成日志文件包括表 3 中列出的五种文件。

  表 3. PHP 自动化测试的输出脚本文件

  日志文件名 日志文件内容 对应的TEST_PHP_LOG_FORMAT里的设置

  001.out运行测试语句后得到的实际输出结果。O

  001.exp脚本中的期待结果,即测试脚本中 EXPECT* 段的内容。E

  001.log实际运行的输出结果和脚本中的期待结果,即 “ .exp ” 和 “ .out ” 的合集。L

  001.diff实际运行的输出结果和脚本中的期待结果通过 diff 命令得到比对后的结果。D

  001.php实际执行的 PHP 测试语句,在测试中解析测试脚本的 FILE 段得到。总会生成

  上面的例子是一次只运行一个脚本。 PHP 也支持多测试脚本一起运行。表 4 列出了三种 PHP 支持的测试方式。

  表 4. PHP 自动化测试方式

  测试方式 参数 举例

  只执行单个测试用例测试脚本名001.phpt 002.phpt

  执行某个目录下的测试用例测试用例的目录名test_dir/

  执行某个文件中列出的测试用例-r 加列举测试用例的文件名-r record_file

  PHP 自动化测试框架的原理和实现

  在清单 3中的运行示例中,实际的执行语句是 “ $HOME/php-5.2.8/sapi/cli/php run-tests.php $HOME/php-5.2.8/sapi/cli/tests/001.phpt ” 。其中,“ 001.phpt ” 是测试脚本;“ run-tests.php ” 为 PHP 测试的驱动脚本,是官方脚本;而 “ $HOME/php-5.2.8/sapi/cli/php ” 是运行驱动脚本的 PHP 可执行对象。这里需要指出的一点是,环境变量 TEST_PHP_EXECUTABLE 中设置的 PHP 可执行对象和这里运行测试脚本中的 “ $HOME/php-5.2.8/sapi/cli/php ” 虽然指向的是同一个可执行对象,但其意义是不一样的。环境变量 TEST_PHP_EXECUTABLE 中设置的 PHP 是被测试对象,而运行测试中使用的 “ $HOME/php-5.2.8/sapi/cli/php ” 只是为了用来驱动测试脚本运行。

  在图 1 中可以具体的看出 PHP 测试过程中两个 PHP 可执行对象及两个 PHP 脚本的关系。在测试的过程中,首先是由 “ $HOME/php-5.2.8/sapi/cli/php ” 去运行脚本 “ run-tests.php ” (第 1 步)。 在 “ run-tests.php ” 脚本中,将解析环境变量的值 “ TEST_PHP_EXECUTABLE =$HOME/php-5.2.8/sapi/cli/php ” (第 2 步)。这里 PHP 可执行对象是被测试的 PHP 。“ run-tests.php ” 脚本中还将把测试脚本 “ 001.phpt ” 中的 FILE 段解析为 PHP 脚本 “ 001.php ” (第 3 步), 用 “ TEST_PHP_EXECUTABLE ” 设置的那个 PHP 可执行对象去执行 “ 001.php ” (第 4 步)并得到实际输出结果,在比对实际输出结果和 EXPECT 段的期待结果后,输出测试结果(第 5 步)。以上运行过程可以从对 “ run-tests.php ” 脚本的分析中得出。

  图 1. PHP 测试运行关系图

  通过以上实例分析可以看出,PHP 官方测试的自动化主要依赖于 “ run-tests.php ” 脚本和测试用例脚本 PHPT 。而 “ run-tests.php ” 脚本正是 PHP 测试自动化框架的搭建者。从代码清单 5 中,可以略微看出 PHP 自动化测试框架的主要工作。

  清单 5. PHP 自动化测试代码片段

  $test_cnt = count($test_files);

  if ($test_cnt) {

  putenv('NO_INTERACTION=1');

  verify_config();

  write_information($html_output);

  usort($test_files, "test_sort");

  $start_time = time();

  if (!$html_output) {

  echo "Running selected tests.\n";

  } else {

  show_start($start_time);

  }

  $test_idx = 0;

  run_all_tests($test_files, $environment);

  $end_time = time();

  if ($html_output) {

  show_end($end_time);

  }

  if ($failed_tests_file) {

  fclose($failed_tests_file);

  }

  if (count($test_files) || count($test_results)) {

原文转自:http://www.ltesting.net