File: test_tags.py

package info (click to toggle)
python-testtools 2.8.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,244 kB
  • sloc: python: 15,086; makefile: 127; sh: 3
file content (81 lines) | stat: -rw-r--r-- 3,028 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# Copyright (c) 2012 testtools developers. See LICENSE for details.

"""Test tag support."""

from testtools import TestCase
from testtools.tags import TagContext


class TestTags(TestCase):
    def test_no_tags(self):
        # A tag context has no tags initially.
        tag_context = TagContext()
        self.assertEqual(set(), tag_context.get_current_tags())

    def test_add_tag(self):
        # A tag added with change_tags appears in get_current_tags.
        tag_context = TagContext()
        tag_context.change_tags({"foo"}, set())
        self.assertEqual({"foo"}, tag_context.get_current_tags())

    def test_add_tag_twice(self):
        # Calling change_tags twice to add tags adds both tags to the current
        # tags.
        tag_context = TagContext()
        tag_context.change_tags({"foo"}, set())
        tag_context.change_tags({"bar"}, set())
        self.assertEqual({"foo", "bar"}, tag_context.get_current_tags())

    def test_change_tags_returns_tags(self):
        # change_tags returns the current tags.  This is a convenience.
        tag_context = TagContext()
        tags = tag_context.change_tags({"foo"}, set())
        self.assertEqual({"foo"}, tags)

    def test_remove_tag(self):
        # change_tags can remove tags from the context.
        tag_context = TagContext()
        tag_context.change_tags({"foo"}, set())
        tag_context.change_tags(set(), {"foo"})
        self.assertEqual(set(), tag_context.get_current_tags())

    def test_child_context(self):
        # A TagContext can have a parent.  If so, its tags are the tags of the
        # parent at the moment of construction.
        parent = TagContext()
        parent.change_tags({"foo"}, set())
        child = TagContext(parent)
        self.assertEqual(parent.get_current_tags(), child.get_current_tags())

    def test_add_to_child(self):
        # Adding a tag to the child context doesn't affect the parent.
        parent = TagContext()
        parent.change_tags({"foo"}, set())
        child = TagContext(parent)
        child.change_tags({"bar"}, set())
        self.assertEqual({"foo", "bar"}, child.get_current_tags())
        self.assertEqual({"foo"}, parent.get_current_tags())

    def test_remove_in_child(self):
        # A tag that was in the parent context can be removed from the child
        # context without affect the parent.
        parent = TagContext()
        parent.change_tags({"foo"}, set())
        child = TagContext(parent)
        child.change_tags(set(), {"foo"})
        self.assertEqual(set(), child.get_current_tags())
        self.assertEqual({"foo"}, parent.get_current_tags())

    def test_parent(self):
        # The parent can be retrieved from a child context.
        parent = TagContext()
        parent.change_tags({"foo"}, set())
        child = TagContext(parent)
        child.change_tags(set(), {"foo"})
        self.assertEqual(parent, child.parent)


def test_suite():
    from unittest import TestLoader

    return TestLoader().loadTestsFromName(__name__)