Better formatting in supybot.Author if some fields are missing

This commit is contained in:
James Lu 2019-11-11 11:09:50 -08:00
parent bace9cb6c0
commit 7854db7135
2 changed files with 74 additions and 6 deletions

View File

@ -40,6 +40,10 @@ del builtins['supybotInternationalization']
(__builtins__ if isinstance(__builtins__, dict) else __builtins__.__dict__)['format'] = utils.str.format (__builtins__ if isinstance(__builtins__, dict) else __builtins__.__dict__)['format'] = utils.str.format
class Author(object): class Author(object):
"""
Describes a plugin author. All fields are optional, but the standard practice
is to include an email and at least one of 'name' and 'nick'.
"""
def __init__(self, name=None, nick=None, email=None, **kwargs): def __init__(self, name=None, nick=None, email=None, **kwargs):
self.__dict__.update(kwargs) self.__dict__.update(kwargs)
self.name = name self.name = name
@ -47,10 +51,17 @@ class Author(object):
self.email = email self.email = email
def __str__(self): def __str__(self):
if self.name != self.nick: # If only one of these are defined, take the nick as the name
return '%s (%s) <%s>' % (self.name, self.nick, self.email) name = self.name or self.nick or 'Unknown author'
else:
return '%s <%s>' % (self.name, self.email) s = name
if self.nick and name != self.nick:
# Format as "Name (nick)" if both are given and different
s += ' (%s)' % self.nick
if self.email:
# Add "Name (nick) <email>" or "Name <email>" if provided
s += ' <%s>' % self.email
return s
class authors(object): # This is basically a bag. class authors(object): # This is basically a bag.
jemfinch = Author('Jeremy Fincher', 'jemfinch', 'jemfinch@users.sf.net') jemfinch = Author('Jeremy Fincher', 'jemfinch', 'jemfinch@users.sf.net')
@ -64,8 +75,8 @@ class authors(object): # This is basically a bag.
grantbow = Author('Grant Bowman', 'Grantbow', 'grantbow@grantbow.com') grantbow = Author('Grant Bowman', 'Grantbow', 'grantbow@grantbow.com')
stepnem = Author('Štěpán Němec', 'stepnem', 'stepnem@gmail.com') stepnem = Author('Štěpán Němec', 'stepnem', 'stepnem@gmail.com')
progval = Author('Valentin Lorentz', 'ProgVal', 'progval@gmail.com') progval = Author('Valentin Lorentz', 'ProgVal', 'progval@gmail.com')
jlu = Author('James Lu', 'GLolol', 'james@overdrivenetworks.com') jlu = Author('James Lu', email='james@overdrivenetworks.com')
unknown = Author('Unknown author', 'unknown', 'unknown@email.invalid') unknown = Author('Unknown author', email='unknown@email.invalid')
# Let's be somewhat safe about this. # Let's be somewhat safe about this.
def __getattr__(self, attr): def __getattr__(self, attr):

57
test/test_misc.py Normal file
View File

@ -0,0 +1,57 @@
###
# Copyright (c) 2019, James Lu <james@overdrivenetworks.com>
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# * Redistributions of source code must retain the above copyright notice,
# this list of conditions, and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions, and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# * Neither the name of the author of this software nor the name of
# contributors to this software may be used to endorse or promote products
# derived from this software without specific prior written consent.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
###
import supybot
from supybot.test import *
class MiscTestCase(SupyTestCase):
def testAuthorExpand(self):
# The standard 3 pair: name, nick, email
self.assertEqual(str(supybot.authors.progval),
'Valentin Lorentz (ProgVal) <progval@gmail.com>')
# All 3 provided, but name == nick
self.assertEqual(str(supybot.Author('foobar', 'foobar', 'foobar@example.net')),
'foobar <foobar@example.net>')
# Only name provided
self.assertEqual(str(supybot.Author('somedev')), 'somedev')
# Only nick provided
self.assertEqual(str(supybot.Author(nick='somedev')), 'somedev')
# Only name and nick provided
self.assertEqual(str(supybot.Author('James Lu', 'tacocat')), 'James Lu (tacocat)')
# Only name and nick provided, but name == nick
self.assertEqual(str(supybot.Author('tacocat', 'tacocat')), 'tacocat')
# Only name and email
self.assertEqual(str(supybot.authors.jlu), 'James Lu <james@overdrivenetworks.com>')
# Only nick and email
self.assertEqual(str(supybot.Author(nick='abcdef', email='abcdef@example.org')), 'abcdef <abcdef@example.org>')
# Only email?
self.assertEqual(str(supybot.Author(email='xyzzy@localhost.localdomain')), 'Unknown author <xyzzy@localhost.localdomain>')
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79: