CakePHP3とPHPUnitでの単体テストコードの勉強をするために簡単なコードを書いて実施してみた。
環境
CakePHP 3.6.3
PHPUnit 5.7.27
PHP 7.0.27
UsersController.phpにsum()を追加する。
sum()はGETまたはPOSTから渡されるパラメータa、bの値を足し算する。
//UsersController.php<br>
public function sum()<br>
{<br>
$this->request->allowMethod(['post', 'get']);<br>
if($this->request->is('post')) {<br>
$a = $this->request->getData('a');<br>
$b = $this->request->getData('b');<br>
} elseif ($this->request->is('get')) {<br>
$a = $this->request->getQuery('a');<br>
$b = $this->request->getQuery('b');<br>
}<br>
$this->set('sum', $a + $b);<br>
}
Controllerがsum()なのでsum.ctpテンプレートを追加する。
//Template/Users/sum.ctp<br> <?php<br> echo $sum;
UsersControllerTest.phpにはGETとPOST用のコードを作成する。
viewVariable()はControllerからset()した値を取得している。
//UsersControllerTest.php<br>
public function testSumGet()<br>
{<br>
$this->get('Users/sum?a=0&b=0');<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(0, $sum);</p>
<p> $this->get('Users/sum?a=10&b=20');<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(30, $sum);</p>
<p> $this->get('Users/sum?a=1000000&b=2000000');<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(3000000, $sum);<br>
}</p>
<p>public function testSumPost()<br>
{<br>
$this->post('Users/sum', ['a' => 0, 'b' => 0]);<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(0, $sum);</p>
<p> $this->post('Users/sum', ['a' => 10, 'b' => 20]);<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(30, $sum);</p>
<p> $this->post('Users/sum', ['a' => 1000000, 'b' => 2000000]);<br>
$sum = $this->viewVariable('sum');<br>
$this->assertEquals(3000000, $sum);<br>
}
PHPUnitを実行すると以下のような成功メッセージが出力される。
> php vendor\phpunit\phpunit\phpunit --coverage-html ./report.html tests\TestCase\Controller\UsersControllerTest.php
PHPUnit 5.7.27 by Sebastian Bergmann and contributors.
.. 2 / 2 (100%)
Time: 1.91 seconds, Memory: 12.00MB
OK (2 tests, 6 assertions)
Generating code coverage report in HTML format ... done
・途中で手が止まった点
testSumGet()とtestSumPost()の2つ目以降のテストがエラーになっていた。
メッセージを見るとControllerから受け取る$sumがnullになっていた。
原因はTemplate/Users/sum.ctpを作成していなかったため。
cli-error.logにテンプレートファイルが見つからないエラーが出ていた。
・今回解決できなかった点
UsersController.phpのsum()はGETとPOST以外は許容していない。
allowMethod()で指定したメソッド以外のアクセスは
500エラーが返るのでassertResponseFailure()を使ったテストコードを作った。
その結果、テストコードは成功した。
しかし、カバレッジレポートが生成されるがテストが通過したことにならなかった。

コメント