Skip to content

Commit

Permalink
Tests: save e_elect summary in a YAML file
Browse files Browse the repository at this point in the history
  • Loading branch information
alongd committed Oct 23, 2023
1 parent 42cae71 commit cf7ff55
Showing 1 changed file with 32 additions and 1 deletion.
33 changes: 32 additions & 1 deletion arc/scheduler_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
import arc.rmgdb as rmgdb
import arc.parser as parser
from arc.checks.ts import check_ts
from arc.common import ARC_PATH, almost_equal_coords_lists, initialize_job_types
from arc.common import ARC_PATH, almost_equal_coords_lists, initialize_job_types, read_yaml_file
from arc.job.factory import job_factory
from arc.level import Level
from arc.plotter import save_conformers_file
Expand Down Expand Up @@ -701,6 +701,37 @@ def test_check_rxn_e0_by_spc(self):
self.assertEqual(rxn.ts_species.ts_checks,
{'E0': True, 'e_elect': True, 'IRC': None, 'freq': True, 'normal_mode_displacement': True, 'warnings': ''})

def test_save_e_elect(self):
"""Test the save_e_elect() method."""
project_directory = os.path.join(ARC_PATH, 'Projects', 'save_e_elect')
self.assertFalse(os.path.isfile(os.path.join(project_directory, 'output', 'e_elect_summary.yml')))
sched = Scheduler(project='test_save_e_elect',
ess_settings=self.ess_settings,
project_directory=project_directory,
species_list=[ARCSpecies(label='formaldehyde', smiles='C=O'),
ARCSpecies(label='mehylamine', smiles='CN')],
freq_scale_factor=1.0,
opt_level=Level(method='B3LYP', basis='6-31G(d,p)', software='psi4'),
sp_level=Level(method='B3LYP', basis='6-31G(d,p)', software='psi4'),
job_types={'opt': True, 'fine_grid': False, 'freq': False, 'sp': True, 'rotors': False,
'conformers': False, 'irc': False},
report_e_elect=True,
testing=True,
)
sched.post_sp_actions(label='formaldehyde',
sp_path=os.path.join(ARC_PATH, 'arc', 'testing', 'sp', 'formaldehyde_sp_terachem_output.out'))
e_elect_summary_path = os.path.join(project_directory, 'output', 'e_elect_summary.yml')
self.assertTrue(os.path.isfile(e_elect_summary_path))
content = read_yaml_file(e_elect_summary_path)
self.assertEqual(content, {'formaldehyde': -300621.95378630824})

sched.post_sp_actions(label='mehylamine',
sp_path=os.path.join(ARC_PATH, 'arc', 'testing', 'sp', 'mehylamine_CCSD(T).out'))
content = read_yaml_file(e_elect_summary_path)
self.assertEqual(content, {'formaldehyde': -300621.95378630824,
'mehylamine': -251377.49160993524})
shutil.rmtree(project_directory, ignore_errors=True)

def test_species_has_geo_sp_freq(self):
"""Test the species_has_geo() / species_has_sp() / species_has_freq() functions."""
for property_, species_has_property in zip(['geo', 'sp', 'freq'], [species_has_geo, species_has_sp, species_has_freq]):
Expand Down

0 comments on commit cf7ff55

Please sign in to comment.