2018-06-10 16:47:49 +00:00
|
|
|
"""
|
|
|
|
Tests that emulates the behaviour of a WorkbenchServer.
|
|
|
|
"""
|
2018-09-08 14:46:39 +00:00
|
|
|
import json
|
|
|
|
import pathlib
|
2018-07-19 19:25:06 +00:00
|
|
|
|
2018-06-19 16:38:42 +00:00
|
|
|
import pytest
|
2018-08-03 16:15:08 +00:00
|
|
|
|
2018-06-10 16:47:49 +00:00
|
|
|
from ereuse_devicehub.client import UserClient
|
2018-07-19 19:25:06 +00:00
|
|
|
from ereuse_devicehub.resources.device.exceptions import NeedsId
|
2018-06-10 16:47:49 +00:00
|
|
|
from ereuse_devicehub.resources.device.models import Device
|
2018-07-19 19:25:06 +00:00
|
|
|
from ereuse_devicehub.resources.event import models as em
|
2018-06-19 16:38:42 +00:00
|
|
|
from ereuse_devicehub.resources.tag.model import Tag
|
2018-06-10 16:47:49 +00:00
|
|
|
from tests.conftest import file
|
|
|
|
|
|
|
|
|
2018-06-19 16:38:42 +00:00
|
|
|
def test_workbench_server_condensed(user: UserClient):
|
|
|
|
"""
|
|
|
|
As :def:`.test_workbench_server_phases` but all the events
|
|
|
|
condensed in only one big ``Snapshot`` file, as described
|
|
|
|
in the docs.
|
|
|
|
"""
|
|
|
|
s = file('workbench-server-1.snapshot')
|
|
|
|
del s['expectedEvents']
|
|
|
|
s['device']['events'].append(file('workbench-server-2.stress-test'))
|
|
|
|
s['components'][4]['events'].extend((
|
|
|
|
file('workbench-server-3.erase'),
|
|
|
|
file('workbench-server-4.install')
|
|
|
|
))
|
2018-10-13 12:53:46 +00:00
|
|
|
s['components'][5]['events'].append(file('workbench-server-3.erase'))
|
2018-06-19 16:38:42 +00:00
|
|
|
# Create tags
|
2018-09-20 07:28:52 +00:00
|
|
|
for t in s['device']['tags']:
|
|
|
|
user.post({'id': t['id']}, res=Tag)
|
|
|
|
|
2018-07-19 19:25:06 +00:00
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
2018-06-19 16:38:42 +00:00
|
|
|
events = snapshot['events']
|
|
|
|
assert {(event['type'], event['device']) for event in events} == {
|
2018-10-13 12:53:46 +00:00
|
|
|
('AggregateRate', 1),
|
2018-06-19 16:38:42 +00:00
|
|
|
('WorkbenchRate', 1),
|
|
|
|
('BenchmarkProcessorSysbench', 5),
|
|
|
|
('StressTest', 1),
|
|
|
|
('EraseSectors', 6),
|
|
|
|
('BenchmarkRamSysbench', 1),
|
|
|
|
('BenchmarkProcessor', 5),
|
|
|
|
('Install', 6),
|
|
|
|
('EraseSectors', 7),
|
|
|
|
('BenchmarkDataStorage', 6),
|
2018-10-13 12:53:46 +00:00
|
|
|
('BenchmarkDataStorage', 7),
|
2018-06-19 16:38:42 +00:00
|
|
|
('TestDataStorage', 6)
|
|
|
|
}
|
|
|
|
assert snapshot['closed']
|
2018-11-08 16:37:14 +00:00
|
|
|
assert snapshot['severity'] == 'Info'
|
2018-10-13 12:53:46 +00:00
|
|
|
device, _ = user.get(res=Device, item=snapshot['device']['id'])
|
|
|
|
assert device['dataStorageSize'] == 1100
|
|
|
|
assert device['chassis'] == 'Tower'
|
|
|
|
assert device['hid'] == 'd1mr-d1s-d1ml'
|
|
|
|
assert device['graphicCardModel'] == device['components'][0]['model'] == 'gc1-1ml'
|
|
|
|
assert device['networkSpeeds'] == [1000, 58]
|
|
|
|
assert device['processorModel'] == device['components'][3]['model'] == 'p1-1ml'
|
|
|
|
assert device['ramSize'] == 2048, 'There are 3 RAM: 2 x 1024 and 1 None sizes'
|
|
|
|
assert device['rate']['closed']
|
2018-11-08 16:37:14 +00:00
|
|
|
assert device['rate']['severity'] == 'Info'
|
2018-10-13 12:53:46 +00:00
|
|
|
assert device['rate']['rating'] == 0
|
|
|
|
assert device['rate']['workbench']
|
2018-10-15 12:20:26 +00:00
|
|
|
assert device['rate']['appearanceRange'] == 'A'
|
|
|
|
assert device['rate']['functionalityRange'] == 'B'
|
2018-10-13 12:53:46 +00:00
|
|
|
assert device['tags'][0]['id'] == 'tag1'
|
2018-06-19 16:38:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.xfail(reason='Functionality not yet developed.')
|
2018-06-10 16:47:49 +00:00
|
|
|
def test_workbench_server_phases(user: UserClient):
|
|
|
|
"""
|
|
|
|
Tests the phases described in the docs section `Snapshots from
|
|
|
|
Workbench <http://devicehub.ereuse.org/
|
|
|
|
events.html#snapshots-from-workbench>`_.
|
|
|
|
"""
|
|
|
|
# 1. Snapshot with sync / rate / benchmarks / test data storage
|
|
|
|
s = file('workbench-server-1.snapshot')
|
2018-07-19 19:25:06 +00:00
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
2018-06-10 16:47:49 +00:00
|
|
|
assert not snapshot['closed'], 'Snapshot must be waiting for the new events'
|
|
|
|
|
|
|
|
# 2. stress test
|
|
|
|
st = file('workbench-server-2.stress-test')
|
|
|
|
st['snapshot'] = snapshot['id']
|
2018-07-19 19:25:06 +00:00
|
|
|
stress_test, _ = user.post(res=em.StressTest, data=st)
|
2018-06-10 16:47:49 +00:00
|
|
|
|
|
|
|
# 3. erase
|
|
|
|
ssd_id, hdd_id = snapshot['components'][4]['id'], snapshot['components'][5]['id']
|
|
|
|
e = file('workbench-server-3.erase')
|
|
|
|
e['snapshot'], e['device'] = snapshot['id'], ssd_id
|
2018-07-19 19:25:06 +00:00
|
|
|
erase1, _ = user.post(res=em.EraseSectors, data=e)
|
2018-06-10 16:47:49 +00:00
|
|
|
|
|
|
|
# 3 bis. a second erase
|
|
|
|
e = file('workbench-server-3.erase')
|
|
|
|
e['snapshot'], e['device'] = snapshot['id'], hdd_id
|
2018-07-19 19:25:06 +00:00
|
|
|
erase2, _ = user.post(res=em.EraseSectors, data=e)
|
2018-06-10 16:47:49 +00:00
|
|
|
|
|
|
|
# 4. Install
|
|
|
|
i = file('workbench-server-4.install')
|
|
|
|
i['snapshot'], i['device'] = snapshot['id'], ssd_id
|
2018-07-19 19:25:06 +00:00
|
|
|
install, _ = user.post(res=em.Install, data=i)
|
2018-06-10 16:47:49 +00:00
|
|
|
|
|
|
|
# Check events have been appended in Snapshot and devices
|
|
|
|
# and that Snapshot is closed
|
2018-07-19 19:25:06 +00:00
|
|
|
snapshot, _ = user.get(res=em.Snapshot, item=snapshot['id'])
|
2018-06-10 16:47:49 +00:00
|
|
|
events = snapshot['events']
|
|
|
|
assert len(events) == 9
|
|
|
|
assert events[0]['type'] == 'Rate'
|
|
|
|
assert events[0]['device'] == 1
|
|
|
|
assert events[0]['closed']
|
|
|
|
assert events[0]['type'] == 'WorkbenchRate'
|
|
|
|
assert events[0]['device'] == 1
|
|
|
|
assert events[1]['type'] == 'BenchmarkProcessor'
|
|
|
|
assert events[1]['device'] == 5
|
|
|
|
assert events[2]['type'] == 'BenchmarkProcessorSysbench'
|
|
|
|
assert events[2]['device'] == 5
|
|
|
|
assert events[3]['type'] == 'BenchmarkDataStorage'
|
|
|
|
assert events[3]['device'] == 6
|
|
|
|
assert events[4]['type'] == 'TestDataStorage'
|
|
|
|
assert events[4]['device'] == 6
|
|
|
|
assert events[4]['type'] == 'BenchmarkDataStorage'
|
|
|
|
assert events[4]['device'] == 7
|
|
|
|
assert events[5]['type'] == 'StressTest'
|
|
|
|
assert events[5]['device'] == 1
|
|
|
|
assert events[6]['type'] == 'EraseSectors'
|
|
|
|
assert events[6]['device'] == 6
|
|
|
|
assert events[7]['type'] == 'EraseSectors'
|
|
|
|
assert events[7]['device'] == 7
|
|
|
|
assert events[8]['type'] == 'Install'
|
|
|
|
assert events[8]['device'] == 6
|
|
|
|
assert snapshot['closed']
|
2018-11-08 16:37:14 +00:00
|
|
|
assert snapshot['severity'] == 'Info'
|
2018-06-10 16:47:49 +00:00
|
|
|
|
|
|
|
pc, _ = user.get(res=Device, item=snapshot['id'])
|
|
|
|
assert len(pc['events']) == 10 # todo shall I add child events?
|
2018-07-02 10:52:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_real_hp_11(user: UserClient):
|
|
|
|
s = file('real-hp.snapshot.11')
|
2018-07-19 19:25:06 +00:00
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
2018-10-13 12:53:46 +00:00
|
|
|
pc = snapshot['device']
|
|
|
|
assert pc['hid'] == 'hewlett-packard-czc0408yjg-hp_compaq_8100_elite_sff'
|
|
|
|
assert pc['chassis'] == 'Tower'
|
2018-07-02 10:52:54 +00:00
|
|
|
assert set(e['type'] for e in snapshot['events']) == {
|
2018-10-23 14:24:26 +00:00
|
|
|
'EreusePrice',
|
|
|
|
'AggregateRate',
|
|
|
|
'WorkbenchRate',
|
2018-07-02 10:52:54 +00:00
|
|
|
'BenchmarkDataStorage',
|
|
|
|
'BenchmarkProcessor',
|
|
|
|
'BenchmarkProcessorSysbench',
|
|
|
|
'TestDataStorage',
|
|
|
|
'BenchmarkRamSysbench',
|
|
|
|
'StressTest'
|
|
|
|
}
|
2018-10-23 14:24:26 +00:00
|
|
|
assert len(list(e['type'] for e in snapshot['events'])) == 9
|
2018-10-13 12:53:46 +00:00
|
|
|
assert pc['networkSpeeds'] == [1000, None], 'Device has no WiFi'
|
|
|
|
assert pc['processorModel'] == 'intel core i3 cpu 530 @ 2.93ghz'
|
|
|
|
assert pc['ramSize'] == 8192
|
|
|
|
assert pc['dataStorageSize'] == 305245
|
2018-10-23 14:24:26 +00:00
|
|
|
# todo check rating
|
2018-07-02 10:52:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_real_toshiba_11(user: UserClient):
|
|
|
|
s = file('real-toshiba.snapshot.11')
|
2018-07-19 19:25:06 +00:00
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
|
|
|
|
|
|
|
|
2018-10-27 07:06:15 +00:00
|
|
|
@pytest.mark.xfail(reason='Wrong rates values')
|
2018-10-13 12:53:46 +00:00
|
|
|
def test_snapshot_real_eee_1001pxd(user: UserClient):
|
2018-07-19 19:25:06 +00:00
|
|
|
"""
|
|
|
|
Checks the values of the device, components,
|
|
|
|
events and their relationships of a real pc.
|
|
|
|
"""
|
|
|
|
s = file('real-eee-1001pxd.snapshot.11')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
|
|
|
pc, _ = user.get(res=Device, item=snapshot['device']['id'])
|
|
|
|
assert pc['type'] == 'Laptop'
|
|
|
|
assert pc['chassis'] == 'Netbook'
|
2018-09-30 10:29:33 +00:00
|
|
|
assert pc['model'] == '1001pxd'
|
|
|
|
assert pc['serialNumber'] == 'b8oaas048286'
|
|
|
|
assert pc['manufacturer'] == 'asustek computer inc.'
|
2018-07-19 19:25:06 +00:00
|
|
|
assert pc['hid'] == 'asustek_computer_inc-b8oaas048286-1001pxd'
|
|
|
|
assert pc['tags'] == []
|
2018-10-13 12:53:46 +00:00
|
|
|
assert pc['networkSpeeds'] == [100, 0], 'Although it has WiFi we do not know the speed'
|
2018-10-23 14:24:26 +00:00
|
|
|
assert pc['rate']
|
|
|
|
rate = pc['rate']
|
|
|
|
assert rate['appearanceRange'] == 'B'
|
|
|
|
assert rate['functionalityRange'] == 'A'
|
|
|
|
assert rate['processorRange'] == 'VERY_LOW'
|
|
|
|
assert rate['ramRange'] == 'VERY_LOW'
|
|
|
|
assert rate['ratingRange'] == 'VERY_LOW'
|
|
|
|
assert rate['ram'] == 1.53
|
|
|
|
assert rate['data_storage'] == 3.76
|
|
|
|
assert rate['type'] == 'AggregateRate'
|
|
|
|
assert rate['biosRange'] == 'C'
|
|
|
|
assert rate['appearance'] > 0
|
2018-10-25 10:39:33 +00:00
|
|
|
# todo check why rate func is not > 0 is 0
|
2018-10-23 14:24:26 +00:00
|
|
|
assert rate['functionality'] > 0
|
|
|
|
assert rate['rating'] > 0 and rate['rating'] != 1
|
2018-07-19 19:25:06 +00:00
|
|
|
components = snapshot['components']
|
|
|
|
wifi = components[0]
|
|
|
|
assert wifi['hid'] == 'qualcomm_atheros-74_2f_68_8b_fd_c8-ar9285_wireless_network_adapter'
|
|
|
|
assert wifi['serialNumber'] == '74:2f:68:8b:fd:c8'
|
|
|
|
assert wifi['wireless']
|
|
|
|
eth = components[1]
|
|
|
|
assert eth['hid'] == 'qualcomm_atheros-14_da_e9_42_f6_7c-ar8152_v2_0_fast_ethernet'
|
|
|
|
assert eth['speed'] == 100
|
|
|
|
assert not eth['wireless']
|
|
|
|
cpu = components[2]
|
|
|
|
assert cpu['address'] == 64
|
|
|
|
assert cpu['cores'] == 1
|
|
|
|
assert cpu['threads'] == 1
|
|
|
|
assert cpu['speed'] == 1.667
|
|
|
|
assert 'hid' not in cpu
|
2018-10-13 12:53:46 +00:00
|
|
|
assert pc['processorModel'] == cpu['model'] == 'intel atom cpu n455 @ 1.66ghz'
|
2018-07-19 19:25:06 +00:00
|
|
|
cpu, _ = user.get(res=Device, item=cpu['id'])
|
|
|
|
events = cpu['events']
|
|
|
|
sysbench = next(e for e in events if e['type'] == em.BenchmarkProcessorSysbench.t)
|
|
|
|
assert sysbench['elapsed'] == 164
|
|
|
|
assert sysbench['rate'] == 164
|
|
|
|
assert sysbench['snapshot'] == snapshot['id']
|
|
|
|
assert sysbench['device'] == cpu['id']
|
|
|
|
assert sysbench['parent'] == pc['id']
|
|
|
|
benchmark_cpu = next(e for e in events if e['type'] == em.BenchmarkProcessor.t)
|
|
|
|
assert benchmark_cpu['rate'] == 6666
|
|
|
|
assert benchmark_cpu['elapsed'] == 0
|
|
|
|
event_types = tuple(e['type'] for e in events)
|
|
|
|
assert em.BenchmarkRamSysbench.t in event_types
|
|
|
|
assert em.StressTest.t in event_types
|
|
|
|
assert em.Snapshot.t in event_types
|
2018-10-23 14:24:26 +00:00
|
|
|
assert len(events) == 7
|
2018-07-19 19:25:06 +00:00
|
|
|
gpu = components[3]
|
2018-09-30 10:29:33 +00:00
|
|
|
assert gpu['model'] == 'atom processor d4xx/d5xx/n4xx/n5xx integrated graphics controller'
|
|
|
|
assert gpu['manufacturer'] == 'intel corporation'
|
2018-07-19 19:25:06 +00:00
|
|
|
assert gpu['memory'] == 256
|
|
|
|
gpu, _ = user.get(res=Device, item=gpu['id'])
|
|
|
|
event_types = tuple(e['type'] for e in gpu['events'])
|
|
|
|
assert em.BenchmarkRamSysbench.t in event_types
|
|
|
|
assert em.StressTest.t in event_types
|
|
|
|
assert em.Snapshot.t in event_types
|
|
|
|
assert len(event_types) == 3
|
|
|
|
sound = components[4]
|
2018-09-30 10:29:33 +00:00
|
|
|
assert sound['model'] == 'nm10/ich7 family high definition audio controller'
|
2018-07-19 19:25:06 +00:00
|
|
|
sound = components[5]
|
2018-09-30 10:29:33 +00:00
|
|
|
assert sound['model'] == 'usb 2.0 uvc vga webcam'
|
2018-07-19 19:25:06 +00:00
|
|
|
ram = components[6]
|
|
|
|
assert ram['interface'] == 'DDR2'
|
|
|
|
assert ram['speed'] == 667
|
2018-10-13 12:53:46 +00:00
|
|
|
assert pc['ramSize'] == ram['size'] == 1024
|
2018-07-19 19:25:06 +00:00
|
|
|
hdd = components[7]
|
|
|
|
assert hdd['type'] == 'HardDrive'
|
|
|
|
assert hdd['hid'] == 'hitachi-e2024242cv86hj-hts54322'
|
|
|
|
assert hdd['interface'] == 'ATA'
|
|
|
|
assert hdd['size'] == 238475
|
|
|
|
hdd, _ = user.get(res=Device, item=hdd['id'])
|
|
|
|
event_types = tuple(e['type'] for e in hdd['events'])
|
|
|
|
assert em.BenchmarkRamSysbench.t in event_types
|
|
|
|
assert em.StressTest.t in event_types
|
|
|
|
assert em.BenchmarkDataStorage.t in event_types
|
|
|
|
assert em.TestDataStorage.t in event_types
|
|
|
|
assert em.EraseBasic.t in event_types
|
|
|
|
assert em.Snapshot.t in event_types
|
|
|
|
assert len(event_types) == 6
|
|
|
|
erase = next(e for e in hdd['events'] if e['type'] == em.EraseBasic.t)
|
|
|
|
assert erase['endTime']
|
|
|
|
assert erase['startTime']
|
|
|
|
assert erase['zeros'] is False
|
2018-11-08 16:37:14 +00:00
|
|
|
assert erase['severity'] == 'Info'
|
2018-10-13 12:53:46 +00:00
|
|
|
assert hdd['privacy'] == 'EraseBasic'
|
2018-07-19 19:25:06 +00:00
|
|
|
mother = components[8]
|
|
|
|
assert mother['hid'] == 'asustek_computer_inc-eee0123456789-1001pxd'
|
|
|
|
|
|
|
|
|
|
|
|
def test_real_custom(user: UserClient):
|
|
|
|
s = file('real-custom.snapshot.11')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s, status=NeedsId)
|
|
|
|
# todo insert with tag
|
|
|
|
|
|
|
|
|
|
|
|
def test_real_hp_quad_core(user: UserClient):
|
|
|
|
s = file('real-hp-quad-core.snapshot.11')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
2018-09-08 14:46:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_real_eee_1000h(user: UserClient):
|
|
|
|
s = file('asus-eee-1000h.snapshot.11')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
|
|
|
|
|
|
|
|
2018-10-13 12:53:46 +00:00
|
|
|
@pytest.mark.xfail(reason='We do not have a snapshot file to use')
|
|
|
|
def test_real_full_with_workbench_rate(user: UserClient):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2018-09-08 14:46:39 +00:00
|
|
|
SNAPSHOTS_NEED_ID = {
|
|
|
|
'box-xavier.snapshot.json',
|
|
|
|
'custom.lshw.snapshot.json',
|
|
|
|
'nox.lshw.snapshot.json',
|
|
|
|
'core2.lshw.snapshot.json',
|
|
|
|
'all-series.lshw.snapshot.json',
|
|
|
|
'ecs-2.lshw.snapshot.json',
|
|
|
|
'ecs-computers.lshw.snapshot.json',
|
|
|
|
'asus-all-series.lshw.snapshot.json'
|
|
|
|
}
|
|
|
|
"""Snapshots that do not generate HID requiring a custom ID."""
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('file',
|
|
|
|
pathlib.Path(__file__).parent.joinpath('workbench_files').iterdir())
|
|
|
|
def test_workbench_fixtures(file: pathlib.Path, user: UserClient):
|
|
|
|
"""Uploads the Snapshot files Workbench tests generate.
|
|
|
|
|
|
|
|
Keep this files up to date with the Workbench version.
|
|
|
|
"""
|
|
|
|
s = json.load(file.open())
|
|
|
|
user.post(res=em.Snapshot,
|
|
|
|
data=s,
|
|
|
|
status=201 if file.name not in SNAPSHOTS_NEED_ID else NeedsId)
|
2018-10-14 21:56:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_workbench_asus_1001pxd_rate_low(user: UserClient):
|
|
|
|
"""Tests an Asus 1001pxd with a low rate."""
|
|
|
|
s = file('asus-1001pxd.snapshot')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|
2018-10-27 06:56:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_david(user: UserClient):
|
|
|
|
s = file('david.lshw.snapshot')
|
|
|
|
snapshot, _ = user.post(res=em.Snapshot, data=s)
|