婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > laravel使用數據庫測試注意事項

laravel使用數據庫測試注意事項

熱門標簽:邢臺400電話辦理 正規電銷機器人系統 辦理400電話哪家好點 濟源百應電銷機器人聯系方式 重慶外呼電銷系統多少錢 南寧電話外呼系統線路 嘟嘟云外呼系統 南京3D地圖標注 咸陽電銷

相對于其它測試,數據庫測試可以說是相對復雜繁瑣的,因為數據庫測試不可避免地會涉及到數據庫的增刪改查,而這些操作會影響數據庫的數據,而我們測試最忌諱的就是修改了數據的測試,因為這樣的話下次測試的時候,可能測試結果就會發生改變。

慶幸的是,laravel為我們提供了非常簡潔的數據庫測試方法,而且不會影響原數據。

use DatabaseMigrations

通過使用轉移表,我們可以對數據進行。不過這就要求我們的數據是通過migration來生成的,如果直接在數據庫創建的話,我們進行測試的時候就會提示:

SQLSTATE[HY000]: General error: 1 no such table: exchange_code

我們可以看下DatabaseMigrations的源碼,可以看到它是trait,它會在執行測試之前

migrate:fresh

執行測試之后

migrate:rollback

這樣的話就保證我們對數據庫的操作都會進行回滾。

注意事項

這里的migrate:fresh 會刪除掉所有表,然后重建數據.

use RefreshDatabase

這種方式回去判斷是否是內存數據測試,如果是的話,因為是在內存操作,不影響數據庫。

如果是mysql等數據庫,它會啟用事務,也就是我們測試的數據不會真的提交,測試完畢后,進行回滾,然后提交,也就是相當于我們對數據庫什么也沒做。

測試數據庫的時候,我們都是使用工廠進行創建數據,否則你會發現即使數據庫有數據,也是空的。

public function testGet()
 {
  factory(Exchange::class)->create();

  $exchange = Exchange::select('code')->where('status', 0)->first();
  $code = $exchange->code;

  $this->assertDatabaseHas('exchange_code', [
   'code' => $code,
  ]);
 }

總結

到此這篇關于laravel使用數據庫測試注意事項的文章就介紹到這了,更多相關laravel數據庫測試內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PHPUnit + Laravel單元測試常用技能
  • laravel單元測試之phpUnit中old()函數報錯解決

標簽:平頂山 黃山 南通 隴南 河南 通遼 武漢 唐山

巨人網絡通訊聲明:本文標題《laravel使用數據庫測試注意事項》,本文關鍵詞  laravel,使用,數據庫,測試,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《laravel使用數據庫測試注意事項》相關的同類信息!
  • 本頁收集關于laravel使用數據庫測試注意事項的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 兴国县| 娄烦县| 德昌县| 新宾| 仪征市| 汉阴县| 新兴县| 岫岩| 烟台市| 义马市| 建平县| 新安县| 博白县| 黄龙县| 秦安县| 明溪县| 澎湖县| 全椒县| 高尔夫| 天水市| 宁强县| 砀山县| 许昌县| 肥西县| 闽侯县| 澎湖县| 汾阳市| 云霄县| 怀柔区| 六盘水市| 中山市| 巩留县| 滦南县| 垣曲县| 黄冈市| 崇左市| 鄂州市| 长兴县| 河南省| 社会| 合水县|