Table of Contents
Laravel database Testing
Usage Example
Advantages and Disadvantages of the Solution
Home Backend Development PHP Tutorial Another way to do Laravel database testing (SQLite)

Another way to do Laravel database testing (SQLite)

Jul 13, 2018 pm 03:21 PM
laravel php phpunit sqlite3 unit test

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 usePHPUnit provides 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, Laravel provides 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 of SQLite:memory:

Laravel The 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 with SQLite.

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 that SQLite has 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');
    }
}
Copy after login
  • First add it in the Laravel database configuration file, that is, the connections array of config/database.php A new database connection

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

A very important parameter here is'database' => ':memory:',:memory:The database is an in-memory database built into SQLite. 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 the SQLite database as the test library. For a detailed explanation, click here.

  • Then you need to modify the configuration file of PHPUnit. In phpunit.xml, change the database connection to the SQLite just defined Connection

<php>
    <env name="APP_ENV" value="testing"/>
    <env name="CACHE_DRIVER" value="array"/>
    <env name="SESSION_DRIVER" value="array"/>
    <env name="QUEUE_DRIVER" value="sync"/>
    
    <!-- 将数据库连接改为刚刚定义的SQLite连接 -->
    <env name="DB_CONNECTION" value="sqlite" />
</php>
Copy after login

This overrides the database connection DB_CONNECTION=mysql defined in .env and tells the framework to run the test Sometimes, use sqlite connection instead of mysql connection.

  • Finally, you need to perform database migration before running the test case, and add the setUp method to the base class of the test class, which is TestCase.php

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

In this way, before each test case is executed, all migrations will be performed to the :memory: database of SQLite to 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 database SQLite: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 in php.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:

<a title="如何解决Laravel.log 文件写入的问题" href="http://www.php.cn/php-weizijiaocheng-406465.html" target="_blank">How to solve the problem of writing the Laravel.log file</a>

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 of this Website
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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Laravel Introduction Example Laravel Introduction Example Apr 18, 2025 pm 12:45 PM

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

Solve caching issues in Craft CMS: Using wiejeben/craft-laravel-mix plug-in Solve caching issues in Craft CMS: Using wiejeben/craft-laravel-mix plug-in Apr 18, 2025 am 09:24 AM

When developing websites using CraftCMS, you often encounter resource file caching problems, especially when you frequently update CSS and JavaScript files, old versions of files may still be cached by the browser, causing users to not see the latest changes in time. This problem not only affects the user experience, but also increases the difficulty of development and debugging. Recently, I encountered similar troubles in my project, and after some exploration, I found the plugin wiejeben/craft-laravel-mix, which perfectly solved my caching problem.

Laravel user login function Laravel user login function Apr 18, 2025 pm 12:48 PM

Laravel provides a comprehensive Auth framework for implementing user login functions, including: Defining user models (Eloquent model), creating login forms (Blade template engine), writing login controllers (inheriting Auth\LoginController), verifying login requests (Auth::attempt) Redirecting after login is successful (redirect) considering security factors: hash passwords, anti-CSRF protection, rate limiting and security headers. In addition, the Auth framework also provides functions such as resetting passwords, registering and verifying emails. For details, please refer to the Laravel documentation: https://laravel.com/doc

What versions of laravel are there? How to choose the version of laravel for beginners What versions of laravel are there? How to choose the version of laravel for beginners Apr 18, 2025 pm 01:03 PM

In the Laravel framework version selection guide for beginners, this article dives into the version differences of Laravel, designed to assist beginners in making informed choices among many versions. We will focus on the key features of each release, compare their pros and cons, and provide useful advice to help beginners choose the most suitable version of Laravel based on their skill level and project requirements. For beginners, choosing a suitable version of Laravel is crucial because it can significantly impact their learning curve and overall development experience.

Laravel framework installation method Laravel framework installation method Apr 18, 2025 pm 12:54 PM

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

How to view the version number of laravel? How to view the version number of laravel How to view the version number of laravel? How to view the version number of laravel Apr 18, 2025 pm 01:00 PM

The Laravel framework has built-in methods to easily view its version number to meet the different needs of developers. This article will explore these methods, including using the Composer command line tool, accessing .env files, or obtaining version information through PHP code. These methods are essential for maintaining and managing versioning of Laravel applications.

The difference between laravel and thinkphp The difference between laravel and thinkphp Apr 18, 2025 pm 01:09 PM

Laravel and ThinkPHP are both popular PHP frameworks and have their own advantages and disadvantages in development. This article will compare the two in depth, highlighting their architecture, features, and performance differences to help developers make informed choices based on their specific project needs.

The Continued Use of PHP: Reasons for Its Endurance The Continued Use of PHP: Reasons for Its Endurance Apr 19, 2025 am 12:23 AM

What’s still popular is the ease of use, flexibility and a strong ecosystem. 1) Ease of use and simple syntax make it the first choice for beginners. 2) Closely integrated with web development, excellent interaction with HTTP requests and database. 3) The huge ecosystem provides a wealth of tools and libraries. 4) Active community and open source nature adapts them to new needs and technology trends.

See all articles