This repository has been archived on 2024-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
devicehub-teal/tests/test_metrics.py

404 lines
15 KiB
Python
Raw Permalink Normal View History

2020-11-24 20:15:49 +00:00
import pytest
from ereuse_devicehub.client import UserClient
from ereuse_devicehub.resources.action import models as ma
2021-10-14 10:56:33 +00:00
from ereuse_devicehub.resources.documents import documents
2021-10-19 16:19:25 +00:00
from ereuse_devicehub.resources.lot.models import Lot
from ereuse_devicehub.resources.tradedocument.models import TradeDocument
2020-11-24 20:15:49 +00:00
from tests import conftest
2022-12-19 19:03:34 +00:00
from tests.conftest import file, json_encode, yaml2json
2020-11-24 20:15:49 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_simple_metrics(user: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics"""
2020-11-24 20:15:49 +00:00
# Insert computer
2021-07-02 15:40:20 +00:00
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
acer = yaml2json('acer.happy.battery.snapshot')
user.post(json_encode(lenovo), res=ma.Snapshot)
snapshot, _ = user.post(json_encode(acer), res=ma.Snapshot)
2020-11-24 20:15:49 +00:00
device_id = snapshot['device']['id']
2022-12-19 19:03:34 +00:00
post_request = {
"transaction": "ccc",
"name": "John",
"endUsers": 1,
"finalUserCode": "abcdefjhi",
"devices": [device_id],
"description": "aaa",
"startTime": "2020-11-01T02:00:00+00:00",
"endTime": "2020-12-01T02:00:00+00:00",
}
2020-11-24 20:15:49 +00:00
# Create Allocate
user.post(res=ma.Allocate, data=post_request)
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec3"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd_action = [a for a in hdd['actions'] if a['type'] == 'TestDataStorage'][0]
hdd_action['powerCycleCount'] += 1000
2020-12-29 18:54:00 +00:00
acer.pop('elapsed')
acer['licence_version'] = '1.0.0'
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Create a live
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec4"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd_action = [a for a in hdd['actions'] if a['type'] == 'TestDataStorage'][0]
hdd_action['powerCycleCount'] += 1000
2020-12-29 18:54:00 +00:00
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Create an other live
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec5"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd_action = [a for a in hdd['actions'] if a['type'] == 'TestDataStorage'][0]
hdd_action['powerCycleCount'] += 1000
2020-12-29 18:54:00 +00:00
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Check metrics
2020-11-25 12:58:32 +00:00
metrics = {'allocateds': 1, 'live': 1}
res, _ = user.get("/metrics/")
2020-11-24 20:15:49 +00:00
assert res == metrics
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_second_hdd_metrics(user: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics"""
2020-11-24 20:15:49 +00:00
# Insert computer
2021-07-02 15:40:20 +00:00
acer = yaml2json('acer.happy.battery.snapshot')
snapshot, _ = user.post(json_encode(acer), res=ma.Snapshot)
2020-11-24 20:15:49 +00:00
device_id = snapshot['device']['id']
2022-12-19 19:03:34 +00:00
post_request = {
"transaction": "ccc",
"name": "John",
"endUsers": 1,
"finalUserCode": "abcdefjhi",
"devices": [device_id],
"description": "aaa",
"startTime": "2020-11-01T02:00:00+00:00",
"endTime": "2020-12-01T02:00:00+00:00",
}
2020-11-24 20:15:49 +00:00
# Create Allocate
user.post(res=ma.Allocate, data=post_request)
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec3"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd_action = [a for a in hdd['actions'] if a['type'] == 'TestDataStorage'][0]
hdd_action['powerCycleCount'] += 1000
2020-12-29 18:54:00 +00:00
acer.pop('elapsed')
acer['licence_version'] = '1.0.0'
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Create a live
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec4"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd_action = [a for a in hdd['actions'] if a['type'] == 'TestDataStorage'][0]
hdd_action['powerCycleCount'] += 1000
2020-12-29 18:54:00 +00:00
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Create a second device
acer['uuid'] = "490fb8c0-81a1-42e9-95e0-5e7db7038ec5"
hdd = [c for c in acer['components'] if c['type'] == 'HardDrive'][0]
hdd['serialNumber'] = 'WD-WX11A80W7440'
2020-12-29 18:54:00 +00:00
user.post(acer, res=ma.Live)
2020-11-24 20:15:49 +00:00
# Check metrics if we change the hdd we need a result of one device
metrics = {'allocateds': 1, 'live': 1}
res, _ = user.get("/metrics/")
2020-11-24 20:15:49 +00:00
assert res == metrics
2020-11-25 16:46:58 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_metrics_with_live_null(user: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics"""
2020-11-25 16:46:58 +00:00
# Insert computer
acer = file('acer.happy.battery.snapshot')
snapshot, _ = user.post(acer, res=ma.Snapshot)
device_id = snapshot['device']['id']
2022-12-19 19:03:34 +00:00
post_request = {
"transaction": "ccc",
"name": "John",
"endUsers": 1,
"finalUserCode": "abcdefjhi",
"devices": [device_id],
"description": "aaa",
"startTime": "2020-11-01T02:00:00+00:00",
"endTime": "2020-12-01T02:00:00+00:00",
}
2020-11-25 16:46:58 +00:00
# Create Allocate
user.post(res=ma.Allocate, data=post_request)
# Check metrics if we change the hdd we need a result of one device
metrics = {'allocateds': 1, 'live': 0}
res, _ = user.get("/metrics/")
assert res == metrics
2021-10-14 10:56:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_metrics_action_status(user: UserClient, user2: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics."""
2021-10-14 10:56:33 +00:00
# Insert computer
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
snap, _ = user.post(json_encode(lenovo), res=ma.Snapshot)
2021-12-09 09:59:26 +00:00
device_id = snap['device']['id']
action = {'type': ma.Use.t, 'devices': [device_id]}
2021-10-14 10:56:33 +00:00
action_use, _ = user.post(action, res=ma.Action)
2022-12-19 19:03:34 +00:00
csv_str, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [device_id]})],
)
head = (
'"DHID";"Hid";"Document-Name";"Action-Type";"Action-User-LastOwner-Supplier";'
)
head += '"Action-User-LastOwner-Receiver";"Action-Create-By";"Trade-Confirmed";'
head += '"Status-Created-By-Supplier-About-Reciber";"Status-Receiver";'
head += '"Status Supplier Created Date";"Status Receiver Created Date";"Trade-Weight";'
head += '"Action-Create";"Allocate-Start";"Allocate-User-Code";"Allocate-NumUsers";'
head += '"UsageTimeAllocate";"Type";"LiveCreate";"UsageTimeHdd"\n'
body = '"O48N2";"adebcc5506213fac43cd8473a9c81bcf0cadaed9cb98b2eae651e377a3533c5a";'
body += '"";"Status";"";"foo@foo.com";"Receiver";"";"";"Use";"";"'
2021-10-14 16:13:20 +00:00
assert head in csv_str
assert body in csv_str
2021-10-14 10:56:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
2021-10-19 16:19:25 +00:00
def test_complet_metrics_with_trade(user: UserClient, user2: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics in a trade enviroment."""
2021-10-14 10:56:33 +00:00
# Insert computer
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
acer = yaml2json('acer.happy.battery.snapshot')
snap1, _ = user.post(json_encode(lenovo), res=ma.Snapshot)
snap2, _ = user.post(json_encode(acer), res=ma.Snapshot)
lot, _ = user.post({'name': 'MyLot'}, res=Lot)
2021-12-09 09:59:26 +00:00
device1_id = snap1['device']['id']
device2_id = snap2['device']['id']
devices_id = [device1_id, device2_id]
2022-12-19 19:03:34 +00:00
devices = [('id', device1_id), ('id', snap2['device']['id'])]
lot, _ = user.post({}, res=Lot, item='{}/devices'.format(lot['id']), query=devices)
2021-11-02 11:47:23 +00:00
2021-12-09 09:59:26 +00:00
action = {'type': ma.Refurbish.t, 'devices': [device1_id]}
2021-11-02 11:47:23 +00:00
user.post(action, res=ma.Action)
2021-10-19 16:19:25 +00:00
request_post = {
'type': 'Trade',
2021-12-09 09:59:26 +00:00
'devices': devices_id,
2021-10-19 16:19:25 +00:00
'userFromEmail': user.email,
'userToEmail': user2.email,
'price': 10,
'date': "2020-12-01T02:00:00+00:00",
'lot': lot['id'],
'confirms': True,
}
user.post(res=ma.Action, data=request_post)
2021-12-09 09:59:26 +00:00
action = {'type': ma.Use.t, 'devices': [device1_id]}
2021-10-19 16:19:25 +00:00
action_use, _ = user.post(action, res=ma.Action)
2022-12-19 19:03:34 +00:00
csv_str, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': devices_id})],
)
body1_lenovo = '"O48N2";"adebcc5506213fac43cd8473a9c81bcf0cadaed9cb98b2eae651e377a3533c5a";"";"Trade";"foo@foo.com";'
2022-08-01 18:06:47 +00:00
body1_lenovo += '"foo2@foo.com";"Supplier";"NeedConfirmation";"Use";"";'
body2_lenovo = ';"";"0";"0";"Trade";"0";"0"\n'
2021-10-19 16:19:25 +00:00
2022-12-19 19:03:34 +00:00
body1_acer = '"K3XW2";"55b1f6d0692d1569c7590f0aeabd1c9874a1c78b8dd3a7d481df95923a629748";"";"Trade";'
body1_acer += (
'"foo@foo.com";"foo2@foo.com";"Supplier";"NeedConfirmation";"";"";"";"";"0";'
)
2022-08-01 18:06:47 +00:00
body2_acer = ';"";"0";"0";"Trade";"0";"4692.0"\n'
2021-10-19 16:19:25 +00:00
assert body1_lenovo in csv_str
assert body2_lenovo in csv_str
assert body1_acer in csv_str
assert body2_acer in csv_str
# User2 mark this device as Refurbish
2021-12-09 09:59:26 +00:00
action = {'type': ma.Use.t, 'devices': [device1_id]}
2021-10-19 16:19:25 +00:00
action_use2, _ = user2.post(action, res=ma.Action)
2022-12-19 19:03:34 +00:00
csv_str, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': devices_id})],
)
body1_lenovo = '"O48N2";"adebcc5506213fac43cd8473a9c81bcf0cadaed9cb98b2eae651e377a3533c5a";"";"Trade";"foo@foo.com";'
2022-08-01 18:06:47 +00:00
body1_lenovo += '"foo2@foo.com";"Supplier";"NeedConfirmation";"Use";"Use";'
body2_lenovo = ';"";"0";"0";"Trade";"0";"0"\n'
body2_acer = ';"";"0";"0";"Trade";"0";"4692.0"\n'
2021-11-03 09:37:15 +00:00
assert body1_lenovo in csv_str
assert body2_lenovo in csv_str
assert body2_acer in csv_str
2021-10-19 16:19:25 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_metrics_action_status_for_containers(user: UserClient, user2: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks one standard query of metrics for a container."""
2021-10-19 16:19:25 +00:00
# Insert computer
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
snap, _ = user.post(json_encode(lenovo), res=ma.Snapshot)
lot, _ = user.post({'name': 'MyLot'}, res=Lot)
devices = [('id', snap['device']['id'])]
2022-12-19 19:03:34 +00:00
lot, _ = user.post({}, res=Lot, item='{}/devices'.format(lot['id']), query=devices)
2021-10-19 16:19:25 +00:00
request_post = {
'type': 'Trade',
'devices': [snap['device']['id']],
'userFromEmail': user.email,
'userToEmail': user2.email,
'price': 10,
'date': "2020-12-01T02:00:00+00:00",
'lot': lot['id'],
'confirms': True,
}
user.post(res=ma.Action, data=request_post)
request_post = {
'filename': 'test.pdf',
'hash': 'bbbbbbbb',
'url': 'http://www.ereuse.org/',
'weight': 150,
2022-12-19 19:03:34 +00:00
'lot': lot['id'],
2021-10-19 16:19:25 +00:00
}
tradedocument, _ = user.post(res=TradeDocument, data=request_post)
action = {'type': ma.Recycling.t, 'devices': [], 'documents': [tradedocument['id']]}
action, _ = user.post(action, res=ma.Action)
trade = TradeDocument.query.one()
assert str(trade.actions[-1].id) == action['id']
2021-12-09 09:59:26 +00:00
# get metrics from botom in lot menu
2022-12-19 19:03:34 +00:00
csv_str, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer']}), ('lot', lot['id'])],
)
2021-10-19 16:19:25 +00:00
2022-08-01 18:06:47 +00:00
body1 = ';"bbbbbbbb";"test.pdf";"Trade-Container";"foo@foo.com";"foo2@foo.com";"Supplier";"False";"Recycling";"";'
body2 = ';"";"150.0";'
body3 = ';"";"0";"0";"Trade-Container";"0";"0"'
2021-12-09 09:59:26 +00:00
assert len(csv_str.split('\n')) == 3
2021-10-20 12:53:33 +00:00
assert body1 in csv_str.split('\n')[-2]
assert body2 in csv_str.split('\n')[-2]
2021-11-23 10:26:21 +00:00
assert body3 in csv_str.split('\n')[-2]
2021-10-20 12:53:33 +00:00
2021-12-09 09:59:26 +00:00
# get metrics from botom in devices menu
2022-12-19 19:03:34 +00:00
csv_str2, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [snap['device']['id']]})],
)
2021-12-09 09:59:26 +00:00
assert len(csv_str2.split('\n')) == 4
assert body1 in csv_str2.split('\n')[-2]
assert body2 in csv_str2.split('\n')[-2]
assert body3 in csv_str2.split('\n')[-2]
2021-10-20 12:53:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_visual_metrics_for_old_owners(user: UserClient, user2: UserClient):
2022-12-19 19:03:34 +00:00
"""Checks if one old owner can see the metrics in a trade enviroment."""
2021-10-20 12:53:33 +00:00
# Insert computer
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
snap1, _ = user.post(json_encode(lenovo), res=ma.Snapshot)
lot, _ = user.post({'name': 'MyLot'}, res=Lot)
2021-12-09 09:59:26 +00:00
device_id = snap1['device']['id']
devices = [('id', device_id)]
2022-12-19 19:03:34 +00:00
lot, _ = user.post({}, res=Lot, item='{}/devices'.format(lot['id']), query=devices)
2021-10-20 12:53:33 +00:00
request_post = {
'type': 'Trade',
2021-12-09 09:59:26 +00:00
'devices': [device_id],
2021-10-20 12:53:33 +00:00
'userFromEmail': user.email,
'userToEmail': user2.email,
'price': 10,
'date': "2020-12-01T02:00:00+00:00",
'lot': lot['id'],
'confirms': True,
}
trade, _ = user.post(res=ma.Action, data=request_post)
2022-12-19 19:03:34 +00:00
request_confirm = {'type': 'Confirm', 'action': trade['id'], 'devices': [device_id]}
2021-10-20 12:53:33 +00:00
user2.post(res=ma.Action, data=request_confirm)
2021-12-09 09:59:26 +00:00
action = {'type': ma.Refurbish.t, 'devices': [device_id]}
2021-10-20 12:53:33 +00:00
action_use, _ = user.post(action, res=ma.Action)
2022-12-19 19:03:34 +00:00
csv_supplier, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [device_id]})],
)
csv_receiver, _ = user2.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [device_id]})],
)
2022-08-01 18:06:47 +00:00
body = ';"";"0";"0";"Trade";"0";"0"\n'
2021-10-20 12:53:33 +00:00
assert body in csv_receiver
assert body in csv_supplier
2021-10-25 08:43:28 +00:00
assert csv_receiver == csv_supplier
@pytest.mark.mvp
@pytest.mark.usefixtures(conftest.app_context.__name__)
def test_bug_trade_confirmed(user: UserClient, user2: UserClient):
"""When the receiber do a Trade, then the confirmation is wrong."""
lenovo = yaml2json('desktop-9644w8n-lenovo-0169622.snapshot')
snap1, _ = user.post(json_encode(lenovo), res=ma.Snapshot)
lot, _ = user.post({'name': 'MyLot'}, res=Lot)
2021-12-09 09:59:26 +00:00
device_id = snap1['device']['id']
devices = [('id', device_id)]
2022-12-19 19:03:34 +00:00
lot, _ = user.post({}, res=Lot, item='{}/devices'.format(lot['id']), query=devices)
2021-10-25 08:43:28 +00:00
request_post = {
'type': 'Trade',
2021-12-09 09:59:26 +00:00
'devices': [device_id],
2021-10-25 08:43:28 +00:00
'userFromEmail': user2.email,
'userToEmail': user.email,
'price': 10,
'date': "2020-12-01T02:00:00+00:00",
'lot': lot['id'],
'confirms': True,
}
trade, _ = user.post(res=ma.Action, data=request_post)
2022-12-19 19:03:34 +00:00
csv_not_confirmed, _ = user.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [device_id]})],
)
request_confirm = {'type': 'Confirm', 'action': trade['id'], 'devices': [device_id]}
2021-10-25 08:43:28 +00:00
user2.post(res=ma.Action, data=request_confirm)
2022-12-19 19:03:34 +00:00
csv_confirmed, _ = user2.get(
res=documents.DocumentDef.t,
item='actions/',
accept='text/csv',
query=[('filter', {'type': ['Computer'], 'ids': [device_id]})],
)
body_not_confirmed = (
'"Trade";"foo2@foo.com";"foo@foo.com";"Receiver";"NeedConfirmation";'
)
2022-08-01 18:06:47 +00:00
body_confirmed = '"Trade";"foo2@foo.com";"foo@foo.com";"Receiver";"TradeConfirmed";'
2021-10-25 08:43:28 +00:00
assert body_not_confirmed in csv_not_confirmed
assert body_confirmed in csv_confirmed