def submit_pilot_data(self, pilot_data_description): """ creates a pilot data object and binds it to a physical resource (a pilotstore) """ pd = PilotData(pilot_data_service=self, pilot_data_description=pilot_data_description) self.pilot_data[pd.id]=pd self.pd_queue.put(pd) # queue currently not persisted CoordinationAdaptor.update_wds(self.url, self) return pd
def add_pilot_store_service(self, pss): """ Add a PilotStoreService Keyword arguments: pss -- The PilotStoreService to add. Return: None """ self.pilot_store_services.append(pss) CoordinationAdaptor.update_wds(self.url, self)
def add_pilot_job_service(self, pjs): """ Add a PilotJobService to this WUS. Keyword arguments: pilotjob_services -- The PilotJob Service(s) to which this Work Unit Service will connect. Return: Result """ self.pilot_job_services.append(pjs) CoordinationAdaptor.update_wds(self.url, self)
def remove_pilot_store_service(self, pss): """ Remove a PilotStoreService Keyword arguments: pss -- The PilotStoreService to remove Return: None """ self.pilot_store_services.remove(pss) CoordinationAdaptor.update_wds(self.url, self)
def submit_work_unit(self, work_unit_description): """ Submit a WU to this Work Unit Service. Keyword argument: wud -- The WorkUnitDescription from the application Return: WorkUnit object """ wu = WorkUnit(work_unit_description, self) self.work_units[wu.id]=wu self.wu_queue.put(wu) CoordinationAdaptor.update_wds(self.url, self) return wu
def remove_pilot_job_service(self, pjs): """ Remove a PilotJobService from this WUS. Note that it won't cancel the PilotJobService, it will just no longer be connected to this WUS. Keyword arguments: pilotjob_services -- The PilotJob Service(s) to remove from this Work Unit Service. Return: Result """ self.pilot_job_services.remove(pjs) CoordinationAdaptor.update_wds(self.url, self)