Как насмехаться с tymondesigns/jwt-auth в Laravel 5?

Я просто добавил tymondesigns/jwt-auth для поддержки авторизации токенов, и, следовательно, мои тестовые примеры не работают, потому что в параметрах заголовков нет токена. Как я могу издеваться (используя Mockery) компонент, чтобы обойти это?

Примечание. $this->be() не работает

Ответ 1

Альтернатива - это аутентификация запроса во время выполнения теста, передаваемого конкретному пользователю. Вот как это было:

# tests/TestCase.php

/**
 * Return request headers needed to interact with the API.
 *
 * @return Array array of headers.
 */
protected function headers($user = null)
{
    $headers = ['Accept' => 'application/json'];

    if (!is_null($user)) {
        $token = JWTAuth::fromUser($user);
        JWTAuth::setToken($token);
        $headers['Authorization'] = 'Bearer '.$token;
    }

    return $headers;
}

Затем в моих тестах я использую его следующим образом:

# tests/StuffTest.php

/**
 * Test: GET /api/stuff.
 */
public function testIndex()
{
    $url = '/api/stuff';

    // Test unauthenticated access.
    $this->get($url, $this->headers())
         ->assertResponseStatus(400);

    // Test authenticated access.
    $this->get($url, $this->headers(User::first()))
         ->seeJson()
         ->assertResponseOk();
}

Надеюсь, это поможет всем вам. Счастливое кодирование!