fangx/testing 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

fangx/testing

Composer 安装命令:

composer require --dev fangx/testing

包简介

hyperf database testing support

README 文档

README

Hyperf 中单元测试增强扩展包

  • 支持数据库测试.
  • 支持 Http Response 直接进行断言.
  • 支持 Event 断言, 而不是直接执行 Event.
  • 支持 Queue 断言, 而不是直接执行 Queue.
  • 支持 Http 伪造响应, 而不需要真正向第三方发送请求.
  • 支持 Blade 视图渲染测试.

在 hyperf 中使用数据库进行单元测试.

推荐使用 fangx/sqlite-driver 作为数据库驱动进行测试.

为了保证测试独立, 所以每个测试完成后都会重新刷新容器. 该情况下会导致使用异步协程情况的时候, 使用 ApplicationContext::getContainer() 每次获取到的容器可能不一样 在异步里面应该避免直接使用 ApplicationContext::getContainer() 获取容器的相关内容. Hyperf 官方推荐做法是通过构造函数直接直接注入 Container, 而不是每次使用容器都通过 ApplicationContext::getContainer() 获取.

安装

composer require fangx/testing --dev

使用

Hyperf 2.0 使用 2.1 版本, Hyperf 2.1 使用 3.* 版本

  • Fangx\Testing\Concerns\CommandCaller: 提供 command() 方法, 在程序中执行命令.
  • Fangx\Testing\Concerns\DatabaseMigrations: 参照 laravel. 需要依赖 CommandCaller 执行迁移命令.
  • Fangx\Testing\Concerns\RefreshDatabase: 参照 laravel. 需要依赖 CommandCaller 执行迁移命令.
  • Fangx\Testing\Concerns\DatabaseTransactions: 参照 laravel.

运行迁移时, 默认执行的是 migrations/testing 目录下的迁移文件. 可以通过设置 getMigrationsPath 方法来自定义迁移文件的目录

使用命令创建

php bin/hyperf.php fx:test UserTest
php bin/hyperf.php fx:test UserTest --unit

直接创建

在项目中的测试目录下创建 Units/UserTest.php 填入一下内容.

<?php
namespace HyperfTest\Cases;

class UserTest extends \Fangx\Testing\TestCase
{
    use \Fangx\Testing\Concerns\CommandCaller;
    use \Fangx\Testing\Concerns\RefreshDatabase;

    public function testExample()
    {
        $this->assertTrue(true);
    }
}

统计信息

  • 总下载量: 3.47k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-05-27