2017-04-15 12:53:08 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2017-04-18 14:16:24 +00:00
|
|
|
import pytest
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
from unittest import mock
|
2017-12-30 15:30:35 +00:00
|
|
|
|
2017-04-18 14:16:24 +00:00
|
|
|
from toot import App, CLIENT_NAME, CLIENT_WEBSITE
|
|
|
|
from toot.api import create_app, login, SCOPES, AuthenticationError
|
2018-06-07 08:00:50 +00:00
|
|
|
from tests.utils import MockResponse
|
2017-04-15 12:46:22 +00:00
|
|
|
|
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
@mock.patch('toot.http.anon_post')
|
|
|
|
def test_create_app(mock_post):
|
|
|
|
mock_post.return_value = MockResponse({
|
|
|
|
'client_id': 'foo',
|
|
|
|
'client_secret': 'bar',
|
|
|
|
})
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2017-12-30 15:30:35 +00:00
|
|
|
create_app('bigfish.software')
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
mock_post.assert_called_once_with('https://bigfish.software/api/v1/apps', {
|
|
|
|
'website': CLIENT_WEBSITE,
|
|
|
|
'client_name': CLIENT_NAME,
|
|
|
|
'scopes': SCOPES,
|
|
|
|
'redirect_uris': 'urn:ietf:wg:oauth:2.0:oob',
|
|
|
|
})
|
|
|
|
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
@mock.patch('toot.http.anon_post')
|
|
|
|
def test_login(mock_post):
|
2017-04-18 14:16:24 +00:00
|
|
|
app = App('bigfish.software', 'https://bigfish.software', 'foo', 'bar')
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2017-12-30 15:30:35 +00:00
|
|
|
data = {
|
|
|
|
'grant_type': 'password',
|
|
|
|
'client_id': app.client_id,
|
|
|
|
'client_secret': app.client_secret,
|
|
|
|
'username': 'user',
|
|
|
|
'password': 'pass',
|
|
|
|
'scope': SCOPES,
|
|
|
|
}
|
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
mock_post.return_value = MockResponse({
|
2017-04-18 14:16:24 +00:00
|
|
|
'token_type': 'bearer',
|
|
|
|
'scope': 'read write follow',
|
|
|
|
'access_token': 'xxx',
|
|
|
|
'created_at': 1492523699
|
2017-12-30 15:30:35 +00:00
|
|
|
})
|
2017-04-18 14:16:24 +00:00
|
|
|
|
2017-12-30 15:30:35 +00:00
|
|
|
login(app, 'user', 'pass')
|
2017-04-18 14:16:24 +00:00
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
mock_post.assert_called_once_with(
|
|
|
|
'https://bigfish.software/oauth/token', data, allow_redirects=False)
|
|
|
|
|
2017-04-18 14:16:24 +00:00
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
@mock.patch('toot.http.anon_post')
|
|
|
|
def test_login_failed(mock_post):
|
2017-04-18 14:16:24 +00:00
|
|
|
app = App('bigfish.software', 'https://bigfish.software', 'foo', 'bar')
|
|
|
|
|
2017-12-30 15:30:35 +00:00
|
|
|
data = {
|
|
|
|
'grant_type': 'password',
|
|
|
|
'client_id': app.client_id,
|
|
|
|
'client_secret': app.client_secret,
|
|
|
|
'username': 'user',
|
|
|
|
'password': 'pass',
|
|
|
|
'scope': SCOPES,
|
|
|
|
}
|
|
|
|
|
2018-06-07 08:00:50 +00:00
|
|
|
mock_post.return_value = MockResponse(is_redirect=True)
|
2017-04-15 12:46:22 +00:00
|
|
|
|
2017-04-18 14:16:24 +00:00
|
|
|
with pytest.raises(AuthenticationError):
|
|
|
|
login(app, 'user', 'pass')
|
2018-06-07 08:00:50 +00:00
|
|
|
|
|
|
|
mock_post.assert_called_once_with(
|
|
|
|
'https://bigfish.software/oauth/token', data, allow_redirects=False)
|