framework/tests/_support/ApiHelper.php
Toby Zerner 2c46888db5 Upgrade to L5 + huge refactor + more. closes #2
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!
2015-02-24 20:33:18 +10:30

40 lines
925 B
PHP

<?php
namespace Codeception\Module;
use Laracasts\TestDummy\Factory;
class ApiHelper extends \Codeception\Module
{
public function haveAnAccount($data = [])
{
$user = Factory::create('Flarum\Core\Models\User', $data);
$user->activate();
return $user;
}
public function login($identification, $password)
{
$this->getModule('REST')->sendPOST('/api/token', [
'identification' => $identification,
'password' => $password
]);
$response = json_decode($this->getModule('REST')->grabResponse(), true);
if ($response && is_array($response) && isset($response['token'])) {
return $response['token'];
}
return false;
}
public function amAuthenticated()
{
$user = $this->haveAnAccount();
$token = $this->login($user->email, 'password');
$this->getModule('REST')->haveHttpHeader('Authorization', 'Token '.$token);
return $user;
}
}