increasing test coverage

This commit is contained in:
Martin Diehl 2020-08-25 00:59:41 +02:00
parent 453f5a14c5
commit 2d98325fa4
2 changed files with 30 additions and 15 deletions

View File

@ -124,12 +124,12 @@ class Geom:
message.append(util.emph( f'origin x y z: {util.srepr( self.get_origin()," ")}')) message.append(util.emph( f'origin x y z: {util.srepr( self.get_origin()," ")}'))
if other.N_microstructure != self.N_microstructure: if other.N_microstructure != self.N_microstructure:
message.append(util.delete(f'# microstructures: {other.N_microstructure}')) message.append(util.delete(f'# materialpoints: {other.N_microstructure}'))
message.append(util.emph( f'# microstructures: { self.N_microstructure}')) message.append(util.emph( f'# materialpoints: { self.N_microstructure}'))
if np.nanmax(other.microstructure) != np.nanmax(self.microstructure): if np.nanmax(other.microstructure) != np.nanmax(self.microstructure):
message.append(util.delete(f'max microstructure: {np.nanmax(other.microstructure)}')) message.append(util.delete(f'max materialpoint: {np.nanmax(other.microstructure)}'))
message.append(util.emph( f'max microstructure: {np.nanmax( self.microstructure)}')) message.append(util.emph( f'max materialpoint: {np.nanmax( self.microstructure)}'))
return util.return_message(message) return util.return_message(message)

View File

@ -13,7 +13,8 @@ from damask import util
def geom_equal(a,b): def geom_equal(a,b):
return np.all(a.get_microstructure() == b.get_microstructure()) and \ return np.all(a.get_microstructure() == b.get_microstructure()) and \
np.all(a.get_grid() == b.get_grid()) and \ np.all(a.get_grid() == b.get_grid()) and \
np.allclose(a.get_size(), b.get_size()) np.allclose(a.get_size(), b.get_size()) and \
str(a.diff(b)) == str(b.diff(a))
@pytest.fixture @pytest.fixture
def default(): def default():
@ -45,6 +46,13 @@ class TestGeom:
print(modified) print(modified)
assert geom_equal(default,modified) assert geom_equal(default,modified)
def test_diff_equal(self,default):
assert str(default.diff(default)) == ''
def test_diff_not_equal(self,default):
new = Geom(default.microstructure[1:,1:,1:]+1,default.size*.9,np.ones(3)-default.origin,comments=['modified'])
assert str(default.diff(new)) != ''
@pytest.mark.parametrize('masked',[True,False]) @pytest.mark.parametrize('masked',[True,False])
def test_set_microstructure(self,default,masked): def test_set_microstructure(self,default,masked):
@ -55,8 +63,8 @@ class TestGeom:
def test_write_read_str(self,default,tmpdir): def test_write_read_str(self,default,tmpdir):
default.to_file(tmpdir/'default.geom') default.to_file(str(tmpdir/'default.geom'))
new = Geom.from_file(tmpdir/'default.geom') new = Geom.from_file(str(tmpdir/'default.geom'))
assert geom_equal(default,new) assert geom_equal(default,new)
def test_write_read_file(self,default,tmpdir): def test_write_read_file(self,default,tmpdir):
@ -139,6 +147,12 @@ class TestGeom:
assert geom_equal(Geom.from_file(reference), assert geom_equal(Geom.from_file(reference),
modified) modified)
@pytest.mark.parametrize('directions',[(1,2,'y'),('a','b','x'),[1]])
def test_mirror_invalid(self,default,directions):
with pytest.raises(ValueError):
default.mirror(directions)
@pytest.mark.parametrize('directions',[ @pytest.mark.parametrize('directions',[
['x'], ['x'],
['x','y','z'], ['x','y','z'],
@ -155,9 +169,10 @@ class TestGeom:
modified) modified)
@pytest.mark.parametrize('directions',[(1,2,'y'),('a','b','x'),[1]]) @pytest.mark.parametrize('directions',[(1,2,'y'),('a','b','x'),[1]])
def test_mirror_invalid(self,default,directions): def test_flip_invalid(self,default,directions):
with pytest.raises(ValueError): with pytest.raises(ValueError):
default.mirror(directions) default.flip(directions)
@pytest.mark.parametrize('stencil',[1,2,3,4]) @pytest.mark.parametrize('stencil',[1,2,3,4])
@pytest.mark.parametrize('selection',[None,[1],[1,2,3]]) @pytest.mark.parametrize('selection',[None,[1],[1,2,3]])