harvester-d4science/ckanext/harvest/tests/test_queue.py

266 lines
9.7 KiB
Python
Raw Normal View History

try:
from ckan.tests.helpers import reset_db
except ImportError:
from ckan.new_tests.helpers import reset_db
import ckanext.harvest.model as harvest_model
2012-10-25 20:01:54 +02:00
from ckanext.harvest.model import HarvestObject, HarvestObjectExtra
from ckanext.harvest.interfaces import IHarvester
import ckanext.harvest.queue as queue
from ckan.plugins.core import SingletonPlugin, implements
import json
import ckan.logic as logic
from ckan import model
2015-11-17 12:09:24 +01:00
from nose.tools import assert_equal
class MockHarvester(SingletonPlugin):
implements(IHarvester)
def info(self):
return {'name': 'test', 'title': 'test', 'description': 'test'}
def gather_stage(self, harvest_job):
2012-11-05 14:17:32 +01:00
if harvest_job.source.url.startswith('basic_test'):
obj = HarvestObject(guid = 'test1', job = harvest_job)
2012-10-25 20:01:54 +02:00
obj.extras.append(HarvestObjectExtra(key='key', value='value'))
obj2 = HarvestObject(guid = 'test2', job = harvest_job)
2012-12-18 00:50:26 +01:00
obj3 = HarvestObject(guid = 'test_to_delete', job = harvest_job)
obj.add()
2012-12-18 00:50:26 +01:00
obj2.add()
obj3.save() # this will commit both
return [obj.id, obj2.id, obj3.id]
return []
def fetch_stage(self, harvest_object):
2015-11-17 12:09:24 +01:00
assert_equal(harvest_object.state, "FETCH")
2012-10-25 20:01:54 +02:00
assert harvest_object.fetch_started != None
harvest_object.content = json.dumps({'name': harvest_object.guid})
harvest_object.save()
return True
def import_stage(self, harvest_object):
2015-11-17 12:09:24 +01:00
assert_equal(harvest_object.state, "IMPORT")
2012-10-25 20:01:54 +02:00
assert harvest_object.fetch_finished != None
assert harvest_object.import_started != None
user = logic.get_action('get_site_user')(
{'model': model, 'ignore_auth': True}, {}
)['name']
2012-12-18 00:50:26 +01:00
package = json.loads(harvest_object.content)
name = package['name']
package_object = model.Package.get(name)
if package_object:
logic_function = 'package_update'
else:
logic_function = 'package_create'
package_dict = logic.get_action(logic_function)(
{'model': model, 'session': model.Session,
2013-08-14 13:28:27 +02:00
'user': user, 'api_version': 3, 'ignore_auth': True},
json.loads(harvest_object.content)
)
2012-12-18 00:50:26 +01:00
2013-04-22 18:55:46 +02:00
# set previous objects to not current
previous_object = model.Session.query(HarvestObject) \
.filter(HarvestObject.guid==harvest_object.guid) \
.filter(HarvestObject.current==True) \
.first()
if previous_object:
previous_object.current = False
previous_object.save()
2012-12-18 00:50:26 +01:00
# delete test_to_delete package on second run
harvest_object.package_id = package_dict['id']
harvest_object.current = True
if package_dict['name'] == 'test_to_delete' and package_object:
harvest_object.current = False
2012-12-18 03:39:14 +01:00
package_object.state = 'deleted'
package_object.save()
2012-12-18 00:50:26 +01:00
harvest_object.save()
return True
class TestHarvestQueue(object):
@classmethod
def setup_class(cls):
reset_db()
harvest_model.setup()
2012-12-18 00:50:26 +01:00
def test_01_basic_harvester(self):
### make sure queues/exchanges are created first and are empty
2015-11-20 15:25:31 +01:00
consumer = queue.get_consumer('ckan.harvest.test.gather',
queue.get_gather_routing_key())
consumer_fetch = queue.get_consumer('ckan.harvest.test.fetch',
queue.get_fetch_routing_key())
consumer.queue_purge(queue='ckan.harvest.test.gather')
consumer_fetch.queue_purge(queue='ckan.harvest.test.fetch')
user = logic.get_action('get_site_user')(
{'model': model, 'ignore_auth': True}, {}
)['name']
context = {'model': model, 'session': model.Session,
2013-08-14 13:28:27 +02:00
'user': user, 'api_version': 3, 'ignore_auth': True}
source_dict = {
'title': 'Test Source',
'name': 'test-source',
'url': 'basic_test',
'source_type': 'test',
}
harvest_source = logic.get_action('harvest_source_create')(
context,
source_dict
)
assert harvest_source['source_type'] == 'test', harvest_source
assert harvest_source['url'] == 'basic_test', harvest_source
harvest_job = logic.get_action('harvest_job_create')(
context,
2015-10-28 22:58:36 +01:00
{'source_id': harvest_source['id'], 'run': True}
)
job_id = harvest_job['id']
assert harvest_job['source_id'] == harvest_source['id'], harvest_job
2015-10-28 22:58:36 +01:00
assert harvest_job['status'] == u'Running'
assert logic.get_action('harvest_job_show')(
context,
{'id': job_id}
)['status'] == u'Running'
## pop on item off the queue and run the callback
reply = consumer.basic_get(queue='ckan.harvest.gather')
2013-04-22 18:55:46 +02:00
queue.gather_callback(consumer, *reply)
2012-10-25 20:01:54 +02:00
all_objects = model.Session.query(HarvestObject).all()
2012-12-18 00:50:26 +01:00
assert len(all_objects) == 3
2012-10-25 20:01:54 +02:00
assert all_objects[0].state == 'WAITING'
assert all_objects[1].state == 'WAITING'
2012-12-18 00:50:26 +01:00
assert all_objects[2].state == 'WAITING'
2012-10-25 20:01:54 +02:00
2012-12-18 00:50:26 +01:00
assert len(model.Session.query(HarvestObject).all()) == 3
2012-10-25 20:01:54 +02:00
assert len(model.Session.query(HarvestObjectExtra).all()) == 1
2012-12-18 00:50:26 +01:00
## do three times as three harvest objects
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
2013-04-22 18:55:46 +02:00
queue.fetch_callback(consumer_fetch, *reply)
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
queue.fetch_callback(consumer_fetch, *reply)
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
queue.fetch_callback(consumer_fetch, *reply)
count = model.Session.query(model.Package) \
2013-04-22 18:55:46 +02:00
.filter(model.Package.type=='dataset') \
.count()
assert count == 3
2012-12-18 00:50:26 +01:00
all_objects = model.Session.query(HarvestObject).filter_by(current=True).all()
2015-11-17 12:09:24 +01:00
assert_equal(len(all_objects), 3)
assert_equal(all_objects[0].state, 'COMPLETE')
assert_equal(all_objects[0].report_status, 'added')
assert_equal(all_objects[1].state, 'COMPLETE')
assert_equal(all_objects[1].report_status, 'added')
assert_equal(all_objects[2].state, 'COMPLETE')
assert_equal(all_objects[2].report_status, 'added')
## fire run again to check if job is set to Finished
2015-10-28 22:58:36 +01:00
logic.get_action('harvest_jobs_run')(
context,
{'source_id':harvest_source['id']}
)
2012-12-18 00:50:26 +01:00
harvest_job = logic.get_action('harvest_job_show')(
context,
{'id': job_id}
)
2015-11-17 12:09:24 +01:00
assert_equal(harvest_job['status'], u'Finished')
assert_equal(harvest_job['stats'], {'added': 3, 'updated': 0, 'not modified': 0, 'errored': 0, 'deleted': 0})
2012-12-18 03:39:14 +01:00
harvest_source_dict = logic.get_action('harvest_source_show')(
context,
{'id': harvest_source['id']}
)
assert_equal(harvest_source_dict['status']['last_job']['stats'], {'added': 3, 'updated': 0, 'not modified': 0, 'errored': 0, 'deleted': 0})
2015-11-17 12:09:24 +01:00
assert_equal(harvest_source_dict['status']['total_datasets'], 3)
assert_equal(harvest_source_dict['status']['job_count'], 1)
2012-12-18 03:39:14 +01:00
2012-12-18 00:50:26 +01:00
########### Second run ########################
harvest_job = logic.get_action('harvest_job_create')(
context,
2015-10-28 22:58:36 +01:00
{'source_id': harvest_source['id'], 'run': True}
2012-12-18 00:50:26 +01:00
)
job_id = harvest_job['id']
2013-04-22 18:55:46 +02:00
assert logic.get_action('harvest_job_show')(
context,
{'id': job_id}
)['status'] == u'Running'
2012-12-18 00:50:26 +01:00
## pop on item off the queue and run the callback
reply = consumer.basic_get(queue='ckan.harvest.gather')
queue.gather_callback(consumer, *reply)
all_objects = model.Session.query(HarvestObject).all()
assert len(all_objects) == 6
2013-04-22 18:55:46 +02:00
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
queue.fetch_callback(consumer_fetch, *reply)
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
queue.fetch_callback(consumer_fetch, *reply)
reply = consumer_fetch.basic_get(queue='ckan.harvest.fetch')
queue.fetch_callback(consumer_fetch, *reply)
2012-12-18 00:50:26 +01:00
2013-04-22 18:55:46 +02:00
count = model.Session.query(model.Package) \
.filter(model.Package.type=='dataset') \
.count()
2015-11-17 12:09:24 +01:00
assert_equal(count, 3)
2012-12-18 00:50:26 +01:00
2013-04-22 18:55:46 +02:00
all_objects = model.Session.query(HarvestObject).filter_by(report_status='added').all()
2015-11-17 12:09:24 +01:00
assert_equal(len(all_objects), 3)
2012-12-18 00:50:26 +01:00
all_objects = model.Session.query(HarvestObject).filter_by(report_status='updated').all()
2015-11-17 12:09:24 +01:00
assert_equal(len(all_objects), 2)
2012-12-18 00:50:26 +01:00
all_objects = model.Session.query(HarvestObject).filter_by(report_status='deleted').all()
2015-11-17 12:09:24 +01:00
assert_equal(len(all_objects), 1)
2012-12-18 00:50:26 +01:00
2012-12-18 03:39:14 +01:00
# run to make sure job is marked as finshed
2015-10-28 22:58:36 +01:00
logic.get_action('harvest_jobs_run')(
context,
{'source_id':harvest_source['id']}
)
2012-12-18 03:39:14 +01:00
2012-12-18 00:50:26 +01:00
harvest_job = logic.get_action('harvest_job_show')(
context,
{'id': job_id}
2012-12-18 00:50:26 +01:00
)
assert_equal(harvest_job['stats'], {'added': 0, 'updated': 2, 'not modified': 0, 'errored': 0, 'deleted': 1})
2012-12-18 00:50:26 +01:00
2012-12-18 03:39:14 +01:00
context['detailed'] = True
harvest_source_dict = logic.get_action('harvest_source_show')(
context,
{'id': harvest_source['id']}
)
assert_equal(harvest_source_dict['status']['last_job']['stats'], {'added': 0, 'updated': 2, 'not modified': 0, 'errored': 0, 'deleted': 1})
2015-11-17 12:09:24 +01:00
assert_equal(harvest_source_dict['status']['total_datasets'], 2)
assert_equal(harvest_source_dict['status']['job_count'], 2)