From 45775a64af38b9fcd4f821acfdad67b5a00d3400 Mon Sep 17 00:00:00 2001 From: ErickSkrauch Date: Fri, 16 Dec 2016 11:32:13 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D1=8B=20unit-=D1=82=D0=B5=D1=81=D1=82=D1=8B=20=D0=B4?= =?UTF-8?q?=D0=BB=D1=8F=20=D1=84=D0=BE=D1=80=D0=BC=D1=8B=20=D0=B1=D0=BB?= =?UTF-8?q?=D0=BE=D0=BA=D0=B8=D1=80=D0=BE=D0=B2=D0=BA=D0=B8=20=D0=B0=D0=BA?= =?UTF-8?q?=D0=BA=D0=B0=D1=83=D0=BD=D1=82=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/modules/internal/models/BlockForm.php | 7 ++- .../modules/internal/models/BlockFormTest.php | 47 +++++++++++++++++++ 2 files changed, 52 insertions(+), 2 deletions(-) create mode 100644 tests/codeception/api/unit/modules/internal/models/BlockFormTest.php diff --git a/api/modules/internal/models/BlockForm.php b/api/modules/internal/models/BlockForm.php index a60b757..7cb0bdb 100644 --- a/api/modules/internal/models/BlockForm.php +++ b/api/modules/internal/models/BlockForm.php @@ -7,6 +7,7 @@ use common\models\Account; use common\models\amqp\AccountBanned; use PhpAmqpLib\Message\AMQPMessage; use Yii; +use yii\base\ErrorException; class BlockForm extends ApiForm { @@ -27,7 +28,7 @@ class BlockForm extends ApiForm { * * @var string */ - public $message; + public $message = ''; /** * @var Account @@ -50,7 +51,9 @@ class BlockForm extends ApiForm { $account = $this->account; $account->status = Account::STATUS_BANNED; - $account->save(); + if (!$account->save()) { + throw new ErrorException('Cannot ban account'); + } $this->createTask(); diff --git a/tests/codeception/api/unit/modules/internal/models/BlockFormTest.php b/tests/codeception/api/unit/modules/internal/models/BlockFormTest.php new file mode 100644 index 0000000..055eaec --- /dev/null +++ b/tests/codeception/api/unit/modules/internal/models/BlockFormTest.php @@ -0,0 +1,47 @@ +getMockBuilder(Account::class) + ->setMethods(['save']) + ->getMock(); + + $account->expects($this->once()) + ->method('save') + ->willReturn(true); + + $model = new BlockForm($account); + $this->assertTrue($model->ban()); + $this->assertEquals(Account::STATUS_BANNED, $account->status); + $this->tester->canSeeAmqpMessageIsCreated('events'); + } + + public function testCreateTask() { + $account = new Account(); + $account->id = 3; + + $model = new BlockForm($account); + $model->createTask(); + $message = json_decode($this->tester->grabLastSentAmqpMessage('events')->body, true); + $this->assertSame(3, $message['accountId']); + $this->assertSame(-1, $message['duration']); + $this->assertSame('', $message['message']); + + $model = new BlockForm($account); + $model->duration = 123; + $model->message = 'test'; + $model->createTask(); + $message = json_decode($this->tester->grabLastSentAmqpMessage('events')->body, true); + $this->assertSame(3, $message['accountId']); + $this->assertSame(123, $message['duration']); + $this->assertSame('test', $message['message']); + } + +}