diff options
author | Matthew Somerville <matthew-github@dracos.co.uk> | 2018-02-12 17:11:58 +0000 |
---|---|---|
committer | Matthew Somerville <matthew-github@dracos.co.uk> | 2018-02-12 17:11:58 +0000 |
commit | 236f615c046dfcfadbba376b735ef7a352a79ef9 (patch) | |
tree | 5dd6c4d18e892cce26e90285c6a7f2d7eab4e9e7 /t/Mock/GoogleGeocoder.pm | |
parent | 5260280b60a1192f87987c34a78fce63fc5c1d26 (diff) | |
parent | 7ec0d3f67766764967a8bb92099c582f8bd6aaf5 (diff) |
Merge branch 'banes-improvements-grab-bag'
Diffstat (limited to 't/Mock/GoogleGeocoder.pm')
-rw-r--r-- | t/Mock/GoogleGeocoder.pm | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/t/Mock/GoogleGeocoder.pm b/t/Mock/GoogleGeocoder.pm new file mode 100644 index 000000000..fd741c00e --- /dev/null +++ b/t/Mock/GoogleGeocoder.pm @@ -0,0 +1,36 @@ +package t::Mock::GoogleGeocoder; + +use JSON::MaybeXS; +use Web::Simple; +use LWP::Protocol::PSGI; + +has json => ( + is => 'lazy', + default => sub { + JSON->new->utf8->pretty->allow_blessed->convert_blessed; + }, +); + +sub dispatch_request { + my $self = shift; + + sub (GET + /maps/api/geocode/json + ?*) { + my ($self, $args) = @_; + my $response = {}; + if ($args->{address} =~ /result/) { + $response->{status} = 'OK'; + push @{$response->{results}}, { formatted_address => 'High Street, Old Town, City of Edinburgh, Scotland', geometry => { location => { lng => -3.1858425, lat => 55.9504009 } } }; + } + if ($args->{address} eq 'two results') { + push @{$response->{results}}, { geometry => { location => { lat => "55.8596449", "lng" => "-4.240377" } }, formatted_address => "High Street, Collegelands, Merchant City, Glasgow, Scotland" }; + } + my $json = mySociety::Locale::in_gb_locale { + $self->json->encode($response); + }; + return [ 200, [ 'Content-Type' => 'application/json' ], [ $json ] ]; + }, +} + +LWP::Protocol::PSGI->register(t::Mock::GoogleGeocoder->to_psgi_app, host => 'maps.googleapis.com'); + +__PACKAGE__->run_if_script; |