~bzr-pqm/bzr/bzr.dev

4634.146.6 by Danny van Heumen
Fixed copyright year.
1
# Copyright (C) 2010 Canonical Ltd
4634.146.3 by Danny van Heumen
Added first, basic test.
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
17
import os
18
from bzrlib import (
19
    branch,
20
    builtins,
21
    errors,
4634.146.4 by Danny van Heumen
Refined test to make use of locking hooks and also validate if lock is truly a checkout-lock.
22
    lock,
4634.146.3 by Danny van Heumen
Added first, basic test.
23
    )
4634.146.11 by Danny van Heumen
Used TestCaseInTempDir as basis for test class. Used assertLength for testing the list lengths.
24
from bzrlib.tests import (
25
    transport_util,
26
    TestCaseInTempDir,
27
    )
28
29
30
class TestRevert(TestCaseInTempDir):
4634.146.3 by Danny van Heumen
Added first, basic test.
31
32
    def setUp(self):
33
        super(TestRevert, self).setUp()
34
35
    def test_revert_tree_write_lock_and_branch_read_lock(self):
36
4634.146.4 by Danny van Heumen
Refined test to make use of locking hooks and also validate if lock is truly a checkout-lock.
37
        # install lock hooks to find out about cmd_revert's locking actions
38
        locks_acquired = []
39
        locks_released = []
40
        lock.Lock.hooks.install_named_hook('lock_acquired',
41
            locks_acquired.append, None)
42
        lock.Lock.hooks.install_named_hook('lock_released',
43
            locks_released.append, None)
44
45
        # execute the revert command (There is nothing to actually revert,
46
        # but locks are acquired either way.)
4634.146.3 by Danny van Heumen
Added first, basic test.
47
        revert = builtins.cmd_revert()
48
        revert.run()
4634.146.4 by Danny van Heumen
Refined test to make use of locking hooks and also validate if lock is truly a checkout-lock.
49
50
        # make sure that only one lock is acquired and released.
4634.146.11 by Danny van Heumen
Used TestCaseInTempDir as basis for test class. Used assertLength for testing the list lengths.
51
        self.assertLength(1, locks_acquired)
52
        self.assertLength(1, locks_released)
4634.146.4 by Danny van Heumen
Refined test to make use of locking hooks and also validate if lock is truly a checkout-lock.
53
54
        # make sure that the nonces are the same, since otherwise
55
        # this would not be the same lock.
56
        self.assertEqual(locks_acquired[0].details, locks_released[0].details)
57
58
        # make sure that the locks are checkout locks.
59
        self.assertEndsWith(locks_acquired[0].lock_url, "/checkout/lock")
60
        self.assertEndsWith(locks_released[0].lock_url, "/checkout/lock")
61