summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Shadura <andrewsh@debian.org>2017-09-08 15:33:50 +0100
committerAndrew Shadura <andrewsh@debian.org>2017-09-08 15:33:50 +0100
commit55ae6c35b51633e5797439ed58ae35489da97486 (patch)
tree9b03a08c622df399dd1c11a5276eb4d11c67ccbf
Import original source of Plack-Test-Agent 1.4
-rw-r--r--Changes21
-rw-r--r--INSTALL43
-rw-r--r--LICENSE379
-rw-r--r--MANIFEST34
-rw-r--r--META.json668
-rw-r--r--META.yml494
-rw-r--r--Makefile.PL96
-rw-r--r--README.md127
-rw-r--r--README.pod9
-rw-r--r--cpanfile49
-rw-r--r--dist.ini12
-rw-r--r--lib/Plack/Test/Agent.pm311
-rw-r--r--t/00-compile.t51
-rw-r--r--t/00-report-prereqs.dd59
-rw-r--r--t/00-report-prereqs.t176
-rw-r--r--t/2args.t19
-rw-r--r--t/author-eol.t16
-rw-r--r--t/author-no-tabs.t41
-rw-r--r--t/author-pod-spell.t44
-rw-r--r--t/cookie.t35
-rw-r--r--t/cycle.t32
-rw-r--r--t/extra_get_args.t20
-rw-r--r--t/hello.t21
-rw-r--r--t/hello_server.t36
-rw-r--r--t/mech.t58
-rw-r--r--t/okay.t63
-rw-r--r--t/release-cpan-changes.t19
-rw-r--r--t/release-pod-coverage.t49
-rw-r--r--t/release-pod-syntax.t14
-rw-r--r--t/release-portability.t19
-rw-r--r--t/release-synopsis.t13
-rw-r--r--tidyall.ERR1
-rw-r--r--weaver.ini17
33 files changed, 3046 insertions, 0 deletions
diff --git a/Changes b/Changes
new file mode 100644
index 0000000..50d9d7b
--- /dev/null
+++ b/Changes
@@ -0,0 +1,21 @@
+1.4 2015-01-06
+
+* Re-assign copyright to chromatic.
+
+1.3 2015-01-05
+
+* Allow extra args to pass through in get() method. (Ran Eilam)
+
+* Fixed a circular reference between the agent object and the Test::TCP it
+ creates internally. (Dave Rolsky)
+
+* Use Plack::Loader::load() rather than Plack::Loader::auto() if server arg has
+ been provided. Previously, the constructor did start a new server when the
+ server arg was defined, but it ignored the value of the server argument.
+ (Olaf Alders)
+
+* Document get_mech(), normalize_uri() and start_server() (Olaf Alders)
+
+1.20111011 2011-10-11
+
+* Initial release
diff --git a/INSTALL b/INSTALL
new file mode 100644
index 0000000..cc6ed0d
--- /dev/null
+++ b/INSTALL
@@ -0,0 +1,43 @@
+This is the Perl distribution Plack-Test-Agent.
+
+Installing Plack-Test-Agent is straightforward.
+
+## Installation with cpanm
+
+If you have cpanm, you only need one line:
+
+ % cpanm Plack::Test::Agent
+
+If you are installing into a system-wide directory, you may need to pass the
+"-S" flag to cpanm, which uses sudo to install the module:
+
+ % cpanm -S Plack::Test::Agent
+
+## Installing with the CPAN shell
+
+Alternatively, if your CPAN shell is set up, you should just be able to do:
+
+ % cpan Plack::Test::Agent
+
+## Manual installation
+
+As a last resort, you can manually install it. Download the tarball, untar it,
+then build it:
+
+ % perl Makefile.PL
+ % make && make test
+
+Then install it:
+
+ % make install
+
+If you are installing into a system-wide directory, you may need to run:
+
+ % sudo make install
+
+## Documentation
+
+Plack-Test-Agent documentation is available as POD.
+You can run perldoc from a shell to read the documentation:
+
+ % perldoc Plack::Test::Agent
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..a804f72
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,379 @@
+This software is copyright (c) 2011 - 2015 by chromatic.
+
+This is free software; you can redistribute it and/or modify it under
+the same terms as the Perl 5 programming language system itself.
+
+Terms of the Perl programming language system itself
+
+a) the GNU General Public License as published by the Free
+ Software Foundation; either version 1, or (at your option) any
+ later version, or
+b) the "Artistic License"
+
+--- The GNU General Public License, Version 1, February 1989 ---
+
+This software is Copyright (c) 2011 - 2015 by chromatic.
+
+This is free software, licensed under:
+
+ The GNU General Public License, Version 1, February 1989
+
+ GNU GENERAL PUBLIC LICENSE
+ Version 1, February 1989
+
+ Copyright (C) 1989 Free Software Foundation, Inc.
+ 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The license agreements of most software companies try to keep users
+at the mercy of those companies. By contrast, our General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. The
+General Public License applies to the Free Software Foundation's
+software and to any other program whose authors commit to using it.
+You can use it for your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Specifically, the General Public License is designed to make
+sure that you have the freedom to give away or sell copies of free
+software, that you receive source code or can get it if you want it,
+that you can change the software or use pieces of it in new free
+programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of a such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must tell them their rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License Agreement applies to any program or other work which
+contains a notice placed by the copyright holder saying it may be
+distributed under the terms of this General Public License. The
+"Program", below, refers to any such program or work, and a "work based
+on the Program" means either the Program or any work containing the
+Program or a portion of it, either verbatim or with modifications. Each
+licensee is addressed as "you".
+
+ 1. You may copy and distribute verbatim copies of the Program's source
+code as you receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice and
+disclaimer of warranty; keep intact all the notices that refer to this
+General Public License and to the absence of any warranty; and give any
+other recipients of the Program a copy of this General Public License
+along with the Program. You may charge a fee for the physical act of
+transferring a copy.
+
+ 2. You may modify your copy or copies of the Program or any portion of
+it, and copy and distribute such modifications under the terms of Paragraph
+1 above, provided that you also do the following:
+
+ a) cause the modified files to carry prominent notices stating that
+ you changed the files and the date of any change; and
+
+ b) cause the whole of any work that you distribute or publish, that
+ in whole or in part contains the Program or any part thereof, either
+ with or without modifications, to be licensed at no charge to all
+ third parties under the terms of this General Public License (except
+ that you may choose to grant warranty protection to some or all
+ third parties, at your option).
+
+ c) If the modified program normally reads commands interactively when
+ run, you must cause it, when started running for such interactive use
+ in the simplest and most usual way, to print or display an
+ announcement including an appropriate copyright notice and a notice
+ that there is no warranty (or else, saying that you provide a
+ warranty) and that users may redistribute the program under these
+ conditions, and telling the user how to view a copy of this General
+ Public License.
+
+ d) You may charge a fee for the physical act of transferring a
+ copy, and you may at your option offer warranty protection in
+ exchange for a fee.
+
+Mere aggregation of another independent work with the Program (or its
+derivative) on a volume of a storage or distribution medium does not bring
+the other work under the scope of these terms.
+
+ 3. You may copy and distribute the Program (or a portion or derivative of
+it, under Paragraph 2) in object code or executable form under the terms of
+Paragraphs 1 and 2 above provided that you also do one of the following:
+
+ a) accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of
+ Paragraphs 1 and 2 above; or,
+
+ b) accompany it with a written offer, valid for at least three
+ years, to give any third party free (except for a nominal charge
+ for the cost of distribution) a complete machine-readable copy of the
+ corresponding source code, to be distributed under the terms of
+ Paragraphs 1 and 2 above; or,
+
+ c) accompany it with the information you received as to where the
+ corresponding source code may be obtained. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form alone.)
+
+Source code for a work means the preferred form of the work for making
+modifications to it. For an executable file, complete source code means
+all the source code for all modules it contains; but, as a special
+exception, it need not include source code for modules which are standard
+libraries that accompany the operating system on which the executable
+file runs, or for standard header files or definitions files that
+accompany that operating system.
+
+ 4. You may not copy, modify, sublicense, distribute or transfer the
+Program except as expressly provided under this General Public License.
+Any attempt otherwise to copy, modify, sublicense, distribute or transfer
+the Program is void, and will automatically terminate your rights to use
+the Program under this License. However, parties who have received
+copies, or rights to use copies, from you under this General Public
+License will not have their licenses terminated so long as such parties
+remain in full compliance.
+
+ 5. By copying, distributing or modifying the Program (or any work based
+on the Program) you indicate your acceptance of this license to do so,
+and all its terms and conditions.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the original
+licensor to copy, distribute or modify the Program subject to these
+terms and conditions. You may not impose any further restrictions on the
+recipients' exercise of the rights granted herein.
+
+ 7. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of the license which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+the license, you may choose any version ever published by the Free Software
+Foundation.
+
+ 8. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 9. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 10. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ Appendix: How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to humanity, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these
+terms.
+
+ To do so, attach the following notices to the program. It is safest to
+attach them to the start of each source file to most effectively convey
+the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) 19yy <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 1, or (at your option)
+ any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) 19xx name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the
+appropriate parts of the General Public License. Of course, the
+commands you use may be called something other than `show w' and `show
+c'; they could even be mouse-clicks or menu items--whatever suits your
+program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the
+ program `Gnomovision' (a program to direct compilers to make passes
+ at assemblers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+That's all there is to it!
+
+
+--- The Artistic License 1.0 ---
+
+This software is Copyright (c) 2011 - 2015 by chromatic.
+
+This is free software, licensed under:
+
+ The Artistic License 1.0
+
+The Artistic License
+
+Preamble
+
+The intent of this document is to state the conditions under which a Package
+may be copied, such that the Copyright Holder maintains some semblance of
+artistic control over the development of the package, while giving the users of
+the package the right to use and distribute the Package in a more-or-less
+customary fashion, plus the right to make reasonable modifications.
+
+Definitions:
+
+ - "Package" refers to the collection of files distributed by the Copyright
+ Holder, and derivatives of that collection of files created through
+ textual modification.
+ - "Standard Version" refers to such a Package if it has not been modified,
+ or has been modified in accordance with the wishes of the Copyright
+ Holder.
+ - "Copyright Holder" is whoever is named in the copyright or copyrights for
+ the package.
+ - "You" is you, if you're thinking about copying or distributing this Package.
+ - "Reasonable copying fee" is whatever you can justify on the basis of media
+ cost, duplication charges, time of people involved, and so on. (You will
+ not be required to justify it to the Copyright Holder, but only to the
+ computing community at large as a market that must bear the fee.)
+ - "Freely Available" means that no fee is charged for the item itself, though
+ there may be fees involved in handling the item. It also means that
+ recipients of the item may redistribute it under the same conditions they
+ received it.
+
+1. You may make and give away verbatim copies of the source form of the
+Standard Version of this Package without restriction, provided that you
+duplicate all of the original copyright notices and associated disclaimers.
+
+2. You may apply bug fixes, portability fixes and other modifications derived
+from the Public Domain or from the Copyright Holder. A Package modified in such
+a way shall still be considered the Standard Version.
+
+3. You may otherwise modify your copy of this Package in any way, provided that
+you insert a prominent notice in each changed file stating how and when you
+changed that file, and provided that you do at least ONE of the following:
+
+ a) place your modifications in the Public Domain or otherwise make them
+ Freely Available, such as by posting said modifications to Usenet or an
+ equivalent medium, or placing the modifications on a major archive site
+ such as ftp.uu.net, or by allowing the Copyright Holder to include your
+ modifications in the Standard Version of the Package.
+
+ b) use the modified Package only within your corporation or organization.
+
+ c) rename any non-standard executables so the names do not conflict with
+ standard executables, which must also be provided, and provide a separate
+ manual page for each non-standard executable that clearly documents how it
+ differs from the Standard Version.
+
+ d) make other distribution arrangements with the Copyright Holder.
+
+4. You may distribute the programs of this Package in object code or executable
+form, provided that you do at least ONE of the following:
+
+ a) distribute a Standard Version of the executables and library files,
+ together with instructions (in the manual page or equivalent) on where to
+ get the Standard Version.
+
+ b) accompany the distribution with the machine-readable source of the Package
+ with your modifications.
+
+ c) accompany any non-standard executables with their corresponding Standard
+ Version executables, giving the non-standard executables non-standard
+ names, and clearly documenting the differences in manual pages (or
+ equivalent), together with instructions on where to get the Standard
+ Version.
+
+ d) make other distribution arrangements with the Copyright Holder.
+
+5. You may charge a reasonable copying fee for any distribution of this
+Package. You may charge any fee you choose for support of this Package. You
+may not charge a fee for this Package itself. However, you may distribute this
+Package in aggregate with other (possibly commercial) programs as part of a
+larger (possibly commercial) software distribution provided that you do not
+advertise this Package as a product of your own.
+
+6. The scripts and library files supplied as input to or produced as output
+from the programs of this Package do not automatically fall under the copyright
+of this Package, but belong to whomever generated them, and may be sold
+commercially, and may be aggregated with this Package.
+
+7. C or perl subroutines supplied by you and linked into this Package shall not
+be considered part of this Package.
+
+8. The name of the Copyright Holder may not be used to endorse or promote
+products derived from this software without specific prior written permission.
+
+9. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
+WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
+MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
+
+The End
+
diff --git a/MANIFEST b/MANIFEST
new file mode 100644
index 0000000..ead6365
--- /dev/null
+++ b/MANIFEST
@@ -0,0 +1,34 @@
+# This file was automatically generated by Dist::Zilla::Plugin::Manifest v5.030.
+Changes
+INSTALL
+LICENSE
+MANIFEST
+META.json
+META.yml
+Makefile.PL
+README.md
+README.pod
+cpanfile
+dist.ini
+lib/Plack/Test/Agent.pm
+t/00-compile.t
+t/00-report-prereqs.dd
+t/00-report-prereqs.t
+t/2args.t
+t/author-eol.t
+t/author-no-tabs.t
+t/author-pod-spell.t
+t/cookie.t
+t/cycle.t
+t/extra_get_args.t
+t/hello.t
+t/hello_server.t
+t/mech.t
+t/okay.t
+t/release-cpan-changes.t
+t/release-pod-coverage.t
+t/release-pod-syntax.t
+t/release-portability.t
+t/release-synopsis.t
+tidyall.ERR
+weaver.ini
diff --git a/META.json b/META.json
new file mode 100644
index 0000000..1045fb2
--- /dev/null
+++ b/META.json
@@ -0,0 +1,668 @@
+{
+ "abstract" : "OO interface for testing low-level Plack/PSGI apps",
+ "author" : [
+ "chromatic <chromatic@wgz.org>",
+ "Dave Rolsky <autarch@urth.org>",
+ "Ran Eilam <ran.eilam@gmail.com>",
+ "Olaf Alders <olaf@wundercounter.com>"
+ ],
+ "dynamic_config" : 0,
+ "generated_by" : "Dist::Zilla version 5.030, CPAN::Meta::Converter version 2.143240",
+ "license" : [
+ "perl_5"
+ ],
+ "meta-spec" : {
+ "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec",
+ "version" : 2
+ },
+ "name" : "Plack-Test-Agent",
+ "prereqs" : {
+ "configure" : {
+ "requires" : {
+ "ExtUtils::MakeMaker" : "0",
+ "perl" : "5.006"
+ }
+ },
+ "develop" : {
+ "requires" : {
+ "Pod::Coverage::TrustPod" : "0",
+ "Test::CPAN::Changes" : "0.19",
+ "Test::EOL" : "0",
+ "Test::More" : "0.88",
+ "Test::NoTabs" : "0",
+ "Test::Pod" : "1.41",
+ "Test::Pod::Coverage" : "1.08",
+ "Test::Spelling" : "0.12",
+ "Test::Synopsis" : "0"
+ }
+ },
+ "runtime" : {
+ "requires" : {
+ "HTTP::Message::PSGI" : "0",
+ "HTTP::Request::Common" : "0",
+ "HTTP::Response" : "0",
+ "Plack::Loader" : "0",
+ "Plack::Util::Accessor" : "0",
+ "Test::TCP" : "0",
+ "Test::WWW::Mechanize" : "0",
+ "parent" : "0",
+ "perl" : "5.008",
+ "strict" : "0",
+ "warnings" : "0"
+ }
+ },
+ "test" : {
+ "recommends" : {
+ "CPAN::Meta" : "2.120900"
+ },
+ "requires" : {
+ "ExtUtils::MakeMaker" : "0",
+ "File::Spec" : "0",
+ "HTTP::Cookies" : "0",
+ "HTTP::Server::Simple::PSGI" : "0",
+ "IO::Handle" : "0",
+ "IPC::Open3" : "0",
+ "Modern::Perl" : "0",
+ "Plack::Request" : "0",
+ "Test::Memory::Cycle" : "0",
+ "Test::More" : "0.88",
+ "Test::Requires" : "0",
+ "open" : "0",
+ "perl" : "5.008",
+ "utf8" : "0"
+ }
+ }
+ },
+ "provides" : {
+ "Plack::Test::Agent" : {
+ "file" : "lib/Plack/Test/Agent.pm",
+ "version" : "1.4"
+ }
+ },
+ "release_status" : "stable",
+ "resources" : {
+ "bugtracker" : {
+ "web" : "https://github.com/chromatic/Plack-Test-Agent/issues"
+ },
+ "repository" : {
+ "type" : "git",
+ "url" : "git://github.com/chromatic/Plack-Test-Agent.git",
+ "web" : "https://github.com/chromatic/Plack-Test-Agent"
+ }
+ },
+ "version" : "1.4",
+ "x_Dist_Zilla" : {
+ "perl" : {
+ "version" : "5.018002"
+ },
+ "plugins" : [
+ {
+ "class" : "Dist::Zilla::Plugin::MakeMaker",
+ "config" : {
+ "Dist::Zilla::Role::TestRunner" : {
+ "default_jobs" : 1
+ }
+ },
+ "name" : "@MAXMIND/MakeMaker",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Authority",
+ "name" : "@MAXMIND/Authority",
+ "version" : "1.009"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::AutoPrereqs",
+ "name" : "@MAXMIND/AutoPrereqs",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::CopyFilesFromBuild",
+ "name" : "@MAXMIND/CopyFilesFromBuild",
+ "version" : "0.103510"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::GatherDir",
+ "config" : {
+ "Dist::Zilla::Plugin::GatherDir" : {
+ "exclude_filename" : [
+ "cpanfile",
+ "LICENSE",
+ "Makefile.PL",
+ "README.md"
+ ],
+ "exclude_match" : [],
+ "follow_symlinks" : "0",
+ "include_dotfiles" : "0",
+ "prefix" : "",
+ "prune_directory" : [],
+ "root" : "."
+ }
+ },
+ "name" : "@MAXMIND/GatherDir",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::GitHub::Meta",
+ "name" : "@MAXMIND/GitHub::Meta",
+ "version" : "0.38"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::GitHub::Update",
+ "name" : "@MAXMIND/GitHub::Update",
+ "version" : "0.38"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MetaProvides::Package",
+ "config" : {
+ "Dist::Zilla::Plugin::MetaProvides::Package" : {
+ "finder_objects" : [
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : "@MAXMIND/MetaProvides::Package/AUTOVIV/:InstallModulesPM",
+ "version" : "5.030"
+ }
+ ]
+ },
+ "Dist::Zilla::Role::MetaProvider::Provider" : {
+ "inherit_missing" : "1",
+ "inherit_version" : "1",
+ "meta_noindex" : "1"
+ }
+ },
+ "name" : "@MAXMIND/MetaProvides::Package",
+ "version" : "2.002000"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::NextRelease",
+ "name" : "@MAXMIND/NextRelease",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::Pod::Coverage::Configurable",
+ "name" : "@MAXMIND/Test::Pod::Coverage::Configurable",
+ "version" : "0.02"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::PodSpelling",
+ "name" : "@MAXMIND/Test::PodSpelling",
+ "version" : "2.006008"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::ReportPrereqs",
+ "name" : "@MAXMIND/Test::ReportPrereqs",
+ "version" : "0.019"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Prereqs",
+ "config" : {
+ "Dist::Zilla::Plugin::Prereqs" : {
+ "phase" : "test",
+ "type" : "requires"
+ }
+ },
+ "name" : "@MAXMIND/TestMoreDoneTesting",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::PromptIfStale",
+ "config" : {
+ "Dist::Zilla::Plugin::PromptIfStale" : {
+ "check_all_plugins" : "1",
+ "check_all_prereqs" : "1",
+ "modules" : [],
+ "phase" : "release",
+ "skip" : [
+ "Dist::Zilla::Plugin::MAXMIND::Contributors",
+ "Dist::Zilla::Plugin::MAXMIND::License"
+ ]
+ }
+ },
+ "name" : "@MAXMIND/stale modules, release",
+ "version" : "0.033"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ReadmeAnyFromPod",
+ "name" : "@MAXMIND/ReadmeMarkdownInBuild",
+ "version" : "0.142470"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ReadmeAnyFromPod",
+ "name" : "@MAXMIND/ReadmeMarkdownInRoot",
+ "version" : "0.142470"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::UploadToCPAN",
+ "name" : "@MAXMIND/UploadToCPAN",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::PruneCruft",
+ "name" : "@MAXMIND/PruneCruft",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ManifestSkip",
+ "name" : "@MAXMIND/ManifestSkip",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MetaYAML",
+ "name" : "@MAXMIND/MetaYAML",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::License",
+ "name" : "@MAXMIND/License",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ExtraTests",
+ "name" : "@MAXMIND/ExtraTests",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ExecDir",
+ "name" : "@MAXMIND/ExecDir",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ShareDir",
+ "name" : "@MAXMIND/ShareDir",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Manifest",
+ "name" : "@MAXMIND/Manifest",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::TestRelease",
+ "name" : "@MAXMIND/TestRelease",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::ConfirmRelease",
+ "name" : "@MAXMIND/ConfirmRelease",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::CheckPrereqsIndexed",
+ "name" : "@MAXMIND/CheckPrereqsIndexed",
+ "version" : "0.013"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::CPANFile",
+ "name" : "@MAXMIND/CPANFile",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::CheckFor::CorrectBranch",
+ "config" : {
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::CheckFor::CorrectBranch",
+ "version" : "0.011"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::CheckFor::MergeConflicts",
+ "config" : {
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::CheckFor::MergeConflicts",
+ "version" : "0.011"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Describe",
+ "name" : "@MAXMIND/Git::Describe",
+ "version" : "0.004"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Contributors",
+ "config" : {
+ "Dist::Zilla::Plugin::Git::Contributors" : {
+ "include_authors" : "0",
+ "include_releaser" : "1",
+ "order_by" : "name",
+ "paths" : []
+ }
+ },
+ "name" : "@MAXMIND/Git::Contributors",
+ "version" : "0.008"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::InstallGuide",
+ "name" : "@MAXMIND/InstallGuide",
+ "version" : "1.200005"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MAXMIND::Contributors",
+ "name" : "@MAXMIND/MAXMIND::Contributors",
+ "version" : "0.05"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MAXMIND::License",
+ "name" : "@MAXMIND/MAXMIND::License",
+ "version" : "0.05"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Meta::Contributors",
+ "name" : "@MAXMIND/Meta::Contributors",
+ "version" : "0.001"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MetaConfig",
+ "name" : "@MAXMIND/MetaConfig",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MetaJSON",
+ "name" : "@MAXMIND/MetaJSON",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::MinimumPerl",
+ "name" : "@MAXMIND/MinimumPerl",
+ "version" : "1.006"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::PkgVersion",
+ "name" : "@MAXMIND/PkgVersion",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::SurgicalPodWeaver",
+ "config" : {
+ "Dist::Zilla::Plugin::PodWeaver" : {
+ "finder" : [
+ ":InstallModules",
+ ":ExecFiles"
+ ],
+ "plugins" : [
+ {
+ "class" : "Pod::Weaver::Plugin::EnsurePod5",
+ "name" : "@CorePrep/EnsurePod5",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Plugin::H1Nester",
+ "name" : "@CorePrep/H1Nester",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Name",
+ "name" : "Name",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Version",
+ "name" : "Version",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Region",
+ "name" : "prelude",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Generic",
+ "name" : "SYNOPSIS",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Generic",
+ "name" : "DESCRIPTION",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Leftovers",
+ "name" : "Leftovers",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Region",
+ "name" : "postlude",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Authors",
+ "name" : "Authors",
+ "version" : "4.010"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Contributors",
+ "name" : "Contributors",
+ "version" : "0.009"
+ },
+ {
+ "class" : "Pod::Weaver::Section::Legal",
+ "name" : "Legal",
+ "version" : "4.010"
+ }
+ ]
+ }
+ },
+ "name" : "@MAXMIND/SurgicalPodWeaver",
+ "version" : "0.0023"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::PodSyntaxTests",
+ "name" : "@MAXMIND/PodSyntaxTests",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::CPAN::Changes",
+ "name" : "@MAXMIND/Test::CPAN::Changes",
+ "version" : "0.008"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::Compile",
+ "config" : {
+ "Dist::Zilla::Plugin::Test::Compile" : {
+ "bail_out_on_fail" : "0",
+ "fail_on_warning" : "author",
+ "fake_home" : "0",
+ "filename" : "t/00-compile.t",
+ "module_finder" : [
+ ":InstallModules"
+ ],
+ "needs_display" : "0",
+ "phase" : "test",
+ "script_finder" : [
+ ":ExecFiles"
+ ],
+ "skips" : []
+ }
+ },
+ "name" : "@MAXMIND/Test::Compile",
+ "version" : "2.051"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::EOL",
+ "config" : {
+ "Dist::Zilla::Plugin::Test::EOL" : {
+ "filename" : "xt/author/eol.t"
+ }
+ },
+ "name" : "@MAXMIND/Test::EOL",
+ "version" : "0.16"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::NoTabs",
+ "config" : {
+ "Dist::Zilla::Plugin::Test::NoTabs" : {
+ "filename" : "xt/author/no-tabs.t",
+ "finder" : [
+ ":InstallModules",
+ ":ExecFiles",
+ ":TestFiles"
+ ]
+ }
+ },
+ "name" : "@MAXMIND/Test::NoTabs",
+ "version" : "0.09"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::Portability",
+ "name" : "@MAXMIND/Test::Portability",
+ "version" : "2.000005"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Test::Synopsis",
+ "name" : "@MAXMIND/Test::Synopsis",
+ "version" : "2.000005"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Check",
+ "config" : {
+ "Dist::Zilla::Plugin::Git::Check" : {
+ "untracked_files" : "die"
+ },
+ "Dist::Zilla::Role::Git::DirtyFiles" : {
+ "allow_dirty" : [
+ ".mailmap",
+ "Changes",
+ "cpanfile",
+ "CONTRIBUTING.md",
+ "LICENSE",
+ "Makefile.PL",
+ "README.md"
+ ],
+ "allow_dirty_match" : [],
+ "changelog" : "Changes"
+ },
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::Check",
+ "version" : "2.029"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Commit",
+ "config" : {
+ "Dist::Zilla::Plugin::Git::Commit" : {
+ "add_files_in" : [],
+ "commit_msg" : "v%v%n%n%c",
+ "time_zone" : "local"
+ },
+ "Dist::Zilla::Role::Git::DirtyFiles" : {
+ "allow_dirty" : [
+ ".mailmap",
+ "Changes",
+ "cpanfile",
+ "CONTRIBUTING.md",
+ "LICENSE",
+ "Makefile.PL",
+ "README.md"
+ ],
+ "allow_dirty_match" : [],
+ "changelog" : "Changes"
+ },
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::Commit",
+ "version" : "2.029"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Tag",
+ "config" : {
+ "Dist::Zilla::Plugin::Git::Tag" : {
+ "branch" : null,
+ "signed" : 0,
+ "tag" : "v1.4",
+ "tag_format" : "v%v",
+ "tag_message" : "v%v",
+ "time_zone" : "local"
+ },
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::Tag",
+ "version" : "2.029"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::Git::Push",
+ "config" : {
+ "Dist::Zilla::Plugin::Git::Push" : {
+ "push_to" : [
+ "origin"
+ ],
+ "remotes_must_exist" : 1
+ },
+ "Dist::Zilla::Role::Git::Repo" : {
+ "repo_root" : "."
+ }
+ },
+ "name" : "@MAXMIND/Git::Push",
+ "version" : "2.029"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":InstallModules",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":IncModules",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":TestFiles",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":ExecFiles",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":ShareFiles",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":MainModule",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":AllFiles",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : ":NoFiles",
+ "version" : "5.030"
+ },
+ {
+ "class" : "Dist::Zilla::Plugin::FinderCode",
+ "name" : "@MAXMIND/MetaProvides::Package/AUTOVIV/:InstallModulesPM",
+ "version" : "5.030"
+ }
+ ],
+ "zilla" : {
+ "class" : "Dist::Zilla::Dist::Builder",
+ "config" : {
+ "is_trial" : "0"
+ },
+ "version" : "5.030"
+ }
+ },
+ "x_authority" : "cpan:MAXMIND",
+ "x_contributors" : [
+ "Dave Rolsky <drolsky@maxmind.com>",
+ "Olaf Alders <oalders@maxmind.com>",
+ "Ran Eilam <reilam@maxmind.com>"
+ ]
+}
+
diff --git a/META.yml b/META.yml
new file mode 100644
index 0000000..3d7ea6b
--- /dev/null
+++ b/META.yml
@@ -0,0 +1,494 @@
+---
+abstract: 'OO interface for testing low-level Plack/PSGI apps'
+author:
+ - 'chromatic <chromatic@wgz.org>'
+ - 'Dave Rolsky <autarch@urth.org>'
+ - 'Ran Eilam <ran.eilam@gmail.com>'
+ - 'Olaf Alders <olaf@wundercounter.com>'
+build_requires:
+ ExtUtils::MakeMaker: '0'
+ File::Spec: '0'
+ HTTP::Cookies: '0'
+ HTTP::Server::Simple::PSGI: '0'
+ IO::Handle: '0'
+ IPC::Open3: '0'
+ Modern::Perl: '0'
+ Plack::Request: '0'
+ Test::Memory::Cycle: '0'
+ Test::More: '0.88'
+ Test::Requires: '0'
+ open: '0'
+ perl: '5.008'
+ utf8: '0'
+configure_requires:
+ ExtUtils::MakeMaker: '0'
+ perl: '5.006'
+dynamic_config: 0
+generated_by: 'Dist::Zilla version 5.030, CPAN::Meta::Converter version 2.143240'
+license: perl
+meta-spec:
+ url: http://module-build.sourceforge.net/META-spec-v1.4.html
+ version: '1.4'
+name: Plack-Test-Agent
+provides:
+ Plack::Test::Agent:
+ file: lib/Plack/Test/Agent.pm
+ version: '1.4'
+requires:
+ HTTP::Message::PSGI: '0'
+ HTTP::Request::Common: '0'
+ HTTP::Response: '0'
+ Plack::Loader: '0'
+ Plack::Util::Accessor: '0'
+ Test::TCP: '0'
+ Test::WWW::Mechanize: '0'
+ parent: '0'
+ perl: '5.008'
+ strict: '0'
+ warnings: '0'
+resources:
+ bugtracker: https://github.com/chromatic/Plack-Test-Agent/issues
+ repository: git://github.com/chromatic/Plack-Test-Agent.git
+version: '1.4'
+x_Dist_Zilla:
+ perl:
+ version: '5.018002'
+ plugins:
+ -
+ class: Dist::Zilla::Plugin::MakeMaker
+ config:
+ Dist::Zilla::Role::TestRunner:
+ default_jobs: 1
+ name: '@MAXMIND/MakeMaker'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::Authority
+ name: '@MAXMIND/Authority'
+ version: '1.009'
+ -
+ class: Dist::Zilla::Plugin::AutoPrereqs
+ name: '@MAXMIND/AutoPrereqs'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::CopyFilesFromBuild
+ name: '@MAXMIND/CopyFilesFromBuild'
+ version: '0.103510'
+ -
+ class: Dist::Zilla::Plugin::GatherDir
+ config:
+ Dist::Zilla::Plugin::GatherDir:
+ exclude_filename:
+ - cpanfile
+ - LICENSE
+ - Makefile.PL
+ - README.md
+ exclude_match: []
+ follow_symlinks: '0'
+ include_dotfiles: '0'
+ prefix: ''
+ prune_directory: []
+ root: .
+ name: '@MAXMIND/GatherDir'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::GitHub::Meta
+ name: '@MAXMIND/GitHub::Meta'
+ version: '0.38'
+ -
+ class: Dist::Zilla::Plugin::GitHub::Update
+ name: '@MAXMIND/GitHub::Update'
+ version: '0.38'
+ -
+ class: Dist::Zilla::Plugin::MetaProvides::Package
+ config:
+ Dist::Zilla::Plugin::MetaProvides::Package:
+ finder_objects:
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: '@MAXMIND/MetaProvides::Package/AUTOVIV/:InstallModulesPM'
+ version: '5.030'
+ Dist::Zilla::Role::MetaProvider::Provider:
+ inherit_missing: '1'
+ inherit_version: '1'
+ meta_noindex: '1'
+ name: '@MAXMIND/MetaProvides::Package'
+ version: '2.002000'
+ -
+ class: Dist::Zilla::Plugin::NextRelease
+ name: '@MAXMIND/NextRelease'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::Test::Pod::Coverage::Configurable
+ name: '@MAXMIND/Test::Pod::Coverage::Configurable'
+ version: '0.02'
+ -
+ class: Dist::Zilla::Plugin::Test::PodSpelling
+ name: '@MAXMIND/Test::PodSpelling'
+ version: '2.006008'
+ -
+ class: Dist::Zilla::Plugin::Test::ReportPrereqs
+ name: '@MAXMIND/Test::ReportPrereqs'
+ version: '0.019'
+ -
+ class: Dist::Zilla::Plugin::Prereqs
+ config:
+ Dist::Zilla::Plugin::Prereqs:
+ phase: test
+ type: requires
+ name: '@MAXMIND/TestMoreDoneTesting'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::PromptIfStale
+ config:
+ Dist::Zilla::Plugin::PromptIfStale:
+ check_all_plugins: '1'
+ check_all_prereqs: '1'
+ modules: []
+ phase: release
+ skip:
+ - Dist::Zilla::Plugin::MAXMIND::Contributors
+ - Dist::Zilla::Plugin::MAXMIND::License
+ name: '@MAXMIND/stale modules, release'
+ version: '0.033'
+ -
+ class: Dist::Zilla::Plugin::ReadmeAnyFromPod
+ name: '@MAXMIND/ReadmeMarkdownInBuild'
+ version: '0.142470'
+ -
+ class: Dist::Zilla::Plugin::ReadmeAnyFromPod
+ name: '@MAXMIND/ReadmeMarkdownInRoot'
+ version: '0.142470'
+ -
+ class: Dist::Zilla::Plugin::UploadToCPAN
+ name: '@MAXMIND/UploadToCPAN'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::PruneCruft
+ name: '@MAXMIND/PruneCruft'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::ManifestSkip
+ name: '@MAXMIND/ManifestSkip'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::MetaYAML
+ name: '@MAXMIND/MetaYAML'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::License
+ name: '@MAXMIND/License'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::ExtraTests
+ name: '@MAXMIND/ExtraTests'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::ExecDir
+ name: '@MAXMIND/ExecDir'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::ShareDir
+ name: '@MAXMIND/ShareDir'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::Manifest
+ name: '@MAXMIND/Manifest'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::TestRelease
+ name: '@MAXMIND/TestRelease'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::ConfirmRelease
+ name: '@MAXMIND/ConfirmRelease'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::CheckPrereqsIndexed
+ name: '@MAXMIND/CheckPrereqsIndexed'
+ version: '0.013'
+ -
+ class: Dist::Zilla::Plugin::CPANFile
+ name: '@MAXMIND/CPANFile'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::Git::CheckFor::CorrectBranch
+ config:
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::CheckFor::CorrectBranch'
+ version: '0.011'
+ -
+ class: Dist::Zilla::Plugin::Git::CheckFor::MergeConflicts
+ config:
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::CheckFor::MergeConflicts'
+ version: '0.011'
+ -
+ class: Dist::Zilla::Plugin::Git::Describe
+ name: '@MAXMIND/Git::Describe'
+ version: '0.004'
+ -
+ class: Dist::Zilla::Plugin::Git::Contributors
+ config:
+ Dist::Zilla::Plugin::Git::Contributors:
+ include_authors: '0'
+ include_releaser: '1'
+ order_by: name
+ paths: []
+ name: '@MAXMIND/Git::Contributors'
+ version: '0.008'
+ -
+ class: Dist::Zilla::Plugin::InstallGuide
+ name: '@MAXMIND/InstallGuide'
+ version: '1.200005'
+ -
+ class: Dist::Zilla::Plugin::MAXMIND::Contributors
+ name: '@MAXMIND/MAXMIND::Contributors'
+ version: '0.05'
+ -
+ class: Dist::Zilla::Plugin::MAXMIND::License
+ name: '@MAXMIND/MAXMIND::License'
+ version: '0.05'
+ -
+ class: Dist::Zilla::Plugin::Meta::Contributors
+ name: '@MAXMIND/Meta::Contributors'
+ version: '0.001'
+ -
+ class: Dist::Zilla::Plugin::MetaConfig
+ name: '@MAXMIND/MetaConfig'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::MetaJSON
+ name: '@MAXMIND/MetaJSON'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::MinimumPerl
+ name: '@MAXMIND/MinimumPerl'
+ version: '1.006'
+ -
+ class: Dist::Zilla::Plugin::PkgVersion
+ name: '@MAXMIND/PkgVersion'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::SurgicalPodWeaver
+ config:
+ Dist::Zilla::Plugin::PodWeaver:
+ finder:
+ - ':InstallModules'
+ - ':ExecFiles'
+ plugins:
+ -
+ class: Pod::Weaver::Plugin::EnsurePod5
+ name: '@CorePrep/EnsurePod5'
+ version: '4.010'
+ -
+ class: Pod::Weaver::Plugin::H1Nester
+ name: '@CorePrep/H1Nester'
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Name
+ name: Name
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Version
+ name: Version
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Region
+ name: prelude
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Generic
+ name: SYNOPSIS
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Generic
+ name: DESCRIPTION
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Leftovers
+ name: Leftovers
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Region
+ name: postlude
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Authors
+ name: Authors
+ version: '4.010'
+ -
+ class: Pod::Weaver::Section::Contributors
+ name: Contributors
+ version: '0.009'
+ -
+ class: Pod::Weaver::Section::Legal
+ name: Legal
+ version: '4.010'
+ name: '@MAXMIND/SurgicalPodWeaver'
+ version: '0.0023'
+ -
+ class: Dist::Zilla::Plugin::PodSyntaxTests
+ name: '@MAXMIND/PodSyntaxTests'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::Test::CPAN::Changes
+ name: '@MAXMIND/Test::CPAN::Changes'
+ version: '0.008'
+ -
+ class: Dist::Zilla::Plugin::Test::Compile
+ config:
+ Dist::Zilla::Plugin::Test::Compile:
+ bail_out_on_fail: '0'
+ fail_on_warning: author
+ fake_home: '0'
+ filename: t/00-compile.t
+ module_finder:
+ - ':InstallModules'
+ needs_display: '0'
+ phase: test
+ script_finder:
+ - ':ExecFiles'
+ skips: []
+ name: '@MAXMIND/Test::Compile'
+ version: '2.051'
+ -
+ class: Dist::Zilla::Plugin::Test::EOL
+ config:
+ Dist::Zilla::Plugin::Test::EOL:
+ filename: xt/author/eol.t
+ name: '@MAXMIND/Test::EOL'
+ version: '0.16'
+ -
+ class: Dist::Zilla::Plugin::Test::NoTabs
+ config:
+ Dist::Zilla::Plugin::Test::NoTabs:
+ filename: xt/author/no-tabs.t
+ finder:
+ - ':InstallModules'
+ - ':ExecFiles'
+ - ':TestFiles'
+ name: '@MAXMIND/Test::NoTabs'
+ version: '0.09'
+ -
+ class: Dist::Zilla::Plugin::Test::Portability
+ name: '@MAXMIND/Test::Portability'
+ version: '2.000005'
+ -
+ class: Dist::Zilla::Plugin::Test::Synopsis
+ name: '@MAXMIND/Test::Synopsis'
+ version: '2.000005'
+ -
+ class: Dist::Zilla::Plugin::Git::Check
+ config:
+ Dist::Zilla::Plugin::Git::Check:
+ untracked_files: die
+ Dist::Zilla::Role::Git::DirtyFiles:
+ allow_dirty:
+ - .mailmap
+ - Changes
+ - cpanfile
+ - CONTRIBUTING.md
+ - LICENSE
+ - Makefile.PL
+ - README.md
+ allow_dirty_match: []
+ changelog: Changes
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::Check'
+ version: '2.029'
+ -
+ class: Dist::Zilla::Plugin::Git::Commit
+ config:
+ Dist::Zilla::Plugin::Git::Commit:
+ add_files_in: []
+ commit_msg: v%v%n%n%c
+ time_zone: local
+ Dist::Zilla::Role::Git::DirtyFiles:
+ allow_dirty:
+ - .mailmap
+ - Changes
+ - cpanfile
+ - CONTRIBUTING.md
+ - LICENSE
+ - Makefile.PL
+ - README.md
+ allow_dirty_match: []
+ changelog: Changes
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::Commit'
+ version: '2.029'
+ -
+ class: Dist::Zilla::Plugin::Git::Tag
+ config:
+ Dist::Zilla::Plugin::Git::Tag:
+ branch: ~
+ signed: 0
+ tag: v1.4
+ tag_format: v%v
+ tag_message: v%v
+ time_zone: local
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::Tag'
+ version: '2.029'
+ -
+ class: Dist::Zilla::Plugin::Git::Push
+ config:
+ Dist::Zilla::Plugin::Git::Push:
+ push_to:
+ - origin
+ remotes_must_exist: 1
+ Dist::Zilla::Role::Git::Repo:
+ repo_root: .
+ name: '@MAXMIND/Git::Push'
+ version: '2.029'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':InstallModules'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':IncModules'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':TestFiles'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':ExecFiles'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':ShareFiles'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':MainModule'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':AllFiles'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: ':NoFiles'
+ version: '5.030'
+ -
+ class: Dist::Zilla::Plugin::FinderCode
+ name: '@MAXMIND/MetaProvides::Package/AUTOVIV/:InstallModulesPM'
+ version: '5.030'
+ zilla:
+ class: Dist::Zilla::Dist::Builder
+ config:
+ is_trial: '0'
+ version: '5.030'
+x_authority: cpan:MAXMIND
+x_contributors:
+ - 'Dave Rolsky <drolsky@maxmind.com>'
+ - 'Olaf Alders <oalders@maxmind.com>'
+ - 'Ran Eilam <reilam@maxmind.com>'
diff --git a/Makefile.PL b/Makefile.PL
new file mode 100644
index 0000000..ab9c7e8
--- /dev/null
+++ b/Makefile.PL
@@ -0,0 +1,96 @@
+
+# This file was automatically generated by Dist::Zilla::Plugin::MakeMaker v5.030.
+use strict;
+use warnings;
+
+use 5.008;
+
+use ExtUtils::MakeMaker;
+
+
+
+my %WriteMakefileArgs = (
+ "ABSTRACT" => "OO interface for testing low-level Plack/PSGI apps",
+ "AUTHOR" => "chromatic <chromatic\@wgz.org>, Dave Rolsky <autarch\@urth.org>, Ran Eilam <ran.eilam\@gmail.com>, Olaf Alders <olaf\@wundercounter.com>",
+ "CONFIGURE_REQUIRES" => {
+ "ExtUtils::MakeMaker" => 0
+ },
+ "DISTNAME" => "Plack-Test-Agent",
+ "EXE_FILES" => [],
+ "LICENSE" => "perl",
+ "MIN_PERL_VERSION" => "5.008",
+ "NAME" => "Plack::Test::Agent",
+ "PREREQ_PM" => {
+ "HTTP::Message::PSGI" => 0,
+ "HTTP::Request::Common" => 0,
+ "HTTP::Response" => 0,
+ "Plack::Loader" => 0,
+ "Plack::Util::Accessor" => 0,
+ "Test::TCP" => 0,
+ "Test::WWW::Mechanize" => 0,
+ "parent" => 0,
+ "strict" => 0,
+ "warnings" => 0
+ },
+ "TEST_REQUIRES" => {
+ "ExtUtils::MakeMaker" => 0,
+ "File::Spec" => 0,
+ "HTTP::Cookies" => 0,
+ "HTTP::Server::Simple::PSGI" => 0,
+ "IO::Handle" => 0,
+ "IPC::Open3" => 0,
+ "Modern::Perl" => 0,
+ "Plack::Request" => 0,
+ "Test::Memory::Cycle" => 0,
+ "Test::More" => "0.88",
+ "Test::Requires" => 0,
+ "open" => 0,
+ "utf8" => 0
+ },
+ "VERSION" => "1.4",
+ "test" => {
+ "TESTS" => "t/*.t"
+ }
+);
+
+
+my %FallbackPrereqs = (
+ "ExtUtils::MakeMaker" => 0,
+ "File::Spec" => 0,
+ "HTTP::Cookies" => 0,
+ "HTTP::Message::PSGI" => 0,
+ "HTTP::Request::Common" => 0,
+ "HTTP::Response" => 0,
+ "HTTP::Server::Simple::PSGI" => 0,
+ "IO::Handle" => 0,
+ "IPC::Open3" => 0,
+ "Modern::Perl" => 0,
+ "Plack::Loader" => 0,
+ "Plack::Request" => 0,
+ "Plack::Util::Accessor" => 0,
+ "Test::Memory::Cycle" => 0,
+ "Test::More" => "0.88",
+ "Test::Requires" => 0,
+ "Test::TCP" => 0,
+ "Test::WWW::Mechanize" => 0,
+ "open" => 0,
+ "parent" => 0,
+ "strict" => 0,
+ "utf8" => 0,
+ "warnings" => 0
+);
+
+
+unless ( eval { ExtUtils::MakeMaker->VERSION(6.63_03) } ) {
+ delete $WriteMakefileArgs{TEST_REQUIRES};
+ delete $WriteMakefileArgs{BUILD_REQUIRES};
+ $WriteMakefileArgs{PREREQ_PM} = \%FallbackPrereqs;
+}
+
+delete $WriteMakefileArgs{CONFIGURE_REQUIRES}
+ unless eval { ExtUtils::MakeMaker->VERSION(6.52) };
+
+WriteMakefile(%WriteMakefileArgs);
+
+
+
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..d9869ec
--- /dev/null
+++ b/README.md
@@ -0,0 +1,127 @@
+# NAME
+
+Plack::Test::Agent - OO interface for testing low-level Plack/PSGI apps
+
+# VERSION
+
+version 1.4
+
+## SYNOPSIS
+
+ use Test::More;
+ use Plack::Test::Agent;
+
+ my $app = sub { ... };
+ my $local_agent = Plack::Test::Agent->new( app => $app );
+ my $server_agent = Plack::Test::Agent->new(
+ app => $app,
+ server => 'HTTP::Server::Simple' );
+
+ my $local_res = $local_agent->get( '/' );
+ my $server_res = $server_agent->get( '/' );
+
+ ok $local_res->is_success, 'local GET / should succeed';
+ ok $server_res->is_success, 'server GET / should succeed';
+
+## DESCRIPTION
+
+`Plack::Test::Agent` is an OO interface to test PSGI applications. It can
+perform GET and POST requests against PSGI applications either in process or
+over HTTP through a [Plack::Handler](https://metacpan.org/pod/Plack::Handler) compatible backend.
+
+**NOTE:** This is an experimental module and its interface may change.
+
+## CONSTRUCTION
+
+### `new`
+
+The `new` constructor creates an instance of `Plack::Test::Agent`. This
+constructor takes one mandatory named argument and several optional arguments.
+
+- `app` is the mandatory argument. You must provide a PSGI application
+to test.
+- `server` is an optional argument. When provided, `Plack::Test::Agent`
+will attempt to start a PSGI handler and will communicate via HTTP to the
+application running through the handler. See [Plack::Loader](https://metacpan.org/pod/Plack::Loader) for details on
+selecting the appropriate server.
+- `host` is an optional argument representing the name or IP address for
+the server to use. The default is `localhost`.
+- `port` is an optional argument representing the TCP port to for the
+server to use. If not provided, the service will run on a randomly selected
+available port outside of the IANA reserved range. (See [Test::TCP](https://metacpan.org/pod/Test::TCP) for
+details on the selection of the port number.)
+- `ua` is an optional argument of something which conforms to the
+[LWP::UserAgent](https://metacpan.org/pod/LWP::UserAgent) interface such that it provides a `request` method which
+takes an [HTTP::Request](https://metacpan.org/pod/HTTP::Request) object and returns an [HTTP::Response](https://metacpan.org/pod/HTTP::Response) object. The
+default is an instance of `LWP::UserAgent`.
+
+## METHODS
+
+This class provides several useful methods:
+
+### `get`
+
+This method takes a URI and makes a `GET` request against the PSGI application
+with that URI. It returns an [HTTP::Response](https://metacpan.org/pod/HTTP::Response) object representing the results
+of that request.
+
+### `post`
+
+This method takes a URI and makes a `POST` request against the PSGI
+application with that URI. It returns an [HTTP::Response](https://metacpan.org/pod/HTTP::Response) object representing
+the results of that request. As an optional second parameter, pass an array
+reference of key/value pairs for the form content:
+
+ $agent->post( '/edit_user',
+ [
+ shoe_size => '10.5',
+ eye_color => 'blue green',
+ status => 'twin',
+ ]);
+
+### `execute_request`
+
+This method takes an [HTTP::Request](https://metacpan.org/pod/HTTP::Request), performs it against the bound app, and
+returns an [HTTP::Response](https://metacpan.org/pod/HTTP::Response). This allows you to craft your own requests
+directly.
+
+### `get_mech`
+
+Used internally to create a default UserAgent, if none is provided to the
+constructor. Returns a Test::WWW::Mechanize::Bound object.
+
+### `normalize_uri`
+
+Used internally to ensure that all requests use the correct scheme, host and
+port. The scheme and host default to `http` and `localhost` respectively,
+while the port is determined by [Test::TCP](https://metacpan.org/pod/Test::TCP).
+
+### `start_server`
+
+Starts a test server via [Test::TCP](https://metacpan.org/pod/Test::TCP). If a `server` arg has been provided to
+the constructor, it will use this class to load a server. Defaults to letting
+Plack::Loader decide which server class to use.
+
+## CREDITS
+
+Thanks to Zbigniew Łukasiak and Tatsuhiko Miyagawa for suggestions.
+
+# AUTHORS
+
+- chromatic <chromatic@wgz.org>
+- Dave Rolsky <autarch@urth.org>
+- Ran Eilam <ran.eilam@gmail.com>
+- Olaf Alders <olaf@wundercounter.com>
+
+# CONTRIBUTORS
+
+- Dave Rolsky <drolsky@maxmind.com>
+- Olaf Alders <oalders@maxmind.com>
+- Ran Eilam <reilam@maxmind.com>
+
+# COPYRIGHT AND LICENSE
+
+This software is copyright (c) 2011 - 2015 by chromatic.
+
+This is free software; you can redistribute it and/or modify it under
+the same terms as the Perl 5 programming language system itself.
diff --git a/README.pod b/README.pod
new file mode 100644
index 0000000..d63946f
--- /dev/null
+++ b/README.pod
@@ -0,0 +1,9 @@
+=head1 Plack::Test::Agent
+
+This experimental distribution is an object oriented version of Plack::Test.
+Its name may change. It may prove to have been a silly idea. Use it if you
+like, and please give feedback if you want to continue to use it.
+
+See
+L<http://www.modernperlbooks.com/mt/2011/09/placktest-and-great-test-interfaces.html>
+and L<https://github.com/miyagawa/Plack/issues/180> for discussion.
diff --git a/cpanfile b/cpanfile
new file mode 100644
index 0000000..d880437
--- /dev/null
+++ b/cpanfile
@@ -0,0 +1,49 @@
+requires "HTTP::Message::PSGI" => "0";
+requires "HTTP::Request::Common" => "0";
+requires "HTTP::Response" => "0";
+requires "Plack::Loader" => "0";
+requires "Plack::Util::Accessor" => "0";
+requires "Test::TCP" => "0";
+requires "Test::WWW::Mechanize" => "0";
+requires "parent" => "0";
+requires "perl" => "5.008";
+requires "strict" => "0";
+requires "warnings" => "0";
+
+on 'test' => sub {
+ requires "ExtUtils::MakeMaker" => "0";
+ requires "File::Spec" => "0";
+ requires "HTTP::Cookies" => "0";
+ requires "HTTP::Server::Simple::PSGI" => "0";
+ requires "IO::Handle" => "0";
+ requires "IPC::Open3" => "0";
+ requires "Modern::Perl" => "0";
+ requires "Plack::Request" => "0";
+ requires "Test::Memory::Cycle" => "0";
+ requires "Test::More" => "0.88";
+ requires "Test::Requires" => "0";
+ requires "open" => "0";
+ requires "perl" => "5.008";
+ requires "utf8" => "0";
+};
+
+on 'test' => sub {
+ recommends "CPAN::Meta" => "2.120900";
+};
+
+on 'configure' => sub {
+ requires "ExtUtils::MakeMaker" => "0";
+ requires "perl" => "5.006";
+};
+
+on 'develop' => sub {
+ requires "Pod::Coverage::TrustPod" => "0";
+ requires "Test::CPAN::Changes" => "0.19";
+ requires "Test::EOL" => "0";
+ requires "Test::More" => "0.88";
+ requires "Test::NoTabs" => "0";
+ requires "Test::Pod" => "1.41";
+ requires "Test::Pod::Coverage" => "1.08";
+ requires "Test::Spelling" => "0.12";
+ requires "Test::Synopsis" => "0";
+};
diff --git a/dist.ini b/dist.ini
new file mode 100644
index 0000000..3c706e0
--- /dev/null
+++ b/dist.ini
@@ -0,0 +1,12 @@
+name = Plack-Test-Agent
+author = chromatic <chromatic@wgz.org>
+author = Dave Rolsky <autarch@urth.org>
+author = Ran Eilam <ran.eilam@gmail.com>
+author = Olaf Alders <olaf@wundercounter.com>
+license = Perl_5
+copyright_holder = chromatic
+copyright_year = 2011
+version = 1.4
+
+[@MAXMIND]
+dist = Plack-Test-Agent
diff --git a/lib/Plack/Test/Agent.pm b/lib/Plack/Test/Agent.pm
new file mode 100644
index 0000000..4623285
--- /dev/null
+++ b/lib/Plack/Test/Agent.pm
@@ -0,0 +1,311 @@
+package Plack::Test::Agent;
+# git description: v1.3-1-g41fa5a5
+$Plack::Test::Agent::VERSION = '1.4';
+# ABSTRACT: OO interface for testing low-level Plack/PSGI apps
+
+use strict;
+use warnings;
+
+use Test::TCP;
+use Plack::Loader;
+use HTTP::Response;
+use HTTP::Message::PSGI;
+use HTTP::Request::Common;
+use Test::WWW::Mechanize;
+
+use Plack::Util::Accessor qw( app host port server ua );
+
+sub new
+{
+ my ($class, %args) = @_;
+
+ my $self = bless {}, $class;
+
+ $self->app( delete $args{app} );
+ $self->ua( delete $args{ua} );
+ $self->host( delete $args{host} || 'localhost' );
+ $self->port( delete $args{port} );
+
+ $self->start_server( delete $args{server} ) if $args{server};
+
+ return $self;
+}
+
+sub start_server
+{
+ my ($self, $server_class) = @_;
+
+ my $app = $self->app;
+ my $host = $self->host;
+
+ my $server = Test::TCP->new(
+ code => sub
+ {
+ my $port = shift;
+ my %args = ( host => $host, port => $port );
+ return $server_class
+ ? Plack::Loader->load( $server_class, %args )->run( $app )
+ : Plack::Loader->auto( %args )->run( $app );
+ },
+ );
+
+ $self->port( $server->port );
+ $self->ua( $self->get_mech ) unless $self->ua;
+ $self->server( $server );
+}
+
+sub execute_request
+{
+ my ($self, $req) = @_;
+
+ my $res = $self->server
+ ? $self->ua->request( $req )
+ : HTTP::Response->from_psgi( $self->app->( $req->to_psgi ) );
+
+ $res->request( $req );
+ return $res;
+}
+
+sub get {
+ my ( $self, $uri, @args ) = @_;
+ my $req = GET $self->normalize_uri($uri), @args;
+ return $self->execute_request($req);
+}
+
+sub post
+{
+ my ($self, $uri, @args) = @_;
+ my $req = POST $self->normalize_uri($uri), @args;
+ return $self->execute_request( $req );
+}
+
+sub normalize_uri
+{
+ my ($self, $uri) = @_;
+ my $normalized = URI->new( $uri );
+ my $port = $self->port;
+
+ $normalized->scheme( 'http' ) unless $normalized->scheme;
+ $normalized->host( 'localhost' ) unless $normalized->host;
+ $normalized->port( $port ) if $port;
+
+ return $normalized;
+}
+
+sub get_mech
+{
+ my $self = shift;
+ return Test::WWW::Mechanize::Bound->new(
+ bound_uri => $self->normalize_uri( '/' )
+ );
+}
+
+package
+ Test::WWW::Mechanize::Bound;
+
+ use parent 'Test::WWW::Mechanize';
+
+ sub new
+ {
+ my ($class, %args) = @_;
+ my $bound_uri = delete $args{bound_uri};
+ my $self = $class->SUPER::new( %args );
+ $self->bound_uri( $bound_uri );
+ return $self;
+ }
+
+ sub bound_uri
+ {
+ my ($self, $base_uri) = @_;
+ $self->_elem( bound_uri => $base_uri ) if @_ == 2;
+ return $self->_elem( 'bound_uri' );
+ }
+
+ sub prepare_request
+ {
+ my $self = shift;
+ my ($req) = @_;
+ my $uri = $req->uri;
+ my $base = $self->bound_uri;
+
+ unless ($uri->scheme)
+ {
+ $uri->scheme( $base->scheme );
+ $uri->host( $base->host );
+ $uri->port( $base->port );
+ }
+ return $self->SUPER::prepare_request( @_ );
+ }
+
+1;
+
+__END__
+
+=pod
+
+=head1 NAME
+
+Plack::Test::Agent - OO interface for testing low-level Plack/PSGI apps
+
+=head1 VERSION
+
+version 1.4
+
+=head2 SYNOPSIS
+
+ use Test::More;
+ use Plack::Test::Agent;
+
+ my $app = sub { ... };
+ my $local_agent = Plack::Test::Agent->new( app => $app );
+ my $server_agent = Plack::Test::Agent->new(
+ app => $app,
+ server => 'HTTP::Server::Simple' );
+
+ my $local_res = $local_agent->get( '/' );
+ my $server_res = $server_agent->get( '/' );
+
+ ok $local_res->is_success, 'local GET / should succeed';
+ ok $server_res->is_success, 'server GET / should succeed';
+
+=head2 DESCRIPTION
+
+C<Plack::Test::Agent> is an OO interface to test PSGI applications. It can
+perform GET and POST requests against PSGI applications either in process or
+over HTTP through a L<Plack::Handler> compatible backend.
+
+B<NOTE:> This is an experimental module and its interface may change.
+
+=head2 CONSTRUCTION
+
+=head3 C<new>
+
+The C<new> constructor creates an instance of C<Plack::Test::Agent>. This
+constructor takes one mandatory named argument and several optional arguments.
+
+=over 4
+
+=item * C<app> is the mandatory argument. You must provide a PSGI application
+to test.
+
+=item * C<server> is an optional argument. When provided, C<Plack::Test::Agent>
+will attempt to start a PSGI handler and will communicate via HTTP to the
+application running through the handler. See L<Plack::Loader> for details on
+selecting the appropriate server.
+
+=item * C<host> is an optional argument representing the name or IP address for
+the server to use. The default is C<localhost>.
+
+=item * C<port> is an optional argument representing the TCP port to for the
+server to use. If not provided, the service will run on a randomly selected
+available port outside of the IANA reserved range. (See L<Test::TCP> for
+details on the selection of the port number.)
+
+=item * C<ua> is an optional argument of something which conforms to the
+L<LWP::UserAgent> interface such that it provides a C<request> method which
+takes an L<HTTP::Request> object and returns an L<HTTP::Response> object. The
+default is an instance of C<LWP::UserAgent>.
+
+=back
+
+=head2 METHODS
+
+This class provides several useful methods:
+
+=head3 C<get>
+
+This method takes a URI and makes a C<GET> request against the PSGI application
+with that URI. It returns an L<HTTP::Response> object representing the results
+of that request.
+
+=head3 C<post>
+
+This method takes a URI and makes a C<POST> request against the PSGI
+application with that URI. It returns an L<HTTP::Response> object representing
+the results of that request. As an optional second parameter, pass an array
+reference of key/value pairs for the form content:
+
+ $agent->post( '/edit_user',
+ [
+ shoe_size => '10.5',
+ eye_color => 'blue green',
+ status => 'twin',
+ ]);
+
+=head3 C<execute_request>
+
+This method takes an L<HTTP::Request>, performs it against the bound app, and
+returns an L<HTTP::Response>. This allows you to craft your own requests
+directly.
+
+=head3 C<get_mech>
+
+Used internally to create a default UserAgent, if none is provided to the
+constructor. Returns a Test::WWW::Mechanize::Bound object.
+
+=head3 C<normalize_uri>
+
+Used internally to ensure that all requests use the correct scheme, host and
+port. The scheme and host default to C<http> and C<localhost> respectively,
+while the port is determined by L<Test::TCP>.
+
+=head3 C<start_server>
+
+Starts a test server via L<Test::TCP>. If a C<server> arg has been provided to
+the constructor, it will use this class to load a server. Defaults to letting
+Plack::Loader decide which server class to use.
+
+=head2 CREDITS
+
+Thanks to Zbigniew E<0x141>ukasiak and Tatsuhiko Miyagawa for suggestions.
+
+=head1 AUTHORS
+
+=over 4
+
+=item *
+
+chromatic <chromatic@wgz.org>
+
+=item *
+
+Dave Rolsky <autarch@urth.org>
+
+=item *
+
+Ran Eilam <ran.eilam@gmail.com>
+
+=item *
+
+Olaf Alders <olaf@wundercounter.com>
+
+=back
+
+=head1 CONTRIBUTORS
+
+=for stopwords Dave Rolsky Olaf Alders Ran Eilam
+
+=over 4
+
+=item *
+
+Dave Rolsky <drolsky@maxmind.com>
+
+=item *
+
+Olaf Alders <oalders@maxmind.com>
+
+=item *
+
+Ran Eilam <reilam@maxmind.com>
+
+=back
+
+=head1 COPYRIGHT AND LICENSE
+
+This software is copyright (c) 2011 - 2015 by chromatic.
+
+This is free software; you can redistribute it and/or modify it under
+the same terms as the Perl 5 programming language system itself.
+
+=cut
diff --git a/t/00-compile.t b/t/00-compile.t
new file mode 100644
index 0000000..2e295c1
--- /dev/null
+++ b/t/00-compile.t
@@ -0,0 +1,51 @@
+use 5.006;
+use strict;
+use warnings;
+
+# this test was generated with Dist::Zilla::Plugin::Test::Compile 2.051
+
+use Test::More;
+
+plan tests => 1 + ($ENV{AUTHOR_TESTING} ? 1 : 0);
+
+my @module_files = (
+ 'Plack/Test/Agent.pm'
+);
+
+
+
+# no fake home requested
+
+my $inc_switch = -d 'blib' ? '-Mblib' : '-Ilib';
+
+use File::Spec;
+use IPC::Open3;
+use IO::Handle;
+
+open my $stdin, '<', File::Spec->devnull or die "can't open devnull: $!";
+
+my @warnings;
+for my $lib (@module_files)
+{
+ # see L<perlfaq8/How can I capture STDERR from an external command?>
+ my $stderr = IO::Handle->new;
+
+ my $pid = open3($stdin, '>&STDERR', $stderr, $^X, $inc_switch, '-e', "require q[$lib]");
+ binmode $stderr, ':crlf' if $^O eq 'MSWin32';
+ my @_warnings = <$stderr>;
+ waitpid($pid, 0);
+ is($?, 0, "$lib loaded ok");
+
+ if (@_warnings)
+ {
+ warn @_warnings;
+ push @warnings, @_warnings;
+ }
+}
+
+
+
+is(scalar(@warnings), 0, 'no warnings found')
+ or diag 'got warnings: ', ( Test::More->can('explain') ? Test::More::explain(\@warnings) : join("\n", '', @warnings) ) if $ENV{AUTHOR_TESTING};
+
+
diff --git a/t/00-report-prereqs.dd b/t/00-report-prereqs.dd
new file mode 100644
index 0000000..59db373
--- /dev/null
+++ b/t/00-report-prereqs.dd
@@ -0,0 +1,59 @@
+do { my $x = {
+ 'configure' => {
+ 'requires' => {
+ 'ExtUtils::MakeMaker' => '0',
+ 'perl' => '5.006'
+ }
+ },
+ 'develop' => {
+ 'requires' => {
+ 'Pod::Coverage::TrustPod' => '0',
+ 'Test::CPAN::Changes' => '0.19',
+ 'Test::EOL' => '0',
+ 'Test::More' => '0.88',
+ 'Test::NoTabs' => '0',
+ 'Test::Pod' => '1.41',
+ 'Test::Pod::Coverage' => '1.08',
+ 'Test::Spelling' => '0.12',
+ 'Test::Synopsis' => '0'
+ }
+ },
+ 'runtime' => {
+ 'requires' => {
+ 'HTTP::Message::PSGI' => '0',
+ 'HTTP::Request::Common' => '0',
+ 'HTTP::Response' => '0',
+ 'Plack::Loader' => '0',
+ 'Plack::Util::Accessor' => '0',
+ 'Test::TCP' => '0',
+ 'Test::WWW::Mechanize' => '0',
+ 'parent' => '0',
+ 'perl' => '5.008',
+ 'strict' => '0',
+ 'warnings' => '0'
+ }
+ },
+ 'test' => {
+ 'recommends' => {
+ 'CPAN::Meta' => '2.120900'
+ },
+ 'requires' => {
+ 'ExtUtils::MakeMaker' => '0',
+ 'File::Spec' => '0',
+ 'HTTP::Cookies' => '0',
+ 'HTTP::Server::Simple::PSGI' => '0',
+ 'IO::Handle' => '0',
+ 'IPC::Open3' => '0',
+ 'Modern::Perl' => '0',
+ 'Plack::Request' => '0',
+ 'Test::Memory::Cycle' => '0',
+ 'Test::More' => '0.88',
+ 'Test::Requires' => '0',
+ 'open' => '0',
+ 'perl' => '5.008',
+ 'utf8' => '0'
+ }
+ }
+ };
+ $x;
+ } \ No newline at end of file
diff --git a/t/00-report-prereqs.t b/t/00-report-prereqs.t
new file mode 100644
index 0000000..402b3d9
--- /dev/null
+++ b/t/00-report-prereqs.t
@@ -0,0 +1,176 @@
+#!perl
+
+use strict;
+use warnings;
+
+# This test was generated by Dist::Zilla::Plugin::Test::ReportPrereqs 0.019
+
+use Test::More tests => 1;
+
+use ExtUtils::MakeMaker;
+use File::Spec;
+
+# from $version::LAX
+my $lax_version_re =
+ qr/(?: undef | (?: (?:[0-9]+) (?: \. | (?:\.[0-9]+) (?:_[0-9]+)? )?
+ |
+ (?:\.[0-9]+) (?:_[0-9]+)?
+ ) | (?:
+ v (?:[0-9]+) (?: (?:\.[0-9]+)+ (?:_[0-9]+)? )?
+ |
+ (?:[0-9]+)? (?:\.[0-9]+){2,} (?:_[0-9]+)?
+ )
+ )/x;
+
+# hide optional CPAN::Meta modules from prereq scanner
+# and check if they are available
+my $cpan_meta = "CPAN::Meta";
+my $cpan_meta_pre = "CPAN::Meta::Prereqs";
+my $HAS_CPAN_META = eval "require $cpan_meta; $cpan_meta->VERSION('2.120900')" && eval "require $cpan_meta_pre"; ## no critic
+
+# Verify requirements?
+my $DO_VERIFY_PREREQS = 1;
+
+sub _max {
+ my $max = shift;
+ $max = ( $_ > $max ) ? $_ : $max for @_;
+ return $max;
+}
+
+sub _merge_prereqs {
+ my ($collector, $prereqs) = @_;
+
+ # CPAN::Meta::Prereqs object
+ if (ref $collector eq $cpan_meta_pre) {
+ return $collector->with_merged_prereqs(
+ CPAN::Meta::Prereqs->new( $prereqs )
+ );
+ }
+
+ # Raw hashrefs
+ for my $phase ( keys %$prereqs ) {
+ for my $type ( keys %{ $prereqs->{$phase} } ) {
+ for my $module ( keys %{ $prereqs->{$phase}{$type} } ) {
+ $collector->{$phase}{$type}{$module} = $prereqs->{$phase}{$type}{$module};
+ }
+ }
+ }
+
+ return $collector;
+}
+
+my @include = qw(
+
+);
+
+my @exclude = qw(
+
+);
+
+# Add static prereqs to the included modules list
+my $static_prereqs = do 't/00-report-prereqs.dd';
+
+# Merge all prereqs (either with ::Prereqs or a hashref)
+my $full_prereqs = _merge_prereqs(
+ ( $HAS_CPAN_META ? $cpan_meta_pre->new : {} ),
+ $static_prereqs
+);
+
+# Add dynamic prereqs to the included modules list (if we can)
+my ($source) = grep { -f } 'MYMETA.json', 'MYMETA.yml';
+if ( $source && $HAS_CPAN_META ) {
+ if ( my $meta = eval { CPAN::Meta->load_file($source) } ) {
+ $full_prereqs = _merge_prereqs($full_prereqs, $meta->prereqs);
+ }
+}
+else {
+ $source = 'static metadata';
+}
+
+my @full_reports;
+my @dep_errors;
+my $req_hash = $HAS_CPAN_META ? $full_prereqs->as_string_hash : $full_prereqs;
+
+# Add static includes into a fake section
+for my $mod (@include) {
+ $req_hash->{other}{modules}{$mod} = 0;
+}
+
+for my $phase ( qw(configure build test runtime develop other) ) {
+ next unless $req_hash->{$phase};
+ next if ($phase eq 'develop' and not $ENV{AUTHOR_TESTING});
+
+ for my $type ( qw(requires recommends suggests conflicts modules) ) {
+ next unless $req_hash->{$phase}{$type};
+
+ my $title = ucfirst($phase).' '.ucfirst($type);
+ my @reports = [qw/Module Want Have/];
+
+ for my $mod ( sort keys %{ $req_hash->{$phase}{$type} } ) {
+ next if $mod eq 'perl';
+ next if grep { $_ eq $mod } @exclude;
+
+ my $file = $mod;
+ $file =~ s{::}{/}g;
+ $file .= ".pm";
+ my ($prefix) = grep { -e File::Spec->catfile($_, $file) } @INC;
+
+ my $want = $req_hash->{$phase}{$type}{$mod};
+ $want = "undef" unless defined $want;
+ $want = "any" if !$want && $want == 0;
+
+ my $req_string = $want eq 'any' ? 'any version required' : "version '$want' required";
+
+ if ($prefix) {
+ my $have = MM->parse_version( File::Spec->catfile($prefix, $file) );
+ $have = "undef" unless defined $have;
+ push @reports, [$mod, $want, $have];
+
+ if ( $DO_VERIFY_PREREQS && $HAS_CPAN_META && $type eq 'requires' ) {
+ if ( $have !~ /\A$lax_version_re\z/ ) {
+ push @dep_errors, "$mod version '$have' cannot be parsed ($req_string)";
+ }
+ elsif ( ! $full_prereqs->requirements_for( $phase, $type )->accepts_module( $mod => $have ) ) {
+ push @dep_errors, "$mod version '$have' is not in required range '$want'";
+ }
+ }
+ }
+ else {
+ push @reports, [$mod, $want, "missing"];
+
+ if ( $DO_VERIFY_PREREQS && $type eq 'requires' ) {
+ push @dep_errors, "$mod is not installed ($req_string)";
+ }
+ }
+ }
+
+ if ( @reports ) {
+ push @full_reports, "=== $title ===\n\n";
+
+ my $ml = _max( map { length $_->[0] } @reports );
+ my $wl = _max( map { length $_->[1] } @reports );
+ my $hl = _max( map { length $_->[2] } @reports );
+ splice @reports, 1, 0, ["-" x $ml, "-" x $wl, "-" x $hl];
+
+ push @full_reports, map { sprintf(" %*s %*s %*s\n", -$ml, $_->[0], $wl, $_->[1], $hl, $_->[2]) } @reports;
+ push @full_reports, "\n";
+ }
+ }
+}
+
+if ( @full_reports ) {
+ diag "\nVersions for all modules listed in $source (including optional ones):\n\n", @full_reports;
+}
+
+if ( @dep_errors ) {
+ diag join("\n",
+ "\n*** WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING ***\n",
+ "The following REQUIRED prerequisites were not satisfied:\n",
+ @dep_errors,
+ "\n"
+ );
+}
+
+pass;
+
+# vim: ts=4 sts=4 sw=4 et:
diff --git a/t/2args.t b/t/2args.t
new file mode 100644
index 0000000..7dde478
--- /dev/null
+++ b/t/2args.t
@@ -0,0 +1,19 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Plack::Test::Agent;
+
+my $app = sub { return [ 200, [], [ 'Hello' ] ] };
+
+my $agent = Plack::Test::Agent->new(
+ server => 'HTTP::Server::PSGI',
+ app => $app,
+);
+
+my $res = $agent->get( '/' );
+is $res->content, 'Hello';
+
+done_testing;
diff --git a/t/author-eol.t b/t/author-eol.t
new file mode 100644
index 0000000..bf16558
--- /dev/null
+++ b/t/author-eol.t
@@ -0,0 +1,16 @@
+
+BEGIN {
+ unless ($ENV{AUTHOR_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for testing by the author');
+ }
+}
+
+use strict;
+use warnings;
+use Test::More;
+
+# generated by Dist::Zilla::Plugin::Test::EOL 0.16
+use Test::EOL;
+
+all_perl_files_ok({ trailing_whitespace => 1 });
diff --git a/t/author-no-tabs.t b/t/author-no-tabs.t
new file mode 100644
index 0000000..af59667
--- /dev/null
+++ b/t/author-no-tabs.t
@@ -0,0 +1,41 @@
+
+BEGIN {
+ unless ($ENV{AUTHOR_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for testing by the author');
+ }
+}
+
+use strict;
+use warnings;
+
+# this test was generated with Dist::Zilla::Plugin::Test::NoTabs 0.09
+
+use Test::More 0.88;
+use Test::NoTabs;
+
+my @files = (
+ 'lib/Plack/Test/Agent.pm',
+ 't/00-compile.t',
+ 't/00-report-prereqs.dd',
+ 't/00-report-prereqs.t',
+ 't/2args.t',
+ 't/author-eol.t',
+ 't/author-no-tabs.t',
+ 't/author-pod-spell.t',
+ 't/cookie.t',
+ 't/cycle.t',
+ 't/extra_get_args.t',
+ 't/hello.t',
+ 't/hello_server.t',
+ 't/mech.t',
+ 't/okay.t',
+ 't/release-cpan-changes.t',
+ 't/release-pod-coverage.t',
+ 't/release-pod-syntax.t',
+ 't/release-portability.t',
+ 't/release-synopsis.t'
+);
+
+notabs_ok($_) foreach @files;
+done_testing;
diff --git a/t/author-pod-spell.t b/t/author-pod-spell.t
new file mode 100644
index 0000000..74aa5a3
--- /dev/null
+++ b/t/author-pod-spell.t
@@ -0,0 +1,44 @@
+
+BEGIN {
+ unless ($ENV{AUTHOR_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for testing by the author');
+ }
+}
+
+use strict;
+use warnings;
+use Test::More;
+
+# generated by Dist::Zilla::Plugin::Test::PodSpelling 2.006008
+use Test::Spelling 0.12;
+use Pod::Wordlist;
+
+
+add_stopwords(<DATA>);
+all_pod_files_spelling_ok( qw( bin lib ) );
+__DATA__
+Alders
+Alders'
+Eilam
+Eilam's
+MaxMind
+MaxMind's
+Oschwald
+Oschwald's
+Rolsky
+Rolsky's
+chromatic
+Dave
+autarch
+Ran
+ran
+Olaf
+olaf
+drolsky
+oalders
+reilam
+lib
+Plack
+Test
+Agent
diff --git a/t/cookie.t b/t/cookie.t
new file mode 100644
index 0000000..d88bd62
--- /dev/null
+++ b/t/cookie.t
@@ -0,0 +1,35 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Plack::Test::Agent;
+use HTTP::Cookies;
+
+my $app = sub
+{
+ return
+ [
+ 200,
+ [
+ 'Content-Type' => 'text/html',
+ 'Set-Cookie' => "ID=123; path=/"
+ ],
+ [ "Hi" ]
+ ];
+};
+
+my $agent = Plack::Test::Agent->new( app => $app );
+my $res = $agent->get( '/' );
+
+my $cookie_jar = HTTP::Cookies->new;
+$cookie_jar->extract_cookies($res);
+
+my @cookies;
+$cookie_jar->scan( sub { @cookies = @_ });
+
+ok @cookies;
+is $cookies[1], 'ID';
+
+done_testing;
diff --git a/t/cycle.t b/t/cycle.t
new file mode 100644
index 0000000..bf33862
--- /dev/null
+++ b/t/cycle.t
@@ -0,0 +1,32 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::Requires 'Test::Memory::Cycle';
+
+use Test::More;
+use Plack::Test::Agent;
+use Test::Memory::Cycle;
+
+my $app = sub
+{
+ return [ 200, [ 'Content-Type' => 'text/plain' ], [ 'Hello World' ] ];
+};
+
+my $agent = Plack::Test::Agent->new(
+ app => $app,
+ server => 'HTTP::Server::PSGI',
+);
+
+memory_cycle_ok(
+ $agent,
+ 'no memory cycles in the Plack::Test::Agent object'
+);
+
+memory_cycle_ok(
+ $agent->get_mech,
+ 'no memory cycles in object returned by Plack::Test::Agent->get_mech'
+);
+
+done_testing;
diff --git a/t/extra_get_args.t b/t/extra_get_args.t
new file mode 100644
index 0000000..32042e8
--- /dev/null
+++ b/t/extra_get_args.t
@@ -0,0 +1,20 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Plack::Test::Agent;
+
+my $app = sub
+{
+ my $content = shift->{HTTP_ACCEPT_LANGUAGE};
+ return [ 200, [], [ $content ] ];
+};
+
+my $agent = Plack::Test::Agent->new( app => $app );
+
+my $res = $agent->get( '/', 'Accept-Language' => 'en' );
+is $res->content, 'en';
+
+done_testing;
diff --git a/t/hello.t b/t/hello.t
new file mode 100644
index 0000000..bc76df9
--- /dev/null
+++ b/t/hello.t
@@ -0,0 +1,21 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Plack::Test::Agent;
+
+my $app = sub
+{
+ return [ 200, [ 'Content-Type' => 'text/plain' ], [ 'Hello World' ] ];
+};
+
+my $agent = Plack::Test::Agent->new( app => $app );
+my $res = $agent->get( 'http://localhost/hello' );
+is $res->content, 'Hello World';
+is $res->content_type, 'text/plain';
+is $res->code, 200;
+is $res->header( 'Server' ), undef, '... should default to MockHTTP server';
+
+done_testing;
diff --git a/t/hello_server.t b/t/hello_server.t
new file mode 100644
index 0000000..140589e
--- /dev/null
+++ b/t/hello_server.t
@@ -0,0 +1,36 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Plack::Test::Agent;
+use HTTP::Server::Simple::PSGI;
+
+my $app = sub
+{
+ return [ 200, [ 'Content-Type' => 'text/plain' ], [ 'Hello World' ] ];
+};
+
+my %server = (
+ 'HTTP::Server::PSGI' => 'HTTP::Server::PSGI',
+ 'HTTP::Server::Simple' => undef,
+);
+
+foreach my $server_class ( keys %server ) {
+ my $agent = Plack::Test::Agent->new(
+ app => $app,
+ server => $server_class,
+ );
+
+ my $res = $agent->get( 'http://localhost/hello' );
+
+ is $res->content, 'Hello World';
+ is $res->content_type, 'text/plain';
+ is $res->code, 200;
+ is $res->header( 'Server' ), $server{$server_class},
+ '... should use server when given server';
+}
+
+
+done_testing;
diff --git a/t/mech.t b/t/mech.t
new file mode 100644
index 0000000..f44bb29
--- /dev/null
+++ b/t/mech.t
@@ -0,0 +1,58 @@
+#!/usr/bin/env perl
+
+use Modern::Perl;
+
+use utf8;
+use open ':encoding(utf8)';
+
+use Test::More;
+use Plack::Test::Agent;
+use Plack::Request;
+
+my $app = sub
+{
+ my $res = Plack::Request->new( shift );
+
+ my $want = $res->param( 'want' );
+ my $have = $res->param( 'have' );
+ my $desc = $res->param( 'desc' );
+
+ my ($code, $output) = ( $want eq $have )
+ ? ( 200, 'ok' )
+ : ( 412, 'not ok' );
+
+ $output .= ' - ' . $desc if $desc;
+ return [ $code, [ 'Content-Type' => 'text/plain' ], [ $output ] ];
+};
+
+my $agent = Plack::Test::Agent->new( app => $app,
+ server => 'HTTP::Server::PSGI' );
+my $mech = $agent->get_mech;
+
+$mech->get_ok( '/?have=foo;want=foo',
+ 'Request should succeed when values match' );
+$mech->content_is( 'ok', '... with descriptive success message' );
+
+$mech->get( '/?have=10;want=20' );
+ok ! $mech->success, 'Request should fail when values do not match';
+$mech->content_is( 'not ok', '... with descriptive error' );
+
+my $uri = URI->new( '/' );
+$uri->query_form( have => 'cow', want => 'cow', desc => 'Cow Comparison' );
+$mech->get_ok( $uri, 'Request should succeed when values do' );
+
+$mech->content_is( 'ok - Cow Comparison',
+ '... including description when provided' );
+is $mech->content_type, 'text/plain', '... with plain text content';
+is $mech->response->content_charset, 'US-ASCII', '... in ASCII';
+
+$mech->post( '/', [ have => 'cow', want => 'pig', desc => 'æ' ] );
+ok ! $mech->success, 'Request should fail given different values';
+$mech->content_is( "not ok - \x{00E6}",
+ '... including description when provided' );
+is $mech->content_type, 'text/plain', '... with plain text content';
+is $mech->response->content_charset, 'UTF-8', '... in ASCII';
+is $mech->response->header( 'Server' ), 'HTTP::Server::PSGI',
+ '... and should use HTTP server';
+
+done_testing;
diff --git a/t/okay.t b/t/okay.t
new file mode 100644
index 0000000..0f4139d
--- /dev/null
+++ b/t/okay.t
@@ -0,0 +1,63 @@
+#!/usr/bin/env perl
+
+use Modern::Perl;
+
+use utf8;
+use open ':encoding(utf8)';
+
+use Test::More;
+use Plack::Test::Agent;
+use Plack::Request;
+
+my $app = sub
+{
+ my $res = Plack::Request->new( shift );
+
+ my $want = $res->param( 'want' );
+ my $have = $res->param( 'have' );
+ my $desc = $res->param( 'desc' );
+
+ my ($code, $output) = ( $want eq $have )
+ ? ( 200, 'ok' )
+ : ( 412, 'not ok' );
+
+ $output .= ' - ' . $desc if $desc;
+ return [ $code, [ 'Content-Type' => 'text/plain' ], [ $output ] ];
+};
+
+my $bare_agent = Plack::Test::Agent->new( app => $app );
+my $server_agent = Plack::Test::Agent->new( app => $app,
+ server => 'HTTP::Server::PSGI' );
+run_tests_with_agent( $bare_agent );
+run_tests_with_agent( $server_agent );
+
+sub run_tests_with_agent
+{
+ my $agent = shift;
+ my $res = $agent->get( '/?have=foo;want=foo' );
+ ok $res->is_success, 'Request should succeed when values match';
+ is $res->decoded_content, 'ok', '... with descriptive success message';
+
+ $res = $agent->get( '/?have=10;want=20' );
+ ok ! $res->is_success, 'Request should fail when values do not match';
+ is $res->decoded_content, 'not ok', '... with descriptive error';
+
+ my $uri = URI->new( '/' );
+ $uri->query_form( have => 'cow', want => 'cow', desc => 'Cow Comparison' );
+ $res = $agent->get( $uri );
+
+ ok $res->is_success, 'Request should succeed when values do';
+ is $res->decoded_content, 'ok - Cow Comparison',
+ '... including description when provided';
+ is $res->content_type, 'text/plain', '... with plain text content';
+ is $res->content_charset, 'US-ASCII', '... in ASCII';
+
+ $res = $agent->post( '/', [ have => 'cow', want => 'pig', desc => 'æ' ] );
+ ok ! $res->is_success, 'Request should fail given different values';
+ is $res->decoded_content, "not ok - \x{00E6}",
+ '... including description when provided';
+ is $res->content_type, 'text/plain', '... with plain text content';
+ is $res->content_charset, 'UTF-8', '... in ASCII';
+}
+
+done_testing;
diff --git a/t/release-cpan-changes.t b/t/release-cpan-changes.t
new file mode 100644
index 0000000..214650f
--- /dev/null
+++ b/t/release-cpan-changes.t
@@ -0,0 +1,19 @@
+#!perl
+
+BEGIN {
+ unless ($ENV{RELEASE_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for release candidate testing');
+ }
+}
+
+
+use strict;
+use warnings;
+
+use Test::More 0.96 tests => 2;
+use_ok('Test::CPAN::Changes');
+subtest 'changes_ok' => sub {
+ changes_file_ok('Changes');
+};
+done_testing();
diff --git a/t/release-pod-coverage.t b/t/release-pod-coverage.t
new file mode 100644
index 0000000..6fe8a95
--- /dev/null
+++ b/t/release-pod-coverage.t
@@ -0,0 +1,49 @@
+#!perl
+
+BEGIN {
+ unless ($ENV{RELEASE_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for release candidate testing');
+ }
+}
+
+# This file was automatically generated by Dist::Zilla::Plugin::Test::Pod::Coverage::Configurable.
+
+use Test::Pod::Coverage 1.08;
+use Test::More 0.88;
+
+BEGIN {
+ if ( $] <= 5.008008 ) {
+ plan skip_all => 'These tests require Pod::Coverage::TrustPod, which only works with Perl 5.8.9+';
+ }
+}
+use Pod::Coverage::TrustPod;
+
+my %skip = map { $_ => 1 } qw( );
+
+my @modules;
+for my $module ( all_modules() ) {
+ next if $skip{$module};
+
+ push @modules, $module;
+}
+
+plan skip_all => 'All the modules we found were excluded from POD coverage test.'
+ unless @modules;
+
+plan tests => scalar @modules;
+
+my %trustme = ();
+
+for my $module ( sort @modules ) {
+ pod_coverage_ok(
+ $module,
+ {
+ coverage_class => 'Pod::Coverage::TrustPod',
+ trustme => $trustme{$module} || [],
+ },
+ "pod coverage for $module"
+ );
+}
+
+done_testing();
diff --git a/t/release-pod-syntax.t b/t/release-pod-syntax.t
new file mode 100644
index 0000000..cdd6a6c
--- /dev/null
+++ b/t/release-pod-syntax.t
@@ -0,0 +1,14 @@
+#!perl
+
+BEGIN {
+ unless ($ENV{RELEASE_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for release candidate testing');
+ }
+}
+
+# This file was automatically generated by Dist::Zilla::Plugin::PodSyntaxTests.
+use Test::More;
+use Test::Pod 1.41;
+
+all_pod_files_ok();
diff --git a/t/release-portability.t b/t/release-portability.t
new file mode 100644
index 0000000..f0fd79f
--- /dev/null
+++ b/t/release-portability.t
@@ -0,0 +1,19 @@
+#!perl
+
+BEGIN {
+ unless ($ENV{RELEASE_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for release candidate testing');
+ }
+}
+
+
+use strict;
+use warnings;
+
+use Test::More;
+
+eval 'use Test::Portability::Files';
+plan skip_all => 'Test::Portability::Files required for testing portability'
+ if $@;
+run_tests();
diff --git a/t/release-synopsis.t b/t/release-synopsis.t
new file mode 100644
index 0000000..2d9b8ee
--- /dev/null
+++ b/t/release-synopsis.t
@@ -0,0 +1,13 @@
+#!perl
+
+BEGIN {
+ unless ($ENV{RELEASE_TESTING}) {
+ require Test::More;
+ Test::More::plan(skip_all => 'these tests are for release candidate testing');
+ }
+}
+
+
+use Test::Synopsis;
+
+all_synopsis_ok();
diff --git a/tidyall.ERR b/tidyall.ERR
new file mode 100644
index 0000000..df7f232
--- /dev/null
+++ b/tidyall.ERR
@@ -0,0 +1 @@
+could not find tidyall.ini or .tidyallrc upwards from '/Users/olaf/Documents/github/Plack-Test-Agent/t' at /Users/olaf/perl5/lib/perl5/Code/TidyAll.pm line 373.
diff --git a/weaver.ini b/weaver.ini
new file mode 100644
index 0000000..90c76a6
--- /dev/null
+++ b/weaver.ini
@@ -0,0 +1,17 @@
+[@CorePrep]
+
+[Name]
+[Version]
+
+[Region / prelude]
+
+[Generic / SYNOPSIS]
+[Generic / DESCRIPTION]
+
+[Leftovers]
+
+[Region / postlude]
+
+[Authors]
+[Contributors]
+[Legal]