laravel单元测试

laravel单元测试

  • 单元测试目录: 项目更目录下的 tests 目录

  • 目录说明

    1. Feature : 功能测试 (测试整个接口)
    2. Unit: 单元测试 (函数级别的测试)
  • 实例流程

    1. Feature 下新建 AuthTest

    2. 新建一个测试函数, 必须已 test 开头

      <?php
      
      namespace Tests\Feature;
      
      use Tests\TestCase;
      
      class AuthTest extends TestCase
      {		
          // 测试函数必须要以 'test' 开头,后面接有意义的函数名
          public function testRegister()
          {
              // 请求接口
              $response = $this->post('wx/auth/register');
      
              // 响应内容
              echo $response->getContent();
          }
      }
      
    3. 运行, 在 phpstorm 中点击函数前面运行按钮。

    4. 点击 解释器, 我本地是 docker 中的环境, 这里选择 docker,选择 镜像PHP路径which php 查看)(TODO 我的环境是 docker隐射到本地,这里必须用本地的php环境才可以调试!

    5. 修改 根目录下的 phpunit.xml

      <server name="DB_CONNECTION" value="mysql"/>
      <server name="DB_DATABASE" value="litemall_test"/>  # litemall_test 数据库名
      
    6. 2个示例

      <?php
      
      namespace Tests\Feature;
      
      use Illuminate\Foundation\Testing\DatabaseTransactions;
      use Tests\TestCase;
      
      class UserTest extends TestCase
      {
          // 为了防止脏数据,不会真的写入数据
          use DatabaseTransactions;
      
          public function testRegister()
          {
              $response = $this->post('/wx/auth/register', [
                  'username' => 'test02',
                  'password' => '123456',
                  'mobile' => '18811112222',
                  'code' => '123'
              ]);
      
              // 断言
              $response->assertStatus(200);
      
              // 拿到原始值
              $ret = $response->getOriginalContent();
      
              // 断言对比
              $this->assertEquals(0, $ret['errno']);
      
              // 断言对比,不为空
              $this->assertNotEmpty($ret['data']);
          }
      
          /**
           * 异常的情况
           */
          public function testRegisterMobile()
          {
              $response = $this->post('/wx/auth/register', [
                  'username' => 'test02',
                  'password' => '123456',
                  'mobile' => '188111122212',
                  'code' => '123'
              ]);
      
              // 断言
              $response->assertStatus(200); 
      
              // 拿到原始值
              $ret = $response->getOriginalContent();
      
              // 断言对比
              $this->assertEquals(707, $ret['errno']);
          }
      
      
      }
      
    7. 如上解析

      • use DatabaseTransactions; 加了之后,所有数据库的事务都不会添加到数据库中。有效防止脏数据。

      • assertEquals, assertNotEmpty 都是断言,用户判断得到的结果的判断。

      • 如果没有断言,需要加一个备注。则不会报错。

        /**
          * @doesNotPerformAssertions
          */
        
  • 用命令创建单元测试

    php artisan make:test AuthTest --unit (加上 --unit 是单元测试放在 Unit 文件夹下,不加是功能测试,放在 Feature 文件夹下。)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Laravel 中,工厂模式主要用于生成测试数据。它可以帮助我们在测试环境下快速生成模型实例,从而方便我们进行单元测试和功能测试。 Laravel 的工厂模式包含两个主要的组件:工厂和蓝图。工厂是生成模型实例的类,而蓝图则定义了模型实例所需的属性。 下面是一个示例: ```php // 定义一个 User 工厂 use App\User; $factory->define(User::class, function (Faker\Generator $faker) { return [ 'name' => $faker->name, 'email' => $faker->safeEmail, 'password' => bcrypt(str_random(10)), 'remember_token' => str_random(10), ]; }); ``` 上述代码中,我们定义了一个 User 工厂,并使用 Faker 库生成了随机的用户名、邮箱、密码和记住登录状态的 token。 接下来,我们可以使用这个工厂在测试中生成 User 模型的实例: ```php $user = factory(User::class)->create(); ``` 上述代码将生成一个随机的 User 模型实例,并将其保存到数据库中。 除了生成单个模型实例外,工厂还可以生成多个模型实例: ```php $users = factory(User::class, 3)->create(); ``` 上述代码将生成三个随机的 User 模型实例,并将它们保存到数据库中。 在使用工厂模式时,我们还可以通过修改蓝图来更改模型实例的属性: ```php $user = factory(User::class)->make([ 'name' => 'John Doe', ]); ``` 上述代码将生成一个用户名为 "John Doe" 的 User 模型实例。 总之,Laravel 的工厂模式非常强大和灵活,可以帮助我们轻松地生成测试数据并进行测试。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值