ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

使用 composer + phpstorm 为 PHP 单元测试助力

2021-12-04 22:31:02  阅读:260  来源: 互联网

标签:xml composer 单元测试 phpstorm phpunit 测试 PHPUnit


简介: 本文主要为大家讲解单元测试的相关内容,以及如何通过 composer + phpstorm 为 PHP 单元测试助力。

35.jpeg


镜像下载、域名解析、时间同步请点击 阿里巴巴开源镜像站
作者:周梦康

一、单元测试一定要用框架吗

我觉得不用,直接一行脚本,可以不可以?我觉得 ok。比如php扩展的各种单元测试,都是简单的比对,非常直观。
那我们为什么现在大家都爱用phpunit呢?
就是一个非常强大的框架,功能比较全,省去了我们很多的工作。
比如我们自己的测试脚本都是简单的自定义的脚本,能全局一次性运行吗?这是最基本的一个举例,实际的优势和便捷,还得自己慢慢使用才会发现。

二、PHP 单元测试的场景分类

1. 工具类

新写了一个工具库,比如时间格式化的方法,(刚刚、一分钟前、一小时前、一天前、一个月前等等)这样的函数或者方法。
误区:简单,发个帖子,帖子末尾会有时间,这样就能看到转换是否正确了。
但是这样测试覆盖的全面吗?当团队里的另外一个人想用你的方法的时候,想看看这个工具方法是否靠谱,怎么办呢?

2. 服务类

  • 调用别人的服务

调用别人的服务,比如验证码服务。封装好了发短信的 api,想看是否 ok。怎么办?
如果你正在写一个验证码的页面,还行。其他人想用的时候呢,只能自己临时写个脚本来验证下咯?

  • 自己编写的服务

我的应用不一定是 web 应用,有时候是 soa 的应用。这样导致整个项目中没有地方验证自己的服务是否ok,这种情况不想写单元测试都不行。

3. 业务类

和自己的业务强相关了,比如普通用户报名了一个课程,才能查看该课程得详情;管理员不需要报名就可以直接查看该课程详情。

三、单元测试的好处

复用性、覆盖率、简单直观、项目规范
Getting Started with Version 7 of PHPUnit – The PHP Testing Framework
2. 编写 PHPUnit 测试 — PHPUnit latest 手册

四、单元测试实际使用

在 phpunit 的基础上,我们使用 composer + phpstorm 配合做单元测试的辅助工具。

1. 通过 composer 安装 phpunit

参考 关于国内如何正确使用 composer 的姿势报告

2. 编写单元测试

参考 2. 编写 PHPUnit 测试 — PHPUnit latest 手册 编写了一个测试,同时自己也写了一个。

3. 自动生成测试类

1.png


这里还是有些低级,没有 java 规范,没有指定测试目录,总是在脚本的当前目录,也不能自动生成测试方法名,得手写。有待改进吧。
然后在测试类里面写需要测试的方法,约定测试方法以test开头,我选择生成的测试脚本在./Test目录下。然后写了一个testSum的方法。

namespace Test;
use PHPUnit\Framework\TestCase;
class CalculatorUtilTest extends TestCase
{
    public function testSum(){
        $a = new \Utils\CalculatorUtil();
        $data = $a->sum(1,2);
        $this->assertEquals(3,$data);
    }
}

4. 编写 phpunit.xml

<phpunit bootstrap="Bootstrap.php">
    <testsuites>
        <testsuite name="demo">
            <directory>Test</directory>
        </testsuite>
    </testsuites>
</phpunit>

Bootstrap.php 里我加了一个psr-4自动加载规则,而没有在composer里配置。

spl_autoload_register(function($class){
    if (class_exists($class)) {
        return true;
    }
    $pathPsr4 = __DIR__."/".strtr($class, '\\', DIRECTORY_SEPARATOR) . ".php";
    if (file_exists($pathPsr4)){
        include_once $pathPsr4;
    }
    return true;
});
include_once __DIR__."/vendor/autoload.php";

5. 配置 phpunit bin 文件路径

2.png


6. 运行 phpunit.xml

3.png

4.png


7. 不使用 phpunit.xml

其实可以不用编写phpunit.xml,直接在phpstorm里配置,但是这样,其他人要测试就方便了。我们也说明下如何操作。
首先我删除了phpunit.xml,然后做如下配置

5.png


然后就可以直接在Test目录上选择run

6.png


五、总结

写单元测试的时候觉得很无趣,感觉肯定成功,完全不用测,但是项目越来越复杂,就会发现之前的单元测试可能跑不通了(比如一些业务型的功能点)。写单元测试,不仅是对工作的一个梳理,也是别人复用时的一颗定心丸。

 本文转自:使用 composer + phpstorm 为 PHP 单元测试助力-阿里云开发者社区

标签:xml,composer,单元测试,phpstorm,phpunit,测试,PHPUnit
来源: https://blog.csdn.net/Aug_Spark/article/details/121722966

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有