* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Flarum\Tests\Api\Controller; use Flarum\Api\Controller\CreateGroupController; use Flarum\Group\Group; use Flarum\Tests\Test\Concerns\RetrievesAuthorizedUsers; use Illuminate\Support\Str; class CreateGroupControllerTestTestCase extends ApiControllerTestCase { use RetrievesAuthorizedUsers; protected $controller = CreateGroupController::class; protected $data = [ 'nameSingular' => 'flarumite', 'namePlural' => 'flarumites', 'icon' => 'test', 'color' => null ]; /** * @test * @expectedException \Illuminate\Validation\ValidationException * @expectedExceptionMessage The given data was invalid. */ public function admin_cannot_create_group_without_data() { $this->actor = $this->getAdminUser(); $this->callWith(); } /** * @test */ public function admin_can_create_group() { $this->actor = $this->getAdminUser(); $response = $this->callWith($this->data); $this->assertEquals(201, $response->getStatusCode()); $group = Group::where('icon', $this->data['icon'])->firstOrFail(); foreach ($this->data as $property => $value) { $property = Str::snake($property); $this->assertEquals($value, $group->{$property}); } } /** * @test * @expectedException \Flarum\User\Exception\PermissionDeniedException */ public function unauthorized_user_cannot_create_group() { $this->actor = $this->getNormalUser(); $this->callWith($this->data); } public function tearDown() { Group::where('icon', $this->data['icon'])->delete(); parent::tearDown(); } }