douzhan4522 2016-10-20 10:19
浏览 94
已采纳

使用JWT-Auth进行Laravel测试

I'm trying to test my api that's made with JWT_auth: https://github.com/tymondesigns/jwt-auth

class UpdateTest extends TestCase
{
    use DatabaseTransactions;

    public $token;

    public function signIn($data = ['email'=>'mail@gmail.com', 'password'=>'secret'])
    {
        $this->post('api/login', $data);
        $content = json_decode($this->response->getContent());
        $this->assertObjectHasAttribute('token', $content);
        $this->token = $content->token;

        return $this;
    }

    /** @test */
    public function a_user_updates_his_account()
    {
        factory(User::class)->create([
            'name'              => 'Test',
            'last_name'         => 'Test',
            'email'             => 'mail@gmail.com',
            'mobile'            => '062348383',
            'function'          => 'ceo',
            'about'             => 'About me.....',
            'corporation_id'    => 1
        ]);

        $user = User::first();
        $user->active = 2;
        $user->save();

        $this->signIn();

        $url = '/api/user/' . $user->slug . '?token=' . $this->token;
        $result = $this->json('GET', $url);
        dd($result);
    }
}

Result is always:

The token could not be parsed from the request

How do I get this t work!?

Source (https://github.com/tymondesigns/jwt-auth/issues/206)

  • 写回答

2条回答 默认 最新

  • douzhan8303 2016-10-20 21:51
    关注

    One way to test your API in this situation is to bypass the actual token verification, but still log your user in (if you need to identify the user). Here is a snippet of the helper method we used in our recent API-based application.

    /**
     * Simulate call api
     *
     * @param  string $endpoint
     * @param  array  $params
     * @param  string $asUser
     *
     * @return mixed
     */
    protected function callApi($endpoint, $params = [], $asUser = 'user@example.org')
    {
        $endpoint = starts_with($endpoint, '/')
            ? $endpoint
            : '/' . $endpoint;
    
        $headers = [];
    
        if (!is_null($asUser)) {
            $token = auth()->guard('api')
                ->login(\Models\User::whereEmail($asUser)->first());
    
            $headers['Authorization'] = 'Bearer ' . $token;
        }
    
        return $this->json(
            'POST', 
            'http://api.dev/' . $endpoint,
            $params,
            $headers
        );
    }
    

    And is used like this:

    $this->callApi('orders/list', [
            'type' => 'customers' 
        ])
        ->seeStatusOk()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?