Fixed merge tests for Places; fixed init for PlaceNames with source

This commit is contained in:
Doug Blank 2015-05-26 22:03:07 -04:00
parent cc6820f80c
commit 962608c6bf
2 changed files with 55 additions and 43 deletions

View File

@ -50,8 +50,12 @@ class PlaceName(SecondaryObject, DateBase):
Create a new PlaceName instance, copying from the source if present.
"""
DateBase.__init__(self, source)
self.value = ''
self.lang = ''
if source:
self.value = source.value
self.lang = source.lang
else:
self.value = ''
self.lang = ''
def serialize(self):
"""

View File

@ -23,7 +23,7 @@
import unittest
from .. import (Person, Surname, Name, NameType, Family, FamilyRelType,
Event, EventType, Source, Place, Citation, Date,
Event, EventType, Source, Place, PlaceName, Citation, Date,
Repository, RepositoryType, MediaObject, Note, NoteType,
StyledText, StyledTextTag, StyledTextTagType, Tag,
ChildRef, ChildRefType, Attribute, MediaRef, AttributeType,
@ -1391,100 +1391,108 @@ class PlaceCheck(unittest.TestCase, PrivacyBaseTest, MediaBaseTest,
self.phoenix.set_title('Place 1')
self.titanic = Place(self.phoenix)
self.ref_obj = Place(self.phoenix)
self.amsterdam = PlaceName()
self.amsterdam.set_value('Amsterdam')
self.rotterdam = PlaceName()
self.rotterdam.set_value('Rotterdam')
self.utrecht = PlaceName()
self.utrecht.set_value('Utrecht')
self.leiden = PlaceName()
self.leiden.set_value('Leiden')
def test_merge_primary_identical(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.titanic.set_title('Place 2')
self.titanic.set_name('Amsterdam')
self.titanic.set_name(self.amsterdam)
self.titanic.set_type(PlaceType.CITY)
self.ref_obj.set_name('Amsterdam')
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_primary_different(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.titanic.set_title('Place 2')
self.titanic.set_name('Rotterdam')
self.titanic.set_name(self.rotterdam)
self.titanic.set_type(PlaceType.CITY)
self.ref_obj.set_name('Amsterdam')
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name(self.rotterdam)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_both_different(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.phoenix.add_alternative_name('Utrecht')
self.phoenix.add_alternative_name(self.utrecht)
self.titanic.set_title('Place 2')
self.titanic.set_name('Rotterdam')
self.titanic.set_name(self.rotterdam)
self.titanic.set_type(PlaceType.CITY)
self.titanic.add_alternative_name('Leiden')
self.ref_obj.set_name('Amsterdam')
self.titanic.add_alternative_name(self.leiden)
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Amsterdam')
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name('Utrecht')
self.ref_obj.add_alternative_name('Leiden')
self.ref_obj.add_alternative_name(self.amsterdam)
self.ref_obj.add_alternative_name(self.rotterdam)
self.ref_obj.add_alternative_name(self.utrecht)
self.ref_obj.add_alternative_name(self.leiden)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_alternative_identical(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.phoenix.add_alternative_name('Rotterdam')
self.phoenix.add_alternative_name(self.rotterdam)
self.titanic.set_title('Place 2')
self.titanic.set_name('Amsterdam')
self.titanic.set_name(self.amsterdam)
self.titanic.set_type(PlaceType.CITY)
self.titanic.add_alternative_name('Rotterdam')
self.ref_obj.set_name('Amsterdam')
self.titanic.add_alternative_name(self.rotterdam)
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name(self.rotterdam)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_alternative_different(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.phoenix.add_alternative_name('Rotterdam')
self.phoenix.add_alternative_name(self.rotterdam)
self.titanic.set_title('Place 2')
self.titanic.set_name('Amsterdam')
self.titanic.set_name(self.amsterdam)
self.titanic.set_type(PlaceType.CITY)
self.titanic.add_alternative_name('Utrecht')
self.ref_obj.set_name('Amsterdam')
self.titanic.add_alternative_name(self.utrecht)
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name('Utrecht')
self.ref_obj.add_alternative_name(self.rotterdam)
self.ref_obj.add_alternative_name(self.utrecht)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_prialt_identical(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.phoenix.add_alternative_name('Rotterdam')
self.phoenix.add_alternative_name(self.rotterdam)
self.titanic.set_title('Place 2')
self.titanic.set_name('Rotterdam')
self.titanic.set_name(self.rotterdam)
self.titanic.set_type(PlaceType.CITY)
self.ref_obj.set_name('Amsterdam')
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name(self.rotterdam)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())
def test_merge_prialt2(self):
self.phoenix.set_name('Amsterdam')
self.phoenix.set_name(self.amsterdam)
self.phoenix.set_type(PlaceType.CITY)
self.phoenix.add_alternative_name('Rotterdam')
self.phoenix.add_alternative_name(self.rotterdam)
self.titanic.set_title('Place 2')
self.titanic.set_name('Rotterdam')
self.titanic.set_name(self.rotterdam)
self.titanic.set_type(PlaceType.CITY)
self.titanic.add_alternative_name('Amsterdam')
self.ref_obj.set_name('Amsterdam')
self.titanic.add_alternative_name(self.amsterdam)
self.ref_obj.set_name(self.amsterdam)
self.ref_obj.set_type(PlaceType.CITY)
self.ref_obj.add_alternative_name('Rotterdam')
self.ref_obj.add_alternative_name(self.rotterdam)
self.phoenix.merge(self.titanic)
self.assertEqual(self.phoenix.serialize(), self.ref_obj.serialize())