def test_wait_all_started(): session_name = generate_random_string() js = JobSession(session_name) ja = js.run_bulk_jobs({'remote_command': '/bin/sleep', 'args': ['5']}, 1, 10, 5, 2) jl = ja.job_list jl_ids = list(map(lambda j: j.id, jl)) jl_ids.sort() print('\nWaiting on start of all jobs: %s' % jl_ids) jl2 = js.wait_all_started(jl) jl2_ids = list(map(lambda j: j.id, jl2)) jl2_ids.sort() assert (jl_ids == jl2_ids) print('Jobs started: ' % jl2_ids)
# you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. ########################################################################### # ___INFO__MARK_END__ from drmaa2 import JobSession if __name__ == '__main__': js = JobSession('js-01') print('Created job session: %s' % js.name) d = {'remote_command': '/bin/sleep', 'args': ['10']} print('Running job array using dictionary: %s' % d) begin_index = 1 end_index = 10 step = 5 max_parallel = 2 ja = js.run_bulk_jobs(d, begin_index, end_index, step, max_parallel) print('Submitted job array: %s' % ja) print('Waiting for all jobs to terminate') jl = ja.job_list jl2 = js.wait_all_started(jl) print('Jobs terminated: %s' % jl2)