LSSTApplications  11.0-13-gbb96280,12.1+18,12.1+7,12.1-1-g14f38d3+72,12.1-1-g16c0db7+5,12.1-1-g5961e7a+84,12.1-1-ge22e12b+23,12.1-11-g06625e2+4,12.1-11-g0d7f63b+4,12.1-19-gd507bfc,12.1-2-g7dda0ab+38,12.1-2-gc0bc6ab+81,12.1-21-g6ffe579+2,12.1-21-gbdb6c2a+4,12.1-24-g941c398+5,12.1-3-g57f6835+7,12.1-3-gf0736f3,12.1-37-g3ddd237,12.1-4-gf46015e+5,12.1-5-g06c326c+20,12.1-5-g648ee80+3,12.1-5-gc2189d7+4,12.1-6-ga608fc0+1,12.1-7-g3349e2a+5,12.1-7-gfd75620+9,12.1-9-g577b946+5,12.1-9-gc4df26a+10
LSSTDataManagementBasePackage
FileWaiter.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 
3 #
4 # LSST Data Management System
5 # Copyright 2008, 2009, 2010 LSST Corporation.
6 #
7 # This product includes software developed by the
8 # LSST Project (http://www.lsst.org/).
9 #
10 # This program is free software: you can redistribute it and/or modify
11 # it under the terms of the GNU General Public License as published by
12 # the Free Software Foundation, either version 3 of the License, or
13 # (at your option) any later version.
14 #
15 # This program is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 # GNU General Public License for more details.
19 #
20 # You should have received a copy of the LSST License Statement and
21 # the GNU General Public License along with this program. If not,
22 # see <http://www.lsstcorp.org/LegalNotices/>.
23 #
24 
25 
26 from __future__ import print_function
27 from builtins import object
28 import os
29 import lsst.log as log
30 
31 
32 class FileWaiter(object):
33  # @brief initializer
34  """Waits for files to come into existence on a remote resource
35  Parameters
36  ----------
37  remoteNode : `str`
38  Name of the remote node to execute on
39  remoteFileWaiter : `str`
40  name of the remote file waiter script
41  fileListName : `str`
42  name of the remote file list file
43  logger: `Log`, optional
44  lsst.log logging object
45 
46  Notes
47  -----
48  Use of logger in this way should be deprecated in the future
49  """
50  def __init__(self, remoteNode, remoteFileWaiter, fileListName, logger=None):
51  log.debug("FileWaiter:__init__")
52 
53  self.remoteNode = remoteNode
54 
55  self.fileListName = fileListName
56 
57  self.remoteFileWaiter = remoteFileWaiter
58 
59  def waitForFirstFile(self):
60  """Waits for first file in the list to come into existence
61  """
62  log.debug("FileWaiter:waitForFirstFile")
63  print("waiting for log file to be created to confirm launch.")
64  cmd = "gsissh %s %s -f %s" % (self.remoteNode, self.remoteFileWaiter, self.fileListName)
65  pid = os.fork()
66  if not pid:
67  os.execvp("gsissh", cmd.split())
68  os.wait()[0]
69 
70  def waitForAllFiles(self):
71  """Waits for all files in the list to come into existence
72  """
73  log.debug("FileWaiter:waitForAllFiles")
74 
75  print("waiting for all log files to be created to confirm launch")
76  cmd = "gsissh %s %s -l %s" % (self.remoteNode, self.remoteFileWaiter, self.fileListName)
77  pid = os.fork()
78  if not pid:
79  os.execvp("gsissh", cmd.split())
80  os.wait()[0]