2018-06-10 16:47:49 +00:00
|
|
|
"""
|
|
|
|
Tests that emulates the behaviour of a WorkbenchServer.
|
|
|
|
"""
|
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')
|
|
|
|
))
|
|
|
|
s['components'][5]['events'] = [file('workbench-server-3.erase')]
|
|
|
|
# Create tags
|
|
|
|
user.post(res=Tag, query=[('ids', t['id']) for t in s['device']['tags']], data={})
|
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} == {
|
|
|
|
# todo missing Rate event aggregating the rates
|
|
|
|
('WorkbenchRate', 1),
|
|
|
|
('BenchmarkProcessorSysbench', 5),
|
|
|
|
('StressTest', 1),
|
|
|
|
('EraseSectors', 6),
|
|
|
|
('BenchmarkRamSysbench', 1),
|
|
|
|
('BenchmarkProcessor', 5),
|
|
|
|
('Install', 6),
|
|
|
|
('EraseSectors', 7),
|
|
|
|
('BenchmarkDataStorage', 6),
|
|
|
|
('TestDataStorage', 6)
|
|
|
|
}
|
|
|
|
assert snapshot['closed']
|
|
|
|
assert not snapshot['error']
|
|
|
|
|
|
|
|
|
|
|
|
@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']
|
|
|
|
assert not snapshot['error']
|
|
|
|
|
|
|
|
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-07-02 10:52:54 +00:00
|
|
|
assert snapshot['device']['hid'] == 'hewlett-packard-czc0408yjg-hp_compaq_8100_elite_sff'
|
|
|
|
assert snapshot['device']['chassis'] == 'Tower'
|
|
|
|
assert set(e['type'] for e in snapshot['events']) == {
|
|
|
|
'BenchmarkDataStorage',
|
|
|
|
'BenchmarkProcessor',
|
|
|
|
'BenchmarkProcessorSysbench',
|
|
|
|
'TestDataStorage',
|
|
|
|
'BenchmarkRamSysbench',
|
|
|
|
'StressTest'
|
|
|
|
}
|
|
|
|
assert len(list(e['type'] for e in snapshot['events'])) == 6
|
|
|
|
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
|
|
|
|
def test_real_eee_1001pxd(user: UserClient):
|
|
|
|
"""
|
|
|
|
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'
|
|
|
|
assert pc['model'] == '1001PXD'
|
|
|
|
assert pc['serialNumber'] == 'B8OAAS048286'
|
|
|
|
assert pc['manufacturer'] == 'ASUSTeK Computer INC.'
|
|
|
|
assert pc['hid'] == 'asustek_computer_inc-b8oaas048286-1001pxd'
|
|
|
|
assert pc['tags'] == []
|
|
|
|
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
|
|
|
|
assert cpu['model'] == 'Intel Atom CPU N455 @ 1.66GHz'
|
|
|
|
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
|
|
|
|
assert len(events) == 5
|
|
|
|
gpu = components[3]
|
|
|
|
assert gpu['model'] == 'Atom Processor D4xx/D5xx/N4xx/N5xx Integrated Graphics Controller'
|
|
|
|
assert gpu['manufacturer'] == 'Intel Corporation'
|
|
|
|
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]
|
|
|
|
assert sound['model'] == 'NM10/ICH7 Family High Definition Audio Controller'
|
|
|
|
sound = components[5]
|
|
|
|
assert sound['model'] == 'USB 2.0 UVC VGA WebCam'
|
|
|
|
ram = components[6]
|
|
|
|
assert ram['interface'] == 'DDR2'
|
|
|
|
assert ram['speed'] == 667
|
|
|
|
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
|
|
|
|
assert erase['error'] is False
|
|
|
|
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)
|