質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

PHPUnit

PHPUnitは、PHP向けのユニット・テスト向けフレームワークで、手動では手間のかかるテスト作業を自動化し、繰り返し実行することが可能です。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

1回答

414閲覧

phpunitでleftjoinをモック化(部分モック)する方法を教えてください

chokochokochok

総合スコア46

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

PHPUnit

PHPUnitは、PHP向けのユニット・テスト向けフレームワークで、手動では手間のかかるテスト作業を自動化し、繰り返し実行することが可能です。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2018/11/02 05:48

編集2018/11/03 11:57

下記の処理で、$no = 11111を渡した際に$value(ここでは1)が返ってくることのテストをphpunitで書きたいのですが、
モック化した値が返って来ません。nullが返却されます。
ここでどのように修正すれば良いか検討がつきません。
どうかご教示お願いします。

php

1protected function getNumber($no) 2 { 3 $numbers = 4 DB::connection('db_name')->table('table_1') 5 ->leftJoin('tables_2', 'table_1.id', '=', 'tables_2.id') 6 ->where('table_1.id', '=', $no) 7 ->get(['table_1.colum_1', 'table_2.colum_2', 'table_1.colum_3']) 8 ->toArray(); 9 10 foreach($numbers as $value){ 11 return $value; 12 } 13 }

phpunit

1 public function test_getNumber() 2 { 3 $mock = Mockery::mock('overload:App\{パス}'); 4 $mock->shouldReceive('getNumber'); 5 $mock->shouldReceive('connection->table->leftJoin->where->get->toArray')->andReturn(1); 6 $no = '11111'; 7 $actual = $mock->getNumber($g_no); 8 $expected = 1; 9 $this->assertEquals($expected, $actual); 10 }

回答が得られないので、追記させていただきます。

1番分からないのはDBファサードの部分をどのようにモック化したら良いかわかりません。
足りない項目があれば、追記致します。
どんな些細な回答でも構いません。
どうか、どうか宜しくおねがいします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

なんとか下記の処理でうまくいきました。

php

1$builder = Mockery::mock("\Illuminate\Database\Query\Builder"); 2 $builder->shouldReceive('table->leftJoin->where->get->toArray')->andReturn([1]); 3 \DB::shouldReceive('connection')->with('db_name')->once()->andReturn($builder);

投稿2018/11/03 16:19

chokochokochok

総合スコア46

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問