complaints by pylint are mainly related to - remove object from base list in class definitions - unnecessary else/elif after return/raise Change-Id: I13d15449149cc8bba0562338d0c9c42e97163bdf Reviewed-on: https://forge.frm2.tum.de/review/c/sine2020/secop/playground/+/21325 Tested-by: JenkinsCodeReview <bjoern_pedersen@frm2.tum.de> Reviewed-by: Markus Zolliker <markus.zolliker@psi.ch>
86 lines
3.4 KiB
Python
86 lines
3.4 KiB
Python
# -*- coding: utf-8 -*-
|
|
# *****************************************************************************
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it under
|
|
# the terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along with
|
|
# this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
# Module authors:
|
|
# Enrico Faulhaber <enrico.faulhaber@frm2.tum.de>
|
|
#
|
|
# *****************************************************************************
|
|
"""test base client."""
|
|
|
|
from collections import OrderedDict
|
|
|
|
import pytest
|
|
|
|
from secop.client.baseclient import Client
|
|
|
|
# define Test-only connection object
|
|
|
|
|
|
class TestConnect:
|
|
callbacks = []
|
|
|
|
def writeline(self, line):
|
|
pass
|
|
|
|
def readline(self):
|
|
return ''
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
def clientobj(request):
|
|
print (" SETUP ClientObj")
|
|
testconnect = TestConnect()
|
|
yield Client(dict(testing=testconnect), autoconnect=False)
|
|
for cb, arg in testconnect.callbacks:
|
|
cb(arg)
|
|
print (" TEARDOWN ClientObj")
|
|
|
|
|
|
# pylint: disable=redefined-outer-name
|
|
def test_describing_data_decode(clientobj):
|
|
assert {'modules': OrderedDict(), 'properties': {}
|
|
} == clientobj._decode_substruct(['modules'], {})
|
|
describing_data = {'equipment_id': 'eid',
|
|
'modules': [['LN2', {'commands': [],
|
|
'interfaces': ['Readable', 'Module'],
|
|
'parameters': [['value', {'datatype': ['double'],
|
|
'description': 'current value',
|
|
'readonly': True,
|
|
}
|
|
]]
|
|
}
|
|
]]
|
|
}
|
|
decoded_data = {'modules': OrderedDict([('LN2', {'commands': OrderedDict(),
|
|
'parameters': OrderedDict([('value', {'datatype': ['double'],
|
|
'description': 'current value',
|
|
'readonly': True,
|
|
}
|
|
)]),
|
|
'properties': {'interfaces': ['Readable', 'Module']}
|
|
}
|
|
)]),
|
|
'properties': {'equipment_id': 'eid',
|
|
}
|
|
}
|
|
|
|
a = clientobj._decode_substruct(['modules'], describing_data)
|
|
for modname, module in a['modules'].items():
|
|
a['modules'][modname] = clientobj._decode_substruct(
|
|
['parameters', 'commands'], module)
|
|
assert a == decoded_data
|