summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/test_authors.py63
-rw-r--r--tests/test_utils.py51
-rw-r--r--tests/utils.py21
3 files changed, 63 insertions, 72 deletions
diff --git a/tests/test_authors.py b/tests/test_authors.py
new file mode 100644
index 00000000..b9c3d101
--- /dev/null
+++ b/tests/test_authors.py
@@ -0,0 +1,63 @@
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2012 OpenStack LLC
+# Copyright 2012 Nebula Inc
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+
+import commands
+import os
+import unittest
+
+
+def parse_mailmap(mailmap='.mailmap'):
+ mapping = {}
+ if os.path.exists(mailmap):
+ fp = open(mailmap, 'r')
+ for l in fp:
+ l = l.strip()
+ if not l.startswith('#') and ' ' in l:
+ canonical_email, alias = l.split(' ')
+ mapping[alias] = canonical_email
+ return mapping
+
+
+def str_dict_replace(s, mapping):
+ for s1, s2 in mapping.iteritems():
+ s = s.replace(s1, s2)
+ return s
+
+
+class AuthorsTestCase(unittest.TestCase):
+ def test_authors_up_to_date(self):
+ root = os.path.normpath(os.path.join(os.path.dirname(__file__), '..'))
+ contributors = set()
+ missing = set()
+ authors_file = open(os.path.join(root, 'AUTHORS'), 'r').read()
+
+ if os.path.exists(os.path.join(root, '.git')):
+ mailmap = parse_mailmap(os.path.join(root, '.mailmap'))
+ for email in commands.getoutput('git log --format=%ae').split():
+ if not email:
+ continue
+ if "jenkins" in email and "openstack.org" in email:
+ continue
+ email = '<' + email + '>'
+ contributors.add(str_dict_replace(email, mailmap))
+
+ for contributor in contributors:
+ if not contributor in authors_file:
+ missing.add(contributor)
+
+ self.assertTrue(len(missing) == 0,
+ '%r not listed in AUTHORS file.' % missing)
diff --git a/tests/test_utils.py b/tests/test_utils.py
deleted file mode 100644
index c8d24966..00000000
--- a/tests/test_utils.py
+++ /dev/null
@@ -1,51 +0,0 @@
-# vim: tabstop=4 shiftwidth=4 softtabstop=4
-
-from openstackclient import utils as os_utils
-from tests import utils
-
-OBJ_LIST = [
- {
- 'id': '123',
- 'name': 'foo',
- 'extra': {
- 'desc': 'foo fu',
- 'status': 'present',
- }
- },
- {
- 'id': 'abc',
- 'name': 'bar',
- 'extra': {
- 'desc': 'babar',
- 'status': 'waiting',
- }
- }
- ]
-
-
-class Obj(object):
-
- def __init__(self):
- pass
-
-
-class UtilsTest(utils.TestCase):
-
- def setUp(self):
- super(UtilsTest, self).setUp()
- self.objs = []
- for o in OBJ_LIST:
- obj = Obj()
- for k in o.keys():
- setattr(obj, k, o.get(k))
- self.objs.append(obj)
-
- def tearDown(self):
- super(UtilsTest, self).tearDown()
- self.objs = []
-
- def test_expand_meta(self):
- ret = os_utils.expand_meta(self.objs, 'extra')
- assert (getattr(ret[0], 'desc') == 'foo fu')
- assert (getattr(ret[0], 'status') == 'present')
- assert (getattr(ret[0], 'extra', 'qaz') == 'qaz')
diff --git a/tests/utils.py b/tests/utils.py
deleted file mode 100644
index 5e42082c..00000000
--- a/tests/utils.py
+++ /dev/null
@@ -1,21 +0,0 @@
-# vim: tabstop=4 shiftwidth=4 softtabstop=4
-
-import time
-
-import mox
-import unittest
-
-
-class TestCase(unittest.TestCase):
-
- def setUp(self):
- super(TestCase, self).setUp()
- self.mox = mox.Mox()
- self._original_time = time.time
- time.time = lambda: 1234
-
- def tearDown(self):
- time.time = self._original_time
- super(TestCase, self).tearDown()
- self.mox.UnsetStubs()
- self.mox.VerifyAll()