laravel怎么在不同的测试环境中使用不同的数据库_laravel测试环境多数据库使用方法

通过环境变量配置文件分离实现Laravel多测试环境数据库隔离,使用.env.testing文件自动加载测试配置,为不同测试套件指定独立数据库,支持在测试类中动态切换连接,推荐内存SQLite提升速度与隔离性,并可在config/database.php中定义多个连接灵活调用,确保各环境数据互不干扰。

laravel怎么在不同的测试环境中使用不同的数据库_laravel测试环境多数据库使用方法

如果您在开发 Laravel 应用时需要针对不同的测试环境使用独立的数据库配置,可以通过环境变量和配置文件分离的方式来实现。这样可以确保每个测试环境操作的数据互不干扰。

本文运行环境:MacBook Pro,macOS Sonoma

一、使用 .env.testing 文件隔离测试环境配置

通过为测试环境创建专用的环境文件,可以完全独立地管理数据库连接信息。Laravel 在运行测试时会自动加载 .env.testing 文件(如果存在)。

1、在项目根目录下创建 .env.testing 文件。

2、在该文件中设置测试环境专用的数据库连接,例如:

DB_CONNECTION=sqlite

DB_DATABASE=:memory:

3、运行测试命令时,Laravel 会自动使用此配置:

php artisan test

二、为不同测试套件指定不同数据库

当需要运行功能测试和单元测试使用不同数据库时,可通过自定义环境文件或动态修改配置来实现隔离。

1、创建多个环境文件,如 .env.feature.env.unit

2、在启动测试前通过命令行指定环境:

cp .env.feature .env && php artisan config:clear && php artisan test –parallel

3、对另一套测试重复此过程,切换至另一个环境文件。

4、可在 phpunit.xml 中设置环境变量覆盖,例如:

三、在测试类中动态切换数据库连接

某些场景下需要在单个测试中临时切换数据库连接,Laravel 提供了运行时配置更改能力。

1、在测试方法开始前调用 config() 函数修改数据库配置:

config([‘database.default’ => ‘mysql_testing’]);

2、确保 config/database.php 中已定义对应的连接:

‘mysql_testing’ => [

‘driver’ => ‘mysql’,

‘host’ => env(‘TEST_DB_HOST’, ‘127.0.0.1’),

‘database’ => env(‘TEST_DB_DATABASE’, ‘laravel_test’),

… ]

3、后续的 Eloquent 查询将自动使用新连接。

四、使用内存 SQLite 进行快速测试

对于不需要持久化数据的测试场景,使用内存型 SQLite 可大幅提升执行速度并保证隔离性。

1、在 .env.testing 中设置数据库驱动为 sqlite,并使用内存模式:

DB_CONNECTION=sqlite

DB_DATABASE=:memory:

2、在测试类的 setUp() 方法中运行迁移:

Artisan::call(‘migrate’);

3、每次测试运行时都会重建全新的数据库结构,确保测试纯净。

五、通过配置文件区分多数据库连接

Laravel 支持在同一应用中定义多个数据库连接,可在不同测试中显式调用。

1、打开 config/database.php 文件,在 connections 数组中添加新的测试连接:

‘testing_mysql’ => [

‘driver’ => ‘mysql’,

‘url’ => env(‘DATABASE_URL’),

‘host’ => env(‘DB_HOST’, ‘127.0.0.1’),

‘port’ => env(‘DB_PORT’, ‘3306’),

‘database’ => env(‘TEST_MYSQL_DB’, ‘test_mysql’),

]

2、在测试代码中使用特定连接:

User::on(‘testing_mysql’)->find(1);

3、结合环境变量控制连接行为,实现灵活切换。

以上就是laravel怎么在不同的测试环境中使用不同的数据库_laravel测试环境多数据库使用方法的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/5926.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 00:44:18
下一篇 2025年11月6日 00:48:21

相关推荐

  • 如何解决PHP中货币数值处理和格式化难题,使用Spryker/Money让财务计算更精确

    最近在开发一个电商平台时,我遇到了一个让人头疼的问题:如何精确地处理和展示商品价格、订单总额等货币数值。PHP中的浮点数计算众所周知地不可靠(比如 0.1 + 0.2 并不严格等于 0.3 ),这在财务计算中是绝对不能接受的。更麻烦的是,我们的平台面向全球用户,这意味着我需要根据不同的国家和地区,以…

    开发工具 2025年12月5日
    000
  • win10关闭自动更新 四种禁止更新方法分享

    windows 10系统内置了自动更新机制,虽然有助于保持系统安全与稳定,但对不少用户来说,频繁的更新提示、计划外的重启甚至强制重启严重影响了使用体验。尤其是在进行重要工作或沉浸式游戏时,突如其来的系统更新极易打断操作流程。那么,如何有效关闭win10的自动更新呢?本文将介绍四种实用、安全且可逆的方…

    2025年12月5日 电脑教程
    600
  • MySQL ERROR 1045出现的原因及怎么解决

    在命令行输入mysql -u root –p,输入密码,或通过工具连接数据库时,经常出现下面的错误信息,相信该错误信息很多人在使用mysql时都遇到过。 ERROR 1045 (28000): Access denied for user ‘root’@’loca…

    2025年12月5日 数据库
    000
  • 如何在Laravel中集成支付网关

    在laravel中集成支付网关的核心步骤包括:1.根据业务需求选择合适的支付网关,如stripe、paypal或支付宝等;2.通过composer安装对应的sdk或laravel包,如stripe/stripe-php或yansongda/pay;3.在.env文件和config/services.…

    2025年12月5日
    300
  • linux上安装docker容器和mysql镜像拉取的方法

    docker pull xxxx 拉取镜像 docker run -it xxxx /bin/bash 启动镜像 启动docker服务 docker ps 查询运行中的容器 docker ps -a 查询所有容器,包括未运行的 mysql容器启动:docker run -itd –nam…

    数据库 2025年12月5日
    000
  • 如何使用spryker/user模块,轻松解决后台用户权限管理难题

    Composer在线学习地址:学习地址 作为一名php开发者,我经常面临一个挑战:为后台管理系统(特别是像spryker这样的复杂电商平台)构建一套健壮、灵活且易于管理的用户权限体系。想象一下,一个拥有数十个功能模块的后台,需要为运营、财务、客服、内容编辑等不同角色分配不同的操作权限。最初,我们可能…

    开发工具 2025年12月5日
    000
  • 如何在Laravel中实现缓存机制

    laravel的缓存机制用于提升应用性能,通过存储耗时操作结果避免重复计算。1. 配置缓存驱动:在.env文件中设置cache_driver,如redis,并安装相应扩展;2. 使用cache facade进行缓存操作,包括put、get、has、forget等方法;3. 使用remember和pu…

    2025年12月5日
    000
  • 如何解决前端JS文件过大导致加载缓慢的问题,使用linkorb/jsmin-php助你轻松实现JS代码压缩优化

    可以通过一下地址学习composer:学习地址 在快节奏的互联网世界里,网站的加载速度是用户体验的生命线。用户往往没有耐心等待一个缓慢的页面,而搜索引擎也更青睐加载迅速的网站。作为一名开发者,我深知这一点,但最近在优化我的php项目时,却遇到了一个让人头疼的问题:前端的javascript文件随着功…

    开发工具 2025年12月5日
    000
  • ubuntu下mysql 8.0.28怎么安装配置

    修改密码改了挺长时间,记录下安装过程 安装ssh服务: sudo apt-get install openssh-server 启动ssh服务: service sshd start 安装mysql服务器端: sudo apt install -y mysql-server 安装mysql客户端: …

    2025年12月5日
    000
  • 如何在Laravel中处理表单提交

    在laravel中处理表单提交的步骤如下:1. 创建包含正确method、action属性和@csrf指令的html表单;2. 在routes/web.php或routes/api.php中定义路由,如route::post(‘/your-route’, ‘you…

    2025年12月5日
    100
  • MySQL事件调度器如何使用_能实现哪些自动化任务?

    mysql事件调度器是内置的定时任务工具,用于自动化周期性操作。一、开启方法:用show variables查看event_scheduler状态,若为off则在配置文件添加event_scheduler=on或临时执行set global开启;二、创建语法:create event定义触发时间、频…

    2025年12月5日 数据库
    000
  • mysql临键锁如何使用

    1、默认情况下,innodb使用临键锁锁定记录。 select … for update 2、当查询索引包含唯一属性时,临键锁将被优化并降级为记录锁,即只锁定索引本身,而不是范围。 3、不同场景下的临键锁会退化。 实例 事务1 start transaction;select SLEEP(4);…

    数据库 2025年12月5日
    000
  • 如何解决Phan静态分析中的“疑难杂症”,drenso/phan-extensions助你提升代码质量

    可以通过一下地址学习composer:学习地址 在现代php开发中,静态代码分析工具如phan已经成为保障代码质量不可或缺的一部分。它能在不运行代码的情况下,发现潜在的错误、不一致和不良实践。然而,即使是phan这样强大的工具,在面对复杂的项目结构、自定义注解或特定php扩展时,也难免会遇到一些“水…

    开发工具 2025年12月5日
    000
  • 126邮箱官网登录入口网页版 126邮箱登录首页官网

    126邮箱官网登录入口网页版为https://mail.126.com,用户可通过邮箱账号或手机号快速注册登录,支持密码找回、扫码验证;页面适配多设备,具备分栏式收件箱、邮件筛选、批量操作及星标分类功能;附件上传下载支持实时进度与断点续传,兼容多种文件格式预览。 126邮箱官网登录入口网页版在哪里?…

    2025年12月5日
    100
  • MySQL命令行中如何修改MySQL密码

    方法一: mysql admin -u 用户名 -p 旧密码 passw 新密码 ‘u’为 username 的简称,‘p’为原 password 简称。 方法二: 我们先登录 MySQL 数据库。之后输入: mysql>set password for root@localhost = pa…

    数据库 2025年12月5日
    000
  • MySQL8如何设置自动创建时间和自动更新时间

    业务场景: 1、在数据库表中的数据,要求记录每一条新增数据的创建时间,时间格式要求明确至:年月日:时分秒。 2、在数据库表中的数据,要求记录每一条更新数据的更新时间,时间格式要求明确至:年月日:时分秒。 功能实现: 1、为每张业务表添加create_time 和update_time 字段,且将字段…

    数据库 2025年12月5日
    000
  • win10怎么关闭用户账户控制UAC_关闭用户账户控制UAC的操作方法

    关闭Windows 10用户帐户控制(UAC)的方法有三种:一是通过控制面板将UAC滑块调至“从不通知”;二是使用msconfig工具快速启动UAC设置并调整;三是通过注册表编辑器将EnableLUA值改为0,彻底禁用UAC并重启生效。 如果您在运行某些程序或进行系统更改时频繁弹出权限确认提示,这可…

    2025年12月5日
    000
  • 如何高效管理客户数据并确保隐私合规?SprykerCustomer模块与Composer助你轻松实现!

    可以通过一下地址学习composer:学习地址 在我的开发生涯中,构建电商平台或任何需要用户账户的系统,客户管理功能总是让人头大。最初,我以为这只是简单的“增删改查”,但随着项目深入,我发现事情远没有那么简单。 我曾面临的客户管理困境 想象一下,你需要为你的用户提供以下功能: 基础账户管理: 创建、…

    开发工具 2025年12月5日
    000
  • PHP中读取并输出文件内容:结合白名单校验的实践指南

    本教程详细介绍了如何在php中安全高效地读取文件内容并将其输出到客户端。通过一个白名单校验的实际案例,我们将演示如何利用`file_get_contents()`函数读取文件,并结合`__dir__`魔术常量处理文件路径,确保代码的健壮性和可移植性,同时提供最佳实践建议。 在PHP Web应用开发中…

    2025年12月5日
    000
  • OPPO Find X9系列新机首发ColorOS 16 10月16日发布

    10月14日,oppo正式宣布:find x9系列将全球首个搭载全新coloros 16操作系统。该系统在ai智能记录、跨平台互联以及便捷传输等功能上实现全方位进化。 OPPO Find X9 据CNMO消息,ColorOS 16全新推出的“AI一键闪记”功能,支持视频、账单、图片及语音内容的快速捕…

    2025年12月5日
    000

发表回复

登录后才能评论
关注微信