1
0
mirror of https://github.com/ihabunek/toot.git synced 2024-11-03 04:17:21 -05:00
toot/tests/test_api.py

81 lines
2.2 KiB
Python
Raw Normal View History

2017-04-15 08:53:08 -04:00
# -*- coding: utf-8 -*-
import pytest
2017-04-15 08:46:22 -04:00
import requests
from toot import App, CLIENT_NAME, CLIENT_WEBSITE
from toot.api import create_app, login, SCOPES, AuthenticationError
from tests.utils import MockResponse
2017-04-15 08:46:22 -04:00
def test_create_app(monkeypatch):
response = {
'client_id': 'foo',
'client_secret': 'bar',
}
2017-04-15 08:46:22 -04:00
def mock_post(url, data):
assert url == 'https://bigfish.software/api/v1/apps'
assert data == {
2017-04-16 08:14:33 -04:00
'website': CLIENT_WEBSITE,
2017-04-15 08:46:22 -04:00
'client_name': CLIENT_NAME,
'scopes': SCOPES,
'redirect_uris': 'urn:ietf:wg:oauth:2.0:oob'
}
return MockResponse(response)
2017-04-15 08:46:22 -04:00
monkeypatch.setattr(requests, 'post', mock_post)
assert create_app('bigfish.software') == response
2017-04-15 08:46:22 -04:00
def test_login(monkeypatch):
app = App('bigfish.software', 'https://bigfish.software', 'foo', 'bar')
2017-04-15 08:46:22 -04:00
response = {
'token_type': 'bearer',
'scope': 'read write follow',
'access_token': 'xxx',
'created_at': 1492523699
}
def mock_post(url, data, allow_redirects):
assert not allow_redirects
2017-04-15 08:46:22 -04:00
assert url == 'https://bigfish.software/oauth/token'
assert data == {
'grant_type': 'password',
'client_id': app.client_id,
'client_secret': app.client_secret,
'username': 'user',
'password': 'pass',
'scope': SCOPES,
}
return MockResponse(response)
2017-04-15 08:46:22 -04:00
monkeypatch.setattr(requests, 'post', mock_post)
assert login(app, 'user', 'pass') == response
def test_login_failed(monkeypatch):
app = App('bigfish.software', 'https://bigfish.software', 'foo', 'bar')
def mock_post(url, data, allow_redirects):
assert not allow_redirects
assert url == 'https://bigfish.software/oauth/token'
assert data == {
'grant_type': 'password',
'client_id': app.client_id,
'client_secret': app.client_secret,
'username': 'user',
'password': 'pass',
'scope': SCOPES,
}
return MockResponse(is_redirect=True)
monkeypatch.setattr(requests, 'post', mock_post)
2017-04-15 08:46:22 -04:00
with pytest.raises(AuthenticationError):
login(app, 'user', 'pass')