搜索
首页后端开发php教程【持续集成你的项目】为你的项目创建自动化测试和代码覆盖率测试

本文以PHP项目作为例子所需要拥有(准备)的:

  • Github账号

  • 一个项目

看着篇幅挺大的,难免有什么遗漏,如果文中有错误的地方,还请各位斧正!谢谢。因为本来篇幅就大,所以就没配图了,如果有很多人反馈看不懂或者失败了,我再后期补下图。谢谢!

Travis-CI

项目为保证项目始终处于健康稳定的状态,我们需要一个可以持续的自动的对贡献的代码进行自动化测试的服务。

Travis-CI就是在这样的背景下于2011年开启服务,到现在为止已经有超过300k个开源项目和235k的用户在使用。

Travis-CI所做的工作就是自动在虚拟机中运行 .travis.yml中设定的内容进行单元测试,生成并导出报告。

Composer

开源项目之间一般有着相互依赖的关系,比如项目A的一个组件依赖于另一个项目B。当这种依赖关系多了之后就需要一个管理依赖的工具。

Composer就是PHP的一个 依赖管理工具。它允许你申明项目所依赖的代码库,并且会在你的项目中安装他们。 Composer中文

Packagist

Packagist is the main Composer repository. It aggregates public PHP packages installable with Composer.

这个网站是主要的Composer仓库,通过Composer发布的项目,所储存的仓库就是这个网站,这也是Composer安装依赖的下载来源。 可以使用Github账号登录

登录之后可以提交自己的项目,不过需要项目中有 composer.json文件,这在之后进行介绍。

Coveralls

单元测试中,代码覆盖率经常被用来衡量测试好坏的指标。

所谓的代码覆盖率简单的说就是在运行完测试用例之后,走过了多少句的代码,比如说,你要测试的一个函数有100行,但是测试用例只走过了80行,所以这个测试用例的代码覆盖率就是80%

Coveralls就是一个根据单元测试导出的数据进行分析,展现代码覆盖率的一个工具。可以和很多的自动构建工具一起使用,本文以 Travis-CI为例。

项目最终的目录结构

/├── src/│   └── ClassName.php|── tests/|   ├── ClassNameTest/|   |   └── ClassNameTest.php|   └── Bootstrap.php|── .coveralls.yml|── .travis.yml|── LICENSE|── README.md|── composer.json|── example.php└── phpunit.xml.dist

下面开始具体的配置方法。

Composer

如果想更深入的学习Composer可以查看官方文档(地址在这一节最后)。一个重要的概念就是 每一个项目都是一个包 注

所以我们首先需要在 项目根目录新建一个 composer.json文件,其中的内容为( 稍后我们再看其中的意思)

{  "name": "jshadowman/package",  "description": "this is a test package",  "version": "0.0.1",  "type": "library",  "keywords": [ "database", "logging" ],  "license": "MIT",  "require": [    "php": ">=5.4.0"  ],  "require-dev": [    "satooshi/php-coveralls":"*",    "phpunit/phpunit": "*"  ],  "autoload": {    "files": [ "./src/ClassName.php" ]  }}
  • name:这个字段顾名思义,包的名字,应该包含Verdor name(供应商)和Project Name(项目名)。值得注意的是这个字段的值应该都是 小写的,这和资源库发布注册有关。具体请参考 Packagist

  • description:这个字段应该是这个项目的一个简短的简介。一行即可

  • version:项目的版本,并不是必须的, 而且建议忽略,具体请参考 Version 中文

  • type:项目的类型,可选的值有 library project metapackage composer-plugin具体请参考 Type 中文

  • keywords:用于在被搜索时的关键字,可以是一个数组 Keywords 中文

  • license:项目发布所使用的开源协议,可选的值请参考 License 中文

  • require:这表示项目所依赖的软件包列表,除非这些依赖被满足,否则不会完成安装。 Require 中文

  • require:我们的项目依赖于 平台软件包,也就是PHP,PHP的扩展包和一些系统类库。所以我们在 require之中添加了对PHP的依赖,如果有依赖于其他的包,可以按照这种格式填写。具体请参考 Platform-packages 中文

  • require-dev:这个字段列出的依赖只有在测试和开发的时候才会安装,属于额外的依赖。具体请参考 Require-dev 中文

  • require & require-dev:这两个字段之下的列表项应该是 包名到版本的映射,其中版本有很多种写法,可以根据需求过滤。具体请参考 Package-Links 中文

  • autoload:表示的是 autoloader的自动加载映射。具体请参考 Autoload 中文

  • autoload:其中的映射关系设计到PHP命名空间(Name Space)的一些知识,具体请参考 PSR-0- PSR-4- PSR0-4_Github

composer.json中有很多可选的字段和值,编写的规范可以参考 Document, 中文文档

Coveralls

在项目的 根目录新建 .coveralls.yml文件,其中的内容为

coverage_clover: build/logs/clover.xmljson_path: build/logs/coveralls-upload.json
  • coverage_clover:表示使用指定目录的 Clover XML格式的XML文件,默认指向 build/logs/clover.xml

  • json_path:用来指定将被上传到 Coveralls网站的json文件,默认指向 build/logs/coveralls-upload.json

值得注意的是旧版本所使用的 src_dir已经在1.0.0版本中 被移除了,所以请注意 不要使用这个选项

Removed src_dir from CoverallsConfiguration

还有其他的配置选项请参考 Github - satooshi/php-coveralls

接下来在 Coveralls网站中添加仓库:

  • 进入 Coveralls网站 https://coveralls.io/

  • 点击右上角的 SIGN IN,在接下来的页面中选择 GITHUB SIGN IN,然后使用自己的Github账号授权登录

  • 如果你没使用过 Coveralls的话,登录成功的界面应该是让你添加一个代码仓库

  • 在 ADD REPO标题下列表中将你的项目从 OFF拨到 ON

  • 接下来配置 PHPunit单元测试。

PHPUnit

在你的 项目根目录新建 phpunit.xml.dist文件,其实这个文件也不一定要新建在根目录,主要记得 修改文件内容中的路径就行,不过最好就是根目录和tests文件夹内了。

phpunit.xml.dist文件的内容为

<phpunit bootstrap="tests/Bootstrap.php"         colors="true"         convertErrorsToExceptions="true"         convertNoticesToExceptions="true"         convertWarningsToExceptions="true"         >    <testsuites>        <testsuite name="Class Test Suite">            <directory>./tests</directory>        </testsuite>    </testsuites>    <filter>        <whitelist>            <directory>./src</directory>            <exclude>                <directory>./vendor</directory>                <directory>./tests</directory>                <file>./example.php</file>            </exclude>        </whitelist>    </filter>    <logging>        <log type="coverage-clover" target="build/logs/clover.xml"/>        <log type="coverage-text" target="php://stdout" showUncoveredFiles="true"/>    </logging></phpunit>
  • 根元素 中的属性

    • bootstrap表示在测试运行前先运行一个 "Bootstrap" PHP文件,一般用于配合 Composer中的自动载入,确保不会发生找不到类的情况

    • colors表示是否使用彩色输出

    • convertErrorsToExceptionsPHPUnit 将会安插一个错误处理函数来将错误转换为异常,设置为 false 则表示禁用

    • convertNoticesToExceptions此选项设置为 true 时,由 convertErrorsToExceptions 安插的错误处理函数会将 E_NOTICE、E_USER_NOTICE、E_STRICT 错误转换为异常。

    • convertWarningsToExceptions此选项设置为 true 时,由 convertErrorsToExceptions 安插的错误处理函数会将 E_WARNING 或 E_USER_WARNING 错误转换为异常。

  • 带有一个或多个 子元素的 元素用于多组的测试套件

  • 顾名思义,过滤器,对目录下的文件或文件夹进行过滤

  • 下的 表示白名单,即需要的部分

  • 下的 顾名思义,即需要的目录

  • 下的 这是需要排除的部分,底下的排除项目看标签名就知道了,可以排除目录或者单个文件

  • 最后的 部分就是日志纪录的内容了。

    • 表示导出 coverage-clover格式的文件,导出文件名为 build/logs/clover.xml

    • 表示将日志直接输出到标准输出,即终端上。

完整的XML格式,内容可以参考 XML配置文件

需要注意的是在根元素 中的属性并不是所有都在那个页面介绍的,还有一部分在 命令行选项之中,所以如果在附录C找不到,那就去命令行选项(注意根元素属性在命令行选项中是以 -分隔的)那一节找找,肯定有的。

Travis-CI

  • 使用 Github账号登录 Travis-CI Sign Up

  • 点击自己的头像进行个人资料界面,在下面你的项目中,点击你所需要自动构建的项目前的按钮,这个按钮就会变成绿色的勾

  • 在点击到自己的用户信息界面之后,在你的Repo上面会有一个简单的使用介绍,开启Travis-CI是很简单的。

在你的 项目根目录新建 .travis.yml文件,其中的内容为

language: phpphp:  - '5.4'  - '5.5'  - '5.6'  - '7.0'before_script:  - composer install --prefer-dist --dev --no-interactionscript:  - mkdir -p build/logs  - phpunit -c phpunit.xml.dist --coverage-clover build/logs/clover.xmlafter_script:  - travis_retry php vendor/bin/coveralls -v
  • language:顾名思义,这就是你项目所用的语言,所支持的语言和格式可以查阅 Document, 配置PHP

  • php:这个底下是自动构建所使用的环境。注意,有固定的格式

  • before_script:顾名思义,在正式 script之前运行的脚本( Shell)命令

  • script:开始测试所用的命令

  • after_script:在测试结束之后运行的命令,比如用于导出结果到 COVERALLS

其中所用到命令介绍

开始测试之前需要做的准备工作,即安装项目需要的依赖包。

composer install --prefer-dist --dev --no-interaction
  • 这句命令的作用是根据 composer.json所描述的依赖关系进行依赖的安装,具体请参考 Install 中文

    • --prefer-dist:composer 将尽可能的从 dist 获取依赖的项目,这将大幅度的加快在 build servers 上的安装

    • --dev:安装 require-dev 字段中列出的包

    • --no-interaction:不要询问任何交互问题。因为是自动进行依赖安装的,我们不能手动控制,所以发生任何需要交互的问题,我们都是处理不了的

准备工作做好之后,开始正式的测试工作,首先当然需要先新建一个存放日志的目录

mkdir -p build/logs
  • 这句命令会让系统创建一个连续的目录,如果父目录不存在就先创建父目录

开始进行单元测试并导出代码覆盖率报告

phpunit -c phpunit.xml.dist --coverage-clover build/logs/clover.xml
  • 这句命令是运行phpunit进行单元测试,具体请参考 PHPUnit- 命令行选项

    • -c phpunit.xml.dist:从指定的文件中读取配置信息,这里的配置文件是 phpunit.xml.dist

    • --coverage-clover build/logs/clover.xml:生成并导出 Clover XML格式的代码覆盖率报告

测试完之后接下来就是导出报告到Coveralls了

travis_retry php vendor/bin/coveralls -v
  • 这句命令是其实是 php vendor/bin/coveralls -v,前面的 travis_retry的作用是检查后面命令的返回值,如果不是0(返回值为0表示正常结束),那就重复执行3次,如果3次都不为0,那就报错。

  • php vendor/bin/coveralls -v:

    • 这句命令是使用PHP执行vendor/bin/下的coveralls这个文件, -v表示 verbose,即显示详细的报告。

      这个命令执行之后就可以在 Coveralls这个网站中看到详细的数据了。

phpunit执行的结果和 coveralls导出的结果都可以在 Travis-CI的 Build Jobs下看到

git push

接下来就是把这些文件push到Github上, Travis-CI就会自动构建,然后开始单元测试,并把测试结果中的代码覆盖率发送到 Coveralls。如此,一套流程就结束了。

展示

辛辛苦苦大半天,就是为了展示自己的成绩啊。所以我们看到的别人家项目地下这么漂亮的图标我们也要有啊。

在 README.md文件中添加( 注意将以下 Github_ID 替换为自己的 Github-ID,将 Repo_Name 替换为你的项目名字。没有尖括号哦~还有注意区分大小写哦~如果还需要改分支(branch)的话,看到链接你应该也懂吧?我相信你!)

[![Build Status](https://travis-ci.org/<Github_ID>/<Repo_Name>.svg?branch=master)](https://travis-ci.org/<Github_ID>/<Repo_Name>)[![Coverage Status](https://coveralls.io/repos/github/<Github_ID>/<Repo_Name>/badge.svg?branch=master)](https://coveralls.io/github/<Github_ID>/<Repo_Name>?branch=master)

其实这些 markdown语句可以直接复制的

  • Travis-CI: Build图标可以在 Travis-CI网站中自己项目名的右边有一个 build:****的图标,直接点击这个图标,将 Image URL改成 Makedown就可以看到啦

  • Coveralls:也是进入自己Repo的详细信息中,中间是 LATEST BUILDS信息,在最右边有一个 README BADGE,底下那个图标右边有个按钮 Embed ▾,点击复制 Markdown的语句即可。

Packagist(可选)

在觉得自己的项目开发的差不多时,我们就可在在 Packagist上发布自己的包啦,发布之后,就可以被别人的项目通过 Composer所依赖~

  • 可以使用Github账号登录,或者自己注册个账号登录,在右上角 Sign In选择是注册还是使用Github账号登录

  • 注册完之后,可以在右上方 Submit中提交一个包,点击 Submit按钮 - Submit

  • 接下来会让你输入 Repository URL,直接输入 git://github.com//

  • Packagit会在后台clone你的项目,并且检查项目中的 composer.json文件,第一个要检查的就是包的名字,如果包名中有大写的字母,Packagit就会报一个包名不应该有大写字母的错误,所以,这就是上文所说包名最好是小写的来由。

  • 提交之后就可以看到自己的这个包的一些信息了,比如被下载了多少次,被安装了多少次。

  • 回到Github,打开代码仓库的 Settings -> Webhooks & services,然后在 Services右边有个 Add Service的按钮,点击输入查找 Packagit

  • 之后会让你输入用户名和Token,这些信息都在你的 Packagit主页中 个人主页

  • 个人主页有个 Your API Token的按钮,按下按钮,就可以看到自己的API TOKEN了, 注意保密哦

  • 其中 packagist海油4个小图标,记得替换 PACKAGIST_ID和 PACKAGE_NAME哦,不是 Github_ID和 Repo_Name哦

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
PHP和Python:解释了不同的范例PHP和Python:解释了不同的范例Apr 18, 2025 am 12:26 AM

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP和Python:深入了解他们的历史PHP和Python:深入了解他们的历史Apr 18, 2025 am 12:25 AM

PHP起源于1994年,由RasmusLerdorf开发,最初用于跟踪网站访问者,逐渐演变为服务器端脚本语言,广泛应用于网页开发。Python由GuidovanRossum于1980年代末开发,1991年首次发布,强调代码可读性和简洁性,适用于科学计算、数据分析等领域。

在PHP和Python之间进行选择:指南在PHP和Python之间进行选择:指南Apr 18, 2025 am 12:24 AM

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

PHP和框架:现代化语言PHP和框架:现代化语言Apr 18, 2025 am 12:14 AM

PHP在现代化进程中仍然重要,因为它支持大量网站和应用,并通过框架适应开发需求。1.PHP7提升了性能并引入了新功能。2.现代框架如Laravel、Symfony和CodeIgniter简化开发,提高代码质量。3.性能优化和最佳实践进一步提升应用效率。

PHP的影响:网络开发及以后PHP的影响:网络开发及以后Apr 18, 2025 am 12:10 AM

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP类型提示如何起作用,包括标量类型,返回类型,联合类型和无效类型?PHP类型提示如何起作用,包括标量类型,返回类型,联合类型和无效类型?Apr 17, 2025 am 12:25 AM

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。

PHP如何处理对象克隆(克隆关键字)和__clone魔法方法?PHP如何处理对象克隆(克隆关键字)和__clone魔法方法?Apr 17, 2025 am 12:24 AM

PHP中使用clone关键字创建对象副本,并通过\_\_clone魔法方法定制克隆行为。1.使用clone关键字进行浅拷贝,克隆对象的属性但不克隆对象属性内的对象。2.通过\_\_clone方法可以深拷贝嵌套对象,避免浅拷贝问题。3.注意避免克隆中的循环引用和性能问题,优化克隆操作以提高效率。

PHP与Python:用例和应用程序PHP与Python:用例和应用程序Apr 17, 2025 am 12:23 AM

PHP适用于Web开发和内容管理系统,Python适合数据科学、机器学习和自动化脚本。1.PHP在构建快速、可扩展的网站和应用程序方面表现出色,常用于WordPress等CMS。2.Python在数据科学和机器学习领域表现卓越,拥有丰富的库如NumPy和TensorFlow。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。