|
1 | 1 | import pytest
|
2 | 2 | import os
|
3 | 3 |
|
4 |
| -from farmOS import farmOS, HTTPError |
5 |
| -from oauthlib.oauth2 import InvalidGrantError |
| 4 | +from farmOS import farmOS, HTTPError, InvalidGrantError, InvalidClientError, InvalidScopeError |
6 | 5 |
|
7 | 6 | from tests.conftest import farmOS_testing_server
|
8 | 7 |
|
| 8 | +# Variables for testing. |
| 9 | +FARMOS_HOSTNAME = os.getenv("FARMOS_HOSTNAME") |
| 10 | +FARMOS_OAUTH_USERNAME = os.getenv("FARMOS_OAUTH_USERNAME") |
| 11 | +FARMOS_OAUTH_PASSWORD = os.getenv("FARMOS_OAUTH_PASSWORD") |
| 12 | + |
9 | 13 |
|
10 |
| -# Test authentication |
11 | 14 | @farmOS_testing_server
|
12 | 15 | def test_invalid_login():
|
13 | 16 | with pytest.raises(InvalidGrantError):
|
14 |
| - farm = farmOS('test.farmos.net') |
| 17 | + farm = farmOS(FARMOS_HOSTNAME) |
15 | 18 | farm.authorize('username', 'password')
|
16 | 19 |
|
17 | 20 |
|
| 21 | +@farmOS_testing_server |
| 22 | +def test_invalid_client_id(): |
| 23 | + with pytest.raises(InvalidClientError): |
| 24 | + farm = farmOS(FARMOS_HOSTNAME, client_id='bad_client') |
| 25 | + farm.authorize(FARMOS_OAUTH_USERNAME, FARMOS_OAUTH_PASSWORD) |
| 26 | + |
| 27 | + |
| 28 | +@farmOS_testing_server |
| 29 | +def test_invalid_client_secret(): |
| 30 | + with pytest.raises(InvalidClientError): |
| 31 | + farm = farmOS(FARMOS_HOSTNAME, client_id='farm', client_secret='bad_pass') |
| 32 | + farm.authorize(FARMOS_OAUTH_USERNAME, FARMOS_OAUTH_PASSWORD) |
| 33 | + |
| 34 | + |
| 35 | +@farmOS_testing_server |
| 36 | +def test_invalid_scopet(): |
| 37 | + with pytest.raises(InvalidScopeError): |
| 38 | + farm = farmOS(FARMOS_HOSTNAME, scope="bad_scope") |
| 39 | + farm.authorize(FARMOS_OAUTH_USERNAME, FARMOS_OAUTH_PASSWORD, scope="bad_scope") |
| 40 | + |
| 41 | + |
18 | 42 | @farmOS_testing_server
|
19 | 43 | def test_unauthorized_request(test_farm):
|
20 | 44 | with pytest.raises(HTTPError, match=r"403 *."):
|
21 |
| - farm = farmOS('test.farmos.net') |
| 45 | + farm = farmOS(FARMOS_HOSTNAME) |
22 | 46 | farm.log.get()
|
23 | 47 |
|
24 | 48 |
|
25 | 49 | @farmOS_testing_server
|
26 | 50 | def test_valid_login(test_farm):
|
27 |
| - FARMOS_OAUTH_USERNAME = os.getenv("FARMOS_OAUTH_USERNAME") |
28 |
| - FARMOS_OAUTH_PASSWORD = os.getenv("FARMOS_OAUTH_PASSWORD") |
29 | 51 | token = test_farm.authorize(username=FARMOS_OAUTH_USERNAME, password=FARMOS_OAUTH_PASSWORD)
|
30 | 52 |
|
31 | 53 | assert 'access_token' in token
|
|
0 commit comments