1. 程式人生 > >【TP5.1】單元測試

【TP5.1】單元測試

author:咔咔

wechat:fangkangfk

建立test模組

並寫index控制器

原始碼:

<?php
namespace app\test\controller;

use think\Controller;
use Request;

class Index extends Controller
{
    public function index(Request $request)
    {
        return view();
    }

    public function execute(Request $request)
    {
        $arr = $request::param();// 注意這裡
        $namespace  = $arr['namespace'];
        $className  = $arr['className'];
        $action     = $arr['action'];
        $param      = $arr['param'];

        // 判斷 名稱空間寫全了  類名稱空間完善
        $class = ($className == "") ? $namespace : $namespace.'\\'.$className;

        //             要提換的值  需要的結果
        $class = str_replace("/", "\\", $class);
        // 建立需要測試的類
        $service = new $class();
        // 引數的解析
        $param = ($param == "") ? [] : explode('|', $param) ;
        // 執行測試類方法
        $data = call_user_func_array([$service, $action], $param);
        // 輸出
        return (is_array($data)) ? json_encode($data) : var_dump($data);
    }
}

 前端程式碼:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <script type="text/javascript" src="__ADMIN__static/js/jquery.js"></script>
    <title>Document</title>
  </head>

  <body>
      <h1>不區分大小寫</h1>
      <br>
      名稱空間:<input type="text" value='' style="width:300px" id='namespace' placeholder="如:app\index\controller 或app\index\controller\Index">可以寫全,然後下面類名不用些<br>
      類名:<input type="text" id='className' placeholder="如:index ">名稱空間全可以不用寫<br>
      測試方法名:<input type="text" id='action' placeholder="index"><br>
      傳遞引數以 | 分割:<input type="text" placeholder="如: 1|2|3" id='param'><br>
      <br>
      <input type="button" name="" value="測試" onclick="test()">
  </body>
  <script type="text/javascript">
    console.log(`{:URL('test/index/execute')}`);
      function test() {
          var namespace = $("#namespace").val();
          var className = $("#className").val();
          var action  = $("#action").val();
          var param   = $("#param").val();
          window.location.href = `{:url('test/index/execute')}?namespace=${namespace}&className=${className}&action=${action}&param=${param}`;
      }
  </script>
</html>

頁面很是不漂亮,將就用,後邊有時間了在寫樣式

我們就測試上一篇文章的模型關聯預載入