Skip to content
This repository has been archived by the owner on Oct 18, 2022. It is now read-only.

Latest commit

 

History

History
 
 

tests

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

测试目录结构

测试文件主要在 tests 文件下面,主要有以下几个文件夹

  • conf 测试环境配置文件。
  • script 测试环境配置脚本。
  • thinkphp 测试用例和相关文件,与项目文件夹机构一致。
  • mock.php 测试入口文件。

主要测试流程

thinkphp5 的测试的主要流程是跟 thinkphp 的系统流程是相似的,大体的流程为:

  1. 引用 mock.php 文件加载框架

  2. 根据文件目录,添加测试文件

  3. 执行单元测试,输出结果

测试举例

例如测试 thinkphp 里的 apc 缓存,将分为以下几个过程:

  1. 创建 apcTest.php 文件

该文件应与 apc.php 目录路径 thinkphp/library/think/cache/driver 一致,命名空间与目录所在一致,并引用 PHPUnit_Framework_TestCase

<?php

namespace tests\thinkphp\library\think\cache\driver;

class apcTest extends \PHPUnit_Framework_TestCase
{
    //设定基境
    public function setUp()
    {
    }
}
  1. 编写测试文件
  • 引用 app、config 和 cache
use think\app;
use think\cache;
use think\config;
  • 在 setUp 函数中设定 require 条件
if(!extension_loaded('apc')){
    $this->markTestSkipped('apc扩展不可用!');
};
  • 编写测试用例

具体写法参照 PHPUnit 官方文档

public function testGet()
{
    App::run();
    $this->assertInstanceOf(
        '\think\cache\driver\Apc',
        Cache::connect(['type' => 'apc', 'expire' => 1])
    );
    $this->assertTrue(Cache::set('key', 'value'));
    $this->assertEquals('value', Cache::get('key'));
    $this->assertTrue(Cache::rm('key'));
    $this->assertFalse(Cache::get('key'));
    $this->assertTrue(Cache::clear('key'));
    Config::reset();
}
  1. 执行单元测试命令

在项目根目录执行

$ phpunit

若想看到所有结果,请添加-v参数

$ phpunit -v
  1. 输出结果

相关文档

各个部分单元测试说明

大家一起来

单元测试的内容会跟框架同步,测试内容方方面面,是一个相对复杂的模块,同时也是一个值得重视的部分。希望大家能够多多提出意见,多多参与。如果你有任何问题或想法,可以随时提 issue,我们期待着收到听大家的质疑和讨论。

任务进度

单元测试任务进度,请大家认领模块

模块 认领人 进度
Base
App Haotong Lin
Build
Config Haotong Lin
Cache
Controller Haotong Lin
Cookie Haotong Lin
Db
Debug 大漠
Error 大漠
Hook
Input Haotong Lin
Lang
Loader
Log
Model
Response 大漠
Route
Session 大漠
Template Haotong Lin
Url
View mahuan