mirror of
				https://github.com/flarum/core.git
				synced 2025-10-20 19:27:14 +02:00 
			
		
		
		
	This creates a dedicated test suite for integration tests. All of them can be run independently, and there is no order dependency - previously, all integration tests needed the installer test to run first, and they would fail if installation failed. Now, the developer will have to set up a Flarum database to be used by these tests. A setup script to make this simple will be added in the next commit. Small tradeoff: the installer is NOT tested in our test suite anymore, only implicitly through the setup script. If we decide that this is a problem, we can still set up separate, dedicated installer tests which should probably test the web installer.
		
			
				
	
	
		
			94 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of Flarum.
 | |
|  *
 | |
|  * (c) Toby Zerner <toby.zerner@gmail.com>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Flarum\Tests\integration\api\Controller;
 | |
| 
 | |
| use Flarum\Api\Controller\CreateDiscussionController;
 | |
| use Flarum\Discussion\Discussion;
 | |
| use Flarum\User\User;
 | |
| use Illuminate\Support\Arr;
 | |
| 
 | |
| class CreateDiscussionControllerTest extends ApiControllerTestCase
 | |
| {
 | |
|     protected $controller = CreateDiscussionController::class;
 | |
| 
 | |
|     protected $data = [
 | |
|         'title' => 'test - too-obscure',
 | |
|         'content' => 'predetermined content for automated testing - too-obscure'
 | |
|     ];
 | |
| 
 | |
|     public function setUp()
 | |
|     {
 | |
|         parent::setUp();
 | |
| 
 | |
|         $this->prepareDatabase([
 | |
|             'discussions' => [],
 | |
|             'posts' => [],
 | |
|             'users' => [
 | |
|                 $this->adminUser(),
 | |
|             ],
 | |
|             'groups' => [
 | |
|                 $this->adminGroup(),
 | |
|             ],
 | |
|             'group_user' => [
 | |
|                 ['user_id' => 1, 'group_id' => 1],
 | |
|             ],
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @test
 | |
|      */
 | |
|     public function can_create_discussion()
 | |
|     {
 | |
|         $this->actor = User::find(1);
 | |
| 
 | |
|         $response = $this->callWith($this->data);
 | |
| 
 | |
|         $this->assertEquals(201, $response->getStatusCode());
 | |
| 
 | |
|         /** @var Discussion $discussion */
 | |
|         $discussion = Discussion::where('title', $this->data['title'])->firstOrFail();
 | |
|         $data = json_decode($response->getBody()->getContents(), true);
 | |
| 
 | |
|         $this->assertEquals($this->data['title'], $discussion->title);
 | |
|         $this->assertEquals($this->data['title'], array_get($data, 'data.attributes.title'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @test
 | |
|      * @expectedException \Illuminate\Validation\ValidationException
 | |
|      * @expectedExceptionMessage The given data was invalid.
 | |
|      */
 | |
|     public function cannot_create_discussion_without_content()
 | |
|     {
 | |
|         $this->actor = User::find(1);
 | |
| 
 | |
|         $data = Arr::except($this->data, 'content');
 | |
| 
 | |
|         $this->callWith($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @test
 | |
|      * @expectedException \Illuminate\Validation\ValidationException
 | |
|      * @expectedExceptionMessage The given data was invalid.
 | |
|      */
 | |
|     public function cannot_create_discussion_without_title()
 | |
|     {
 | |
|         $this->actor = User::find(1);
 | |
| 
 | |
|         $data = Arr::except($this->data, 'title');
 | |
| 
 | |
|         $this->callWith($data);
 | |
|     }
 | |
| }
 |