五月天激情丁香,国产精品2019,国产成人精品亚洲2020,国产精品免费视频一区二区三区,开心久久婷婷综合中文字幕,天堂视频在线观看免费完整版

code-generation 2.x (代碼生成組件)

EasySwoole 代碼生成組件,使用命令行就可以一鍵生成業務通用代碼,支持生成的代碼如下:

  • 一鍵生成 項目初始化 baseController、baseModel、baseUnitTest
  • 一鍵生成 表 Model,自帶屬性注釋
  • 一鍵生成 表 curd 控制器,自帶 5 個 curd 方法
  • 一鍵生成 控制器單元測試用例,測試 5 個 curd 方法

組件版本說明

code-generation 組件當前最新穩定版本為 2.xcode-generation 2.x 相對于 1.x 版本,兼容了 EasySwoole 的最新注解組件,支持了新的 EasySwoole 文檔自動生成,以及最新的 phpunit 版本,同時完善了 Model->getList 返回參數,以及控制器 getOne、getListresponse 參數注解。

注:code-generation 1.x 版本組件文檔詳見 code-generation 1.x

組件要求

  • easyswoole/trigger: ^1.0
  • easyswoole/socket: ^1.0
  • easyswoole/orm: ^1.4
  • nette/php-generator: ^3.2
  • easyswoole/http-annotation: ^1.4
  • php-curl-class/php-curl-class: ^8.5
  • easyswoole/command: ^1.1

安裝方法

composer require easyswoole/code-generation=2.x

倉庫地址

easyswoole/code-generation 2.x

基本使用

配置文件 dev.php 配置如下:

<?php
return [
    'SERVER_NAME' => "EasySwoole",
    'MAIN_SERVER' => [
        'LISTEN_ADDRESS' => '0.0.0.0',
        'PORT' => 9501,
        'SERVER_TYPE' => EASYSWOOLE_WEB_SERVER, //可選為 EASYSWOOLE_SERVER  EASYSWOOLE_WEB_SERVER EASYSWOOLE_WEB_SOCKET_SERVER
        'SOCK_TYPE' => SWOOLE_TCP,
        'RUN_MODEL' => SWOOLE_PROCESS,
        'SETTING' => [
            'worker_num' => 8,
            'reload_async' => true,
            'max_wait_time' => 3
        ],
        'TASK' => [
            'workerNum' => 4,
            'maxRunningNum' => 128,
            'timeout' => 15
        ]
    ],
    'TEMP_DIR' => null,
    'LOG_DIR' => null,
    'MYSQL' => [
        'host'          => '127.0.0.1',
        'port'          => 3306,
        'user'          => 'easyswoole',
        'timeout'       => 5,
        'charset'       => 'utf8mb4',
        'password'      => 'easyswoole100%',
        'database'      => 'easyswoole',
        'maxObjectNum'  => 20,
        'minObjectNum'  => 5,
        'getObjectTimeout'  => 3.0,
    ]
];

在項目根目錄新建一個 TestCodeGeneration.php,代碼內容如下:

<?php

include __DIR__ . "/vendor/autoload.php";

\EasySwoole\EasySwoole\Core::getInstance()->initialize();

go(function () {
    // 生成基礎類
    $generation = new \EasySwoole\CodeGeneration\InitBaseClass\Controller\ControllerGeneration();
    $generation->generate();
    $generation = new \EasySwoole\CodeGeneration\InitBaseClass\UnitTest\UnitTestGeneration();
    $generation->generate();
    $generation = new \EasySwoole\CodeGeneration\InitBaseClass\Model\ModelGeneration();
    $generation->generate();

    // 獲取 dev.php 中的 MYSQL 配置文件,配置文件具體說明請看:http://m.fe88.cn/QuickStart/config.html
    $mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));

    // 獲取數據庫連接
    $connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);

    // 指定表名(這里以 user_list 表作為示例表,表結構請看下文)
    $tableName = 'user_list';
    $codeGeneration = new EasySwoole\CodeGeneration\CodeGeneration($tableName, $connection);

    // 生成 model (默認生成模型的路徑前綴為 App\Model 目錄,例如:如下生成的模型文件為 User模型【\App\Model\User\UserModel.php】 和 基礎模型【\App\Model\User\BaseModel.php】)
    $codeGeneration->generationModel("\\User");

    // 生成 controller (默認生成控制器的路徑前綴為 App\HttpController 目錄,例如:如下生成的控制器文件為 User控制器【\App\Model\Api\User\User.php】 和 基礎控制器【\App\HttpController\Api\Base.php】)
    $codeGeneration->generationController("\\Api\\User", null);

    // 生成 unitTest (默認生成 unitTest 的路徑前綴為項目根目錄的 UnitTest 目錄,例如:如下生成的單元測試用例為 UserTest【UnitTest\Api\User\UserTest.php】 和 基礎單元測試用例【UnitTest\BaseTest.php】)
    $codeGeneration->generationUnitTest("\\Api\\User", null);
});
\Swoole\Timer::clearAll();

在配置好數據庫和數據庫配置文件之后,然后在項目根目錄運行 TestCodeGeneration.php(php TestCodeGeneration.php),即可看到自動生成的模型、控制器和單元測試用例。

EasySwoole\CodeGeneration\CodeGeneration 方法可自行查看,代碼很簡單。

示例表結構(user_list)

CREATE TABLE `user_list` (
  `id` int(11) NOT NULL,
  `name` varchar(50) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `email` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

命令行使用

由于命令行特殊的特性,命令行功能支持并不完善,如果想要體驗全部功能,請使用 \EasySwoole\CodeGeneration\CodeGeneration 生成,或參考 \EasySwoole\CodeGeneration\CodeGeneration 代碼生成。

注冊命令

配置數據庫配置文件 dev.php,配置文件內容詳見上文。

EasySwoole 項目根目錄中的 bootstrap.php(即 bootstrap事件) 中使用 Di 注入配置項:

<?php
// 全局bootstrap事件
date_default_timezone_set('Asia/Shanghai');

\EasySwoole\EasySwoole\Core::getInstance()->initialize();

## 1 直接注入 mysql 連接
// 獲取 dev.php 中的 MYSQL 配置文件,配置文件具體說明請看:http://m.fe88.cn/QuickStart/config.html
$mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
// 獲取連接
$connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);
\EasySwoole\Component\Di::getInstance()->set('CodeGeneration.connection', $connection);

## 2 直接注入 mysql 配置對象
//   $mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
//   \EasySwoole\Component\Di::getInstance()->set('CodeGeneration.connection', $mysqlConfig);

## 3 直接注入 mysql 配置項
//   \EasySwoole\Component\Di::getInstance()->set('CodeGeneration.connection',\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));

// 以上 3 種注入 mysql 連接的方式均可,用戶可以任選 1 種進行注入 mysql

// 注入執行目錄項,后面的為默認值,initClass 不能通過注入改變目錄
\EasySwoole\Component\Di::getInstance()->set('CodeGeneration.modelBaseNameSpace', "App\\Model");
\EasySwoole\Component\Di::getInstance()->set('CodeGeneration.controllerBaseNameSpace', "App\\HttpController");
\EasySwoole\Component\Di::getInstance()->set('CodeGeneration.unitTestBaseNameSpace', "UnitTest");
\EasySwoole\Component\Di::getInstance()->set('CodeGeneration.rootPath', getcwd());

然后即可使用命令實現自動生成代碼,具體使用命令如下(使用如下命令前提:必須先在 bootstrap事件 中使用 Di 注冊上述說明的配置項):

php ./vendor/bin/code-generator
 ______                          _____                              _
|  ____|                        / ____|                            | |
| |__      __ _   ___   _   _  | (___   __      __   ___     ___   | |   ___
|  __|    / _` | / __| | | | |  \___ \  \ \ /\ / /  / _ \   / _ \  | |  / _ \
| |____  | (_| | \__ \ | |_| |  ____) |  \ V  V /  | (_) | | (_) | | | |  __/
|______|  \__,_| |___/  \__, | |_____/    \_/\_/    \___/   \___/  |_|  \___|
                         __/ |
                        |___/

Code auto generation tool
Usage:
  ./vendor/bin/code-generator ACTION [--opts ...]
Actions:
  init  initialization
  all   specify build
Options:
  --tableName       specify table name
  --modelPath       specify model path
  --controllerPath  specify controller path
  --unitTestPath    specify unit-test path

php ./vendor/bin/code-generator all --tableName="tableName" --modelPath="生成的模型所在目錄" [--controllerPath="生成的控制器所在目錄"] [--unitTestPath="生成的單元測試用例所在目錄"]

// 生成基礎模型(BaseModel)、基礎控制器(BaseController)、基礎單元測試用例(BaseUnitTest)
php ./vendor/bin/code-generator init

// 自動生成指定的模型、控制器、單元測試用例和 基礎模型、基礎控制器、基礎單元測試用例
php vendor/bin/code-generator all --tableName="user_list" --modelPath="\\User" --controllerPath="\\Api\\User" --unitTestPath="\\User"

執行結果示例如下:

[root@localhost es-code-generation]# php ./vendor/bin/code-generator init
┌────────────┬─────────────────────────────────────────────────────────────────────┐
│ className  │                              filePath                               │
├────────────┼─────────────────────────────────────────────────────────────────────┤
│ Model      │ /www/wwwroot/easyswoole-code-generation/App/Model/BaseModel.php     │
├────────────┼─────────────────────────────────────────────────────────────────────┤
│ Controller │ /www/wwwroot/easyswoole-code-generation/App/HttpController/Base.php │
├────────────┼─────────────────────────────────────────────────────────────────────┤
│ UnitTest   │ /www/wwwroot/easyswoole-code-generation/UnitTest/BaseTest.php       │
└────────────┴─────────────────────────────────────────────────────────────────────┘

[root@localhost es-code-generation]# php ./vendor/bin/code-generator all --tableName="user_list" --modelPath="\\User" --controllerPath="\\Api\\User" --unitTestPath="\\User"
┌────────────┬──────────────────────────────────────────────────────────────────────────────┐
│ className  │                                   filePath                                   │
├────────────┼──────────────────────────────────────────────────────────────────────────────┤
│ Model      │ /www/wwwroot/easyswoole-code-generation/App/Model/User/UserModel.php         │
├────────────┼──────────────────────────────────────────────────────────────────────────────┤
│ Controller │ /www/wwwroot/easyswoole-code-generation/App/HttpController/Api/User/User.php │
├────────────┼──────────────────────────────────────────────────────────────────────────────┤
│ UnitTest   │ /www/wwwroot/easyswoole-code-generation/UnitTest/User/UserTest.php           │
└────────────┴──────────────────────────────────────────────────────────────────────────────┘

獨立使用

生成器流程說明

  • 通過 \EasySwoole\ORM\Utility\TableObjectGeneration,傳入 \EasySwoole\ORM\Db\Connection 連接對象,通過 generationTable 方法獲取表結構對象;
  • 實例化類生成器配置,配置命名空間、生成文件路徑、類名等(詳情看下面);
  • 實例化生成器對象,調用 generate方法生成。

生成器基礎配置項

  • extendClass 繼承類,默認為\EasySwoole\ORM\AbstractModel::class
  • directory 生成路徑,生成路徑默認為 rootPath+namespace對應路徑,namespace路徑將自動通過composer.json->(autoload/autoload-dev)['psr-4'] 配置目錄生成,如果沒有則默認為根目錄
  • namespace 命名空間配置.
  • className 類名
  • rootPath 項目根目錄,默認為執行目錄.

獲取數據表結構

所有生成器都依賴于數據表結構對象EasySwoole\ORM\Utility\Schema\Table

<?php
$mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
//獲取連接
$connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);
$tableName = 'user_list';
//獲取數據表結構對象
$tableObjectGeneration = new \EasySwoole\ORM\Utility\TableObjectGeneration($connection, $tableName);
$schemaInfo = $tableObjectGeneration->generationTable();

Model生成

Model配置項說明

  • extendClass 繼承類,默認為\EasySwoole\ORM\AbstractModel::class
  • directory 生成路徑,生成路徑默認為 rootPath+namespace對應路徑,namespace路徑將自動通過composer.json->(autoload/autoload-dev)['psr-4'] 配置目錄生成,如果沒有則默認為根目錄
  • namespace 命名空間配置.默認為 App\Model
  • className 類名,Model配置無效,強制為realTableName+fileSuffix
  • rootPath 項目根目錄,默認為執行目錄.
  • tablePre 表前綴,如果有配置,es_user 表=> UserModel
  • table 表結構對象
  • realTableName 真實表名,通過下劃線形式轉為大駝峰,自動轉化.用于生成最后的類名和文件名.
  • fileSuffix 文件后綴,默認為Model,用于生成最后的類名和文件名.
  • ignoreString 默認為['list', 'log'], //生成時忽略表名存在的字符,例如user_list將生成=>UserModel

Model生成示例:

<?php
/**
 * Created by PhpStorm.
 * User: tioncico
 * Date: 2020-05-20
 * Time: 10:26
 */
include "./vendor/autoload.php";

\EasySwoole\EasySwoole\Core::getInstance()->initialize();

go(function () {
    $mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
    //獲取連接
    $connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);
    $tableName = 'user_list';
    //獲取數據表結構對象
    $tableObjectGeneration = new \EasySwoole\ORM\Utility\TableObjectGeneration($connection, $tableName);
    $schemaInfo = $tableObjectGeneration->generationTable();

    $tablePre = '';//表前綴
    $path = "App\\Model";
    $extendClass = \EasySwoole\ORM\AbstractModel::class;
    $modelConfig = new \EasySwoole\CodeGeneration\ModelGeneration\ModelConfig($schemaInfo, $tablePre, "{$path}", $extendClass);
    $modelConfig->setRootPath(EASYSWOOLE_ROOT);//設置項目運行目錄,默認為當前執行腳本目錄.
    $modelConfig->setIgnoreString(['list', 'log']);//生成時忽略表名存在的字符,例如user_list將生成=>UserModel

    $modelGeneration = new \EasySwoole\CodeGeneration\ModelGeneration\ModelGeneration($modelConfig);
    $result = $modelGeneration->generate();
    var_dump($result);//生成成功返回生成文件路徑,否則返回false
});
\Swoole\Timer::clearAll();

Model方法

Model方法默認生成一個GetList方法,用于獲取列表.

<?php
public function getList(int $page = 1, int $pageSize = 10, string $field = '*'): array
{
    $list = $this
        ->withTotalCount()
        ->order($this->schemaInfo()->getPkFiledName(), 'DESC')
        ->field($field)
        ->page($page, $pageSize)
        ->all();
    $total = $this->lastQueryResult()->getTotalCount();;
    return ['total' => $total, 'list' => $list];
}

可參考EasySwoole\CodeGeneration\ModelGeneration\Method\GetList自定義其他方法.再進行注入即可.

addGenerationMethod(new \EasySwoole\CodeGeneration\ModelGeneration\Method\GetList($modelGeneration));

Controller生成

Controller 配置項說明

Controller配置項繼承與Model配置項

  • modelClass Model類類名(包含命名空間),Controller生成依賴于Model,所以需要傳入Model類類名
  • authSessionName 權限驗證session參數名,比如在需要用戶登錄的控制器方法中,都需要傳入session字段名用于驗權,controller將在生成方法時自動生成驗證這個session參數的注解,默認為空
  • extendClass 繼承類,默認為\EasySwoole\HttpAnnotation\AnnotationController
  • directory 生成路徑,生成路徑默認為 rootPath+namespace對應路徑,namespace路徑將自動通過composer.json->(autoload/autoload-dev)['psr-4'] 配置目錄生成,如果沒有則默認為根目錄
  • namespace 命名空間配置.默認為 App\\HttpController
  • className 類名,Model配置無效,強制為realTableName+fileSuffix
  • fileSuffix 文件后綴,默認為空,用于生成最后的類名和文件名.
  • ignoreString 默認為['list', 'log'], //生成時忽略表名存在的字符,例如user_list將生成=>User

controller生成示例

<?php
/**
 * Created by PhpStorm.
 * User: tioncico
 * Date: 2020-05-20
 * Time: 10:26
 */
include "./vendor/autoload.php";
\EasySwoole\EasySwoole\Core::getInstance()->initialize();

go(function () {
    $mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
    //獲取連接
    $connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);
    $tableName = 'user_list';
    //獲取數據表結構對象
    $tableObjectGeneration = new \EasySwoole\ORM\Utility\TableObjectGeneration($connection, $tableName);
    $schemaInfo = $tableObjectGeneration->generationTable();

    $tablePre = '';//表前綴
    $path = "App\\HttpController";
    $extendClass = \EasySwoole\HttpAnnotation\AnnotationController::class;
    $modelClass = \App\Model\UserModel::class;//$modelGeneration->getConfig()->getNamespace() . '\\' . $modelGeneration->getClassName();
    $controllerConfig = new \EasySwoole\CodeGeneration\ControllerGeneration\ControllerConfig($modelClass, $schemaInfo, $tablePre, "{$path}", $extendClass);
    $controllerConfig->setRootPath(EASYSWOOLE_ROOT);
    $controllerGeneration = new \EasySwoole\CodeGeneration\ControllerGeneration\ControllerGeneration($controllerConfig);
    $result = $controllerGeneration->generate();
    var_dump($result);
});
\Swoole\Timer::clearAll();

Controller方法.

Controller支持了5個方法,Add,Delete,GetList,GetOne,Update. 自定義其他方法可參考Model方法自定義.

unitTest

單元測試生成器生成.生成后的文件為作者本人自定義風格代碼,需要依賴于BaseUnitTest

<?php

namespace UnitTest;

use Curl\Curl;
use EasySwoole\EasySwoole\Core;
use PHPUnit\Framework\TestCase;

/**
 * BaseTest
 * Class BaseTest
 * Create With ClassGeneration
 */
class BaseTest extends TestCase
{
    public static $isInit = 0;

    /** @var Curl */
    public $curl;
    public $apiBase = 'http://127.0.0.1:9501';
    public $modelName;

    public function request($action, $data = [], $modelName = null)
    {
        $modelName = $modelName ?? $this->modelName;
        $url = $this->apiBase . '/' . $modelName . '/' . $action;
        $curl = $this->curl;
        $curl->post($url, $data);
        if ($curl->response) {
        //            var_dump($curl->response);
        } else {
            echo 'Error: ' . $curl->errorCode . ': ' . $curl->errorMessage . "
";
        }
        $this->assertTrue(!!$curl->response);
        $this->assertEquals(200, $curl->response->code, $curl->response->msg);
        return $curl->response;
    }

    public function setUp()
    {
        if (self::$isInit == 1) {
            return true;
        }
        require_once dirname(__FILE__, 2) . '/vendor/autoload.php';
        defined('EASYSWOOLE_ROOT') or define('EASYSWOOLE_ROOT', dirname(__FILE__, 2));
        require_once dirname(__FILE__, 2) . '/EasySwooleEvent.php';
        Core::getInstance()->initialize()->globalInitialize();
        self::$isInit = 1;
        $this->curl = new Curl();
    }
}

unitTest配置項說明

unitTest配置項繼承于Model配置項

  • modelClass Model類類名(包含命名空間),UnitTest生成依賴于Model,所以需要傳入Model類類名
  • ControllerClass ControllerClass類類名(包含命名空間),UnitTest生成依賴于ControllerClass,所以需要傳入ControllerClass類類名
  • extendClass 繼承類,默認為\PHPUnit\Framework\TestCase
  • directory 生成路徑,生成路徑默認為 rootPath+namespace對應路徑,namespace路徑將自動通過composer.json->(autoload/autoload-dev)['psr-4'] 配置目錄生成,如果沒有則默認為根目錄
  • namespace 命名空間配置.默認為 UnitTest
  • className 類名,Model配置無效,強制為realTableName+fileSuffix
  • fileSuffix 文件后綴,默認為Test,用于生成最后的類名和文件名.
  • ignoreString 默認為['list', 'log'], //生成時忽略表名存在的字符,例如user_list將生成=>UserTest

unitTest生成示例

<?php
/**
 * Created by PhpStorm.
 * User: tioncico
 * Date: 2020-05-20
 * Time: 10:26
 */
include "./vendor/autoload.php";
\EasySwoole\EasySwoole\Core::getInstance()->initialize();

go(function () {
    $mysqlConfig = new \EasySwoole\ORM\Db\Config(\EasySwoole\EasySwoole\Config::getInstance()->getConf('MYSQL'));
    //獲取連接
    $connection = new \EasySwoole\ORM\Db\Connection($mysqlConfig);
    $tableName = 'user_list';
    //獲取數據表結構對象
    $tableObjectGeneration = new \EasySwoole\ORM\Utility\TableObjectGeneration($connection, $tableName);
    $schemaInfo = $tableObjectGeneration->generationTable();

    $path = "UnitTest";
    $modelClass = \App\Model\UserModel::class;
    $controllerClass= \App\HttpController\User::class;
    $extendClass = \PHPUnit\Framework\TestCase::class;
    $tablePre = '';//表前綴
    $controllerConfig = new \EasySwoole\CodeGeneration\UnitTest\UnitTestConfig($modelClass, $controllerClass, $schemaInfo, $tablePre, "{$path}", $extendClass);
    $controllerConfig->setRootPath(EASYSWOOLE_ROOT);
    $unitTestGeneration = new \EasySwoole\CodeGeneration\UnitTest\UnitTestGeneration($controllerConfig);
    $result = $unitTestGeneration->generate();
    var_dump($result);
});
\Swoole\Timer::clearAll();

UnitTest方法.

UnitTest支持了5個方法,Add,Delete,GetList,GetOne,Update. 自定義其他方法可參考Model方法自定義.

初始化類

為了方便開發,提供了Controller,Model,UnitTest的初始化類.

Controller

生成方法:

<?php
$generation = new \EasySwoole\CodeGeneration\InitBaseClass\Controller\ControllerGeneration();
    $generation->generate();

類內容:

<?php

namespace App\HttpController;

use EasySwoole\EasySwoole\ServerManager;
use EasySwoole\EasySwoole\Trigger;
use EasySwoole\HttpAnnotation\AnnotationController;
use EasySwoole\HttpAnnotation\Exception\Annotation\ParamValidateError;
use EasySwoole\Http\Message\Status;

/**
 * Base
 * Class Base
 * Create With ClassGeneration
 */
class Base extends AnnotationController
{
    public function index()
    {
        $this->actionNotFound('index');
    }

    public function clientRealIP($headerName = 'x-real-ip')
    {
        $server = ServerManager::getInstance()->getSwooleServer();
        $client = $server->getClientInfo($this->request()->getSwooleRequest()->fd);
        $clientAddress = $client['remote_ip'];
        $xri = $this->request()->getHeader($headerName);
        $xff = $this->request()->getHeader('x-forwarded-for');
        if ($clientAddress === '127.0.0.1') {
            if (!empty($xri)) {  // 如果有xri 則判定為前端有NGINX等代理
                $clientAddress = $xri[0];
            } elseif (!empty($xff)) {  // 如果不存在xri 則繼續判斷xff
                $list = explode(',', $xff[0]);
                if (isset($list[0])) $clientAddress = $list[0];
            }
        }
        return $clientAddress;
    }

    public function onException(\Throwable $throwable): void
    {
        if ($throwable instanceof ParamValidateError) {
            $this->writeJson(Status::CODE_BAD_REQUEST,[], $throwable->getValidate()->getError()->__toString());
        }  else {
            Trigger::getInstance()->throwable($throwable);
            $this->writeJson(Status::CODE_INTERNAL_SERVER_ERROR, null, $throwable->getMessage());
        }
    }
}

Model

生成方法:

<?php
$generation = new \EasySwoole\CodeGeneration\InitBaseClass\Model\ModelGeneration();
$generation->generate();

類內容:

<?php

namespace App\Model;

use EasySwoole\ORM\AbstractModel;
use EasySwoole\ORM\DbManager;

/**
 * BaseModel
 * Class BaseModel
 * Create With ClassGeneration
 */
class BaseModel extends AbstractModel
{
    public static function transaction(callable $callable)
    {
        try {
            DbManager::getInstance()->startTransaction();
            $result = $callable();
            DbManager::getInstance()->commit();
            return $result;
        } catch (\Throwable $throwable) {
            DbManager::getInstance()->rollback();
            throw $throwable;;
        }
    }
}

UnitTest

生成方法:

<?php
$generation = new \EasySwoole\CodeGeneration\InitBaseClass\UnitTest\UnitTestGeneration();
$generation->generate();

類內容:

<?php

namespace UnitTest;

use Curl\Curl;
use EasySwoole\EasySwoole\Core;
use PHPUnit\Framework\TestCase;

/**
 * BaseTest
 * Class BaseTest
 * Create With ClassGeneration
 */
class BaseTest extends TestCase
{
    public static $isInit = 0;

    /** @var Curl */
    public $curl;
    public $apiBase = 'http://127.0.0.1:9501';
    public $modelName;

    public function request($action, $data = [], $modelName = null)
    {
        $modelName = $modelName ?? $this->modelName;
        $url = $this->apiBase . '/' . $modelName . '/' . $action;
        $curl = $this->curl;
        $curl->post($url, $data);
        if ($curl->response) {
        //            var_dump($curl->response);
        } else {
            echo 'Error: ' . $curl->errorCode . ': ' . $curl->errorMessage . "
";
        }
        $this->assertTrue(!!$curl->response);
        $this->assertEquals(200, $curl->response->code, $curl->response->msg);
        return $curl->response;
    }

    public function setUp()
    {
        if (self::$isInit == 1) {
            return true;
        }
        require_once dirname(__FILE__, 2) . '/vendor/autoload.php';
        defined('EASYSWOOLE_ROOT') or define('EASYSWOOLE_ROOT', dirname(__FILE__, 2));
        require_once dirname(__FILE__, 2) . '/EasySwooleEvent.php';
        Core::getInstance()->initialize()->globalInitialize();
        self::$isInit = 1;
        $this->curl = new Curl();
    }
}
主站蜘蛛池模板: 西川结衣在线观看 | 超碰超在线 | 欧美又大又硬又粗bbbbb | 黄色小视频免费 | 黄色a免费 | 国产视频一区二区三区四区 | 国产精品免费一区二区区 | 可以免费看成人啪啪过程的软件 | 三级黄色免费片 | 久草久 | 欧美日本国产欧美日本韩国99 | 五月天天丁香婷婷在线中 | 国产91玉足脚交在线播放 | 日韩精品久久无码中文字幕 | 国产人妻人伦精品 | 国产va免费精品观看 | 天堂欧美城网站地址 | 日韩av综合在线 | 欧美嫩草影院 | 国产在线资源站 | 色就色综合 | 国产精品日韩av在线播放 | 激性欧美激情在线 | 毛片毛片毛片毛片毛片毛片毛片毛片毛片 | 农村妇女一区二区 | 午夜不卡久久精品无码免费 | 日本免费一区二区三区在线播放 | 无遮挡又黄又刺激的视频 | 欧美成人午夜精品 | 日韩在线观看视频网站 | 7m精品福利视频导航 | 免费日本特黄 | 国产69精品久久久久999天美 | 18禁真人抽搐一进一出在线 | 五月丁香色综合久久4438 | 免费一级大片 | 国产免费一区二区三区最新6 | 少妇一级免费 | 日韩欧美人妻一区二区三区 | 友田真希中文字幕在线视频中 | 日产精品久久久久久久性色 | 欧美在线观看一区 | 国产69熟| 亚洲黄色片网站 | 日韩av高清 | 精品国语对白 | 91看片一区二区三区 | 国产人与zoxxxx另类一一 | 亚洲精品玖玖玖av在线看 | 亚洲第一男人天堂 | 日本三级免费看 | 全网免费在线播放视频入口 | 两女女百合互慰av赤裸无遮挡 | 久久久久久亚洲国产精品 | 和嫩模做爰在线播放 | 国产成人免费在线视频 | 日韩一中文字幕 | 欧美成人久久 | 国内揄拍国内精品少妇国语 | 日批免费网站 | 国产微拍精品一区 | 性欧美视频在线观看 | 久久综合亚洲色hezyo国产 | 久久久麻豆| 少妇系列之白嫩人妻 | 天天干天天爱天天射 | 亚洲精品一区二区三区蜜桃 | 久久精品视频在线看99 | 91丨九色丨蝌蚪丨丝袜 | 国产综合视频在线观看 | 中文字幕乱码亚洲无线三区 | 日啪 | 91网址在线 | 午夜精品久久久久久久久久久久 | 久久久久久片 | 91精品视频免费在线观看 | 欧美又粗又大aaa片 熟女少妇内射日韩亚洲 | wwwxxxx国产| 欧美日韩中文字幕视频 | 爱爱视频免费网站 | 国产精品高清网站 | 一级精品毛片 | 伊人中文字幕无码专区 | 毛片av免费看 | 青青免费视频在线观看 | 少妇口述偷人好爽的一次 | 2019狠狠干 | 亚洲综合激情另类小说区 | 欧美三级韩国三级日本一级 | jizzjizz在线播放 | 五月天久久久久久九一站片 | 久久久综合av | 国产激情在线看 | av在线观| 欧美黑人xxxx高潮猛交 | 天天爽天天噜在线播放 | 久久久av波多野一区二区 | 国产精品伦一区二区三级视频 | 18成人在线 | 手机免费av在线 | 啪啪的网站 | 欧美一区二区人人喊爽 | 国产一区二区三区免费看 | 免费在线亚洲 | 国产精品999视频 | 国产黄a三级三级三级av在线看 | 日韩综合夜夜香内射 | 国产乱子伦视频一区二区三区 | 久久综合av色老头免费观看 | 波多野结衣在线视频网站 | 欧美一区二区三区日韩 | 清朝荒淫性艳史 | 麻豆精品一区 | 国产成人久久综合第一区 | 国产精品极品白嫩在线 | 黑人无套内谢中国美女 | 久久久无码精品一区二区三区蜜桃 | 一级特黄aa | 高清国产精品人妻一区二区 | 九九免费观看视频 | 亚洲成av人片在线观看无 | 国产精品极品美女自在线观看免费 | 无码精品a∨在线观看中文 亚洲熟妇自偷自拍另欧美 无码少妇a片一区二区三区 | 日韩avxxx | 欧美日韩在线成人 | 国产精品久久久久久欧美 | 色女孩综合 | 久久狠狠高潮亚洲精品 | 两性午夜免费视频 | 久久人人添人人爽添人人88v | 波多野结衣在线观看一区二区 | 免费一级淫片 | 精品无码一区二区三区电影 | 欧美成人精品一区二区三区在线观看 | 久草在线色站 | 亚洲精品国产精品乱码不66 | 男人的天堂av女优 | 国严产品自偷自偷在线观看 | 久久成人国产精品入口 | 无码熟熟妇丰满人妻啪啪 | 极品粉嫩国产18尤物 | 欧美麻豆| 97国产精| 亚洲欧美日韩中文字幕一区二区三区 | 奶波霸巨乳一二三区乳 | 波多野吉衣在线观看视频 | 一级片网址 | 无码成人一区二区 | 色葡萄影院| 麻豆网站观看 | 精品无码久久久久久国产 | 亚洲在线不卡 | 日本精品婷婷久久爽一下 | 国产毛片在线视频 | 国产三级漂亮女教师 | 男人天堂中文字幕 | 最近中文字幕mv在线资源 | 亚洲视频自拍偷拍 | 青青草娱乐在线 | 亚洲日韩av一区二区三区中文 | 国产乱淫av麻豆国产 | 精品久久久久久亚洲综合网 | 中文字幕亚洲综合久久筱田步美 | 韩国黄色av| 午夜一级大片 | 亚洲va在线va天堂xxxx中文 | 亚洲熟少妇在线播放999 | 亚洲日本中文字幕天天更新 | 99视频在线精品免费观看2 | 99久久精品免费看国产一区二区三区 | 超碰在线99 | 国产精品亚韩精品无码a在线 | 国产日韩精品一区 | 美女黄色影院 | 日本精品婷婷久久爽一下 | 国产成人无码区免费内射一片色欲 | 伊人蕉久影院 | 成人手机看片 | 中文字幕不卡在线 | 美女在线一区 | 欧美大肥婆大肥bbbbb | 快色网站| 天天爽夜夜爽夜夜爽精品视频 | 成人做爰www网站视频 | 日本黄色不卡 | 日韩在线 中文字幕 | 特黄性暴力强在线线播放 | 中国久久 | 亚洲视频在线看 | 情趣用品a∨视频在线观看 情一色一乱一欲一区二区 情欲都市成熟美妇大肉臀 秋霞成人 | 久久中文字幕一区二区 | 六月婷婷久香在线视频 | 八戒八戒在线www视频中文 | 久久不见久久见免费影院 | 天堂网亚洲 | 一道本在线播放 | 毛片24种姿势无遮无拦 | 本道综合精品 | 国产又色又爽又黄刺激在线视频 | 丁香婷婷久久久综合精品国产 | 麻豆91精品91久久久的优点 | 色综合天天综合色综合av | av免费观看网站 | 欧美成人伊人 | 欧美变态另类牲交 | 中文国产日韩精品av片 | 色视频在线观看免费 | 毛片网站在线播放 | 精品无码一区二区三区在线 | 久久久久久91 | 天天夜天天干 | jizz久久 | 国产农村妇女aaaaa视频 | 久久逼逼 | 国产精品特级毛片一区二区三区 | 人人妻人人澡人人爽 | 欧美午夜网 | 国产xxxx裸体xxx免费 | 人妻少妇精品无码专区动漫 | 国产精品嫩草影院久久久 | 学生妹亚洲一区二区 | 日本在线视频中文字幕 | 日韩午夜一区二区在线精品三级伦理 | 国产成人精品日本亚洲直播 | 国产精品无| 色婷婷av在线 | 国产性受xxxx白人性爽 | 无人区码一码二码w358cc | 国产精品一区二区免费在线观看 | 国产精品毛片a∨一区二区三区 | 久久久免费观看视频 | 亚洲欧美一区二区三区在线 | 国产精品久久久久久久久免费高清 | 一区二区三区四区国产 | av动漫网站| 摸大乳喷奶水www视频 | 久久国产精品久久久久久久久久 | 久久久成人免费 | 污污免费观看 | 国产三级高清 | 国产乱肥老妇女精品视频网站 | 人妻丰满熟妇av无码区 | 亚洲男人最新版本天堂 | 欧美性极品 | 男人网站在线观看 | 国产aaaaav久久久一区二区 | 天天碰天天碰 | 国产亚洲欧美精品永久 | 国模冰莲大胆自慰难受 | 日本无翼乌邪恶大全彩h | 人人妻人人妻人人片av | 亚洲天堂av线 | 激情综合一区二区三区 | 亚洲女优一区 | 午夜裸体性播放 | 黑人日批视频 | 成人午夜视频免费在线观看 | 亚洲精品乱码久久久久久日本蜜臀 | 久久久黄色大片 | 精产国品一二三产区区别在线观看 | 用力来高潮了再用力91 | 久久精品网址 | 国产精品免费无遮挡无码永久视频 | 男人天堂视频在线 | 少妇扒开双腿自慰出白浆 | 一本色道久久综合亚洲精品 | 国产猛男猛女超爽免费视频 | 六月婷婷啪啪 | 欧美黄色大片网站 | 久久无码专区国产精品s | 欧美v亚洲v综合ⅴ国产v | 日韩精品一区二区三区四区 | 超碰在线中文字幕 | 亚洲色图自拍 | 国产男女猛烈无遮挡免费网站 | 中文一二区| 最新偷窥盗摄 | 朝鲜女人大白屁股ass孕交 | 日本免费网站 | 二区三区av | 日韩欧美大片在线观看 | 538国产精品视频一区二区 | 精品在线播放 | 国产午夜免费福利 | 日韩欧美精品在线 | 黄色免费网站视频 | 一级录像免费录像性高湖 | 99999精品视频 | 国产精品丝袜一区二区三区 | 韩日av一区二区 | 日日摸夜夜添夜夜添欧美毛片小说 | 国产精品69午夜妇大片 | 性高湖久久久久久久久 | 一本色道久久亚洲综合精品蜜桃 | 女人裸体偷拍全过程 | 嫩草视频在线播放 | 粉嫩欧美一区二区三区 | 又硬又粗又大一区二区三区视频 | 久久国产精品精品 | 91性高潮久久久久久久 | 亚洲精品久久久久中文字幕欢迎你 | 艳妇臀荡乳欲伦交换日本 | 亚洲自拍p | 久久中文精品 | 中文无码热在线视频 | 国内精品久久久久久 | 国产午夜啪啪 | 成人性生交片无码免费看 | 亚洲自偷自偷偷色无码中文 | 精东影业一区二区三区 | 成年人免费在线 | 日本一区二区三区在线免费观看 | 久久久精品波多野结衣av | 国产成年人视频网站 | 暖暖在线日本免费高清最新版 | 午夜不卡久久精品无码免费 | 亚洲精品日韩激情欧美 | 麻豆国产91在线播放 | 国内精品国产三级国产a久久 | 丰满妇女强制高潮18xxxx | 东北老头老太国产 | 久久久久久久久毛片精品 | 午夜精品视频一区二区三区在线看 | 黄色三级小视频 | 在线观看免费福利 | 女体拷问一区二区三区 | 免费日韩一区二区 | 国产精品美女一区二区 | 成人必看www.| 午夜性刺激在线视频免费 | 久操视频在线免费观看 | 香蕉视频一区 | 日韩av二区| 影音先锋女人aa鲁色资源 | 日本一区二区三区视频免费看 | 久久久久亚洲国产av麻豆 | 国产日韩精品一区 | 成人做爰66片免费看网站 | 极品少妇xxxx精品少妇小说 | 天天天色综合 | 中文字幕国产一区二区 | 精品人妻av区 | 一区二区免费在线观看 | 久久99国产精一区二区三区 | 亚洲猛少妇又大又xxxxx | 在线观看免费一区 | 绿帽av| 夜夜高潮夜夜爽夜夜爱爱 | 日本欧美色 | xvideos亚洲网站入口 | 黑人3p波多野结衣在线观看 | 九色蝌蚪9l视频蝌蚪9l视频开放 | 麻豆人妻少妇精品无码专区 | 欧洲妇女成人淫片aaa视频 | 成人在线视频一区二区 | 日韩视频网 | 中文字幕在线免费 | 亚洲中文字幕在线无码一区二区 | 久久国产热精品波多野结衣av | 国产一区二区黄色 | 狠狠色狠狠色综合久久一 | 人人射人人干 | 伊人网在线播放 | 日韩av地址 | 亚洲а∨天堂久久精品9966 | 精品亚洲韩国一区二区三区 | 99精品在线免费观看 | 亚洲天堂1 | 国产又粗又猛又爽又黄的视频免费 | 国内丰满少妇猛烈精品播 | 欧美一区二区三区成人 | 九九激情网 | 成人国产一区二区三区精品 | 激情小说中文字幕 | 97精品伊人久久久大香线蕉97如何观看 | а√中文在线资源库 | 岛国大片在线免费观看 | 青青视频免费 | 狠狠干狠狠干 | 午夜看毛片 | 三级欧美韩日大片在线看 | 国产一区二区三区黄 | 丁香五香天堂网 | 免费国产在线一区二区 | 成年人黄色片网站 | 国产在线麻豆精品入口 | 女人夜夜春高潮爽a∨片传媒 | 日韩特黄| 男人天堂视频网 | 青青青爽视频在线观看 | 国产一区二区三区精品久久久 | 久久久久人妻精品一区 | 国产hxc132乱人免费视频 | 色吧视频 | 欧美最猛性xxxxx免费 | 日韩第一色 | 久久久久久国产精品免费播放 | 国产卡一卡二卡三无线乱码新区 | yjizz国产| 欧美黄色免费视频 | 日本在线二区 | 欧美在线观看一区二区三区 | 国产麻豆视频 | 国精品人妻无码一区二区三区性色 | 亚洲精选网站 | 做爰xxxⅹ性69免费软件 | 绝顶高潮videos合集 | 亚洲a免费| 97人人模人人爽人人少妇 | 7777色鬼xxxⅹ欧美色妇 | 综合久久国产 | 超碰在线看 | 国产成人精品午夜福利 | 凹凸日日摸日日碰夜夜爽孕妇 | 一区二区三区黄色片 | jizz性欧美10 | 曰批全过程免费视频在线观看无码 | 黑人巨茎大战欧美白妇 | 四虎av在线 | 寡妇疯狂性猛交 | 国模杨依粉嫩蝴蝶150p | 日本精品在线看 | 亚洲最大成人网色 | 国产精品无码久久久久成人影院 | 亚洲天堂女人 | 中文字幕乱码熟女人妻水蜜桃 | 天堂无码人妻精品av一区 | 日韩一区二区三区四区 | 久久久久久久久久久久久9999 | 国产伦精品一区二区三区照片 | 伦理片免费完整片在线观看 | 亚洲精品电影院 | 日日噜噜夜夜狠狠久久丁香五月 | 特级毛片在线 | 成人在线三级 | 亚洲日韩中文字幕在线播放 | 欧美一区二区三区成人久久片 | 国产ts人妖系列张思妮在线观看 | 亚洲熟妇色自偷自拍另类 | 国产刺激视频 | 精品国产乱 | 又色又污又爽又黄的网站 | 瑟瑟久久 | 文中字幕一区二区三区视频播放 | 国产精品丝袜一区二区三区 | 国产伦精品一区二区三区免费 | 免费在线看污 | 国产china男男激情 | aⅴ亚洲 日韩 色 图网站 播放 | 免费看男女做好爽好硬视频 | 一区二区三区在线观看视频 | 成人羞羞视频在线看网址 | 国产成人无码av一区二区 | 国产极品美女高潮抽搐免费网站 | 无码av波多野结衣久久 | 国产精品久久午夜夜伦鲁鲁 | 99久久精品无免国产免费 | 成人免费视频观看视频 | 亚州视频在线 | 成人精品一区二区三区视频播放 | 无码国产精品久久一区免费 | 99精品国产99久久久久久51 | 亚洲 美腿 欧美 偷拍 | 国产成人精品一区 | 成人免费看片又大又黄 | 美女裸体十八禁免费网站 | 久久久久久久久久久免费精品 | 深夜福利成人 | 无码国产69精品久久久久同性 | 亚洲欧美网址 | 成人性生生活性生交免费 | 国产一区二区精品在线 | 欧美日韩中文字幕在线视频 | 人妻人人澡人人添人人爽人人玩 | wwwsss在线观看 | 亚洲免费综合色在线视频 | 亚洲精品一线二线三线 | 亚洲成a∨人片在线观看不卡 | 国产精品久久久久aaaa | 香蕉视频网站在线观看 | 精品视频一区二区三区四区五区 | 国产在线综合视频 | 特黄特色大片bbbb | 夜色成人网| 天堂av2021 | 成年人网站免费观看 | 先锋影音资源2中文字幕 | 欧美综合自拍亚洲综合图 | 少妇特黄a一区二区三区 | 乱lun合集小可的奶水 | 欧美国产在线观看 | 欧美xxxx视频 | 早起邻居人妻奶罩太松av | 在线观看欧美 | 尤物视频网站在线观看 | 中日韩美中文字幕av一区 | 综合影院 | 国产色视频一区二区三区 | 欧美做爰性生交视频 | 国产视频手机在线观看 | 中文字幕色 | 一级黄色性感片 | 刘亦菲毛片一区二区三区 | 黄色91免费 | 久久久网站 | 国产不卡视频一区二区三区 | 狠狠色香婷婷久久亚洲精品 | 国精产品一区二区三区有限公司 | 欧美韩国日本 | 国偷自产av一区二区三区 | 国产尤物精品视频 | 日本一区二区久久 | 免费a级毛片出奶水 | 亚洲黄色小视频 | 一级黄色大片免费观看 | 国产精品捆绑调教网站 | 亚洲 欧美 变态 另类 制服 | 亚洲免费一区二区 | 一级片久久久 | 久久亚洲美女 | 国产91视频在线 | 特黄特色大片免费播放器下 | 女同理伦片在线观看禁男之园 | 欧美日韩精品久久久 | 亚洲欧美日韩精品久久 | 国产精品国产三级国产专播 | 亚洲精品视频在线观看免费视频 | 青青草免费观看视频 | 精品精品国产毛片在线看 | 欧美亚洲在线视频 | 国产91精清纯白嫩高中在线观看 | 国产午夜精品一区二区三 | 久久精品人成免费 | 亚洲一区av| 欧美大片免费 | 免费高清毛片 | 日本电车痴汉 | 一本色道久久88亚洲精品综合 | 97人人视频 | 特黄aaaaaaa片免费视频 | 夜夜嗨av一区二区三区中文字幕 | 色哟哟一区二区 | 欧美在线一区视频 | 日本三级小视频 | 日韩精品在线播放 | 亚洲最大色大成人av | 超碰97在线免费 | 午夜激情影院在线观看 | av国产传媒精品免费 | 无码午夜福利片 | 亚洲精品久久久口爆吞精 | 澳门黄色录像 | 国产九色| 国产精品ai换脸张天爱 | www.嫩草蜜桃| 久久精品99国产精品酒店日本 | 在线观看免费的av | 91精品毛片一区二区三区 | 日韩精品久 | 欧美精品国产动漫 | 男人天堂影院 | 国模一区二区 | 国产愉拍精品手机 | 欧美精品久久久久久 | 亚洲国产成人va在线观看天堂 | 国产乱子伦视频一区二区三区 | 三级中文字幕 | 亚洲青草视频 | 午夜婷婷色 | av一区免费| 韩国一级淫一片免费放 | 六十路熟妇乱子伦 | 干美女少妇 | 韩日午夜在线资源一区二区 | 久久久久免费视频 | 无码av一区二区三区无码 | 亚洲成色| 久久网站热最新地址 | 亚洲日本欧美在线 | 人与拘一级a毛片 | 麻豆传媒av在线播放 | 舌吻激情大尺度做爰视频 | 亚洲成a人v欧美综合天堂麻豆 | 中文字幕一区二区精品 | 国产欧美精品国产国产专区 | 91久久人人夜色一区二区 | 国产午夜伦鲁鲁 | 国产99在线 | 中文 | 中文字幕一区二区三区在线播放 | 午夜免费国产体验区免费的 | 欧美日韩免费在线观看 | 麻豆成人久久精品二区三区免费 | 国产成人一区二区三区视频 | 欧美精品一区二区三区四区 | 国产精品久久九九 | 国产91在线播放九色000 | 国产美女亚洲精品久久久毛片小说 | 久久婷婷五月综合色国产 | 国产福利在线观看视频 | 一曲二曲三曲在线观看中文字幕动漫 | av在线不卡观看 | 亚洲精品久久久久午夜福禁果tⅴ | 日韩精品久久久久久久电影蜜臀 | 久久久久久国产精品久久 | 亚洲综合黄色 | 午夜两性视频 | 成人一级在线 | 中文字幕在线观看网站 | 91精品老司机久久一区啪 | 在线观看91 | 九九久久精品无码专区 | 在线资源av | 大陆少妇xxxx做受 | 亚洲欧美色图在线 | 国产jizzz |