[ 
https://issues.apache.org/jira/browse/CLI-255?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17138940#comment-17138940
 ] 

chenshuming commented on CLI-255:
---------------------------------

Hi, I was using the follow test case in 1.5-SNAPSHOT. And it pass.
{code:java}
    public void testUnlimitedArgs() throws Exception
    {
        String[] args = new String[] {"-unlimitedOne", "one", "two", 
"-unlimitedTwo", "alpha"};

        Options options = new Options();
        options.addOption(Option.builder("unlimitedOne").hasArgs().build());
        options.addOption(Option.builder("unlimitedTwo").hasArgs().build());

        CommandLineParser parser = new Options();
        CommandLine cl = parser.parse(options, args);

        assertTrue("Confirm -unlimitedOne is set", 
cl.hasOption("unlimitedOne"));
        assertEquals("number of arg for -unlimitedOne", 2, 
cl.getOptionValues("unlimitedOne").length);
        assertTrue("Confirm -unlimitedTwo is set", 
cl.hasOption("unlimitedTwo"));
        assertEquals("number of arg for -unlimitedTwo", 1, 
cl.getOptionValues("unlimitedTwo").length);
    }
{code}

> DefaultParser, option with long name and single dash, unlimited arguments
> -------------------------------------------------------------------------
>
>                 Key: CLI-255
>                 URL: https://issues.apache.org/jira/browse/CLI-255
>             Project: Commons CLI
>          Issue Type: Bug
>          Components: Parser
>    Affects Versions: 1.3, 1.3.1
>            Reporter: Alexander Prishchepov
>            Priority: Minor
>
> If I have options with long name and single hyphen, DefaultParser does not 
> recognize them after a list of unlimited arguments.
> Here is the test case:
> {code:java}
>     public void testUnlimitedArgs() throws Exception
>     {
>         String[] args = new String[] {"-unlimitedOne", "one", "two", 
> "-unlimitedTwo", "alpha"};
>         Options options = new Options();
>         options.addOption(Option.builder("unlimitedOne").hasArgs().build());
>         options.addOption(Option.builder("unlimitedTwo").hasArgs().build());
>         CommandLine cl = parser.parse(options, args);
>         assertTrue("Confirm -unlimitedOne is set", 
> cl.hasOption("unlimitedOne"));
>         assertEquals("number of arg for -unlimitedOne", 2, 
> cl.getOptionValues("unlimitedOne").length);
>         assertTrue("Confirm -unlimitedTwo is set", 
> cl.hasOption("unlimitedTwo"));
>         assertEquals("number of arg for -unlimitedTwo", 1, 
> cl.getOptionValues("unlimitedTwo").length);
>     }
> {code}



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to