diff options
author | Matthew Somerville <matthew-github@dracos.co.uk> | 2017-05-23 09:49:12 +0100 |
---|---|---|
committer | Matthew Somerville <matthew-github@dracos.co.uk> | 2017-05-23 09:49:12 +0100 |
commit | 8ccf0d95199e026c202a4bede9b45e646744423e (patch) | |
tree | ead46cfa384c5ae34718671e2201f3afe7e7c975 /t/Mock/Bing.pm | |
parent | 082f2c31c8dc94fe5e2492b0dd3ad65c4db9f2c1 (diff) | |
parent | 675744156c56d7b5ea5c8866fdd59a1c3cbcee1b (diff) |
Merge branch '1695-scientific-no-tation'
Diffstat (limited to 't/Mock/Bing.pm')
-rw-r--r-- | t/Mock/Bing.pm | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/t/Mock/Bing.pm b/t/Mock/Bing.pm new file mode 100644 index 000000000..3dfb8fbe0 --- /dev/null +++ b/t/Mock/Bing.pm @@ -0,0 +1,37 @@ +package t::Mock::Bing; + +use JSON::MaybeXS; +use Web::Simple; +use LWP::Protocol::PSGI; + +has json => ( + is => 'lazy', + default => sub { + JSON->new->pretty->allow_blessed->convert_blessed; + }, +); + +sub dispatch_request { + my $self = shift; + + sub (GET + /REST/v1/Locations/* + ?*) { + my ($self, $location, $query) = @_; + my $data = { + resourceSets => [ { + resources => [ { + name => 'Constitution Hill, London, SW1A', + address => { + addressLine => 'Constitution Hill', + locality => 'London', + } + } ], + } ], + }; + my $json = $self->json->encode($data); + return [ 200, [ 'Content-Type' => 'application/json' ], [ $json ] ]; + }, +} + +LWP::Protocol::PSGI->register(t::Mock::Bing->to_psgi_app, host => 'dev.virtualearth.net'); + +__PACKAGE__->run_if_script; |