File: 12-append.t

package info (click to toggle)
libdbix-class-tree-nestedset-perl 0.10-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 196 kB
  • sloc: perl: 1,672; makefile: 2
file content (111 lines) | stat: -rwxr-xr-x 3,053 bytes parent folder | download | duplicates (3)
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
#!/usr/bin/env perl
#
# $Id: $
# $Revision: $
# $Author: $
# $Source:  $
#
# $Log: $
#
use strict;
use warnings;
use Test::More;
use DBICx::TestDatabase;
use Data::Dumper;

use FindBin;
use lib "$FindBin::Bin/../lib";
use lib "$FindBin::Bin/tlib";

BEGIN { use_ok('TestSchema') }

my $schema = DBICx::TestDatabase->new('TestSchema');
isa_ok($schema, 'DBIx::Class::Schema');

my $trees = $schema->resultset('MultiTree');
isa_ok($trees, 'DBIx::Class::ResultSet');

my $tree1 = $trees->create({ content => 'tree1 root', root_id => 10});
my $tree2 = $trees->create({ content => 'tree2 root', root_id => 20});

is($tree1->ancestors->count, 0, "Root has no ancestors");
is($tree2->parent, undef, "Root has no parent");

# Add children to tree1
my $child1_0 = $tree1->create_rightmost_child({ content => 'child1_0'});
my $child1_1 = $child1_0->create_right_sibling({ content => 'child1-1'});
my $child1_2 = $child1_0->create_right_sibling({ content => 'child1-2'});
my $child1_3 = $child1_0->create_right_sibling({ content => 'child1-3'});

my $g_child10_1     = $child1_0->add_to_children({ content => 'g_child10_1'});
my $g_child10_2     = $child1_0->add_to_children({ content => 'g_child10_2'});
my $gg_child102_1   = $g_child10_2->add_to_children({ content => 'g_child102_1'});

$tree1->discard_changes;
$child1_0->discard_changes;
$child1_1->discard_changes;
$child1_2->discard_changes;
$child1_3->discard_changes;
$g_child10_1->discard_changes;
$g_child10_2->discard_changes;
$gg_child102_1->discard_changes;

is_deeply(
    [map { $_->id} $tree1->nodes],
    [map { $_->id} $tree1, $child1_0, $g_child10_1, $g_child10_2, $gg_child102_1, $child1_3, $child1_2, $child1_1],
    'Tree 1 is organised correctly.',
);

#Test deleting a leaf node
$child1_2->delete;
$tree1->discard_changes;
$child1_0->discard_changes;
$child1_1->discard_changes;
$child1_3->discard_changes;
$g_child10_1->discard_changes;
$g_child10_2->discard_changes;
$gg_child102_1->discard_changes;

is_deeply(
    [map { $_->id} $tree1->nodes],
    [map { $_->id} $tree1, $child1_0, $g_child10_1, $g_child10_2, $gg_child102_1, $child1_3, $child1_1],
    'Tree 1 is organised correctly after deletion.',
);

# Test deleting a branch
$g_child10_2->delete;
$tree1->discard_changes;
$child1_0->discard_changes;
$child1_1->discard_changes;
$child1_3->discard_changes;
$g_child10_1->discard_changes;

is_deeply(
    [map { $_->id} $tree1->nodes],
    [map { $_->id} $tree1, $child1_0, $g_child10_1, $child1_3, $child1_1],
    'Tree 1 is organised correctly after deletion.',
);

# Delete remaining nodes except root
$child1_0->delete;
$child1_1->delete;
$child1_3->delete;

is_deeply(
    [map { $_->id} $tree1->nodes],
    [map { $_->id} $tree1],
    'Tree 1 is organised correctly after deletion of all nodes.',
);

# Delete the root
$tree1->delete;

my $tree1_count = $trees->search({root_id => 10})->count;
is($tree1_count, 0, "There are no more nodes in tree1");

my $tree2_count = $trees->search({root_id => 20})->count;
is($tree2_count, 1, "Tree2 still exists");

done_testing();
exit;