NAME Test::Mountebank - Perl client library for mountebank SYNOPSIS use Test::Mountebank; # Create mountebank client with default port 2525 my $mb = Test::Mountebank::Client->new( base_url => 'http://127.0.0.1' ); # Create an imposter that answers on port 4546 my $imposter = $mb->create_imposter( port => 4546 ); # Adds a stub to the imposter with a predicate and a response # (Responds to URL /foobar.json, returns JSON content '{"foo":"bar"}') $imposter->stub->predicate( path => "/foobar.json", method => "GET", )->response( status_code => 200, content_type => "application/json", # Equivalent: # headers => { Content_Type => "application/json" }, body => { foo => "bar" }, # Equivalent: # body => '{ "foo":"bar" }', ); # Adds a stub for a non-existent resource $imposter->stub->predicate( path => "/qux/999/json", method => "GET", )->response( status_code => 404, content_type => "application/json", body => '{ "error": "No such qux: 999" }', ); # Add a stub to return HTML content read from a file $imposter->stub->predicate( path => "/foobar.html", method => "GET", )->response( status_code => 200, content_type => "text/html", body_from_file => './foobar.html', ); # Clear existing imposter on port 4546 $mb->delete_imposters(4546); # Takes more than one port number, if desired # Send the new imposter to mountebank $mb->save_imposter($imposter); DESCRIPTION The example in the synopsis builds an object structure that generates JSON code like the following, which can be sent to the running mountebank instance in a POST request. { "port": 4546, "protocol": "http", "stubs": [ { "predicates": [ { "equals": { "method": "GET", "path": "/foobar.json" } } ], "responses": [ { "is": { "body": { "foo": "bar" }, "headers": { "Content-Type": "application/json" }, "statusCode": 200 } } ] }, { "predicates": [ { "equals": { "method": "GET", "path": "/qux/999/json" } } ], "responses": [ { "is": { "body": "{ \"error\": \"No such qux: 999\" }", "headers": { "Content-Type": "application/json" }, "statusCode": 404 } } ] }, { "predicates": [ { "equals": { "method": "GET", "path": "/foobar.html" } } ], "responses": [ { "is": { "body": "<html>\n <head>\n <title>foobar</title>\n </head>\n <body>\n foobar\n </body>\n</html>\n\n", "headers": { "Content-Type": "text/html" }, "statusCode": 200 } } ] } ] } Compare the mountebank documentation at http://www.mbtest.org/docs/api/stubs and http://www.mbtest.org/docs/api/predicates. Currently at least, Test::Mountebank implements only the features of mountebank stubs that are most useful for simulating a REST API. There is only one type of predicate (`equals') and only one type of response (`is'). AUTHOR Dagfinn Reiersøl dagfinn@reiersol.com COPYRIGHT Copyright (C) 2016, Dagfinn Reiersøl.