Home>Article>Backend Development> Another way to do Laravel database testing (SQLite)

Another way to do Laravel database testing (SQLite)

不言
不言 Original
2018-07-13 15:21:32 2971browse

This article mainly introduces another method to conduct Laravel database testing (SQLite), which has certain reference value. Now I share it with you. Friends in need can refer to it

Laravel database Testing

In terms of testing,Laravelbuilt-in usePHPUnitprovides a very convenient solution. For the test of database addition, deletion, modification and query, a very important problem to be solved is how to restore the original appearance of the database after the test is completed. For example, to test a user registration method, a user record needs to be inserted into the database, but after the test is completed, , we don’t want this test case to be saved in the database. In order to solve this problem,Laravelprovides a very convenient solution:

  • Use migrations:DatabaseMigrations

  • Use transactions:DatabaseTransactions

Reference: https://laravel.com/docs/5.3/database-testing#resetting-the-database- after-each-test

Another solution: use the in-memory database ofSQLite:memory:

LaravelThe two solutions provided still perform read and write operations on the database. Sometimes you may not want to do this (for example, multiple people share an online development database). In this case, you can also use a more elegant way:SQLlite, the logic is actually very simple: when running the test case, replace the database connection withSQLite.

Usage Example

For example, we have the following test class (this example is not representative, it is only used to illustrate the problem, and it is assumed thatSQLitehas been installed on this machine):

class HomePageTest extends TestCase { public function testHomePage() { // 创建一个测试用户,并保存 $user = factory(App\User::class)->create(); $this->actingAs($user)->visit('/home')->see('Dashboard'); } }
  • First add it in theLaraveldatabase configuration file, that is, theconnectionsarray ofconfig/database.phpA new database connection

'sqlite' => [ 'driver' => 'sqlite', 'database' => ':memory:', 'prefix' => '', ],

A very important parameter here is'database' => ':memory:',:memory:The database is an in-memory database built intoSQLite. Each time a test case is run, a new database will be created in the memory and will be automatically cleared after the test is completed and the database connection is closed. It has good performance. Isolation, and because it is in memory, it is also very fast. These features are very convenient for testing. This is also a very important reason why we choose theSQLitedatabase as the test library. For a detailed explanation, click here.

  • Then you need to modify the configuration file ofPHPUnit. Inphpunit.xml, change the database connection to theSQLite just definedConnection

       

This overrides the database connectionDB_CONNECTION=mysqldefined in.envand tells the framework to run the test Sometimes, usesqliteconnection instead ofmysqlconnection.

  • Finally, you need to perform database migration before running the test case, and add thesetUpmethod to the base class of the test class, which isTestCase.php

public function setUp() { parent::setUp(); // 执行数据库迁移 $this->artisan('migrate'); }

In this way, before each test case is executed, all migrations will be performed to the:memory:database ofSQLiteto generate business Data table required for logic.

Advantages and Disadvantages of the Solution

  • The key point of this solution is to use a built-in memory databaseSQLite:memory:, so It is relatively fast, has good isolation, and will not have any impact on our development database.

  • Of course, this solution also has shortcomings. If the project database is huge, there are a large number of data tables or migration files, it will consume a lot of memory. When running the test, there may be insufficient memory, resulting in Test interrupted. At this time, you need to allocate appropriate memory to PHP and modify the configuration inphp.inimemory_limit = 128M

The above is the entire content of this article , I hope it will be helpful to everyone’s learning. For more related content, please pay attention to the PHP Chinese website!

Related recommendations:

How to solve the problem of writing the Laravel.log file

Laravel development environment deployment Homestead installation and configuration process (windows system)

Laravel routing (router) graphic and text explanation

The above is the detailed content of Another way to do Laravel database testing (SQLite). For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn