mirror of
https://github.com/triqs/dft_tools
synced 2025-01-08 04:15:50 +01:00
c8badb39ff
Originally, the tests worked only when run from their respective directory. If one tries to run them from another directory (which happens when test discovery is used) the tests were not able to find the input files. Now, a dummy module 'rpath' is added to all tests whose sole role is to obtain the current path.
81 lines
2.6 KiB
Python
81 lines
2.6 KiB
Python
r"""
|
|
Tests of 'parse_shells()' defined in ConfigParameters class
|
|
"""
|
|
import os
|
|
import rpath
|
|
_rpath = os.path.dirname(rpath.__file__) + '/'
|
|
|
|
import arraytest
|
|
import numpy as np
|
|
from inpconf import ConfigParameters
|
|
|
|
################################################################################
|
|
#
|
|
# TestParseShells
|
|
#
|
|
################################################################################
|
|
class TestParseShells(arraytest.ArrayTestCase):
|
|
"""
|
|
Function:
|
|
|
|
def parse_shells(self)
|
|
|
|
Scenarios:
|
|
|
|
- **if** config-file does not contain a valid [Shell] section
|
|
**raise** AssertionError
|
|
- **if** a [Shell] section does not contain a valid index
|
|
**raise** ValueError
|
|
- **if** a [Shell] section does not contain all required parameters
|
|
**raise** Exception
|
|
- **if** two correct [Shell] sections are defined
|
|
**return** a dictionary of shell parameters
|
|
"""
|
|
# Scenario 1
|
|
def test_no_shell(self):
|
|
conf_pars = ConfigParameters(_rpath + 'parse_shells_1.cfg')
|
|
err_mess = "No projected shells"
|
|
with self.assertRaisesRegexp(AssertionError, err_mess):
|
|
conf_pars.parse_shells()
|
|
|
|
# Scenario 2
|
|
def test_bad_indices(self):
|
|
conf_pars = ConfigParameters(_rpath + 'parse_shells_2.cfg')
|
|
err_mess = "Failed to extract shell indices"
|
|
with self.assertRaisesRegexp(ValueError, err_mess):
|
|
conf_pars.parse_shells()
|
|
|
|
# Scenario 3
|
|
def test_sh_required(self):
|
|
conf_pars = ConfigParameters(_rpath + 'parse_shells_3.cfg')
|
|
err_mess = "Required parameter"
|
|
with self.assertRaisesRegexp(Exception, err_mess):
|
|
conf_pars.parse_shells()
|
|
|
|
# Scenario 4
|
|
def test_two_shells(self):
|
|
conf_pars = ConfigParameters(_rpath + 'parse_shells_4.cfg')
|
|
conf_pars.parse_shells()
|
|
res = conf_pars.shells
|
|
expected = [{'user_index': 1, 'lshell': 2, 'ion_list': np.array([4, 5, 6, 7])},
|
|
{'user_index': 2, 'lshell': 1, 'ion_list': np.array([0, 1, 2, 3]),
|
|
'tmatrix': np.array([[ 0., 1., 0.], [ 1., 0., 0.], [ 0., 0., 1.]])}]
|
|
# ...lousy way to test equality of two dictionaries containing numpy arrays
|
|
self.assertEqual(len(res), len(expected))
|
|
|
|
arr = res[0].pop('ion_list')
|
|
arr_exp = expected[0].pop('ion_list')
|
|
self.assertEqual(arr, arr_exp)
|
|
|
|
arr = res[1].pop('ion_list')
|
|
arr_exp = expected[1].pop('ion_list')
|
|
self.assertEqual(arr, arr_exp)
|
|
|
|
arr = res[1].pop('tmatrix')
|
|
arr_exp = expected[1].pop('tmatrix')
|
|
self.assertEqual(arr, arr_exp)
|
|
|
|
self.assertListEqual(res, expected)
|
|
|
|
|