首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Laravel phpunit多个数据库测试未运行

Laravel是一种流行的PHP开发框架,它提供了一套简洁优雅的语法和丰富的功能,用于快速构建高质量的Web应用程序。PHPUnit是Laravel框架中用于进行单元测试的工具。

在Laravel中,我们可以使用PHPUnit来编写和运行单元测试。对于多个数据库的测试,我们可以通过配置不同的数据库连接来实现。

首先,我们需要在Laravel的配置文件中定义多个数据库连接。可以在config/database.php文件中的connections数组中添加多个数据库连接的配置,例如:

代码语言:txt
复制
'connections' => [
    'mysql' => [
        'driver' => 'mysql',
        'host' => env('DB_HOST', '127.0.0.1'),
        'port' => env('DB_PORT', '3306'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'forge'),
        'password' => env('DB_PASSWORD', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'strict' => true,
        'engine' => null,
    ],
    'second_db' => [
        'driver' => 'mysql',
        'host' => env('SECOND_DB_HOST', '127.0.0.1'),
        'port' => env('SECOND_DB_PORT', '3306'),
        'database' => env('SECOND_DB_DATABASE', 'forge'),
        'username' => env('SECOND_DB_USERNAME', 'forge'),
        'password' => env('SECOND_DB_PASSWORD', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'strict' => true,
        'engine' => null,
    ],
],

在上述配置中,我们定义了两个数据库连接,一个是默认的mysql连接,另一个是名为second_db的连接。

接下来,我们可以在测试类中使用这些数据库连接。可以通过在测试类的setUp方法中设置连接属性来指定使用的数据库连接,例如:

代码语言:txt
复制
use Illuminate\Foundation\Testing\DatabaseTransactions;

class ExampleTest extends TestCase
{
    use DatabaseTransactions;

    protected function setUp(): void
    {
        parent::setUp();

        // 使用默认的mysql连接
        $this->app['config']->set('database.default', 'mysql');
    }

    public function testExample()
    {
        // 测试代码
    }

    public function testSecondDatabase()
    {
        // 使用second_db连接进行测试
        $this->app['config']->set('database.default', 'second_db');

        // 测试代码
    }
}

在上述示例中,我们使用了Laravel框架提供的DatabaseTransactions trait来确保每个测试方法在运行之前都会启动一个数据库事务,并在测试结束后回滚事务,以保持数据库的干净状态。

通过设置$this->app['config']->set('database.default', 'second_db'),我们可以在testSecondDatabase方法中切换到使用second_db连接进行测试。

这样,我们就可以在Laravel中编写和运行多个数据库的测试了。

关于Laravel的更多信息和PHPUnit的使用,请参考以下链接:

  • Laravel官方网站:https://laravel.com/
  • PHPUnit官方文档:https://phpunit.de/documentation.html
  • Laravel PHPUnit文档:https://laravel.com/docs/8.x/testing
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

laravelphpunit单元测试

1,什么是单元测试PHPUnit 是一个用PHP编程语言开发的开源软件,是一个单元测试框架。...D:\WWW\laravel\项目\vendor\bin; 有如下显示说明配置成功: PHPUnit 5.7.27 by Sebastian Bergmann and contributors....Runtime: PHP 7.0.12 with Xdebug 2.4.1 Configuration: D:\WWW\laravel\项目名称\phpunit.xml 执行命令 phpunit...成功时输出 F 运行过程中一个断言失败时输出 E 运行过程中产生一个错误时输出 R 被标记为有风险时输出 S 被跳过时输出 I 被标记为不完整或实现时输出 w 运行过程中产生一个警告 4,常用的PHPunit...5,phpstorm 配置,运行 phpunit 1,检查php版本 2,setting里设置自动加载组件文件路径 3,在要测试的单元中,如图操作 4,创建测试单元 5,会在tests下生成一个测试

1.7K20

laravel单元测试phpUnit中old()函数报错解决

前言 最近在做laravel单元测试.遇到了一个问题: 当添加的view里面使用old()函数时就会报错,正常url访问没问题,但是在phpUnit中就报错 错误原因: exception 'RuntimeException...' with message 'Session store not set on request.' in /Users/lei/Sites/goodstyle/vendor/laravel/framework.../src/Illuminate/Http/Request.php:870 很明显这是一个跑出session没有开启的原因,但是phpUnitlaravel自己配置环境的,很是纠结,于是查看源代码 解决过程...开启session(app/Http/kerner) 很明显我已经开启了session,但是我又找到了我单元测试的代码发现我开启了这段代码 忽略中间件的限制 因为这段代码导致我session无法开启,...聪明反被聪明误,本来想用这个方法不想写中间件的东西然后却被自己给套进去了,然后去了这段代码,重写了逻辑,运行正常了.

48810

玩玩PHPUnit数据库测试 (上)

的程序员都感觉没有啥用的数据库测试。...啥是数据库测试? 很多人可能玩过单元测试,设定呀,断言呀,等等条件。...但单元测试具有局限性,现如今大部分代码与数据库耦合度较高,无法独立进行单元测试,例如要做了登录模块,大概逻辑如下 那可以用单元测试的地方有哪些呢? 1....这时候就需要做数据库测试了,数据库测试实际很简单,大概的流程如下 我们不看官方文档的例子,因为那对新人来说很多名词难于理解,如果你准备好了,那接下来,让我们通过实操来初试数据库测试吧!...准备测试数据 在准备数据前,来看看PHPUnit为我们准备的几种测试数据文件的格式。 Flat XML DataSet (平直 XML 数据集) <?xml version="1.0" ?

45540

基于 PHPStorm 编辑器的 Laravel 开发

对Blade模板引擎的支持 使用PHPStorm调试Laravel程序 使用PHPStorm调试Laravel程序 使用PHPStorm的单元测试功能 使用PHPStorm的数据库功能 1、一些准备工作...4、使用PHPUnit单元测试Laravel程序 首先需要在本地安装下PHPUnit: wget https://phar.phpunit.de/phpunit.phar chmod +x phpunit.phar...Configuration file指向本地的phpunit.xml.dist文件,该文件是用来配置phpunit测试套件的,可以看官网中文版的:用 XML 配置来编排测试套件,比如本人这里的套件配置...> 在写好PHPUnit测试后,可以在终端执行phpunit命令就行,或者单独执行某个测试类,可以在测试类里右键选择Run xxxTest.php就行,如: ?...写测试还是很有必要的,而且是必须的。PHPUnit测试,以后还会详聊。

3.6K80

Laravel 6.10 版本发布,支持 PHPUnit 9,为 PHP 8 留下后手

第一部分:重要新特性介绍 下面,我们一起来看下几个重要的新特性: Laravel Mix 测试辅助函数 在新版本中,可以通过 withoutMix() 和 withMix() 测试辅助函数启用或禁用异常处理...支持 PHPUnit 9 从 v6.10 开始,Laravel 开始支持 PHPUnit 9,可以通过完整的 pull request 查看实现细节:https://github.com/laravel...至于为什么要引入 PHPUnit 9,主要原因是 PHP 8.0、8.1、8.2 或者 8.3 中将很有可能不再支持 PHPUnit 8,而 Laravel 6 是 LTS 版本,我们希望它可以支持最新版本的...PHP,所以需要能够运行最新版本的 PHPUnit。...第二部分:更新日志速览 新增特性 新增 withoutMix() 和 withMix() 测试辅助函数 新增 validateWithBag() 宏方法到 Request 类 新增对 PHPUnit 9

2.5K30

创建并运行一个新的 Laravel 项目

应用的一些核心配置,比如数据库、队列、邮件等,都位于 config 目录下,通过配置文件名称就可以很直观地甄别出不同的服务配置。...4、运行 安装好 Laravel 项目,了解了目录结构及其作用,以及如何对项目进行配置后,我们就可以运行这个应用了,启动方式因开发环境而异,我们在前面的 Homestead、Laradock、Valet...5、测试 Laravel 开箱提供了基于 PHPUnit 进行单元测试和功能测试的功能,并且为我们做好了基础配置(phpunit.xml)和示例代码(位于 tests 目录下),由于本节并没有编写任何代码...,所以可以通过以下命令运行示例测试: ..../vendor/bin/phpunit 测试结果通过: ? 注:我们后续教程将以这篇教程创建的 blog 项目为基础,且访问域名为 http://blog.test,后面不再重复声明这一点。

6.7K30

Laravel学习笔记(一)——初次见面,多多关照!

所有默认配置项; Database目录 database 目录包含了数据库迁移文件及填充文件,如果有使用 SQLite 的话,你还可以将其作为 SQLite 数据库存放目录; Public目录 public...Tests目录 tests 目录包含自动化测试文件,其中默认已经提供了一个开箱即用的PHPUnit 示例;每一个测试类都要以 Test 开头,你可以通过 phpunit 或 php vendor/bin.../phpunit 命令来运行测试。...artisan文件 artisan是Lavarel开发的利器,几行命令轻松搞定网站上线、下线、维护、测试数据库测试、代码测试等大部分便于开发的工作。以后我们在开发过程中会经常和他打交道!...同理,路由只需将”击中“路由规则的正常请求转发到对应的控制器,”击中“路由规则的请求拦截即可。其他的事情交给服务员(C)和厨师(M)做就行了。

2.2K00

laravel 之 Unit 单元测试

(比如在调用之前对数据库进行了相关操作)。造成脏数据。 由于以上原因,我们想寻找一个简单并且高效的方法去对我们的类/方法进行测试,但是又苦于框架的单一入口原则。不能直接去调用对应的类。...Unit: laravel 提供了非常优秀的测试基因: 默认情况,你的应用 tests 目录中包含两个子目录:Feature 和 Unit。对应功能测试和单元测试。...功能测试是针对大面积代码进行的测试,包括多个对象之间的交互,甚至是对 JSON 端点的完整 HTTP 请求。 单元测试是针对你的代码中非常少,而且相对独立的一部分代码来进行的测试(方法)。...$this->assertTrue(true); } } 然后我们在终端运行 phpunit命令。.../vender/bin/phpunit tests/Unit/UserTest.php 单个方法:phpunit --filter=a_test_function, 单个类:phpunit --class

1.3K10

Laravel框架下载,安装及路由操作图文详解

目录四:database 数据库操作相关文件(数据库迁移和数据填充) ? 目录五:public 前端控制器和资源相关文件(图片、JavaScript、CSS) ?...目录八:text 应用测试相关文件 ? 目录九:vendor Composer 依赖模块 ?...(数据库迁移和数据填充) node_modules 存放 NPM 依赖模块 package.json 应用所需的 NPM 包配置文件 phpunit.xml 测试工具 PHPUnit 的配置文件 public...前端控制器和资源相关文件(图片、JavaScript、CSS) readme.md 项目介绍说明文件 resources 应用资源 resources/assets 编译的应用资源文件(图片、JavaScript...mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》 希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

4.5K51

玩转 PhpStorm 系列(十二):单元测试

PHP 生态有很多测试框架,其中最流行的当属 PHPUnit,我们还是以 Laravel 项目为例,在 PhpStorm 中演示如何通过 PHPUnit 对 PHP 项目进行单元测试。...对指定目录、类、方法运行测试 Laravel 自带的测试演示类位于项目根目录下的 tests 子目录中。在 PhpStorm 中,该目录会被自动标记为绿色,表示是测试目录: ?...在 PhpStorm 中基于 PHPUnit 进行单元测试很简单,PhpStorm 已经内置了通过本地 PHPUnit 运行测试用例的支持(Laravel 项目初始化的时候已经安装了 phpunit 依赖...要对指定文件进行测试,还可以在打开该文件的代码编辑区域任意位置右键,选择运行该文件的测试代码: ? 或者在声明该测试类所在行的左侧点击绿色的运行测试图标进行测试: ?...PHPUnit 代码覆盖率分析 在上面运行测试用例的时候,细心的同学可能已经看到在下拉菜单中除了运行测试的选项外,还有一个包含覆盖率的测试选项: ?

2.4K30

【PHP 随记】—— laravel 目录结构分析

bootstrap |-- cache |-- app.php (3) \textbf{config 目录} :项目的配置目录,主要存放配置文件,比如项目总体配置、数据库的配置等。...; filesystems.php:文件系统(如文件存储等)的配置文件; (4) \textbf{database 目录} :包含数据填充和迁移文件以及模型工厂类,还可以把它作为 SQLite 数据库存放目录...lang:存储语言包的目录; views:视图文件存储目录; (7) \textbf{routes 目录} :包含了应用的所有路由定义,Laravel 默认包含了几个路由文件:web.php、api.php...,其中默认已经提供了一个开箱即用的 PHPUnit 示例;每一个测试类都要以 Test 开头,可以通过 phpunit 或 php vendor/bin/phpunit 命令来运行测试。...(10) \textbf{vendor 目录} :主要是存放第三方的类库文件;laravel 思想主要是共同的开发,不要重复的造轮子(例如,里面可能存在验证码类,上传类,邮件类),该目录还存放 laravel

3.3K10

在 Slim 中伪造Request来进行你的HTTP测试

代码需要做HTTP测试Laravel中有自带这方面的功能。现在使用slim就得自己动手丰衣足食。 网上找了许多例子,关于这方便的比较少。...然后就想到了查看Laravel的源码 看了一下,发现其实是自己伪造一个Request对象,然后执行返回结果 然后自己也参考这个在slim中实现 构建好测试文件 composer.json加入以下内容自动加载...payload); return $response ->withHeader('Content-Type', 'application/json'); }); // 这里不要运行...app->run(); // 并且声明一个函数得到 App 对象 function getApplication() { global $app; return $app; } 创建测试文件...得到测试结果 $ phpunit PHPUnit 7.5.17 by Sebastian Bergmann and contributors. ..

13510
领券