easyswoole - 基于swoole扩展实现的一款高性能php框架

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.zbjtqy.com/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.zbjtqy.com/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();
    }
}
主站蜘蛛池模板: 伸缩接头,限位伸缩接头,传力接头,可拆卸接头,橡胶接头,衬四氟橡胶接头,橡胶软连接,橡胶补偿器,防水套管- 巩义市隆盛管道设备有限公司 | 中国江苏国际经济技术合作集团有限公司-致力于做大做强国际工程、国内工程、国际贸易和城镇投资 中国建材信息总网-中国建材行业权威的信息资讯平台 | 石英砂|无烟煤滤料|火山岩|聚合硫酸铁|活性炭-河南碧水清源水处理材料有限公司 | 陕西筱润智能科技有限公司 干部人事智能档案柜 智能密集架 智能档案柜 部队选层文件智能柜 智能枪弹柜 财务智能档案柜 边防武警智能密集架 医院智能档案柜 部队选层文件智能柜智能枪弹柜 学校医院文件柜 企事业单位公检法智能文件柜 生产厂家-筱润智能科技有限公司 RFID射频智能密集架 全自动智能选层档案柜 智能密保柜 枪柜部队营房营具床桌椅办公家具 办公用品档案盒设备货架 全自动智能选层柜生产厂家-筱润智能科技有限公司 | 兰州沙盘模型公司_兰州模型公司_兰州沙盘模型厂家_地形沙盘制作_兰州沙盘模型制作公司 | 喷涂机器人|自动喷涂生产线|自动喷涂设备|自动化生产线-深圳市荣德机器人科技有限公司 | 无锡今飞激光技术有限公司-手持激光焊接机_激光打标机_激光清洗机_平台激光焊接机_焊接专机- | 消防施工,消防工程施工,消防施工改造-北京消防工程公司-亿杰(北京)消防工程有限公司 | 气动法兰软密封蝶阀-电动高温通风蝶阀-气动开关球阀-川沪阀门 | 在线红外水分测控仪-SK-100水分测试仪-上海拓西电子科技有限公司 | 湖北江南专用特种汽车有限公司官方网站 | 沈阳东鹰实业有限公司【官网】-聚氨酯清扫器-胶带输送机保护装置 | 拉布机_全自动拉布机_全自动拉布机厂家-江苏拉布机械科技有限公司 | 山东临沂春鑫新能源科技有限公司|官网|生物质颗粒锅炉|燃气锅炉|水源热泵 | 厦门海为科技有限公司 - 工业物联网|国产PLC|HMI|SCADA | 扭力扳手_扭力扳手检定仪_数显扭力扳手_扭力测试仪_测力计_推拉力计_拉力测试仪_测试台架-上海实干实业有限公司 | 绿化工程-绿化养护-园林设计-东莞市泉桦园林绿化有限公司 | 助乐邦轮椅,北京轮椅置换,电动轮椅置换,轮椅回收北京,轮椅送货上门服务 | 武汉凯美隆窗帘厂家_定做商用窗帘_家用遮阳帘_涵盖电动窗帘_天棚帘_遮阳棚_凯美隆-专注遮阳产品 武汉净化机-武汉全热新风换气机-武汉静音送风机-武汉东信新风节能设备有限公司 | 上海栋彤物流有限公司-可信赖的物流服务提供商 | 天津市力豹润滑科技有限公司 | 洁净室、手术室、实验室、无尘车间厂房的净化工程装修设计施工公司-福临建设 | 永磁耦合_重载永磁软起_能量回馈式调速器_磁力耦合器_江苏磁谷科技股份有限公司官方网站 | 上饶环亚电脑会计培训学校--电脑学校|上饶电脑学校|上饶电脑培训|会计培训|上饶会计培训|上饶县会计培训|广丰会计培训|玉山会计培训|横峰会计培训|上饶网店培训 上进电缆(嘉兴)股份有限公司官网 - 光伏电缆|防火电缆|电力电缆|铝合金电缆专业生产厂家 | 西安测试仪-西安电压测试仪-西安电流测试仪-西安热油汽水测试仪-西安阻抗测试仪-西安时间速度测试仪-西安电力设备厂家-西安中洲电力设备有限公司 | 山东中煤建设工程有限公司| 上海海外置业展_2024海外置业移民留学展_4月5-7日_企业参展处/免费领门票 | 泊头市特种油泵阀制造有限公司&nbsp;-&nbsp;渣油泵,重油泵,沥青泵,高压齿轮泵,煤焦油泵,导热油泵,三螺杆泵,圆弧齿轮泵,不锈钢齿轮泵, | 热电偶_电磁流量计_温度传感器_涡轮流量计_铠装PT100_压力变送器-中瑞能 | 系统门窗加盟_门窗十大品牌_欧享门窗官网 | 气动球阀,电动蝶阀,调节阀,衬氟阀门,水利控制阀,大口径阀门生产厂家-上海百钢阀门集团有限公司-官网,上海阀门品牌 | 每天一篇励志文章,每晚一个励志故事—励志人生网 | 托盘缠绕机|全自动缠绕机|悬臂缠绕机-上海晏陵智能设备有限公司 托辊|滚筒|聚氨酯托辊|缓冲托辊|尼龙托琨|衡水良龙输送机械有限公司 | 合肥食品检测-安徽卫生检测-水质检测机构-安徽金标准检测研究院有限公司 | 生物质蒸发器_燃气蒸发器_燃气锅炉价格|厂家直销-山东泰锅锅炉设备有限公司 | 华药药业集团|华药修医师|修医师浸膏|河南华药药业有限公司 | 热水工程|空气能热水工程|超低温采暖工程|太阳能热水工程|空气源热泵厂家|炬邦热能设备有限公司 热熔钻孔机【优质厂家】_多年热熔钻设备研发制造经验 | 瑞安网站建设_网站制作_做网站找瑞安联创网络:专业网页制作、手机网站、SEO百度网站关键字优化 软文营销推广-新闻稿发布-软文撰写-百科词条编辑-品牌全案策划推广网络营销传播-喜尚传媒 | 上海家博会_2025上海家博会时间表_5月31-6月2日_上海家博会门票_免费领取入口 | 久久黄色一级视频_视频一区精品自拍_理论片免费ā片在线观看_亚洲色视频在线播放网站_香港经典a毛片免费观看_亚州三级久久电影 | 永光机械-小型建筑机械领航者,公司专注于小型建筑、工程机械的研发与制造 |