Merge branch 'metaodi-145-catch-no-harvesting-jobs-exception'

This commit is contained in:
amercader 2015-07-21 11:16:43 +01:00
commit 83cca925c9
3 changed files with 11 additions and 5 deletions

View File

@ -3,6 +3,7 @@ from pprint import pprint
from ckan import model from ckan import model
from ckan.logic import get_action, ValidationError from ckan.logic import get_action, ValidationError
from ckanext.harvest.logic import NoNewHarvestJobError
from ckan.lib.cli import CkanCommand from ckan.lib.cli import CkanCommand
@ -301,9 +302,10 @@ class Harvester(CkanCommand):
def run_harvester(self): def run_harvester(self):
context = {'model': model, 'user': self.admin_user['name'], 'session':model.Session} context = {'model': model, 'user': self.admin_user['name'], 'session':model.Session}
try:
jobs = get_action('harvest_jobs_run')(context,{}) jobs = get_action('harvest_jobs_run')(context,{})
except NoNewHarvestJobError:
#print 'Sent %s jobs to the gather queue' % len(jobs) print 'There are no new harvest jobs to run.'
def import_stage(self): def import_stage(self):

View File

@ -7,3 +7,7 @@ except ImportError:
class HarvestJobExists(Exception): class HarvestJobExists(Exception):
pass pass
class NoNewHarvestJobError(Exception):
pass

View File

@ -26,7 +26,7 @@ from ckanext.harvest.plugin import DATASET_TYPE_NAME
from ckanext.harvest.queue import get_gather_publisher, resubmit_jobs from ckanext.harvest.queue import get_gather_publisher, resubmit_jobs
from ckanext.harvest.model import HarvestSource, HarvestJob, HarvestObject from ckanext.harvest.model import HarvestSource, HarvestJob, HarvestObject
from ckanext.harvest.logic import HarvestJobExists from ckanext.harvest.logic import HarvestJobExists, NoNewHarvestJobError
from ckanext.harvest.logic.schema import harvest_source_show_package_schema from ckanext.harvest.logic.schema import harvest_source_show_package_schema
from ckanext.harvest.logic.action.get import harvest_source_show, harvest_job_list, _get_sources_for_user from ckanext.harvest.logic.action.get import harvest_source_show, harvest_job_list, _get_sources_for_user
@ -365,7 +365,7 @@ def harvest_jobs_run(context,data_dict):
jobs = harvest_job_list(context,{'source_id':source_id,'status':u'New'}) jobs = harvest_job_list(context,{'source_id':source_id,'status':u'New'})
if len(jobs) == 0: if len(jobs) == 0:
log.info('No new harvest jobs.') log.info('No new harvest jobs.')
raise Exception('There are no new harvesting jobs') raise NoNewHarvestJobError('There are no new harvesting jobs')
# Send each job to the gather queue # Send each job to the gather queue
publisher = get_gather_publisher() publisher = get_gather_publisher()