Fix for Windows line separator
svn: r22818
This commit is contained in:
parent
fe98bbd6ff
commit
894701e2f2
@ -27,6 +27,7 @@ from __future__ import print_function
|
|||||||
import unittest
|
import unittest
|
||||||
import time
|
import time
|
||||||
import subprocess
|
import subprocess
|
||||||
|
import os
|
||||||
import xml.etree.ElementTree as ET
|
import xml.etree.ElementTree as ET
|
||||||
|
|
||||||
from ...lib.libgrampsxml import GRAMPS_XML_VERSION
|
from ...lib.libgrampsxml import GRAMPS_XML_VERSION
|
||||||
@ -81,6 +82,10 @@ class VCardCheck(unittest.TestCase):
|
|||||||
input_str = (self.header.encode('utf-8') +
|
input_str = (self.header.encode('utf-8') +
|
||||||
ET.tostring(input_doc, encoding='utf-8'))
|
ET.tostring(input_doc, encoding='utf-8'))
|
||||||
result_str, err_str = process.communicate(input_str)
|
result_str, err_str = process.communicate(input_str)
|
||||||
|
|
||||||
|
separator = '\r' + os.linesep
|
||||||
|
expect_str = separator.join(expect_str) + (separator * 2)
|
||||||
|
|
||||||
if debug:
|
if debug:
|
||||||
print(err_str)
|
print(err_str)
|
||||||
print(result_str)
|
print(result_str)
|
||||||
@ -89,7 +94,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
|
|
||||||
def test_base(self):
|
def test_base(self):
|
||||||
self.do_test(self.database,
|
self.do_test(self.database,
|
||||||
"\r\n".join(self.expect) + '\r\n\r\n')
|
self.expect)
|
||||||
|
|
||||||
def test_esc_string_none(self):
|
def test_esc_string_none(self):
|
||||||
self.assertEqual(VCardWriter.esc("nothing"), "nothing")
|
self.assertEqual(VCardWriter.esc("nothing"), "nothing")
|
||||||
@ -114,7 +119,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(self.name, "title").text = 'Sir.'
|
ET.SubElement(self.name, "title").text = 'Sir.'
|
||||||
self.expect[3] = "FN:Sir. Lastname"
|
self.expect[3] = "FN:Sir. Lastname"
|
||||||
self.expect[4] = "N:Lastname;;;Sir.;"
|
self.expect[4] = "N:Lastname;;;Sir.;"
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_multiple_surname(self):
|
def test_write_name_multiple_surname(self):
|
||||||
self.lastname.text = "Oranje"
|
self.lastname.text = "Oranje"
|
||||||
@ -123,7 +128,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
self.expect[3] = "FN:van Oranje Nassau"
|
self.expect[3] = "FN:van Oranje Nassau"
|
||||||
self.expect[4] = "N:van Oranje,Nassau;;;;"
|
self.expect[4] = "N:van Oranje,Nassau;;;;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Oranje".ljust(55)
|
self.expect[5] = "SORT-STRING:" + "Oranje".ljust(55)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_callname(self):
|
def test_write_name_callname(self):
|
||||||
# callname not in first names!
|
# callname not in first names!
|
||||||
@ -132,7 +137,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
self.expect[3] = "FN:B C Lastname"
|
self.expect[3] = "FN:B C Lastname"
|
||||||
self.expect[4] = "N:Lastname;A;B,C;;"
|
self.expect[4] = "N:Lastname;A;B,C;;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "B C".ljust(30)
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "B C".ljust(30)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_callname_in_addnames(self):
|
def test_write_name_callname_in_addnames(self):
|
||||||
ET.SubElement(self.name, "first").text = "A B C"
|
ET.SubElement(self.name, "first").text = "A B C"
|
||||||
@ -140,35 +145,35 @@ class VCardCheck(unittest.TestCase):
|
|||||||
self.expect[3] = "FN:A B C Lastname"
|
self.expect[3] = "FN:A B C Lastname"
|
||||||
self.expect[4] = "N:Lastname;B;A,C;;"
|
self.expect[4] = "N:Lastname;B;A,C;;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A B C".ljust(30)
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A B C".ljust(30)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_no_callname(self):
|
def test_write_name_no_callname(self):
|
||||||
ET.SubElement(self.name, "first").text = "A B C"
|
ET.SubElement(self.name, "first").text = "A B C"
|
||||||
self.expect[3] = "FN:A B C Lastname"
|
self.expect[3] = "FN:A B C Lastname"
|
||||||
self.expect[4] = "N:Lastname;A;B,C;;"
|
self.expect[4] = "N:Lastname;A;B,C;;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A B C".ljust(30)
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A B C".ljust(30)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_no_additional_names(self):
|
def test_write_name_no_additional_names(self):
|
||||||
ET.SubElement(self.name, "first").text = "A"
|
ET.SubElement(self.name, "first").text = "A"
|
||||||
self.expect[3] = "FN:A Lastname"
|
self.expect[3] = "FN:A Lastname"
|
||||||
self.expect[4] = "N:Lastname;A;;;"
|
self.expect[4] = "N:Lastname;A;;;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A".ljust(30)
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(25) + "A".ljust(30)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_honprefix(self):
|
def test_write_name_honprefix(self):
|
||||||
ET.SubElement(self.name, "title").text = "Sir"
|
ET.SubElement(self.name, "title").text = "Sir"
|
||||||
self.expect[3] = "FN:Sir Lastname"
|
self.expect[3] = "FN:Sir Lastname"
|
||||||
self.expect[4] = "N:Lastname;;;Sir;"
|
self.expect[4] = "N:Lastname;;;Sir;"
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(55)
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(55)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_name_honsuffix(self):
|
def test_write_name_honsuffix(self):
|
||||||
ET.SubElement(self.name, "suffix").text = "Jr."
|
ET.SubElement(self.name, "suffix").text = "Jr."
|
||||||
self.expect[3] = "FN:Lastname\, Jr."
|
self.expect[3] = "FN:Lastname\, Jr."
|
||||||
self.expect[4] = "N:Lastname;;;;Jr."
|
self.expect[4] = "N:Lastname;;;;Jr."
|
||||||
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(55)+ "Jr."
|
self.expect[5] = "SORT-STRING:" + "Lastname".ljust(55)+ "Jr."
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
|
|
||||||
def test_nicknames_regular(self):
|
def test_nicknames_regular(self):
|
||||||
@ -178,7 +183,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
name = ET.SubElement(self.person, "name", attrib=attribs)
|
name = ET.SubElement(self.person, "name", attrib=attribs)
|
||||||
ET.SubElement(name, 'nick').text = 'N.'
|
ET.SubElement(name, 'nick').text = 'N.'
|
||||||
self.expect.insert(6, "NICKNAME:Nick,N.")
|
self.expect.insert(6, "NICKNAME:Nick,N.")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_nicknames_primary_nick(self):
|
def test_nicknames_primary_nick(self):
|
||||||
ET.SubElement(self.name, 'nick').text = 'Nick'
|
ET.SubElement(self.name, 'nick').text = 'Nick'
|
||||||
@ -186,7 +191,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
name = ET.SubElement(self.person, "name", attrib=attribs)
|
name = ET.SubElement(self.person, "name", attrib=attribs)
|
||||||
ET.SubElement(name, 'nick').text = 'N.'
|
ET.SubElement(name, 'nick').text = 'N.'
|
||||||
self.expect.insert(6, "NICKNAME:Nick,N.")
|
self.expect.insert(6, "NICKNAME:Nick,N.")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_birthdate_regular(self):
|
def test_write_birthdate_regular(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -198,7 +203,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.expect.insert(6, "BDAY:2001-02-28")
|
self.expect.insert(6, "BDAY:2001-02-28")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_birthdate_empty(self):
|
def test_write_birthdate_empty(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -208,7 +213,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(event, 'type').text = 'Birth'
|
ET.SubElement(event, 'type').text = 'Birth'
|
||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_birhtdate_textonly(self):
|
def test_write_birhtdate_textonly(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -219,7 +224,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(event, 'dateval', val='Christmas 2001')
|
ET.SubElement(event, 'dateval', val='Christmas 2001')
|
||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_birthdate_span(self):
|
def test_write_birthdate_span(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -231,7 +236,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(event, 'datespan', attrib=attribs)
|
ET.SubElement(event, 'datespan', attrib=attribs)
|
||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_birthdate_range(self):
|
def test_write_birthdate_range(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -243,7 +248,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(event, 'daterange', attrib=attribs)
|
ET.SubElement(event, 'daterange', attrib=attribs)
|
||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_addresses_regular(self):
|
def test_write_addresses_regular(self):
|
||||||
address = ET.SubElement(self.person, 'address')
|
address = ET.SubElement(self.person, 'address')
|
||||||
@ -253,31 +258,31 @@ class VCardCheck(unittest.TestCase):
|
|||||||
ET.SubElement(address, 'state').text = 'province'
|
ET.SubElement(address, 'state').text = 'province'
|
||||||
ET.SubElement(address, 'postal').text = 'zip'
|
ET.SubElement(address, 'postal').text = 'zip'
|
||||||
self.expect.insert(6, "ADR:;;pobox bis street;place;province;zip;country")
|
self.expect.insert(6, "ADR:;;pobox bis street;place;province;zip;country")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_addresses_phone(self):
|
def test_write_addresses_phone(self):
|
||||||
address = ET.SubElement(self.person, 'address')
|
address = ET.SubElement(self.person, 'address')
|
||||||
ET.SubElement(address, 'phone').text = '01234-56789'
|
ET.SubElement(address, 'phone').text = '01234-56789'
|
||||||
self.expect.insert(6, "TEL:01234-56789")
|
self.expect.insert(6, "TEL:01234-56789")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_urls_email(self):
|
def test_write_urls_email(self):
|
||||||
attribs = {'type': 'E-mail', 'href': 'me@example.com'}
|
attribs = {'type': 'E-mail', 'href': 'me@example.com'}
|
||||||
ET.SubElement(self.person, 'url', attrib=attribs)
|
ET.SubElement(self.person, 'url', attrib=attribs)
|
||||||
self.expect.insert(6, "EMAIL:me@example.com")
|
self.expect.insert(6, "EMAIL:me@example.com")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_urls_emial_mailto(self):
|
def test_write_urls_emial_mailto(self):
|
||||||
attribs = {'type': 'E-mail', 'href': 'mailto:me@example.com'}
|
attribs = {'type': 'E-mail', 'href': 'mailto:me@example.com'}
|
||||||
ET.SubElement(self.person, 'url', attrib=attribs)
|
ET.SubElement(self.person, 'url', attrib=attribs)
|
||||||
self.expect.insert(6, "EMAIL:me@example.com")
|
self.expect.insert(6, "EMAIL:me@example.com")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_urls_url(self):
|
def test_write_urls_url(self):
|
||||||
attribs = {'type': 'Web Home', 'href': 'http://www.example.org'}
|
attribs = {'type': 'Web Home', 'href': 'http://www.example.org'}
|
||||||
ET.SubElement(self.person, 'url', attrib=attribs)
|
ET.SubElement(self.person, 'url', attrib=attribs)
|
||||||
self.expect.insert(6, "URL:http://www.example.org")
|
self.expect.insert(6, "URL:http://www.example.org")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_occupation_regular(self):
|
def test_write_occupation_regular(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -289,7 +294,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
attribs = {'hlink': '_e0000', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.expect.insert(6, "ROLE:carpenter")
|
self.expect.insert(6, "ROLE:carpenter")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
def test_write_occupation_lastdate(self):
|
def test_write_occupation_lastdate(self):
|
||||||
events = ET.Element('events')
|
events = ET.Element('events')
|
||||||
@ -309,7 +314,7 @@ class VCardCheck(unittest.TestCase):
|
|||||||
attribs = {'hlink': '_e0001', 'role': 'Primary'}
|
attribs = {'hlink': '_e0001', 'role': 'Primary'}
|
||||||
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
ET.SubElement(self.person, 'eventref', attrib=attribs)
|
||||||
self.expect.insert(6, "ROLE:foreman")
|
self.expect.insert(6, "ROLE:foreman")
|
||||||
self.do_test(self.database, "\r\n".join(self.expect) + '\r\n\r\n')
|
self.do_test(self.database, self.expect)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
Loading…
Reference in New Issue
Block a user