Return-Path: X-Original-To: apmail-cxf-commits-archive@www.apache.org Delivered-To: apmail-cxf-commits-archive@www.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id BF45817371 for ; Wed, 24 Jun 2015 10:41:02 +0000 (UTC) Received: (qmail 43747 invoked by uid 500); 24 Jun 2015 10:41:02 -0000 Delivered-To: apmail-cxf-commits-archive@cxf.apache.org Received: (qmail 43685 invoked by uid 500); 24 Jun 2015 10:41:02 -0000 Mailing-List: contact commits-help@cxf.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@cxf.apache.org Delivered-To: mailing list commits@cxf.apache.org Received: (qmail 43676 invoked by uid 99); 24 Jun 2015 10:41:02 -0000 Received: from git1-us-west.apache.org (HELO git1-us-west.apache.org) (140.211.11.23) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 24 Jun 2015 10:41:02 +0000 Received: by git1-us-west.apache.org (ASF Mail Server at git1-us-west.apache.org, from userid 33) id 670DEDFF1B; Wed, 24 Jun 2015 10:41:02 +0000 (UTC) Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: sergeyb@apache.org To: commits@cxf.apache.org Message-Id: <6896a47184824f3a987d59360120f9ec@git.apache.org> X-Mailer: ASF-Git Admin Mailer Subject: cxf git commit: [CXF-6474] Minor update to UriTemplate Date: Wed, 24 Jun 2015 10:41:02 +0000 (UTC) Repository: cxf Updated Branches: refs/heads/master 9c5f2a657 -> c1387810b [CXF-6474] Minor update to UriTemplate Project: http://git-wip-us.apache.org/repos/asf/cxf/repo Commit: http://git-wip-us.apache.org/repos/asf/cxf/commit/c1387810 Tree: http://git-wip-us.apache.org/repos/asf/cxf/tree/c1387810 Diff: http://git-wip-us.apache.org/repos/asf/cxf/diff/c1387810 Branch: refs/heads/master Commit: c1387810b05a79a219a3fe89adac5e23fb8ef87f Parents: 9c5f2a6 Author: Sergey Beryozkin Authored: Wed Jun 24 11:40:43 2015 +0100 Committer: Sergey Beryozkin Committed: Wed Jun 24 11:40:43 2015 +0100 ---------------------------------------------------------------------- .../org/apache/cxf/jaxrs/model/URITemplate.java | 3 +- .../apache/cxf/jaxrs/model/URITemplateTest.java | 35 +++++++++++++++++++- 2 files changed, 36 insertions(+), 2 deletions(-) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/cxf/blob/c1387810/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/model/URITemplate.java ---------------------------------------------------------------------- diff --git a/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/model/URITemplate.java b/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/model/URITemplate.java index 637beb1..47ed9a6 100644 --- a/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/model/URITemplate.java +++ b/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/model/URITemplate.java @@ -188,7 +188,8 @@ public final class URITemplate { for (String name : variables) { while (i <= groupCount) { String value = m.group(i++); - if (value == null || value.length() == 0 && i < groupCount) { + if ((value == null || value.length() == 0 && i < groupCount) + && variables.size() + 1 < groupCount) { continue; } templateVariableToValue.add(name, value); http://git-wip-us.apache.org/repos/asf/cxf/blob/c1387810/rt/frontend/jaxrs/src/test/java/org/apache/cxf/jaxrs/model/URITemplateTest.java ---------------------------------------------------------------------- diff --git a/rt/frontend/jaxrs/src/test/java/org/apache/cxf/jaxrs/model/URITemplateTest.java b/rt/frontend/jaxrs/src/test/java/org/apache/cxf/jaxrs/model/URITemplateTest.java index 47bb62c..acfd7da 100644 --- a/rt/frontend/jaxrs/src/test/java/org/apache/cxf/jaxrs/model/URITemplateTest.java +++ b/rt/frontend/jaxrs/src/test/java/org/apache/cxf/jaxrs/model/URITemplateTest.java @@ -65,7 +65,7 @@ public class URITemplateTest extends Assert { String value = values.getFirst("id"); assertEquals("123", value); } - + @Test public void testMatchWithMatrixAndTemplate() throws Exception { URITemplate uriTemplate = new URITemplate("/customers/{id}"); @@ -439,6 +439,39 @@ public class URITemplateTest extends Assert { assertEquals("/", finalPath); } + @Test + public void testExpressionWithTwoVars() throws Exception { + URITemplate uriTemplate = new URITemplate("/{tenant : [^/]*}/resource/{id}"); + MultivaluedMap values = new MetadataMap(); + boolean match = uriTemplate.match("/t1/resource/1", values); + assertTrue(match); + String tenant = values.getFirst("tenant"); + assertEquals("t1", tenant); + String id = values.getFirst("id"); + assertEquals("1", id); + String finalPath = values.getFirst(URITemplate.FINAL_MATCH_GROUP); + assertEquals("/", finalPath); + + values.clear(); + match = uriTemplate.match("//resource/1", values); + assertTrue(match); + tenant = values.getFirst("tenant"); + assertEquals("", tenant); + id = values.getFirst("id"); + assertEquals("1", id); + finalPath = values.getFirst(URITemplate.FINAL_MATCH_GROUP); + assertEquals("/", finalPath); + + values.clear(); + match = uriTemplate.match("/t1/resource/1/sub", values); + assertTrue(match); + tenant = values.getFirst("tenant"); + assertEquals("t1", tenant); + id = values.getFirst("id"); + assertEquals("1", id); + finalPath = values.getFirst(URITemplate.FINAL_MATCH_GROUP); + assertEquals("/sub", finalPath); + } @Test public void testExpressionWithNestedGroupAndManySegments() throws Exception {