~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_info.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2009-08-27 02:27:19 UTC
  • mfrom: (4634.3.19 gc-batching)
  • Revision ID: pqm@pqm.ubuntu.com-20090827022719-bl2yoqhpj3fcfczu
(andrew) Fix #402657: 2a fetch over dumb transport reads one group at
        a time.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006, 2007 Canonical Ltd
 
1
# Copyright (C) 2006, 2007, 2008 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
 
18
18
"""Tests for the info command of bzr."""
35
35
 
36
36
class TestInfo(ExternalBase):
37
37
 
 
38
    def setUp(self):
 
39
        ExternalBase.setUp(self)
 
40
        self._repo_strings = "2a or development-subtree"
 
41
 
38
42
    def test_info_non_existing(self):
39
43
        if sys.platform == "win32":
40
44
            location = "C:/i/do/not/exist/"
61
65
""", out)
62
66
        self.assertEqual('', err)
63
67
 
 
68
        # Standalone branch - verbose mode
64
69
        out, err = self.run_bzr('info standalone -v')
65
70
        self.assertEqualDiff(
66
71
"""Standalone tree (format: weave)
85
90
 
86
91
Branch history:
87
92
         0 revisions
 
93
 
 
94
Repository:
 
95
         0 revisions
 
96
""", out)
 
97
        self.assertEqual('', err)
 
98
 
 
99
        # Standalone branch - really verbose mode
 
100
        out, err = self.run_bzr('info standalone -vv')
 
101
        self.assertEqualDiff(
 
102
"""Standalone tree (format: weave)
 
103
Location:
 
104
  branch root: standalone
 
105
 
 
106
Format:
 
107
       control: All-in-one format 6
 
108
  working tree: Working tree format 2
 
109
        branch: Branch format 4
 
110
    repository: Weave repository format 6
 
111
 
 
112
In the working tree:
 
113
         0 unchanged
 
114
         0 modified
 
115
         1 added
 
116
         0 removed
 
117
         0 renamed
 
118
         0 unknown
 
119
         0 ignored
 
120
         0 versioned subdirectories
 
121
 
 
122
Branch history:
 
123
         0 revisions
88
124
         0 committers
89
125
 
90
126
Repository:
139
175
 
140
176
Branch history:
141
177
         1 revision
142
 
         1 committer
143
178
         0 days old
144
179
   first revision: %s
145
180
  latest revision: %s
186
221
 
187
222
Branch history:
188
223
         1 revision
189
 
         1 committer
190
224
         0 days old
191
225
   first revision: %s
192
226
  latest revision: %s
230
264
 
231
265
Branch history:
232
266
         1 revision
233
 
         1 committer
234
267
         0 days old
235
268
   first revision: %s
236
269
  latest revision: %s
247
280
        branch5 = tree5.branch
248
281
        out, err = self.run_bzr('info -v lightcheckout')
249
282
        self.assertEqualDiff(
250
 
"""Lightweight checkout (format: 1.6 or 1.6.1-rich-root \
251
 
or dirstate or dirstate-tags or \
252
 
pack-0.92 or rich-root or rich-root-pack)
 
283
"""Lightweight checkout (format: %s)
253
284
Location:
254
285
  light checkout root: lightcheckout
255
286
   checkout of branch: standalone
256
287
 
257
288
Format:
258
289
       control: Meta directory format 1
259
 
  working tree: Working tree format 4
 
290
  working tree: Working tree format 6
260
291
        branch: Branch format 4
261
292
    repository: Weave repository format 6
262
293
 
272
303
 
273
304
Branch history:
274
305
         1 revision
275
 
         1 committer
276
306
         0 days old
277
307
   first revision: %s
278
308
  latest revision: %s
279
309
 
280
310
Repository:
281
311
         1 revision
282
 
""" % (datestring_first, datestring_first,), out)
 
312
""" % (self._repo_strings, datestring_first, datestring_first,), out)
283
313
        self.assertEqual('', err)
284
314
 
285
315
        # Update initial standalone branch
318
348
 
319
349
Branch history:
320
350
         1 revision
321
 
         1 committer
322
351
         0 days old
323
352
   first revision: %s
324
353
  latest revision: %s
360
389
 
361
390
Branch history:
362
391
         1 revision
363
 
         1 committer
364
392
         0 days old
365
393
   first revision: %s
366
394
  latest revision: %s
400
428
 
401
429
Branch history:
402
430
         1 revision
403
 
         1 committer
404
431
         0 days old
405
432
   first revision: %s
406
433
  latest revision: %s
415
442
        # Out of date lightweight checkout
416
443
        out, err = self.run_bzr('info lightcheckout --verbose')
417
444
        self.assertEqualDiff(
418
 
"""Lightweight checkout (format: 1.6 or 1.6.1-rich-root or \
419
 
dirstate or dirstate-tags or \
420
 
pack-0.92 or rich-root or rich-root-pack)
 
445
"""Lightweight checkout (format: %s)
421
446
Location:
422
447
  light checkout root: lightcheckout
423
448
   checkout of branch: standalone
424
449
 
425
450
Format:
426
451
       control: Meta directory format 1
427
 
  working tree: Working tree format 4
 
452
  working tree: Working tree format 6
428
453
        branch: Branch format 4
429
454
    repository: Weave repository format 6
430
455
 
442
467
 
443
468
Branch history:
444
469
         2 revisions
445
 
         1 committer
446
470
         0 days old
447
471
   first revision: %s
448
472
  latest revision: %s
449
473
 
450
474
Repository:
451
475
         2 revisions
452
 
""" % (datestring_first, datestring_last,), out)
 
476
""" % (self._repo_strings, datestring_first, datestring_last,), out)
453
477
        self.assertEqual('', err)
454
478
 
455
479
    def test_info_standalone_no_tree(self):
470
494
 
471
495
Branch history:
472
496
         0 revisions
473
 
         0 committers
474
497
 
475
498
Repository:
476
499
         0 revisions
521
544
 
522
545
Branch history:
523
546
         0 revisions
524
 
         0 committers
525
547
 
526
548
Repository:
527
549
         0 revisions
533
555
        # Create lightweight checkout
534
556
        transport.mkdir('tree')
535
557
        transport.mkdir('tree/lightcheckout')
536
 
        tree2 = branch1.create_checkout('tree/lightcheckout', 
 
558
        tree2 = branch1.create_checkout('tree/lightcheckout',
537
559
            lightweight=True)
538
560
        branch2 = tree2.branch
539
561
        self.assertCheckoutStatusOutput('-v tree/lightcheckout', tree2,
552
574
        datestring_first = format_date(rev.timestamp, rev.timezone)
553
575
        out, err = self.run_bzr('info tree/lightcheckout --verbose')
554
576
        self.assertEqualDiff(
555
 
"""Lightweight checkout (format: 1.6 or 1.6.1-rich-root or \
556
 
dirstate or dirstate-tags or \
557
 
pack-0.92 or rich-root or rich-root-pack)
 
577
"""Lightweight checkout (format: %s)
558
578
Location:
559
579
  light checkout root: tree/lightcheckout
560
580
   checkout of branch: repo/branch
562
582
 
563
583
Format:
564
584
       control: Meta directory format 1
565
 
  working tree: Working tree format 4
 
585
  working tree: Working tree format 6
566
586
        branch: %s
567
587
    repository: %s
568
588
 
578
598
 
579
599
Branch history:
580
600
         1 revision
581
 
         1 committer
582
601
         0 days old
583
602
   first revision: %s
584
603
  latest revision: %s
585
604
 
586
605
Repository:
587
606
         1 revision
588
 
""" % (format.get_branch_format().get_format_description(),
 
607
""" % (self._repo_strings, format.get_branch_format().get_format_description(),
589
608
       format.repository_format.get_format_description(),
590
609
       datestring_first, datestring_first,
591
610
       ), out)
594
613
        # Out of date checkout
595
614
        out, err = self.run_bzr('info -v tree/checkout')
596
615
        self.assertEqualDiff(
597
 
"""Checkout (format: dirstate)
 
616
"""Checkout (format: unnamed)
598
617
Location:
599
618
       checkout root: tree/checkout
600
619
  checkout of branch: repo/branch
601
620
 
602
621
Format:
603
622
       control: Meta directory format 1
604
 
  working tree: Working tree format 4
 
623
  working tree: Working tree format 6
605
624
        branch: %s
606
625
    repository: %s
607
626
 
619
638
 
620
639
Branch history:
621
640
         0 revisions
622
 
         0 committers
623
641
 
624
642
Repository:
625
643
         0 revisions
634
652
        tree3.add('b')
635
653
        out, err = self.run_bzr('info tree/checkout --verbose')
636
654
        self.assertEqualDiff(
637
 
"""Checkout (format: dirstate)
 
655
"""Checkout (format: unnamed)
638
656
Location:
639
657
       checkout root: tree/checkout
640
658
  checkout of branch: repo/branch
641
659
 
642
660
Format:
643
661
       control: Meta directory format 1
644
 
  working tree: Working tree format 4
 
662
  working tree: Working tree format 6
645
663
        branch: %s
646
664
    repository: %s
647
665
 
657
675
 
658
676
Branch history:
659
677
         1 revision
660
 
         1 committer
661
678
         0 days old
662
679
   first revision: %s
663
680
  latest revision: %s
676
693
        datestring_last = format_date(rev.timestamp, rev.timezone)
677
694
        out, err = self.run_bzr('info tree/lightcheckout --verbose')
678
695
        self.assertEqualDiff(
679
 
"""Lightweight checkout (format: 1.6 or 1.6.1-rich-root or \
680
 
dirstate or dirstate-tags or \
681
 
pack-0.92 or rich-root or rich-root-pack)
 
696
"""Lightweight checkout (format: %s)
682
697
Location:
683
698
  light checkout root: tree/lightcheckout
684
699
   checkout of branch: repo/branch
686
701
 
687
702
Format:
688
703
       control: Meta directory format 1
689
 
  working tree: Working tree format 4
 
704
  working tree: Working tree format 6
690
705
        branch: %s
691
706
    repository: %s
692
707
 
704
719
 
705
720
Branch history:
706
721
         2 revisions
707
 
         1 committer
708
722
         0 days old
709
723
   first revision: %s
710
724
  latest revision: %s
711
725
 
712
726
Repository:
713
727
         2 revisions
714
 
""" % (format.get_branch_format().get_format_description(),
 
728
""" % (self._repo_strings, format.get_branch_format().get_format_description(),
715
729
       format.repository_format.get_format_description(),
716
730
       datestring_first, datestring_last,
717
731
       ), out)
732
746
 
733
747
Branch history:
734
748
         2 revisions
735
 
         1 committer
736
749
         0 days old
737
750
   first revision: %s
738
751
  latest revision: %s
819
832
 
820
833
Branch history:
821
834
         0 revisions
822
 
         0 committers
823
835
 
824
836
Repository:
825
837
         0 revisions
860
872
 
861
873
Branch history:
862
874
         1 revision
863
 
         1 committer
864
875
         0 days old
865
876
   first revision: %s
866
877
  latest revision: %s
902
913
 
903
914
Branch history:
904
915
         0 revisions
905
 
         0 committers
906
916
 
907
917
Repository:
908
918
         1 revision
942
952
 
943
953
Branch history:
944
954
         1 revision
945
 
         1 committer
946
955
         0 days old
947
956
   first revision: %s
948
957
  latest revision: %s
974
983
       ),
975
984
       out)
976
985
        self.assertEqual('', err)
977
 
    
 
986
 
978
987
    def test_info_shared_repository_with_tree_in_root(self):
979
988
        format = bzrdir.format_registry.make_bzrdir('knit')
980
989
        transport = self.get_transport()
1029
1038
 
1030
1039
Branch history:
1031
1040
         0 revisions
1032
 
         0 committers
1033
1041
 
1034
1042
Repository:
1035
1043
         0 revisions
1038
1046
       ), out)
1039
1047
        self.assertEqual('', err)
1040
1048
 
 
1049
    def test_info_repository_hook(self):
 
1050
        format = bzrdir.format_registry.make_bzrdir('knit')
 
1051
        def repo_info(repo, stats, outf):
 
1052
            outf.write("more info\n")
 
1053
        info.hooks.install_named_hook('repository', repo_info, None)
 
1054
        # Create shared repository with working trees
 
1055
        repo = self.make_repository('repo', shared=True, format=format)
 
1056
        out, err = self.run_bzr('info -v repo')
 
1057
        self.assertEqualDiff(
 
1058
"""Shared repository with trees (format: dirstate or dirstate-tags or knit)
 
1059
Location:
 
1060
  shared repository: repo
 
1061
 
 
1062
Format:
 
1063
       control: Meta directory format 1
 
1064
    repository: %s
 
1065
 
 
1066
Create working tree for new branches inside the repository.
 
1067
 
 
1068
Repository:
 
1069
         0 revisions
 
1070
more info
 
1071
""" % (format.repository_format.get_format_description(),
 
1072
       ), out)
 
1073
        self.assertEqual('', err)
 
1074
 
1041
1075
    def assertCheckoutStatusOutput(self,
1042
1076
        command_string, lco_tree, shared_repo=None,
1043
1077
        repo_branch=None,
1053
1087
        allow us, the test writers, to document what *should* be present in
1054
1088
        the output. Removing this separation would remove the value of the
1055
1089
        tests.
1056
 
        
 
1090
 
1057
1091
        :param path: the path to the light checkout.
1058
1092
        :param lco_tree: the tree object for the light checkout.
1059
1093
        :param shared_repo: A shared repository is in use, expect that in
1067
1101
            actually locked then this parameter is overridden. This is because
1068
1102
            pack repositories do not have any public API for obtaining an
1069
1103
            exclusive repository wide lock.
1070
 
        :param verbose: If true, expect verbose output
 
1104
        :param verbose: verbosity level: 2 or higher to show committers
1071
1105
        """
1072
1106
        def friendly_location(url):
1073
1107
            path = urlutils.unescape_for_display(url, 'ascii')
1092
1126
            (False, True): 'Lightweight checkout',
1093
1127
            (False, False): 'Checkout',
1094
1128
            }[(shared_repo is not None, light_checkout)]
1095
 
        format = {True: '1.6 or 1.6.1-rich-root'
1096
 
                        ' or dirstate or dirstate-tags or pack-0.92'
1097
 
                        ' or rich-root or rich-root-pack',
1098
 
                  False: 'dirstate'}[light_checkout]
 
1129
        format = {True: self._repo_strings,
 
1130
                  False: 'unnamed'}[light_checkout]
1099
1131
        if repo_locked:
1100
1132
            repo_locked = lco_tree.branch.repository.get_physical_lock_status()
1101
1133
        if repo_locked or branch_locked or tree_locked:
1138
1170
        else:
1139
1171
            branch_data = ("   checkout of branch: %s\n" %
1140
1172
                lco_tree.branch.bzrdir.root_transport.base)
1141
 
        
1142
 
        if verbose:
 
1173
 
 
1174
        if verbose >= 2:
1143
1175
            verbose_info = '         0 committers\n'
1144
1176
        else:
1145
1177
            verbose_info = ''
1146
 
            
 
1178
 
1147
1179
        self.assertEqualDiff(
1148
1180
"""%s (format: %s)
1149
1181
Location:
1296
1328
    def test_info_locking_oslocks(self):
1297
1329
        if sys.platform == "win32":
1298
1330
            raise TestSkipped("don't use oslocks on win32 in unix manner")
 
1331
        self.thisFailsStrictLockCheck()
1299
1332
 
1300
1333
        tree = self.make_branch_and_tree('branch',
1301
1334
                                         format=bzrdir.BzrDirFormat6())
1331
1364
 
1332
1365
Branch history:
1333
1366
         0 revisions
1334
 
         0 committers
1335
1367
 
1336
1368
Repository:
1337
1369
         0 revisions
1364
1396
 
1365
1397
Branch history:
1366
1398
         0 revisions
1367
 
         0 committers
1368
1399
 
1369
1400
Repository:
1370
1401
         0 revisions
1376
1407
    def test_info_stacked(self):
1377
1408
        # We have a mainline
1378
1409
        trunk_tree = self.make_branch_and_tree('mainline',
1379
 
            format='development1')
 
1410
            format='1.6')
1380
1411
        trunk_tree.commit('mainline')
1381
1412
        # and a branch from it which is stacked
1382
1413
        new_dir = trunk_tree.bzrdir.sprout('newbranch', stacked=True)
1383
1414
        out, err = self.run_bzr('info newbranch')
1384
1415
        self.assertEqual(
1385
 
"""Standalone tree (format: development1)
 
1416
"""Standalone tree (format: 1.6)
1386
1417
Location:
1387
1418
  branch root: newbranch
1388
1419