Skip to content

Commit

Permalink
Added the ability of uploading custom libraries for RMG T3 runs
Browse files Browse the repository at this point in the history
  • Loading branch information
calvinp0 committed Nov 10, 2023
1 parent 5e09081 commit c4e0827
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 23 deletions.
19 changes: 0 additions & 19 deletions requirements.txt

This file was deleted.

34 changes: 32 additions & 2 deletions t3/runners/rmg_adapter.py
Original file line number Diff line number Diff line change
Expand Up @@ -55,8 +55,8 @@ def __init__(self,
server: str=None,
testing: bool=False,
):
self.rmg = rmg
self.t3 = t3
self.rmg = rmg.copy()
self.t3 = t3.copy()
self.iteration = iteration
self.paths = paths
self.walltime = walltime
Expand Down Expand Up @@ -84,6 +84,26 @@ def __init__(self,
self.rmg_errors = list()
self.rmg_run_count = 0
self.cont_run_rmg = True
self.dict_of_custom_libraries = dict()
if self.rmg_execution_type == 'queue':
self.set_file_paths()
# We need to check if the strings in the rmg database kintetic library are path to the files
for library_key, library_value in self.rmg['database'].items():
if isinstance(library_value, list):
for library_item in range(len(library_value)):
if os.path.isdir(self.rmg['database'][library_key][library_item]):

# Make the library item name the key, and then inside that key there are two keys: local and remote
# The local key will be the path to the library item on the local machine
# The remote key will be the path to the library item on the remote machine
if os.path.basename(self.rmg['database'][library_key][library_item]) not in self.dict_of_custom_libraries:
self.dict_of_custom_libraries[os.path.basename(self.rmg['database'][library_key][library_item])] = dict()
self.dict_of_custom_libraries[os.path.basename(self.rmg['database'][library_key][library_item])]['local'] = self.rmg['database'][library_key][library_item]
self.dict_of_custom_libraries[os.path.basename(self.rmg['database'][library_key][library_item])]['remote'] = os.path.join(self.remote_path, os.path.basename(self.rmg['database'][library_key][library_item]))
# Add the library item to the dict of custom libraries
# We now need to change it's path to the path on the server
self.rmg['database'][library_key][library_item] = os.path.join(self.remote_path, os.path.basename(self.rmg['database'][library_key][library_item]))


def run_rmg(self):
"""
Expand Down Expand Up @@ -483,6 +503,16 @@ def set_files(self) -> None:
file_name=submit_filenames[CLUSTER_SOFT]))
# 1.2. RMG input file
self.write_rmg_input_file()
# 1.3 Custom Libraries
# Need to upload the custom libraries if they exist and are not already uploaded
if self.dict_of_custom_libraries:
for lib_name, lib_paths in self.dict_of_custom_libraries.items():
if lib_paths['local'] not in self.files_to_upload:
self.files_to_upload.append(self.get_file_property_dictionary(
file_name=lib_name,
local=lib_paths['local'],
remote=lib_paths['remote']))

# If this a restart, we need to upload the restart file
if self.restart_rmg:
restart_string = "restartFromSeed(path='seed')"
Expand Down
16 changes: 14 additions & 2 deletions t3/utils/ssh.py
Original file line number Diff line number Diff line change
Expand Up @@ -151,18 +151,30 @@ def upload_file(self,
if not local_file_path and not file_string:
raise InputError('Cannot upload file to server. Either `file_string` or `local_file_path`'
' must be specified')
if local_file_path and not os.path.isfile(local_file_path):
if local_file_path and not os.path.isfile(local_file_path) and not os.path.isdir(local_file_path):
raise InputError(f'Cannot upload a non-existing file. '
f'Check why file in path {local_file_path} is missing.')

# If the directory does not exist, _upload_file cannot create a file based on the given path
remote_dir_path = os.path.dirname(remote_file_path)
if os.path.isdir(local_file_path):
remote_dir_path = remote_file_path
else:
remote_dir_path = os.path.dirname(remote_file_path)
if not self._check_dir_exists(remote_dir_path):
self._create_dir(remote_dir_path)

try:
if file_string:
with self._sftp.open(remote_file_path, 'w') as f_remote:
f_remote.write(file_string)

elif os.path.isdir(local_file_path):
for root, dirs, files in os.walk(local_file_path):
for file in files:
local_file_path = os.path.join(root, file)
remote_file_path = os.path.join(remote_dir_path, file)
self._sftp.put(localpath=local_file_path,
remotepath=remote_file_path)
else:
self._sftp.put(localpath=local_file_path,
remotepath=remote_file_path)
Expand Down

0 comments on commit c4e0827

Please sign in to comment.