From f9ecf8d9f17d04de2d0853ca71aac055b44fa829 Mon Sep 17 00:00:00 2001 From: franck cuny Date: Mon, 11 Jul 2011 16:45:32 +0200 Subject: add test for loading a middleware outside N::H::Spore namespace Signed-off-by: franck cuny --- t/spore-middleware/ns.t | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 t/spore-middleware/ns.t diff --git a/t/spore-middleware/ns.t b/t/spore-middleware/ns.t new file mode 100644 index 0000000..3d8a57c --- /dev/null +++ b/t/spore-middleware/ns.t @@ -0,0 +1,44 @@ +use strict; +use warnings; +use Test::More; +use Net::HTTP::Spore; +use Test::Exception; + +package test::runtime; + +use Moose; +extends 'Net::HTTP::Spore::Middleware'; + +sub call { + my ( $self, $req) = @_; + $self->response_cb( + sub { + my $res = shift; + $res->header('X-Test' => 1); + } + ); +} + +package main; + +my $mock_server = { + '/show' => sub { + my $req = shift; + $req->new_response( 200, [ 'Content-Type' => 'text/plan' ], 'ok'); + }, +}; + +ok my $client = + Net::HTTP::Spore->new_from_spec( 't/specs/api.json', + base_url => 'http://localhost' ); + +dies_ok { $client->enable('test::runtime') } +"can't load unknown middleware in N::H::Spore namespace"; + +$client->enable('+test::runtime'); +$client->enable('Mock', tests => $mock_server); + +my $res = $client->get_info(); +ok $res->header('X-Test'); + +done_testing; -- cgit 1.4.1