~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/intertree_implementations/test_compare.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2007-04-26 15:39:04 UTC
  • mfrom: (2456.2.6 rename_iter_changes_109993)
  • Revision ID: pqm@pqm.ubuntu.com-20070426153904-l91p9ybsqpxt2vyv
(John Arbash Meinel) Fix bug #109993 by fixing _iter_changes to not sync an on-disk file with an 'absent' dirblock record.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1246
1246
                         self.do_iter_changes(tree1, tree2,
1247
1247
                                              require_versioned=False,
1248
1248
                                              want_unversioned=True))
 
1249
 
 
1250
    def test_rename_over_deleted(self):
 
1251
        tree1 = self.make_branch_and_tree('tree1')
 
1252
        tree2 = self.make_to_branch_and_tree('tree2')
 
1253
        root_id = tree1.get_root_id()
 
1254
        tree2.set_root_id(root_id)
 
1255
 
 
1256
        # The final changes should be:
 
1257
        #   touch a b c d
 
1258
        #   add a b c d
 
1259
        #   commit
 
1260
        #   rm a d
 
1261
        #   mv b a
 
1262
        #   mv c d
 
1263
        self.build_tree_contents([
 
1264
            ('tree1/a', 'a contents\n'),
 
1265
            ('tree1/b', 'b contents\n'),
 
1266
            ('tree1/c', 'c contents\n'),
 
1267
            ('tree1/d', 'd contents\n'),
 
1268
            ('tree2/a', 'b contents\n'),
 
1269
            ('tree2/d', 'c contents\n'),
 
1270
            ])
 
1271
        tree1.add(['a', 'b', 'c', 'd'], ['a-id', 'b-id', 'c-id', 'd-id'])
 
1272
        tree2.add(['a', 'd'], ['b-id', 'c-id'])
 
1273
 
 
1274
        tree1, tree2 = self.mutable_trees_to_locked_test_trees(tree1, tree2)
 
1275
 
 
1276
        expected = sorted([
 
1277
            self.deleted(tree1, 'a-id'),
 
1278
            self.deleted(tree1, 'd-id'),
 
1279
            self.renamed(tree1, tree2, 'b-id', False),
 
1280
            self.renamed(tree1, tree2, 'c-id', False),
 
1281
            ])
 
1282
        self.assertEqual(expected,
 
1283
                         self.do_iter_changes(tree1, tree2))
 
1284
 
 
1285
    def test_deleted_and_unknown(self):
 
1286
        """Test a file marked removed, but still present on disk."""
 
1287
        tree1 = self.make_branch_and_tree('tree1')
 
1288
        tree2 = self.make_to_branch_and_tree('tree2')
 
1289
        root_id = tree1.get_root_id()
 
1290
        tree2.set_root_id(root_id)
 
1291
 
 
1292
        # The final changes should be:
 
1293
        # bzr add a b c
 
1294
        # bzr rm --keep b
 
1295
        self.build_tree_contents([
 
1296
            ('tree1/a', 'a contents\n'),
 
1297
            ('tree1/b', 'b contents\n'),
 
1298
            ('tree1/c', 'c contents\n'),
 
1299
            ('tree2/a', 'a contents\n'),
 
1300
            ('tree2/b', 'b contents\n'),
 
1301
            ('tree2/c', 'c contents\n'),
 
1302
            ])
 
1303
        tree1.add(['a', 'b', 'c'], ['a-id', 'b-id', 'c-id'])
 
1304
        tree2.add(['a', 'c'], ['a-id', 'c-id'])
 
1305
 
 
1306
        tree1, tree2 = self.mutable_trees_to_locked_test_trees(tree1, tree2)
 
1307
 
 
1308
        expected = sorted([
 
1309
            self.deleted(tree1, 'b-id'),
 
1310
            self.unversioned(tree2, 'b'),
 
1311
            ])
 
1312
        self.assertEqual(expected,
 
1313
                         self.do_iter_changes(tree1, tree2,
 
1314
                                              want_unversioned=True))
 
1315
        expected = sorted([
 
1316
            self.deleted(tree1, 'b-id'),
 
1317
            ])
 
1318
        self.assertEqual(expected,
 
1319
                         self.do_iter_changes(tree1, tree2,
 
1320
                                              want_unversioned=False))