| 1 | use strict; |
|---|
| 2 | use Wiki::Toolkit::Setup::SQLite; |
|---|
| 3 | use OpenGuides::Config; |
|---|
| 4 | use OpenGuides; |
|---|
| 5 | use OpenGuides::Test; |
|---|
| 6 | use Test::More; |
|---|
| 7 | |
|---|
| 8 | eval { require DBD::SQLite; }; |
|---|
| 9 | if ( $@ ) { |
|---|
| 10 | my ($error) = $@ =~ /^(.*?)\n/; |
|---|
| 11 | plan skip_all => "DBD::SQLite could not be used - no database to test with. ($error)"; |
|---|
| 12 | } |
|---|
| 13 | |
|---|
| 14 | eval { require Plucene; }; |
|---|
| 15 | if ( $@ ) { |
|---|
| 16 | plan skip_all => "Plucene not installed"; |
|---|
| 17 | } |
|---|
| 18 | |
|---|
| 19 | # Strictly speaking we don't need to skip _all_ tests if we don't have |
|---|
| 20 | # the modules below. Revisit this when not in a hurry. |
|---|
| 21 | # We only actually need the former for the National Grid tests and the |
|---|
| 22 | # latter for the UTM tests. |
|---|
| 23 | eval { require Geography::NationalGrid; }; |
|---|
| 24 | if ( $@ ) { |
|---|
| 25 | plan skip_all => "Geography::NationalGrid not installed"; |
|---|
| 26 | } |
|---|
| 27 | |
|---|
| 28 | eval { require Geo::Coordinates::UTM; }; |
|---|
| 29 | if ( $@ ) { |
|---|
| 30 | plan skip_all => "Geo::Coordinates::UTM not installed"; |
|---|
| 31 | } |
|---|
| 32 | |
|---|
| 33 | plan tests => 53; |
|---|
| 34 | |
|---|
| 35 | # Clear out the database from any previous runs. |
|---|
| 36 | unlink "t/node.db"; |
|---|
| 37 | unlink <t/indexes/*>; |
|---|
| 38 | |
|---|
| 39 | Wiki::Toolkit::Setup::SQLite::setup( { dbname => "t/node.db" } ); |
|---|
| 40 | my $config = OpenGuides::Config->new( |
|---|
| 41 | vars => { |
|---|
| 42 | dbtype => "sqlite", |
|---|
| 43 | dbname => "t/node.db", |
|---|
| 44 | indexing_directory => "t/indexes", |
|---|
| 45 | script_name => "wiki.cgi", |
|---|
| 46 | script_url => "http://example.com/", |
|---|
| 47 | site_name => "Test Site", |
|---|
| 48 | template_path => "./templates", |
|---|
| 49 | use_plucene => 1, |
|---|
| 50 | geo_handler => 1, |
|---|
| 51 | } |
|---|
| 52 | ); |
|---|
| 53 | |
|---|
| 54 | # First check that British National Grid will accept both OS X/Y and lat/long, |
|---|
| 55 | # and will store both however the data was given to it. |
|---|
| 56 | my $guide = OpenGuides->new( config => $config ); |
|---|
| 57 | is( $guide->locator->x_field, "os_x", "correct x field" ); |
|---|
| 58 | is( $guide->locator->y_field, "os_y", "correct y field" ); |
|---|
| 59 | |
|---|
| 60 | OpenGuides::Test->write_data( |
|---|
| 61 | guide => $guide, |
|---|
| 62 | node => "Crabtree Tavern", |
|---|
| 63 | os_x => 523465, |
|---|
| 64 | os_y => 177490, |
|---|
| 65 | categories => "Pubs", |
|---|
| 66 | ); |
|---|
| 67 | my %data = $guide->wiki->retrieve_node( "Crabtree Tavern" ); |
|---|
| 68 | is( $data{metadata}{os_x}[0], 523465, "os_x stored correctly" ); |
|---|
| 69 | is( $data{metadata}{os_y}[0], 177490, "os_y stored correctly" ); |
|---|
| 70 | ok( defined $data{metadata}{latitude}[0], "latitude stored" ); |
|---|
| 71 | ok( defined $data{metadata}{longitude}[0], "longitude stored" ); |
|---|
| 72 | |
|---|
| 73 | OpenGuides::Test->write_data( |
|---|
| 74 | guide => $guide, |
|---|
| 75 | node => "El Sombrero", |
|---|
| 76 | latitude => 51.368, |
|---|
| 77 | longitude => -0.097, |
|---|
| 78 | categories => "Restaurants", |
|---|
| 79 | ); |
|---|
| 80 | %data = $guide->wiki->retrieve_node( "El Sombrero" ); |
|---|
| 81 | ok( defined $data{metadata}{os_x}[0], "os_x stored" ); |
|---|
| 82 | like( $data{metadata}{os_x}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 83 | ok( defined $data{metadata}{os_y}[0], "os_y stored" ); |
|---|
| 84 | like( $data{metadata}{os_y}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 85 | is( $data{metadata}{latitude}[0], 51.368, "latitude stored correctly" ); |
|---|
| 86 | is( $data{metadata}{longitude}[0], -0.097, "longitude stored correctly" ); |
|---|
| 87 | |
|---|
| 88 | eval { |
|---|
| 89 | local $SIG{__WARN__} = sub { die $_[0]; }; |
|---|
| 90 | OpenGuides::Test->write_data( |
|---|
| 91 | guide => $guide, |
|---|
| 92 | node => "Locationless Page 1", |
|---|
| 93 | ); |
|---|
| 94 | }; |
|---|
| 95 | is( $@, "", |
|---|
| 96 | "commit doesn't warn when using BNG and node has no location data" ); |
|---|
| 97 | %data = $guide->wiki->retrieve_node( "Locationless Page 1" ); |
|---|
| 98 | ok( !defined $data{metadata}{latitude}[0], "...and latitude not stored" ); |
|---|
| 99 | ok( !defined $data{metadata}{longitude}[0], "...nor longitude" ); |
|---|
| 100 | ok( !defined $data{metadata}{os_x}[0], "...nor os_x" ); |
|---|
| 101 | ok( !defined $data{metadata}{os_y}[0], "...nor os_y" ); |
|---|
| 102 | ok( !defined $data{metadata}{osie_x}[0], "...nor osie_x" ); |
|---|
| 103 | ok( !defined $data{metadata}{osie_y}[0], "...nor osie_y" ); |
|---|
| 104 | |
|---|
| 105 | # Now check Irish National Grid. |
|---|
| 106 | $config->geo_handler( 2 ); |
|---|
| 107 | $guide = OpenGuides->new( config => $config ); |
|---|
| 108 | is( $guide->locator->x_field, "osie_x", "correct x field" ); |
|---|
| 109 | is( $guide->locator->y_field, "osie_y", "correct y field" ); |
|---|
| 110 | |
|---|
| 111 | OpenGuides::Test->write_data( |
|---|
| 112 | guide => $guide, |
|---|
| 113 | node => "I Made This Place Up", |
|---|
| 114 | osie_x => 100000, |
|---|
| 115 | osie_y => 200000, |
|---|
| 116 | ); |
|---|
| 117 | %data = $guide->wiki->retrieve_node( "I Made This Place Up" ); |
|---|
| 118 | is( $data{metadata}{osie_x}[0], 100000, "osie_x stored correctly" ); |
|---|
| 119 | is( $data{metadata}{osie_y}[0], 200000, "osie_y stored correctly" ); |
|---|
| 120 | ok( defined $data{metadata}{latitude}[0], "latitude stored" ); |
|---|
| 121 | ok( defined $data{metadata}{longitude}[0], "longitude stored" ); |
|---|
| 122 | |
|---|
| 123 | OpenGuides::Test->write_data( |
|---|
| 124 | guide => $guide, |
|---|
| 125 | node => "Brambles Coffee Shop", |
|---|
| 126 | latitude => 54.6434, |
|---|
| 127 | longitude => -5.6731, |
|---|
| 128 | ); |
|---|
| 129 | %data = $guide->wiki->retrieve_node( "Brambles Coffee Shop" ); |
|---|
| 130 | ok( defined $data{metadata}{osie_x}[0], "osie_x stored" ); |
|---|
| 131 | like( $data{metadata}{osie_x}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 132 | ok( defined $data{metadata}{osie_y}[0], "osie_y stored" ); |
|---|
| 133 | like( $data{metadata}{osie_y}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 134 | is( $data{metadata}{latitude}[0], 54.6434, "latitude stored correctly" ); |
|---|
| 135 | is( $data{metadata}{longitude}[0], -5.6731, "longitude stored correctly" ); |
|---|
| 136 | |
|---|
| 137 | eval { |
|---|
| 138 | local $SIG{__WARN__} = sub { die $_[0]; }; |
|---|
| 139 | OpenGuides::Test->write_data( |
|---|
| 140 | guide => $guide, |
|---|
| 141 | node => "Locationless Page 2", |
|---|
| 142 | ); |
|---|
| 143 | }; |
|---|
| 144 | is( $@, "", |
|---|
| 145 | "commit doesn't warn when using ING and node has no location data" ); |
|---|
| 146 | %data = $guide->wiki->retrieve_node( "Locationless Page 2" ); |
|---|
| 147 | ok( !defined $data{metadata}{latitude}[0], "...and latitude not stored" ); |
|---|
| 148 | ok( !defined $data{metadata}{longitude}[0], "...nor longitude" ); |
|---|
| 149 | ok( !defined $data{metadata}{os_x}[0], "...nor os_x" ); |
|---|
| 150 | ok( !defined $data{metadata}{os_y}[0], "...nor os_y" ); |
|---|
| 151 | ok( !defined $data{metadata}{osie_x}[0], "...nor osie_x" ); |
|---|
| 152 | ok( !defined $data{metadata}{osie_y}[0], "...nor osie_y" ); |
|---|
| 153 | |
|---|
| 154 | # Finally check UTM. |
|---|
| 155 | $config->geo_handler( 3 ); |
|---|
| 156 | $config->ellipsoid( "Airy" ); |
|---|
| 157 | $guide = OpenGuides->new( config => $config ); |
|---|
| 158 | is( $guide->locator->x_field, "easting", "correct x field" ); |
|---|
| 159 | is( $guide->locator->y_field, "northing", "correct y field" ); |
|---|
| 160 | |
|---|
| 161 | OpenGuides::Test->write_data( |
|---|
| 162 | guide => $guide, |
|---|
| 163 | node => "London Aquarium", |
|---|
| 164 | latitude => 51.502, |
|---|
| 165 | longitude => -0.118, |
|---|
| 166 | ); |
|---|
| 167 | %data = $guide->wiki->retrieve_node( "London Aquarium" ); |
|---|
| 168 | ok( defined $data{metadata}{easting}[0], "easting stored" ); |
|---|
| 169 | like( $data{metadata}{easting}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 170 | ok( defined $data{metadata}{northing}[0], "northing stored" ); |
|---|
| 171 | like( $data{metadata}{northing}[0], qr/^\d+$/, "...as integer" ); |
|---|
| 172 | is( $data{metadata}{latitude}[0], 51.502, "latitude stored correctly" ); |
|---|
| 173 | is( $data{metadata}{longitude}[0], -0.118, "longitude stored correctly" ); |
|---|
| 174 | |
|---|
| 175 | eval { |
|---|
| 176 | local $SIG{__WARN__} = sub { die $_[0]; }; |
|---|
| 177 | OpenGuides::Test->write_data( |
|---|
| 178 | guide => $guide, |
|---|
| 179 | node => "Locationless Page 3", |
|---|
| 180 | ); |
|---|
| 181 | }; |
|---|
| 182 | is( $@, "", |
|---|
| 183 | "commit doesn't warn when using UTM and node has no location data" ); |
|---|
| 184 | %data = $guide->wiki->retrieve_node( "Locationless Page 3" ); |
|---|
| 185 | ok( !defined $data{metadata}{latitude}[0], "...and latitude not stored" ); |
|---|
| 186 | ok( !defined $data{metadata}{longitude}[0], "...nor longitude" ); |
|---|
| 187 | ok( !defined $data{metadata}{os_x}[0], "...nor os_x" ); |
|---|
| 188 | ok( !defined $data{metadata}{os_y}[0], "...nor os_y" ); |
|---|
| 189 | ok( !defined $data{metadata}{osie_x}[0], "...nor osie_x" ); |
|---|
| 190 | ok( !defined $data{metadata}{osie_y}[0], "...nor osie_y" ); |
|---|