PHPUnit 自動化測試大作戰【CH29】

更新於 發佈於 閱讀時間約 13 分鐘

在前一篇文章中,我們探討了多重資料庫連線情境下,Model 及 Database Assertion 的應對方式,不過實際上筆者認為比較有難度的,其實是 Migration 應對方式

今天就讓我們來探討這部分吧!

Migration 應對方式

對於多重資料庫連線這種情境,筆者實務上做過的對應方式大致如下:

a. 將其他專案程式庫的 Migration 檔收集起來,放到主專案程式庫中的某個位置,並依不同專案程式庫設置不同資料夾存放。

  • 將 SunnyProject 的 Migration 檔案複製到 MainProject 的 tests/migrations/sunny 資料夾下
  • 同時將 MoonProject 的 Migration 檔案複製到 MainProject 的 tests/migrations/moon 資料夾下

b. 建立一個 RefreshMigrationTrait 類別,放置於 tests/Traits 之下:

  • tests/Traits/RefreshMigrationTrait.php
<?php

namespace Tests\Traits;

trait RefreshMigrationTrait{

public function refreshDatabase(): void {

$this->artisan('migrate:refresh', [

'--database' => 'mysql',

'--path' => 'database/migrations'

]); $this->artisan('migrate:refresh', [

'--database' => 'mysql_sunny',

'--path' => 'database/migrations/sunny'

]); $this->artisan('migrate:refresh', [

'--database' => 'mysql_moon',

'--path' => 'database/migrations/moon'

]); }}

在以上程式碼中,會執行3次 Migrate Refresh,第1次是針對 MainProject 的 Migration 檔案進行 Migrate Refresh,第2次是針對 SunnyProject 的 Migration 檔案進行 Migrate Refresh,第3次是針對 MoonProject 的 Migration 檔案進行 Migrate Refresh。

c. 調整 config/database.php

'mysql' => [

'driver' => env('DB_DRIVER', 'mysql'), // 原預設是 'mysql',改為由env注入

'database' => env('DB_DATABASE', 'forge'),

'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', ''),

'unix_socket' => env('DB_SOCKET', ''),

'charset' => 'utf8mb4',

'collation' => 'utf8mb4_unicode_ci',

'prefix' => env('DB_PREFIX', ''), // 由env注入

'strict' => false,

'engine' => null,

],'mysql_sunny' => [

'driver' => env('DB_SUNNY_DRIVER', 'mysql'), // 原預設是 'mysql',改為由env注入

'database' => env('DB_SUNNY_DATABASE', 'forge'),

'host' => env('DB_SUNNY_HOST', '127.0.0.1'),

'port' => env('DB_SUNNY_PORT', '3306'),

'database' => env('DB_SUNNY_DATABASE', 'forge'),

'username' => env('DB_SUNNY_USERNAME', 'forge'),

'password' => env('DB_SUNNY_PASSWORD', ''),

'unix_socket' => env('DB_SUNNY_SOCKET', ''),

'charset' => 'utf8mb4',

'collation' => 'utf8mb4_unicode_ci',

'prefix' => env('DB_SUNNY_PREFIX', ''), // 由env注入

'strict' => false,

'engine' => null,

],'mysql_moon' => [

'driver' => env('DB_MOON_DRIVER', 'mysql'), // 原預設是 'mysql',改為由env注入

'database' => env('DB_MOON_DATABASE', 'forge'),

'prefix' => env('DB_MOON_PREFIX', ''),

'host' => env('DB_MOON_HOST', '127.0.0.1'),

'port' => env('DB_MOON_PORT', '3306'),

'database' => env('DB_MOON_DATABASE', 'forge'),

'username' => env('DB_MOON_USERNAME', 'forge'),

'password' => env('DB_MOON_PASSWORD', ''),

'unix_socket' => env('DB_MOON_SOCKET', ''),

'charset' => 'utf8mb4',

'collation' => 'utf8mb4_unicode_ci',

'prefix' => env('DB_MOON_PREFIX', ''), // 由env注入

'strict' => false,

'engine' => null,

],// 下略

d. 調整 phpunit.xml

<?xml version="1.0" encoding="UTF-8"?>

<phpunit backupGlobals="false">

<!---->

<php>

<env name="DB_DATABASE" value=":memory:"/>

<env name="DB_DATABASE_SUNNY" value=":memory:"/> // 增加此項

<env name="DB_DATABASE_MOON" value=":memory:"/> // 增加此項

<env name="DB_PREFIX_SUNNY" value="sunny_"/> // 增加此項

<env name="DB_PREFIX_MOON" value="moon_"/> // 增加此項

<env name="DB_DRIVER" value="sqlite"/>

<env name="DB_DRIVER_SUNNY" value="sqlite"/> // 增加此項

<env name="DB_DRIVER_MOON" value="sqlite"/> // 增加此項

<!---->

</php>

</phpunit>

做好以上調整後,當日後需要做多重資料庫測試時,我們便可使用以下方式,在每次測試執行前進行資料庫重建:

<?php

namespace Tests\Unit;

use Tests\TestCase;

use Tests\Traits\RefreshMigrationTrait

class ExampleTest extends TestCase

{ use RefreshMigrationTrait;

public function setUp(): void {

// 重建測試資料庫

$this->refreshDatabase();

} // 下略

}

這種實作及設定方式,會將3個專案的資料庫都建在 SQLite 上(藉由改變各連線的 Driver 值),再用設定前綴(Prefix)的方式,將原屬不同資料庫的不同資料表區隔開來,因此就算 MainProject 與 SunnyProject 都有 users 這個資料表,也會因為 SunnyProject 的 users 資料表實際上會建立成 sunny_users ,因而不會產生衝突。

以上就是今天的介紹,希望對大家的實務應用上有所幫助,也歡迎大家分享其它有用的應對方式唷!

下一篇再讓我們探討其他情境。

如果您喜歡這篇文章,歡迎加入追蹤以接收新文章通知 😄

本系列文章目錄

留言
avatar-img
留言分享你的想法!
avatar-img
WilliamP的沙龍
13會員
528內容數
歡迎來到 WilliamP 的沙龍天地,在這裡將與各位讀者探討各種主題,包刮高中數學題庫、PHP開發經驗、LINE聊天機器人開發經驗、書摘筆記等,歡迎交流!
WilliamP的沙龍的其他內容
2023/12/18
今天讓我們探討「缺乏 Migration Files 與 Factory Files」的 Legacy 情境吧! 很多時候我們會遇到沒有 Migration Files 或 Factory Files 的 Legacy Codebase,原因大概有以下幾種: 該程式庫原本不是以 Laravel
2023/12/18
今天讓我們探討「缺乏 Migration Files 與 Factory Files」的 Legacy 情境吧! 很多時候我們會遇到沒有 Migration Files 或 Factory Files 的 Legacy Codebase,原因大概有以下幾種: 該程式庫原本不是以 Laravel
2023/12/18
在實務情境上,常會有在單一專案程式庫中,存取多個不同資料庫的使用情境,在這種情況下,我們通常會設置多個資料庫連線(Database Connection)設定。 在平常開發使用設很方便,但要做測試時就會發現一些問題: 在測試程式碼或 Seeder 中調用 factory() 時,都是在預設連線資
2023/12/18
在實務情境上,常會有在單一專案程式庫中,存取多個不同資料庫的使用情境,在這種情況下,我們通常會設置多個資料庫連線(Database Connection)設定。 在平常開發使用設很方便,但要做測試時就會發現一些問題: 在測試程式碼或 Seeder 中調用 factory() 時,都是在預設連線資
2023/12/18
今天就讓我們依照前一天的情境題,來撰寫測試案例函數吧! 這次同樣地,先讓我們規畫擬訂測試案例: 測試案例 使用者註冊: 使用者可送出註冊資料,系統將建立使用者資料,並送出含有專屬驗證連結之驗證信,當此驗證連結被開啟後,將讓使用者轉為已驗證狀態 請求錯誤的驗證連結: 錯誤的驗證連結被開啟後
2023/12/18
今天就讓我們依照前一天的情境題,來撰寫測試案例函數吧! 這次同樣地,先讓我們規畫擬訂測試案例: 測試案例 使用者註冊: 使用者可送出註冊資料,系統將建立使用者資料,並送出含有專屬驗證連結之驗證信,當此驗證連結被開啟後,將讓使用者轉為已驗證狀態 請求錯誤的驗證連結: 錯誤的驗證連結被開啟後
看更多
你可能也想看
Thumbnail
常常被朋友問「哪裡買的?」嗎?透過蝦皮分潤計畫,把日常購物的分享多加一個步驟,就能轉換成現金回饋。門檻低、申請簡單,特別適合學生與上班族,讓零碎時間也能創造小確幸。
Thumbnail
常常被朋友問「哪裡買的?」嗎?透過蝦皮分潤計畫,把日常購物的分享多加一個步驟,就能轉換成現金回饋。門檻低、申請簡單,特別適合學生與上班族,讓零碎時間也能創造小確幸。
Thumbnail
本文介紹了在網站開發中如何運用狀態機的原則和設計方法。通過具體案例分析,以及狀態和數據的區分,詳細介紹了狀態機的設計原則和應用。讀者可以通過本文瞭解如何將狀態機應用於實際的網站開發中。
Thumbnail
本文介紹了在網站開發中如何運用狀態機的原則和設計方法。通過具體案例分析,以及狀態和數據的區分,詳細介紹了狀態機的設計原則和應用。讀者可以通過本文瞭解如何將狀態機應用於實際的網站開發中。
Thumbnail
KSQL引擎, 串流形式的SQL? 聽了應該霧煞煞吧! 想像一下傳統的SQL, 是不是一個指令一個動作, 每發送一個指令之後就必須等到查詢/寫入…動作皆完成之後才回應, 然而在Streaming的應用上這顯然不太可行, 每分每秒都有資料流入的情境下, 資料的狀態都在變化, 假設我們一個指令一個動作,
Thumbnail
KSQL引擎, 串流形式的SQL? 聽了應該霧煞煞吧! 想像一下傳統的SQL, 是不是一個指令一個動作, 每發送一個指令之後就必須等到查詢/寫入…動作皆完成之後才回應, 然而在Streaming的應用上這顯然不太可行, 每分每秒都有資料流入的情境下, 資料的狀態都在變化, 假設我們一個指令一個動作,
Thumbnail
當我們架好站、WebService測試完,接著就是測試區域網路連線啦~
Thumbnail
當我們架好站、WebService測試完,接著就是測試區域網路連線啦~
Thumbnail
上篇我們已經把風格融入在一個網路之中,實現了訓練一次就可以轉換不同的圖片成我們訓練的風格,但是這樣還不夠,因為這樣每個風格都得訓練一個網路來轉換,太浪費了,那麼,我們有沒有辦法在同一個網路中訓練多個風格呢?
Thumbnail
上篇我們已經把風格融入在一個網路之中,實現了訓練一次就可以轉換不同的圖片成我們訓練的風格,但是這樣還不夠,因為這樣每個風格都得訓練一個網路來轉換,太浪費了,那麼,我們有沒有辦法在同一個網路中訓練多個風格呢?
Thumbnail
軟體系統的發展歷程大多相似,首重解決基本需求、提供操作介面,進而提升安全性、擴充功能、優化操作。
Thumbnail
軟體系統的發展歷程大多相似,首重解決基本需求、提供操作介面,進而提升安全性、擴充功能、優化操作。
Thumbnail
進入物件導向設計的實戰階段,我們通過建立人力資源管理功能來實踐理論知識。透過這些實作練習,能夠深化對物件導向概念的理解,並學會如何在實際開發中應用這些概念。
Thumbnail
進入物件導向設計的實戰階段,我們通過建立人力資源管理功能來實踐理論知識。透過這些實作練習,能夠深化對物件導向概念的理解,並學會如何在實際開發中應用這些概念。
Thumbnail
在工作情境中手動執行SQL語法更新中文字時,有時會遇到中文字顯示問號(?)的情況。這篇文章將介紹如何解決手動執行SQL語法時造成中文顯示問號(?)的方法。
Thumbnail
在工作情境中手動執行SQL語法更新中文字時,有時會遇到中文字顯示問號(?)的情況。這篇文章將介紹如何解決手動執行SQL語法時造成中文顯示問號(?)的方法。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News