Laravel Passport and different database for testing.

Posted 8 months ago by vladistick

Hello guys, I'm having terrible luck finding an anwser to my question anywhere so I thought I will ask on this forum. I'm trying to make some unit tests for API. I'm using Laravel Passport. I'm using different database for testing, the whole testing environment is located in .env.testing file, however, whenever I try to run any controllers functions related to creating a tokens in database, they use a database from .env files.

Here is what I mean by that Function to login an user:

public function login($email, $password)
    {
        if (Auth::attempt(['email' => $email, 'password' => $password])) {
            $http = new GuzzleHttp\Client;

            $response = $http->post(url('oauth/token'), [
                'form_params' => [
                    'grant_type' => 'password',
                    'client_id' => '2',
                    'client_secret' => $this->secret,
                    'username' => $email,
                    'password' => $password,
                    'scope' => '',
                ],
            ]);
            return response(['data' => json_decode((string)$response->getBody(), true)]);
        }
        else {
            return response()->json(['error' => 'Unauthorised'], 401);
        }

    }

Function to test if user logs in:

 public function testUserLoginsSuccessfully()
    {
       $response=$this->userService->
       login('[email protected]', 'secret');

    }

When I use phpunit, I get the error "GuzzleHttp\Exception\ClientException: Client error: POST http://127.0.0.1:8000/oauth/token resulted in a 401 Unauthorized response: {"error":"invalid_credentials","message":"The user credentials were incorrect."}"

When I change the .env.testing database to the one in .env everything works fine. Any ideas how to solve this?

Please sign in or create an account to participate in this conversation.

Reply to

Use Markdown with GitHub-flavored code blocks.