lemur/lemur/tests/test_accounts.py

133 lines
4.9 KiB
Python
Raw Normal View History

2015-06-25 01:48:40 +02:00
from lemur.accounts.service import *
from lemur.accounts.views import *
from json import dumps
2015-06-25 01:48:40 +02:00
def test_crud(session):
account = create('111111', 'account1')
assert account.id > 0
2015-06-25 01:48:40 +02:00
account = update(account.id, 11111, 'account2')
assert account.label == 'account2'
2015-06-25 01:48:40 +02:00
assert len(get_all()) == 1
2015-06-25 01:48:40 +02:00
delete(1)
assert len(get_all()) == 0
2015-06-25 01:48:40 +02:00
def test_account_get(client):
2015-06-25 01:48:40 +02:00
assert client.get(api.url_for(Accounts, account_id=1)).status_code == 401
def test_account_post(client):
2015-07-06 19:53:12 +02:00
assert client.post(api.url_for(Accounts, account_id=1), data={}).status_code == 405
def test_account_put(client):
2015-07-06 19:53:12 +02:00
assert client.put(api.url_for(Accounts, account_id=1), data={}).status_code == 401
def test_account_delete(client):
2015-06-25 01:48:40 +02:00
assert client.delete(api.url_for(Accounts, account_id=1)).status_code == 401
def test_account_patch(client):
2015-07-06 19:53:12 +02:00
assert client.patch(api.url_for(Accounts, account_id=1), data={}).status_code == 405
2015-06-25 01:48:40 +02:00
VALID_USER_HEADER_TOKEN = {
'Authorization': 'Basic ' + 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpYXQiOjE0MzUyMzMzNjksInN1YiI6MSwiZXhwIjoxNTIxNTQ2OTY5fQ.1qCi0Ip7mzKbjNh0tVd3_eJOrae3rNa_9MCVdA4WtQI'}
2015-06-26 19:31:55 +02:00
def test_auth_account_get(client):
assert client.get(api.url_for(Accounts, account_id=1), headers=VALID_USER_HEADER_TOKEN).status_code == 200
2015-06-26 19:31:55 +02:00
def test_auth_account_post_(client):
2015-07-06 19:53:12 +02:00
assert client.post(api.url_for(Accounts, account_id=1), data={}, headers=VALID_USER_HEADER_TOKEN).status_code == 405
2015-06-26 19:31:55 +02:00
def test_auth_account_put(client):
assert client.put(api.url_for(Accounts, account_id=1), data={}, headers=VALID_USER_HEADER_TOKEN).status_code == 403
2015-06-26 19:31:55 +02:00
def test_auth_account_delete(client):
assert client.delete(api.url_for(Accounts, account_id=1), headers=VALID_USER_HEADER_TOKEN).status_code == 403
2015-06-26 19:31:55 +02:00
def test_auth_account_patch(client):
2015-07-06 19:53:12 +02:00
assert client.patch(api.url_for(Accounts, account_id=1), data={}, headers=VALID_USER_HEADER_TOKEN).status_code == 405
VALID_ADMIN_HEADER_TOKEN = {
'Authorization': 'Basic ' + 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpYXQiOjE0MzUyNTAyMTgsInN1YiI6MiwiZXhwIjoxNTIxNTYzODE4fQ.6mbq4-Ro6K5MmuNiTJBB153RDhlM5LGJBjI7GBKkfqA'}
2015-06-26 19:31:55 +02:00
def test_admin_account_get(client):
assert client.get(api.url_for(Accounts, account_id=1), headers=VALID_ADMIN_HEADER_TOKEN).status_code == 200
2015-06-26 19:31:55 +02:00
def test_admin_account_post(client):
2015-07-06 19:53:12 +02:00
assert client.post(api.url_for(Accounts, account_id=1), data={}, headers=VALID_ADMIN_HEADER_TOKEN).status_code == 405
2015-06-26 19:31:55 +02:00
def test_admin_account_put(client):
assert client.put(api.url_for(Accounts, account_id=1), data={}, headers=VALID_ADMIN_HEADER_TOKEN).status_code == 400
2015-06-26 19:31:55 +02:00
def test_admin_account_delete(client):
assert client.delete(api.url_for(Accounts, account_id=1), headers=VALID_ADMIN_HEADER_TOKEN).status_code == 500
2015-06-26 19:31:55 +02:00
def test_admin_account_patch(client):
2015-07-06 19:53:12 +02:00
assert client.patch(api.url_for(Accounts, account_id=1), data={}, headers=VALID_ADMIN_HEADER_TOKEN).status_code == 405
def test_accounts_get(client):
assert client.get(api.url_for(AccountsList)).status_code == 401
def test_accounts_post(client):
2015-07-06 19:53:12 +02:00
assert client.post(api.url_for(AccountsList), data={}).status_code == 401
def test_accounts_put(client):
2015-07-06 19:53:12 +02:00
assert client.put(api.url_for(AccountsList), data={}).status_code == 405
def test_accounts_delete(client):
assert client.delete(api.url_for(AccountsList)).status_code == 405
def test_accounts_patch(client):
2015-07-06 19:53:12 +02:00
assert client.patch(api.url_for(AccountsList), data={}).status_code == 405
2015-06-26 19:31:55 +02:00
def test_auth_accounts_get(client):
assert client.get(api.url_for(AccountsList), headers=VALID_USER_HEADER_TOKEN).status_code == 200
2015-06-26 19:31:55 +02:00
def test_auth_accounts_post(client):
2015-07-06 19:53:12 +02:00
assert client.post(api.url_for(AccountsList), data={}, headers=VALID_USER_HEADER_TOKEN).status_code == 403
2015-06-26 19:31:55 +02:00
def test_admin_accounts_get(client):
resp = client.get(api.url_for(AccountsList), headers=VALID_ADMIN_HEADER_TOKEN)
assert resp.status_code == 200
assert resp.json == {'items': [], 'total': 0}
2015-06-26 19:31:55 +02:00
def test_admin_accounts_crud(client):
assert client.post(api.url_for(AccountsList), headers=VALID_ADMIN_HEADER_TOKEN).status_code == 400
data = {'accountNumber': 111, 'label': 'test', 'comments': 'test'}
resp = client.post(api.url_for(AccountsList), data=dumps(data), content_type='application/json', headers=VALID_ADMIN_HEADER_TOKEN)
assert resp.status_code == 200
assert client.get(api.url_for(Accounts, account_id=resp.json['id']), headers=VALID_ADMIN_HEADER_TOKEN).status_code == 200
resp = client.get(api.url_for(AccountsList), headers=VALID_ADMIN_HEADER_TOKEN)
assert resp.status_code == 200
assert resp.json == {'items': [{'accountNumber': 111, 'label': 'test', 'comments': 'test', 'id': 2}], 'total': 1}
assert client.delete(api.url_for(Accounts, account_id=2), headers=VALID_ADMIN_HEADER_TOKEN).status_code == 200
resp = client.get(api.url_for(AccountsList), headers=VALID_ADMIN_HEADER_TOKEN)
assert resp.status_code == 200
assert resp.json == {'items': [], 'total': 0}