#noticket No functionality has changed! Factored out responsible_organisation stuff into a separate method to add tests to show what it does.
This commit is contained in:
parent
9daff6a5b2
commit
aa080e9f75
|
@ -338,36 +338,10 @@ class GeminiHarvester(SpatialHarvester):
|
||||||
extras['temporal_coverage-to'] = gemini_values['temporal-extent-end']
|
extras['temporal_coverage-to'] = gemini_values['temporal-extent-end']
|
||||||
|
|
||||||
# Save responsible organization roles
|
# Save responsible organization roles
|
||||||
parties = {}
|
provider, responsible_parties = self._process_responsible_organisation(
|
||||||
owners = []
|
gemini_values['responsible-organisation'])
|
||||||
publishers = []
|
extras['provider'] = provider
|
||||||
for responsible_party in gemini_values['responsible-organisation']:
|
extras['responsible-party'] = '; '.join(responsible_parties)
|
||||||
|
|
||||||
if responsible_party['role'] == 'owner':
|
|
||||||
owners.append(responsible_party['organisation-name'])
|
|
||||||
elif responsible_party['role'] == 'publisher':
|
|
||||||
publishers.append(responsible_party['organisation-name'])
|
|
||||||
|
|
||||||
if responsible_party['organisation-name'] in parties:
|
|
||||||
if not responsible_party['role'] in parties[responsible_party['organisation-name']]:
|
|
||||||
parties[responsible_party['organisation-name']].append(responsible_party['role'])
|
|
||||||
else:
|
|
||||||
parties[responsible_party['organisation-name']] = [responsible_party['role']]
|
|
||||||
|
|
||||||
parties_extra = []
|
|
||||||
for party_name in parties:
|
|
||||||
parties_extra.append('%s (%s)' % (party_name, ', '.join(parties[party_name])))
|
|
||||||
extras['responsible-party'] = '; '.join(parties_extra)
|
|
||||||
|
|
||||||
# Save provider in a separate extra:
|
|
||||||
# first organization to have a role of 'owner', and if there is none, first one with
|
|
||||||
# a role of 'publisher'
|
|
||||||
if len(owners):
|
|
||||||
extras['provider'] = owners[0]
|
|
||||||
elif len(publishers):
|
|
||||||
extras['provider'] = publishers[0]
|
|
||||||
else:
|
|
||||||
extras['provider'] = u''
|
|
||||||
|
|
||||||
# Construct a GeoJSON extent so ckanext-spatial can register the extent geometry
|
# Construct a GeoJSON extent so ckanext-spatial can register the extent geometry
|
||||||
extent_string = self.extent_template.substitute(
|
extent_string = self.extent_template.substitute(
|
||||||
|
@ -489,6 +463,48 @@ class GeminiHarvester(SpatialHarvester):
|
||||||
|
|
||||||
return package
|
return package
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def _process_responsible_organisation(cls, responsible_organisations):
|
||||||
|
'''Given the list of responsible_organisations and their roles,
|
||||||
|
(extracted from the GeminiDocument) determines who the provider is
|
||||||
|
and the list of all responsible organisations and their roles.
|
||||||
|
|
||||||
|
:param responsible_organisations: list of dicts, each with keys
|
||||||
|
includeing 'organisation-name' and 'role'
|
||||||
|
:returns: tuple of: 'provider' (string, may be empty) and
|
||||||
|
'responsible-parties' (list of strings)
|
||||||
|
'''
|
||||||
|
parties = {}
|
||||||
|
owners = []
|
||||||
|
publishers = []
|
||||||
|
for responsible_party in responsible_organisations:
|
||||||
|
if responsible_party['role'] == 'owner':
|
||||||
|
owners.append(responsible_party['organisation-name'])
|
||||||
|
elif responsible_party['role'] == 'publisher':
|
||||||
|
publishers.append(responsible_party['organisation-name'])
|
||||||
|
|
||||||
|
if responsible_party['organisation-name'] in parties:
|
||||||
|
if not responsible_party['role'] in parties[responsible_party['organisation-name']]:
|
||||||
|
parties[responsible_party['organisation-name']].append(responsible_party['role'])
|
||||||
|
else:
|
||||||
|
parties[responsible_party['organisation-name']] = [responsible_party['role']]
|
||||||
|
|
||||||
|
responsible_parties = []
|
||||||
|
for party_name in parties:
|
||||||
|
responsible_parties.append('%s (%s)' % (party_name, ', '.join(parties[party_name])))
|
||||||
|
|
||||||
|
# Save provider in a separate extra:
|
||||||
|
# first organization to have a role of 'owner', and if there is none, first one with
|
||||||
|
# a role of 'publisher'
|
||||||
|
if len(owners):
|
||||||
|
provider = owners[0]
|
||||||
|
elif len(publishers):
|
||||||
|
provider = publishers[0]
|
||||||
|
else:
|
||||||
|
provider = u''
|
||||||
|
|
||||||
|
return provider, responsible_parties
|
||||||
|
|
||||||
def gen_new_name(self, title):
|
def gen_new_name(self, title):
|
||||||
name = munge_title_to_name(title).replace('_', '-')
|
name = munge_title_to_name(title).replace('_', '-')
|
||||||
while '--' in name:
|
while '--' in name:
|
||||||
|
|
|
@ -830,6 +830,67 @@ class TestImportStageTools:
|
||||||
['http://www.test.gov.uk/licenseurl Reference and PSMA Only']),
|
['http://www.test.gov.uk/licenseurl Reference and PSMA Only']),
|
||||||
'http://www.test.gov.uk/licenseurl Reference and PSMA Only')
|
'http://www.test.gov.uk/licenseurl Reference and PSMA Only')
|
||||||
|
|
||||||
|
def test_responsible_organisation_basic(self):
|
||||||
|
responsible_organisation = [{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'owner'},
|
||||||
|
{'organisation-name': 'Maps Ltd',
|
||||||
|
'role': 'distributor'}]
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('Ordnance Survey', ['Maps Ltd (distributor)',
|
||||||
|
'Ordnance Survey (owner)']))
|
||||||
|
|
||||||
|
def test_responsible_organisation_publisher(self):
|
||||||
|
# no owner, so falls back to publisher
|
||||||
|
responsible_organisation = [{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'publisher'},
|
||||||
|
{'organisation-name': 'Maps Ltd',
|
||||||
|
'role': 'distributor'}]
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('Ordnance Survey', ['Maps Ltd (distributor)',
|
||||||
|
'Ordnance Survey (publisher)']))
|
||||||
|
|
||||||
|
def test_responsible_organisation_owner(self):
|
||||||
|
# provider is the owner (ignores publisher)
|
||||||
|
responsible_organisation = [{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'publisher'},
|
||||||
|
{'organisation-name': 'Owner',
|
||||||
|
'role': 'owner'},
|
||||||
|
{'organisation-name': 'Maps Ltd',
|
||||||
|
'role': 'distributor'}]
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('Owner', ['Owner (owner)',
|
||||||
|
'Maps Ltd (distributor)',
|
||||||
|
'Ordnance Survey (publisher)',
|
||||||
|
]))
|
||||||
|
|
||||||
|
def test_responsible_organisation_multiple_roles(self):
|
||||||
|
# provider is the owner (ignores publisher)
|
||||||
|
responsible_organisation = [{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'publisher'},
|
||||||
|
{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'custodian'},
|
||||||
|
{'organisation-name': 'Distributor',
|
||||||
|
'role': 'distributor'}]
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('Ordnance Survey', ['Distributor (distributor)',
|
||||||
|
'Ordnance Survey (publisher, custodian)',
|
||||||
|
]))
|
||||||
|
|
||||||
|
def test_responsible_organisation_blank_provider(self):
|
||||||
|
# no owner or publisher, so blank provider
|
||||||
|
responsible_organisation = [{'organisation-name': 'Ordnance Survey',
|
||||||
|
'role': 'resourceProvider'},
|
||||||
|
{'organisation-name': 'Maps Ltd',
|
||||||
|
'role': 'distributor'}]
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('', ['Maps Ltd (distributor)',
|
||||||
|
'Ordnance Survey (resourceProvider)']))
|
||||||
|
|
||||||
|
def test_responsible_organisation_blank(self):
|
||||||
|
# no owner or publisher, so blank provider
|
||||||
|
responsible_organisation = []
|
||||||
|
assert_equal(GeminiHarvester._process_responsible_organisation(responsible_organisation),
|
||||||
|
('', []))
|
||||||
|
|
||||||
class TestValidation(HarvestFixtureBase):
|
class TestValidation(HarvestFixtureBase):
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue