ホームページ > 開発ツール > PHPstorm > phpstorm hyperf 単体テストの構成方法を説明します

phpstorm hyperf 単体テストの構成方法を説明します

藏色散人
リリース: 2020-07-23 13:26:30
転載
5581 人が閲覧しました

次のチュートリアルコラムでは、phpstorm hyperf 単体テストの構成について紹介します。困っている友人の役に立てば幸いです。

phpstorm hyperf 単体テストの構成方法を説明します

1. PHPUnit\Framework\TestCase から継承した testCase 基本クラスを作成します。ヒント: ログイン成功後のトークンを次の場所に置きます。キャッシュに保存され、次のインターフェイス要求をキャッシュから直接フェッチできます。

<?php

declare(strict_types=1);
/**
 * This file is part of Hyperf.
 *
 * @link     https://www.hyperf.io
 * @document https://doc.hyperf.io
 * @contact  group@hyperf.io
 * @license  https://github.com/hyperf-cloud/hyperf/blob/master/LICENSE
 */

namespace HyperfTest;

use App\Model\SysUser;
use App\Service\Instance\JwtInstance;
use Hyperf\Testing\Client;
use PHPUnit\Framework\TestCase;

/**
 * Class HttpTestCase.
 * @method get($uri, $data = [], $headers = [])
 * @method post($uri, $data = [], $headers = [])
 * @method json($uri, $data = [], $headers = [])
 * @method file($uri, $data = [], $headers = [])
 */
abstract class AdminTestCase extends TestCase
{
    /**
     * @var Client
     */
    protected $client;

    // token缓存key
    protected $cacheKey = &#39;test_admin_token&#39;;

    // token
    protected $header = [];


    public function __construct($name = null, array $data = [], $dataName = &#39;&#39;)
    {
        parent::__construct($name, $data, $dataName);
        $this->client = di(Client::class);
        $this->login();
    }

    public function __call($name, $arguments)
    {
        return $this->client->{$name}(...$arguments);
    }

    /**
     * @return mixed|string
     * @throws \Psr\SimpleCache\InvalidArgumentException
     */
    public function login()
    {
        $token = cache()->get($this->cacheKey);
        $this->header[&#39;token&#39;] = $token;
        if (!$token) {
            $userId = 1;
            $user = SysUser::query()->where([&#39;user_id&#39; => $userId])->first();
            $token = JwtInstance::instance()->encode($user);
            $this->header[&#39;token&#39;] = $token;
            // 设置到缓存
             cache()->set($this->cacheKey,  $token, 43200);
        }
        return $token;
    }

    /**
     * @param array $result
     * @return false|string
     */
    public function pretty(array $result)
    {
        // 表示成功
        $this->assertSame(0, 0);
        echo  json_encode($result, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE) . PHP_EOL;
    }
}
ログイン後にコピー

2. AdminTestCase を継承するテスト コントローラーを作成し、テスト ケースを作成します

<?php
/**
 * Created by PhpStorm.
 * User: phpstorm
 * Date: 2020/6/9 14:36
 * Description:
 */


namespace HyperfTest\Cases\Admin;


use App\Service\SysUserService;
use HyperfTest\AdminTestCase;
use Swoole\Coroutine\Channel;
use Hyperf\Utils\Context;

class SysUserControllerTest extends AdminTestCase
{
    // 测试
    public function testGet()
    {
        // $this->assertTrue(true);

        $res = $this->client->get(&#39;/&#39;);

        // $this->assertSame(0, $res[&#39;code&#39;]);

        $this->pretty($res);
    }


    /**
     * 后台用户列表
     * 执行命令:composer test -- --filter testGetSysUserList --group adminUser
     *
     * @group adminUser
     */
    public function testGetSysUserList()
    {
        $params = [
            &#39;username&#39; => &#39;&#39;,
            &#39;page&#39; => 1,
            &#39;limit&#39; => 20
        ];
        $result = $this->get(&#39;/admin/sys/user/list&#39;, $params, $this->header);

        $this->pretty($result);
    }
}
ログイン後にコピー

    testGetSysUserList メソッドの左側にある緑色の三角形をクリックします:
  • phpstorm hyperf单元测试配置
  • または、プロジェクト ディレクトリでコマンドを直接使用することもできます:
    composer test -- --filter testGetSysUserList --group adminUser
    ログイン後にコピー
  • 実行結果:

    phpstorm hyperf单元测试配置
  • #3. hyperf でコルーチンをオンにすると phpunit が使用できなくなり、付属の co-phpunit を使用する必要があります。 hyperf フレームワークなので、phpstorm 設定を変更する必要があります

    ステップ 1: phpstorm->設定->言語&フレームワーク->PHP->CLI インタープリターを開きます。

    phpstorm hyperf单元测试配置

    phpstorm hyperf单元测试配置

    phpstorm hyperf单元测试配置

    ##設定後、[OK] または [適用] をクリックします

    phpstorm hyperf单元测试配置

    ステップ 2: プロジェクト ディレクトリのマッピング

    [OK] をクリックします

    phpstorm hyperf单元测试配置

    ステップ 3: 設定co-phpunit コマンド

    「phpstorm を開く」->「設定」->「言語」&「フレームワーク」->「PHP」->「テスト フレームワーク」

    phpstorm hyperf单元测试配置

    phpstorm hyperf单元测试配置

    #図に示すように、構成を表示し、[OK] または [適用] をクリックして保存します。

    phpstorm hyperf单元测试配置
    # これで、hyperf ユニットを問題なくデバッグできるようになります。

    以上がphpstorm hyperf 単体テストの構成方法を説明しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:learnku.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート