五月天激情丁香,国产精品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://www.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://www.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();
    }
}
主站蜘蛛池模板: 久久综合伊人中文字幕 | 关秀媚三级| 人妻av无码一区二区三区 | 成人影片麻豆国产影片免费观看 | 成人日b视频 | 手机看片国产一区 | 成–人–黄–色–网–站 | 欧美不卡在线观看 | 国产69精品久久99的软件特点 | 日韩一卡2卡3卡4卡新区亚洲 | 99在线观看精品 | 亚洲一二三区av | 免费看片成人 | 中文毛片无遮挡高潮免费 | 国产老妇av | 高清乱码免费看污 | 乌克兰少妇videos高潮 | 久久亚洲色www成人欧美 | 韩日视频在线 | www日本tv| 欧美色就是色 | 2023天天操 | 黄色aaa视频 | 日本妇人成熟免费 | 国产精品免费视频网站 | 和三个男人4p爽爆了 | 国产精品jk白丝av网站 | 久久不见久久见免费影院视频 | 免费av中文字幕 | 亚洲处破女av日韩精品 | 成年人免费视频网站 | 三a大片| 亚洲精品亚洲人成在线 | 欧美天天性影院 | 狠狠久 | 涩涩涩涩涩涩涩涩涩涩 | 亚洲九九九九 | 国产精品乱子伦免费视频 | 亚洲春色在线 | 天海翼一区二区三区免费 | 成人免费视频毛片 | 国产一区视频网站 | 巨乳女教师佐山爱,夫前在线 | 欧美成人自拍视频 | 又大又长粗又爽又黄少妇毛片 | 亚洲精品中文字幕制 | 欧美精品久久久久久久久久丰满 | 久久亚洲精品中文字幕冲田杏梨 | 一级生性活片免费视频片 | 国产精自产拍久久久久久蜜 | 永久免费看啪啪的网站 | 国产精品3 | 久久久青草婷婷精品综合日韩 | 强行从后面挺进人妻 | 国产精品新婚之夜泄露女同 | 日本三级韩国三级美三级91 | 国产色xx群视频射精 | 性色免费视频 | 99久久婷婷国产综合亚洲 | 天天躁狠狠躁狠狠躁性色牛牛影视 | 俺来俺也去www色在线观看 | 国产乱色国产精品播放视频 | 欧美肥妇毛多水多bbxx | 高清国产mv在线观看 | 国产白丝袜喷白浆毛片av | 亚洲国产人午在线一二区 | 又大又粗又爽免费视频a片 日本丰满熟妇videossex8k | 国产99久久久国产精品免费看 | 成人一级网站 | 成人性午夜免费网站蜜蜂 | 精品国产一区二区三区四区四 | 亚洲黄色视屏 | 国产极品探花一区二区三区 | 成人久久精品 | 99精品久久精品一区二区 | www国产亚洲| 欧美日韩精品一区二区 | a在线播放| 欧美大片aaa | 开心五月色婷婷综合开心网 | 一二三国产777avav | 亚洲欧美国产毛片在线 | 久久综合激的五月天 | а天堂中文最新一区二区三区 | 欧美日韩中 | 国产精品污www在线观看 | 国产福利精品在线 | 99爱免费视频 | 天堂久久一区二区 | 日韩欧美中文字幕公布 | 国产精品奇米一区二区三区小说 | 91久久国产最好的精华液 | 97视频网址 | 精品国产一区二区三区四区在线看 | 亚洲乱码日产精品bd在线看 | 国产明星精品一区二区刘亦菲 | 亚洲中文无码永久免 | 午夜免费福利影院 | 殴美一级片 | 男女啪啪免费观看网站 | 综合av第一页 | 亚洲一区二区三区丝袜 | 91在线播放视频 | 天堂网一区二区 | 久久国产精品久久久久久 | 欧美性在线观看 | 精品国产一区二区三区久久影院 | 国产欧美在线播放 | 国内精品久久久久久久影视红豆 | 日韩a级大片 | 国产性精品 | 观看av| 欧美老熟妇videos极品另类 | 91精品众筹嫩模在线私拍 | 精品国产成人一区二区 | 五月婷婷激情网 | 天天av天天翘 | 久久久久日本精品一区二区三区 | 少妇性l交大片 | 按摩69xxx| 青青国产在线视频 | 国产漂亮白嫩美女在线观看 | 亚洲专区在线 | 98国产精品| 免费看av的网址 | 黑人性xxx | 日本少妇高潮叫床声一区二 | av久操| 亚洲人成电影在线播放 | 91九色精品女同系列 | 91亚洲网站 | 亚洲精品一品区二品区三品区 | 日本欧美大码aⅴ在线播放 中文人妻无码一区二区三区在线 | 日韩毛片在线视频x | 奶大交一乱一乱一视一频 | 中文字幕在线视频播放 | 麻豆一区二区在我观看 | 久热欧美 | 最近中文在线观看 | av网站久久 | 欧美老人巨大xxxx做受 | 国产欧美视频一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 国产裸体无遮挡免费视频 | 亚洲视频在线看 | 深爱五月网 | 青青操在线视频 | 一级片中文 | 国产乱码精品一区二区三区爽爽爽 | 一本色道久久综合亚洲精品 | 初尝情欲h名器av | 国产精品毛片a∨一区二区三区 | 少妇性l交大片 | 韩国伦理中文字幕 | 99国产超薄肉色丝袜交足 | 色视频网站在线 | 欧美黄网站在线观看 | 成人欧美视频 | 88av视频 | 强开小受嫩苞第一次免费视频 | 蜜臀91丨九色丨蝌蚪中文 | 97精品人妻一区二区三区香蕉 | 国产在线不卡精品网站 | 农村寡妇一区二区三区 | 久久精品无码一区二区三区免费 | 亚洲v在线 | 丁香婷婷久久久综合精品国产 | 亚洲xxxx做受欧美 | 免费一区视频 | 精品人妻系列无码专区 | 在线观看三级网站 | 国产午夜精品一区二区三区 | 91在线免费视频观看 | 亚洲免费成人 | 国产乱论视频 | 99热这里只有精品首页 | 亚洲欧美日韩精品成人 | 免费特级黄毛片 | 亚洲欧美国产一区二区三区 | 成人在线观看黄色 | 日日爽视频 | 青青草狠狠操 | 国产精品女人精品久久久天天 | 亚洲最大综合网 | 亚洲精品国产欧美 | 欧美 国产 亚洲 卡通 综合 | 爱情岛论坛亚洲品质有限公司18 | 丰满岳乱妇一区二区三区 | 天天噜日日噜狠狠噜免费 | 亚洲视频五区 | 天堂网www.| 国精产品一品二品国精在线观看 | 香蕉视频一区 | 日韩精品一区二区三区四区新区 | 精品国产一区二区三区四区精华 | 91偷拍一区二区三区精品 | 无码国产精品成人 | 亚洲精品免费在线观看视频 | 国产性猛交粗暴力xxxx | 亚洲国产欧美一区二区三区丁香婷 | 成人动漫综合网 | 久久9久久| 大伊香蕉在线精品视频75 | 一级特黄色片 | 久久综合狠狠 | 日本肉体bbbbbb肉交内谢 | 日本嫩草影院 | 91精品久久久久久久久不卡 | 韩国黄色av | 小sao货水好多真紧h国产 | 久久香蕉国产线看观看猫咪av | jzzijzzij日本成熟少妇 | 久精品在线| 亚洲国产真实交换 | 天天看片天天爽 | 久久久香蕉 | 亚洲第7页 | 韩国三级做爰楼梯在线 | 波多野结衣视频网址 | 国产亚洲一卡2卡3卡4卡网站 | 天天色综网 | jizzjizz免费 | yy1111111少妇影院免费 | 亚欧激情乱码久久久久久久久 | 国产区在线 | 四虎影视久久久免费 | 两个人看的www在线观看 | 午夜久久福利 | 影音先锋男人av橹橹色 | 免费观看激色视频网站 | 国产又粗又猛又爽又黄的视频9 | 欧美一区二区三区四区在线观看地址 | 日本免费福利视频 | 国产精品99久久久久久久久久 | 成人欧美一区二区三区的电影 | 亚洲成人精品 | 欧美色图一区二区 | 国产在线观看精品 | 天天躁日日躁狠狠躁av麻豆 | 日韩久久久久久久久久 | 丁香六月欧美 | 成人淫片免费视频95视频 | 波多野结衣日韩 | 黑人边吃奶边摸边做边爱 | 在线观看视频色 | 青青青草网站免费视频在线观看 | 亚洲视频黄 | 国产偷久久一级精品60部 | 全部免费的毛片在线看 | 天天爽夜夜爽国产精品视频 | 亚洲aⅴ无码专区在线观看春色 | 美女福利视频 | 日本大尺度吃奶做爰视频 | 亚洲女同一区二区 | 四只虎影院在线免费 | 国精产品一区一区三区 | 免费的a级毛片 | 高清日韩av| 日韩欧美麻豆 | 欧美激情自拍偷拍 | 国产精品少妇 | 久久国产精久久精产国 | 欧美日韩国产一区 | 久久ww| 羞羞视频在线观看免费观看 | 香蕉福利视频 | a天堂中文网 | 日本一本在线 | 3d动漫精品啪啪一区二区 | 特级黄色毛片在放 | 国精品人妻无码一区二区三区蜜柚 | 一区二区三区四区免费 | 成人黄色小视频 | 比色毛片 | 国产免费一区二区三区免费视频 | 日韩综合色 | 欧美成人欧美edvon | 亚洲精品沙发午睡系列 | 青娱乐精品视频 | 国产成人精品av在线观 | 夜鲁鲁鲁夜夜综合视频欧美 | 成人免费毛片aaaaaa片 | 在线黄网站 | 黑人狂躁曰本人aⅴ | 久久久国产精品一区 | 91精品国产一区二区在线观看 | 亚洲视频免费观看 | 久久国产尿小便嘘嘘97 | 无码欧精品亚洲日韩一区 | 久久久国产一区二区三区 | 91极品国产情侣高潮对白 | 欧美一级特黄aaaaaaa什 | 色综合天天综合网天天看片 | 日本肥老妇色xxxxx日本老妇 | 欧美三级午夜理伦三级老人 | 91九色porny首页最多播放 | 快色网站 | 久久精品无码一区二区无码 | 制服丝袜一区 | 欧美成人家庭影院 | 看全色黄大色大片60岁 | 国产周晓琳在线另类视频 | 奇米影视四色7777 | 国产精品视频不卡 | 国产偷窥熟女精品视频大全 | 亚洲天堂国产 | 夜色jjj.av| 国产在线精品一区二区高清不卡 | 亚洲精品入口a级 | 欧美性猛交xxx乱大交3 | 伊人www22综合色 | 国产猛男猛女超爽免费视频 | 乱女伦露脸对白在线播放 | 超碰人人人人人人 | 五月婷影院 | 欧美激情一区二区三区 | 精品国偷自产在线视频 | 日韩激情一区二区三区 | 久久77777| 青青草无码精品伊人久久 | 日本美女一区二区 | 亚洲国产精品入口 | 末发育娇小性色xxxx | 噜噜噜久久 | 激情网站在线 | 国产精品偷伦费观看一次 | 国产精品va在线播放 | 久久免费视频在线观看 | 日本一级淫片免费啪啪3 | 欧美日韩中文国产 | 夜色毛片永久免费 | 国产亚洲精品久久久网站好莱 | 无码乱肉视频免费大全合集 | 国产一区精品在线 | 日日色综合 | 日本阿v视频在线观看 | 污视频在线免费 | 极品粉嫩嫩模大尺度无码视频 | 欧美大胆a视频 | 开心五月激情综合婷婷 | 日韩中文字幕精品视频 | 亚洲专区区免费 | 国产成人精品久久亚洲高清不卡 | 天天躁日日躁狠狠躁av麻豆 | 国产一区二区不卡老阿姨 | 樱花草在线社区www 国产又爽又黄又刺激的视频 | 少妇高潮惨叫久久久久久 | 婷婷丁香狼人久久大香线蕉 | 国产精品久久久久久久久久久久久久久久久 | 天堂视频在线免费观看 | 国产成熟人妻换╳╳╳╳ | 精品福利视频一区二区 | 99久久久无码国产精品免费 | 综合色伊人 | 国产99久一区二区三区a片 | 欧美九九 | 欧美亚州国产 | 91精品国产99久久久久久红楼 | 粉嫩粉嫩一区二区三区在线播放 | 日本免费网站在线观看 | 香蕉视频亚洲 | 国产三级小视频 | 二区三区在线观看 | 秋霞自拍| 性开放的女人aaa片 久久视频在线观看精品 | 亚洲一级淫片 | 黄色a级片视频 | a√毛片 | 亚洲 国产 另类 精品 专区 | 欧美啊v | 已婚少妇露脸日出白浆 | 内射老阿姨1区2区3区4区 | 少妇无套内谢免费视频 | 老妇高潮潮喷到猛进猛出 | 国产毛片农村妇女系列bd | 亚洲欧美日韩中文字幕一区二区三区 | 青青青手机在线视频 | 成人黄色一级视频 | 国产乱肥老妇女精品视频网站 | 超碰人人干人人 | 亚洲精品综合一区二区 | 日韩精品中文字幕一区二区三区 | 免费一级黄色 | 草草影院在线观看视频 | av第下页| 精品少妇一区二区 | 国产精品久久久久久久久 | 欧美久久久久久久高潮 | 人妖欧美一区二区三区 | 欧美成人免费在线视频 | 日本www.小久久 | 黄 色 软件 成 人在线 | 精品乱 | 国产中文字幕网 | 国语做受对白xxxxx在线流氓 | 韩日毛片 | 能在线观看的av | 女娃videosex娇小 | 狠狠躁夜夜躁人人爽蜜桃 | 午夜精品欧美 | 一区二区欧美日韩 | 亚洲国产一区二区视频 | 日韩av免费播放 | www色午夜com| 久久视频精品 | 在线免费观看视频你懂的 | 免费全部高h视频 | 男女猛烈xx00免费视频试看 | 日日鲁鲁夜夜狼狼视频 | 精品一区二区免费 | 国产精品19乱码一区二区三区 | 日本韩国欧美一区二区三区 | 光棍影院一区二区 | 黄av在线免费观看 | 五月婷婷六月综合 | 日本少妇高潮喷水视频 | 亚洲中文字幕无码av永久 | 欧美人与性禽动交情品 | 三级av免费 | 成人三一级一片aaa 成人涩涩 | 抽搐一进一出aaaaa | 国产一区二区在线精品 | 国产精品后入内射日本在线观看 | 香蕉视频在线网址 | 99精品福利视频 | 尤物视频在线播放 | 好男人天堂网 | 俺来也俺来啦awww官网 | 国产人妻777人伦精品hd | 9·1·黄·色·视·频 | 国产又粗又硬又大爽黄老大爷视 | 亚洲va一区二区 | 欧美成人一区二区三区在线观看 | 丁香婷婷视频 | 18禁无遮挡羞羞污污污污免费 | 啪啪av大全导航福利网址 | 欧洲熟妇性色黄 | 老司机午夜影院 | 久久久国产精品入口麻豆 | 欧美爱爱免费视频 | 久久99精品久久久久久动态图 | 正在播放重口老熟女露脸 | 亚洲va久久久噜噜噜久久狠狠 | 国产乱码久久久久久 | 懂色av一区二区三区四区五区 | 日本美女久久 | 97日日夜夜| 日本三级一区二区三区 | 网色网站| 国语对白嫖老妇videos | 黄色三级国产 | 怡红院最新网址 | 1024精品一区二区三区日韩 | 欧美另类极品videosbest使用方法 | 美乳少妇与邻居尤物啪啪 | 99自拍偷拍| 操日本老妇 | 窝窝视频在线 | 影音先锋啪啪 | 亚洲综合视频网站 | 向日葵视频在线播放 | 可以直接免费观看的av网站 | 久久国色| 丝袜视频在线观看 | 欧美午夜精品一区二区蜜桃 | 亚洲精品综合网 | 爱丝aiss无内高清丝袜视频 | а√天堂资源中文在线官网九色 | 高潮毛片无遮挡高清视频播放 | 激情高潮呻吟抽搐喷水 | 久久久亚洲欧美 | 色www国产亚洲阿娇 色爱av综合 | 中文在线a天堂 | 在线黄色大片 | 欧美视频一区二区三区在线观看 | 国产黄色片在线免费观看 | 亚洲午夜网 | 久久精品入口九色 | 色人阁亚洲 | 喷水一区二区 | 亚洲天堂免费在线观看视频 | 91精品国产综合久久福利不卡 | 免费看日产一区二区三区 | 亚洲国产成人片在线观看无码 | 国产色视频一区二区三区 | 日本大片在线播放在线软件功能 | 久久综合av色老头免费观看 | 国产免费无码一区二区 | 日韩精品大片 | 影音先锋成人资源网 | 怡红院a∨人人爰人人爽 | bbbbbbbbb毛片大片按摩 | 四虎影视4hu4虎成人 | 久久久久久久艹 | 寡妇高潮一级视频免费看 | 亚洲人亚洲人成电影网站色 | 东热ca大乱合集 | 久久久久久久av | 亚洲成aⅴ人在线观看 | 国产午夜精品一区二区三区视频 | 亚洲无av | 在线三级网址 | 色综合久久88色综合天天免费 | 欧美美女破处 | 欧美精品国产动漫 | 久青草影院在线观看国产 | 毛片视频免费观看 | 欧美日韩精品中文字幕 | 日本肉体bbbbbb肉交内谢 | 人妻少妇久久中文字幕 | 亚洲社区在线观看 | 国语对白做受69 | 99久热在线精品视频观看 | 亚洲成a人片在线观看无码专区 | 成人wxx视频免费 | 91香蕉视频在线看 | 亚州精品天堂中文字幕 | 久久一视频 | 日韩精品第一页 | 日韩成人高清 | 中文字幕在线视频精品 | 中文字幕成人 | 黑人一级黄色片 | 免费欧美一级片 | 亚洲人视频 | 美女露胸无遮挡 | 2024av在线播放 | 2020自拍偷拍| 少妇高跟鞋做爰20p 少妇和黑人老外做爰av | 色噜噜综合 | 邻居少妇张开腿让我爽视频 | 林雅儿欧洲留学恋爱日记在线 | 岛国av网站| 五月花成人网 | 亚洲综合激情另类小说区 | 日韩夜夜操 | 91亚洲国产成人精品性色 | 午夜成人理论无码电影在线播放 | 成人在线观看视频网站 | 精品黑人一区二区三区久久 | 亚洲色图150p | 搡老女人一区二区三区视频tv | 自拍偷拍亚洲一区 | 日本在线 | 欧美亚洲国产精品久久蜜芽直播 | 高清无码视频直接看 | 天天狠天天干 | 国产一区精品视频 | 成人小视频在线观看免费 | 在线免费观看视频黄 | 亚洲一区色 | a级毛片黄免费观看 m | 伊人久久大香线蕉综合网站 | 国产a三级| 久久久久在线观看 | 丰满人妻一区二区三区无码av | а√中文在线资源库 | 欧美激情专区 | 欧美激情午夜 | 能看的黄色网址 | 一区二区三区国产在线 | 国产人妻aⅴ色偷 | 国产98色在线 | 国产 | 国产无套乱子伦精彩是白视频 | 免费黄色国产视频 | 三上悠亚在线精品二区 | 国产欧美一区二区精品性色 | www.五月.com| 午夜一二三 | 精品区一区二区三区 | 亚洲色www成人永久网址 | 先锋影音xfyy5566男人资源 | 涩视频在线观看 | 少妇性l交大片 | 成人影片麻豆国产影片免费观看 | 99精品久久99久久久久 | 亚洲精品乱码久久久久久动图 | 麻豆精品乱码一二三区别蜜臀在线 | 饥渴的熟妇张开腿呻吟视频 | 国产熟睡乱子伦午夜视频 | 中文人妻无码一区二区三区信息 | 国产午夜毛片 | 国产一级视频在线 | 一本色道久久88综合亚洲精品ⅰ | 国产自国产自愉自愉免费24区 | 日韩精品视频一区二区三区 | 成人性做爰aaa片免费看曹查理 | 亚洲狠狠丁香综合一区 | 色哟哟av| 国产粉嫩高中好第一次不戴 | 精品一区二区三区无码免费视频 | 国产欧美日韩成人 | 国产人妻丰满熟妇嗷嗷叫 | 欧美一本 | 永久免费观看国产裸体美女 | 欧洲lv尺码大精品久久久 | 国产色av| 欧美精品乱人伦久久久久久 | 三a级做爰 | 公妇乱淫视频 | 中文字字幕在线中文乱码 | 日本性插视频 | 久久中文精品无码中文字幕下载 | 亚洲高清乱码午夜电影网 | 波多野结衣视频一区二区 | 欧美日韩无 | 日本熟妇色一本在线视频 | 91久久久国产精品 | 中国农村少妇xxxx视频 | asiass极品裸体女pics | 97成人免费视频 | 777片理伦片在线观看 | 丰满岳乱妇在线观看中字无码 | 亚洲视频中文 | 天堂在线一区二区 |