completely tested

This commit is contained in:
Martin Diehl 2020-09-30 08:49:55 +02:00
parent fdfcb16d15
commit 5ad46ae021
4 changed files with 79 additions and 10 deletions

View File

@ -28,21 +28,29 @@ class Config(dict):
@classmethod @classmethod
def load(cls,fname): def load(cls,fname):
"""Load from yaml file.""" """
Load from yaml file.
Parameters
----------
fname : file, str, or pathlib.Path
Filename or file for writing.
"""
try: try:
fhandle = open(fname) fhandle = open(fname)
except TypeError: except TypeError:
fhandle = fname fhandle = fname
return cls(yaml.safe_load(fhandle)) return cls(yaml.safe_load(fhandle))
def save(self,fname='material.yaml'): def save(self,fname):
""" """
Save to yaml file. Save to yaml file.
Parameters Parameters
---------- ----------
fname : file, str, or pathlib.Path fname : file, str, or pathlib.Path
Filename or file for reading. Filename or file for writing.
""" """
try: try:

View File

@ -9,6 +9,18 @@ from . import Rotation
class ConfigMaterial(Config): class ConfigMaterial(Config):
"""Material configuration.""" """Material configuration."""
def save(self,fname='material.yaml'):
"""
Save to yaml file.
Parameters
----------
fname : file, str, or pathlib.Path, optional
Filename or file for writing. Defaults to 'material.yaml'.
"""
super().save(fname)
@property @property
def is_complete(self): def is_complete(self):
"""Check for completeness.""" """Check for completeness."""

View File

@ -0,0 +1,34 @@
from damask import Config
class TestConfig:
def test_load_save_str(self,tmp_path):
config = Config()
config['A'] = 1
config['B'] = [2,3]
config.save(tmp_path/'config.yaml')
assert Config.load(tmp_path/'config.yaml') == config
def test_load_save_file(self,tmp_path):
config = Config()
config['A'] = 1
config['B'] = [2,3]
with open(tmp_path/'config.yaml','w') as f:
config.save(f)
with open(tmp_path/'config.yaml') as f:
assert Config.load(f) == config
def test_repr(self,tmp_path):
config = Config()
config['A'] = 1
config['B'] = [2,3]
with open(tmp_path/'config.yaml','w') as f:
f.write(config.__repr__())
assert Config.load(tmp_path/'config.yaml') == config
def test_abstract_is_valid(self):
assert Config().is_valid is None
def test_abstract_is_complete(self):
assert Config().is_complete is None

View File

@ -10,7 +10,7 @@ def reference_dir(reference_dir_base):
return reference_dir_base/'ConfigMaterial' return reference_dir_base/'ConfigMaterial'
class TestMaterial: class TestConfigMaterial:
@pytest.mark.parametrize('fname',[None,'test.yaml']) @pytest.mark.parametrize('fname',[None,'test.yaml'])
def test_load_save(self,reference_dir,tmp_path,fname): def test_load_save(self,reference_dir,tmp_path,fname):
@ -43,13 +43,28 @@ class TestMaterial:
material_config['microstructure'][0]['constituents'][0]['fraction']=.9 material_config['microstructure'][0]['constituents'][0]['fraction']=.9
assert not material_config.is_valid assert not material_config.is_valid
@pytest.mark.parametrize('item',['homogenization','phase','microstructure']) @pytest.mark.parametrize('item',['homogenization','phase','microstructure'])
def test_incomplete_missing(self,reference_dir,item): def test_incomplete_missing(self,reference_dir,item):
material_config = ConfigMaterial.load(reference_dir/'material.yaml') material_config = ConfigMaterial.load(reference_dir/'material.yaml')
del material_config[item] del material_config[item]
assert not material_config.is_complete assert not material_config.is_complete
@pytest.mark.parametrize('item',['orientation','phase'])
def test_incomplete_material_constituent(self,reference_dir,item):
material_config = ConfigMaterial.load(reference_dir/'material.yaml')
del material_config['microstructure'][0]['constituents'][0][item]
assert not material_config.is_complete
def test_incomplete_material_homogenization(self,reference_dir):
material_config = ConfigMaterial.load(reference_dir/'material.yaml')
del material_config['microstructure'][0]['homogenization']
assert not material_config.is_complete
def test_incomplete_phase_lattice(self,reference_dir):
material_config = ConfigMaterial.load(reference_dir/'material.yaml')
del material_config['phase']['Aluminum']['lattice']
assert not material_config.is_complete
def test_incomplete_wrong_phase(self,reference_dir): def test_incomplete_wrong_phase(self,reference_dir):
material_config = ConfigMaterial.load(reference_dir/'material.yaml') material_config = ConfigMaterial.load(reference_dir/'material.yaml')
new = material_config.microstructure_rename_phase({'Steel':'FeNbC'}) new = material_config.microstructure_rename_phase({'Steel':'FeNbC'})