Stay out of the guts of Getopt::Long::Descriptive::Usage when testing its text
[gitmo/MooseX-Getopt.git] / t / 109_help_flag.t
CommitLineData
81b19ed8 1#!/usr/bin/env perl
2
3# The documentation claims:
4# If Getopt::Long::Descriptive is installed and any of the following command
5# line params are passed (--help, --usage, --?), the program will exit with
6# usage information...
7
8# This is not actually true (as of 0.29), as:
9# 1. the consuming class must set up a attributes named 'help', 'usage' and
10# '?' to contain these command line options, which is not clearly
11# documented as a requirement
12# 2. the code is checking whether an option was parsed into an attribute
13# *called* 'help', 'usage' or '?', not whether the option --help, --usage
14# or --? was passed on the command-line (the mapping could be different,
15# if cmd_flag or cmd_aliases is used),
16
17# This inconsistency is the underlying cause of RT#52474, RT#57683, RT#47865.
18
19use strict; use warnings;
20use Test::More tests => 6;
aabf4179 21use Test::Fatal;
81b19ed8 22
23{
24 package MyClass;
25 use strict; use warnings;
26 use Moose;
27 with 'MooseX::Getopt';
28}
29
30# before fix, prints this on stderr:
31#Unknown option: ?
b94db425 32#usage: test1.t
81b19ed8 33
34# after fix, prints this on stderr:
35#usage: test1.t [-?] [long options...]
36# -? --usage --help Prints this usage information.
37
3aaa34a1 38my $obj = MyClass->new_with_options;
39ok($obj->meta->has_attribute('usage'), 'class has usage attribute');
40isa_ok($obj->usage, 'Getopt::Long::Descriptive::Usage');
41my $usage_text = $obj->usage->text;
42
81b19ed8 43foreach my $args ( ['--help'], ['--usage'], ['--?'], ['-?'] )
44{
45 local @ARGV = @$args;
46
3aaa34a1 47 is exception { MyClass->new_with_options() },
48 $usage_text,
81b19ed8 49 'Help request detected; usage information properly printed';
50}
51
81b19ed8 52