~launchpad-pqm/launchpad/devel

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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
# Copyright 2010 Canonical Ltd.  This software is licensed under the
# GNU Affero General Public License version 3 (see the file LICENSE).

"""Test the pillar vocabularies."""

__metaclass__ = type

from canonical.testing.layers import DatabaseFunctionalLayer
from lp.registry.vocabularies import (
    DistributionOrProductVocabulary,
    DistributionOrProductOrProjectGroupVocabulary,
    PillarVocabularyBase,
    )
from lp.testing import (
    celebrity_logged_in,
    TestCaseWithFactory,
    )


class TestPillarVocabularyBase(TestCaseWithFactory):
    """Test that the PillarVocabularyBase behaves as expected."""
    layer = DatabaseFunctionalLayer

    def setUp(self):
        super(TestPillarVocabularyBase, self).setUp()
        self.vocabulary = PillarVocabularyBase()
        self.product = self.factory.makeProduct(name='orchid-snark')
        self.distribution = self.factory.makeDistribution(name='zebra-snark')
        self.project_group = self.factory.makeProject(name='apple-snark')

    def test_toTerm(self):
        # Product terms are composed of title, name, and the object.
        term = self.vocabulary.toTerm(self.product)
        title = '%s (Product)' % self.product.title
        self.assertEqual(title, term.title)
        self.assertEqual(self.product.name, term.token)
        self.assertEqual(self.product, term.value)

    def test_getTermByToken(self):
        # Tokens are case insentive because the product name is lowercase.
        term = self.vocabulary.getTermByToken('ORCHID-SNARK')
        self.assertEqual(self.product, term.value)

    def test_getTermByToken_LookupError(self):
        # getTermByToken() raises a LookupError when no match is found.
        self.assertRaises(
            LookupError,
            self.vocabulary.getTermByToken, 'does-notexist')

    def test_ordering(self):
        # Results are ordered by rank, with exact matches first.
        terms = self.vocabulary.searchForTerms('snark')
        result = [term.value for term in terms]
        self.assertEqual(
            [self.project_group, self.product, self.distribution], result)


class TestDistributionOrProductVocabulary(TestCaseWithFactory):
    """Test that the ProductVocabulary behaves as expected."""
    layer = DatabaseFunctionalLayer

    def setUp(self):
        super(TestDistributionOrProductVocabulary, self).setUp()
        self.vocabulary = DistributionOrProductVocabulary()
        self.product = self.factory.makeProduct(name='orchid-snark')
        self.distribution = self.factory.makeDistribution(name='zebra-snark')

    def test_inactive_products_are_excluded(self):
        # Inactive product are not in the vocabulary.
        with celebrity_logged_in('registry_experts'):
            self.product.active = False
        terms = self.vocabulary.searchForTerms('snark')
        result = [term.value for term in terms]
        self.assertEqual([self.distribution], result)
        self.assertFalse(self.product in self.vocabulary)

    def test_project_groups_are_excluded(self):
        # Project groups are not in the vocabulary.
        project_group = self.factory.makeProject(name='apple-snark')
        terms = self.vocabulary.searchForTerms('snark')
        result = [term.value for term in terms]
        self.assertEqual([self.product, self.distribution], result)
        self.assertFalse(project_group in self.vocabulary)


class TestDistributionOrProductOrProjectGroupVocabulary(TestCaseWithFactory):
    """Test for DistributionOrProductOrProjectGroupVocabulary."""
    layer = DatabaseFunctionalLayer

    def setUp(self):
        super(TestDistributionOrProductOrProjectGroupVocabulary, self).setUp()
        self.vocabulary = DistributionOrProductOrProjectGroupVocabulary()
        self.product = self.factory.makeProduct(name='orchid-snark')
        self.distribution = self.factory.makeDistribution(name='zebra-snark')
        self.project_group = self.factory.makeProject(name='apple-snark')

    def test_contains_all_pillars_active(self):
        # All active products, project groups and distributions are included.
        self.assertTrue(self.product in self.vocabulary)
        self.assertTrue(self.distribution in self.vocabulary)
        self.assertTrue(self.project_group in self.vocabulary)

    def test_inactive_products_are_excluded(self):
        # Inactive product are not in the vocabulary.
        with celebrity_logged_in('registry_experts'):
            self.product.active = False
        terms = self.vocabulary.searchForTerms('snark')
        result = [term.value for term in terms]
        self.assertEqual([self.project_group, self.distribution], result)
        self.assertFalse(self.product in self.vocabulary)

    def test_inactive_product_groups_are_excluded(self):
        # Inactive project groups are not in the vocabulary.
        with celebrity_logged_in('registry_experts'):
            self.project_group.active = False
        terms = self.vocabulary.searchForTerms('snark')
        result = [term.value for term in terms]
        self.assertEqual([self.product, self.distribution], result)
        self.assertFalse(self.project_group in self.vocabulary)