From f4ebd2ba6607ebaa5e1c47e36cb03484434b6e76 Mon Sep 17 00:00:00 2001 From: Johannes Laurin Hoermann Date: Fri, 12 Jan 2024 11:55:34 +0100 Subject: [PATCH] CLI, TST: resolve https://github.com/libAtoms/matscipy/issues/211 and refactor CLI tests to run with renamed commands --- .../poisson_nernst_planck_solver_cli.py | 7 +++++- ...st_c2d.py => test_electrochemistry_cli.py} | 25 +++++++++++-------- 2 files changed, 20 insertions(+), 12 deletions(-) rename tests/{test_c2d.py => test_electrochemistry_cli.py} (91%) diff --git a/matscipy/cli/electrochemistry/poisson_nernst_planck_solver_cli.py b/matscipy/cli/electrochemistry/poisson_nernst_planck_solver_cli.py index a35666dc..83c234fc 100644 --- a/matscipy/cli/electrochemistry/poisson_nernst_planck_solver_cli.py +++ b/matscipy/cli/electrochemistry/poisson_nernst_planck_solver_cli.py @@ -39,7 +39,6 @@ def main(): Specify quantities in SI units at this command line interface.""" - # in order to have both: # * preformatted help text and ... # * automatic display of defaults @@ -222,6 +221,12 @@ class ArgumentDefaultsAndRawDescriptionHelpFormatter( raise ValueError("Boundary conditions '{}' not implemented!".format( args.boundary_conditions)) + if not args.outfile: + # fenics writes some log messages to stdout. If we pipe the output, + # we don't want that, hence here we have to suppress fenics logging + # if no output file has been specified + dolfin.cpp.log.set_log_active(False) + pnp.solve() extra_kwargs = {} diff --git a/tests/test_c2d.py b/tests/test_electrochemistry_cli.py similarity index 91% rename from tests/test_c2d.py rename to tests/test_electrochemistry_cli.py index 63eab896..dd028da6 100644 --- a/tests/test_c2d.py +++ b/tests/test_electrochemistry_cli.py @@ -31,8 +31,9 @@ from looseversion import LooseVersion -class c2dCliTest(matscipytest.MatSciPyTestCase): - """Tests c2d and pnp command line interfaces""" + +class ElectrochemistryCliTest(matscipytest.MatSciPyTestCase): + """Tests continuous2discrete and poisson-nernst-planck command line interfaces""" def setUp(self): """Reads reference data files""" @@ -60,9 +61,9 @@ def setUp(self): # command line interface scripts are expected to reside within # ../matscipy/cli/electrochemistry relative to this test directory self.pnp_cli = os.path.join( - self.test_path,os.path.pardir,'matscipy','cli','electrochemistry','pnp.py') + self.test_path,os.path.pardir,'matscipy','cli','electrochemistry','poisson_nernst_planck_solver_cli.py') self.c2d_cli = os.path.join( - self.test_path,os.path.pardir,'matscipy','cli','electrochemistry','c2d.py') + self.test_path,os.path.pardir,'matscipy','cli','electrochemistry','continuous2discrete_cli.py') self.assertTrue(os.path.exists(self.pnp_cli)) self.assertTrue(os.path.exists(self.c2d_cli)) @@ -86,7 +87,7 @@ def tearDown(self): self.bin_path.cleanup() def test_c2d_input_format_npz_output_format_xyz(self): - """c2d NaCl.npz NaCl.xyz""" + """continuous2discrete NaCl.npz NaCl.xyz""" print(" RUN test_c2d_input_format_npz_output_format_xyz") with tempfile.TemporaryDirectory() as tmpdir: subprocess.run( @@ -101,7 +102,7 @@ def test_c2d_input_format_npz_output_format_xyz(self): self.assertTrue( ( xyz.cell == self.ref_xyz.cell ).all() ) def test_c2d_input_format_txt_output_format_xyz(self): - """c2d NaCl.txt NaCl.xyz""" + """continuous2discrete NaCl.txt NaCl.xyz""" print(" RUN test_c2d_input_format_txt_output_format_xyz") with tempfile.TemporaryDirectory() as tmpdir: subprocess.run( @@ -119,7 +120,7 @@ def test_c2d_input_format_txt_output_format_xyz(self): """ LAMMPS data file won't work for ASE version up until 3.18.1, LAMMPS data file input broken in ASE 3.19.0, skipped""") def test_c2d_input_format_npz_output_format_lammps(self): - """c2d NaCl.npz NaCl.lammps""" + """continuous2discrete NaCl.npz NaCl.lammps""" print(" RUN test_c2d_input_format_npz_output_format_lammps") with tempfile.TemporaryDirectory() as tmpdir: subprocess.run( @@ -147,13 +148,14 @@ def test_pnp_output_format_npz(self): test_npz = np.load(os.path.join(tmpdir,'out.npz')) - # depending on which solver is used for the tests, absolute values might deviate more than the default tolerance + # depending on which solver is used for the tests, + # absolute values might deviate more than the default tolerance self.assertArrayAlmostEqual(test_npz['x'], self.ref_npz['x'], tol=1e-7) self.assertArrayAlmostEqual(test_npz['u'], self.ref_npz['u'], tol=1e-5) self.assertArrayAlmostEqual(test_npz['c'], self.ref_npz['c'], tol=1e-3) def test_pnp_output_format_txt(self): - """pnp -c 0.1 0.1 -u 0.05 -l 1.0e-7 -bc cell NaCl.txt""" + """poisson-nernst-planck -c 0.1 0.1 -u 0.05 -l 1.0e-7 -bc cell NaCl.txt""" print(" RUN test_pnp_output_format_txt") with tempfile.TemporaryDirectory() as tmpdir: subprocess.run( @@ -164,13 +166,14 @@ def test_pnp_output_format_txt(self): test_txt = np.loadtxt(os.path.join(tmpdir,'out.txt'), unpack=True) - # depending on which solver is used for the tests, absolute values might deviate more than the default tolerance + # depending on which solver is used for the tests, + # absolute values might deviate more than the default tolerance self.assertArrayAlmostEqual(test_txt[0,:], self.ref_txt[0,:], tol=1e-5) # x self.assertArrayAlmostEqual(test_txt[1,:],self.ref_txt[1,:], tol=1e-5) # u self.assertArrayAlmostEqual(test_txt[2:,:],self.ref_txt[2:,:], tol=1e-3) # c def test_pnp_c2d_pipeline_mode(self): - """pnp -c 0.1 0.1 -u 0.05 -l 1.0e-7 -bc cell | c2d > NaCl.xyz""" + """poisson-nernst-planck -c 0.1 0.1 -u 0.05 -l 1.0e-7 -bc cell | continuous2discrete > NaCl.xyz""" print(" RUN test_pnp_c2d_pipeline_mode") with tempfile.TemporaryDirectory() as tmpdir: pnp = subprocess.Popen(