add some more transposition logic
[scpubgit/stemmatology.git] / t / text_tradition_collation_relationshipstore.t
CommitLineData
b0b4421a 1#!/usr/bin/perl -w
2
3use strict;
4use Test::More 'no_plan';
5$| = 1;
6
7
8
9# =begin testing
10{
11use Text::Tradition;
ee801e17 12use TryCatch;
b0b4421a 13
14use_ok( 'Text::Tradition::Collation::RelationshipStore' );
ee801e17 15
16# Add some relationships, and delete them
17
18my $cxfile = 't/data/Collatex-16.xml';
19my $t = Text::Tradition->new(
20 'name' => 'inline',
21 'input' => 'CollateX',
22 'file' => $cxfile,
23 );
24my $c = $t->collation;
25
f8331a4d 26my @v1 = $c->add_relationship( 'n21', 'n22', { 'type' => 'lexical' } );
ee801e17 27is( scalar @v1, 1, "Added a single relationship" );
28is( $v1[0]->[0], 'n21', "Got correct node 1" );
29is( $v1[0]->[1], 'n22', "Got correct node 2" );
679f17e1 30my @v2 = $c->add_relationship( 'n24', 'n23',
ee801e17 31 { 'type' => 'spelling', 'scope' => 'global' } );
32is( scalar @v2, 2, "Added a global relationship with two instances" );
33@v1 = $c->del_relationship( 'n22', 'n21' );
34is( scalar @v1, 1, "Deleted first relationship" );
679f17e1 35@v2 = $c->del_relationship( 'n12', 'n13' );
ee801e17 36is( scalar @v2, 2, "Deleted second global relationship" );
681893aa 37my @v3 = $c->del_relationship( 'n1', 'n2' );
38is( scalar @v3, 0, "Nothing deleted on non-existent relationship" );
b0b4421a 39}
40
41
42
6d381462 43# =begin testing
44{
45use Text::Tradition;
46use TryCatch;
47
48my $t1 = Text::Tradition->new( 'input' => 'Self', 'file' => 't/data/legendfrag.xml' );
49# Test 1: try to equate nodes that are prevented with an intermediate collation
50ok( $t1, "Parsed test fragment file" );
51my $c1 = $t1->collation;
414cc046 52## HACK
53$c1->calculate_ranks();
6d381462 54my $trel = $c1->get_relationship( '9,2', '9,3' );
55is( ref( $trel ), 'Text::Tradition::Collation::Relationship',
56 "Troublesome relationship exists" );
57is( $trel->type, 'collated', "Troublesome relationship is a collation" );
58
59# Try to make the link we want
60try {
61 $c1->add_relationship( '8,6', '10,3', { 'type' => 'orthographic' } );
62 ok( 1, "Added cross-collation relationship as expected" );
63} catch {
64 ok( 0, "Existing collation blocked equivalence relationship" );
65}
66
67try {
68 $c1->calculate_ranks();
69 ok( 1, "Successfully calculated ranks" );
70} catch {
71 ok( 0, "Collation now has a cycle" );
72}
73
74# Test 2: try to equate nodes that are prevented with a real intermediate
75# equivalence
76
77my $t2 = Text::Tradition->new( 'input' => 'Self', 'file' => 't/data/legendfrag.xml' );
78# Test 1: try to equate nodes that are prevented with an intermediate collation
79my $c2 = $t2->collation;
414cc046 80## HACK
81$c2->calculate_ranks();
6d381462 82$c2->add_relationship( '9,2', '9,3', { 'type' => 'lexical' } );
83my $trel2 = $c2->get_relationship( '9,2', '9,3' );
84is( ref( $trel2 ), 'Text::Tradition::Collation::Relationship',
85 "Created blocking relationship" );
86is( $trel2->type, 'lexical', "Blocking relationship is not a collation" );
87# This time the link ought to fail
88try {
89 $c2->add_relationship( '8,6', '10,3', { 'type' => 'orthographic' } );
90 ok( 0, "Existing equivalence blocked crossing relationship" );
91} catch {
92 ok( 1, "Added cross-equivalent bad relationship" );
93}
94
95try {
96 $c2->calculate_ranks();
97 ok( 1, "Successfully calculated ranks" );
98} catch {
99 ok( 0, "Collation now has a cycle" );
100}
101}
102
103
104
b0b4421a 105
1061;