mirror of
				https://github.com/flarum/core.git
				synced 2025-10-20 19:27:14 +02:00 
			
		
		
		
	New stuff: - Signup + email confirmation. - Updated authentication strategy with remember cookies. closes #5 - New search system with some example gambits! This is cool - check out the source. Fulltext drivers will be implemented as decorators overriding the EloquentPostRepository’s findByContent method. - Lay down the foundation for bootstrapping the Ember app. - Update Web layer’s asset manager to properly publish CSS/JS files. - Console commands to run installation migrations and seeds. Refactoring: - New structure: move models, repositories, commands, and events into their own namespaces, rather than grouping by entity. - All events are classes. - Use L5 middleware and command bus implementations. - Clearer use of repositories and the Active Record pattern. Repositories are used only for retrieval of ActiveRecord objects, and then save/delete operations are called directly on those ActiveRecords. This way, we don’t over-abstract at the cost of Eloquent magic, but testing is still easy. - Refactor of Web layer so that it uses the Actions routing architecture. - “Actor” concept instead of depending on Laravel’s Auth. - General cleanup!
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| use \ApiTester;
 | |
| 
 | |
| use Laracasts\TestDummy\Factory;
 | |
| 
 | |
| class AuthCest
 | |
| {
 | |
|     protected $endpoint = '/api/auth';
 | |
| 
 | |
|     public function loginWithEmail(ApiTester $I)
 | |
|     {
 | |
|         $I->wantTo('login via API with email');
 | |
| 
 | |
|         $user = $I->haveAnAccount([
 | |
|             'email' => 'foo@bar.com',
 | |
|             'password' => 'pass7word'
 | |
|         ]);
 | |
| 
 | |
|         $I->login('foo@bar.com', 'pass7word');
 | |
|         $I->seeResponseCodeIs(200);
 | |
|         $I->seeResponseIsJson();
 | |
| 
 | |
|         $token = $I->grabDataFromJsonResponse('token');
 | |
|         $userId = $I->grabDataFromJsonResponse('userId');
 | |
|         $I->assertNotEmpty($token);
 | |
| 
 | |
|         $loggedIn = User::where('token', $token)->where('id', $userId)->first();
 | |
|         $I->assertEquals($user->id, $loggedIn->id);
 | |
|     }
 | |
| 
 | |
|     public function loginWithUsername(ApiTester $I)
 | |
|     {
 | |
|         $I->wantTo('login via API with username');
 | |
| 
 | |
|         $user = $I->haveAnAccount([
 | |
|             'username' => 'tobscure',
 | |
|             'password' => 'pass7word'
 | |
|         ]);
 | |
| 
 | |
|         $I->login('tobscure', 'pass7word');
 | |
|         $I->seeResponseCodeIs(200);
 | |
|         $I->seeResponseIsJson();
 | |
| 
 | |
|         $token = $I->grabDataFromJsonResponse('token');
 | |
|         $userId = $I->grabDataFromJsonResponse('userId');
 | |
|         $I->assertNotEmpty($token);
 | |
| 
 | |
|         $loggedIn = User::where('token', $token)->where('id', $userId)->first();
 | |
|         $I->assertEquals($user->id, $loggedIn->id);
 | |
|     }
 | |
| 
 | |
|     public function invalidLogin(ApiTester $I)
 | |
|     {
 | |
|         $user = $I->haveAnAccount([
 | |
|             'email' => 'foo@bar.com',
 | |
|             'password' => 'pass7word'
 | |
|         ]);
 | |
| 
 | |
|         $I->login('foo@bar.com', 'incorrect');
 | |
|         $I->seeResponseCodeIs(401);
 | |
|         $I->seeResponseIsJson();
 | |
|     }
 | |
| }
 |