From 6f1ef33e320547f6c68867fa28d1189be7fa3519 Mon Sep 17 00:00:00 2001 From: David Reher Date: Fri, 15 Jan 2016 17:23:12 +0100 Subject: [PATCH] fix(router): fix url path for star segment in path recognizer Url path of star segments should equal the original path. If you register the route `/app/*location` and invoke a url like `/app/foo/bar` the PathRecognizer should return a url path equal to the invoked url. Before this patch, everything after `foo` was ignored, which resulted in a redirect to `/app/foo` which was probably not intended (at least in the angular 1.5 component router). Closes #6976 --- modules/angular2/src/router/path_recognizer.ts | 5 +++-- modules/angular2/test/router/path_recognizer_spec.ts | 9 +++++++++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/modules/angular2/src/router/path_recognizer.ts b/modules/angular2/src/router/path_recognizer.ts index 263ae9446d..36a1cd8887 100644 --- a/modules/angular2/src/router/path_recognizer.ts +++ b/modules/angular2/src/router/path_recognizer.ts @@ -208,15 +208,16 @@ export class PathRecognizer { } if (isPresent(currentSegment)) { - captured.push(currentSegment.path); - // the star segment consumes all of the remaining URL, including matrix params if (segment instanceof StarSegment) { positionalParams[segment.name] = currentSegment.toString(); + captured.push(currentSegment.toString()); nextSegment = null; break; } + captured.push(currentSegment.path); + if (segment instanceof DynamicSegment) { positionalParams[segment.name] = currentSegment.path; } else if (!segment.match(currentSegment.path)) { diff --git a/modules/angular2/test/router/path_recognizer_spec.ts b/modules/angular2/test/router/path_recognizer_spec.ts index 08fddc1044..c0acfc59c7 100644 --- a/modules/angular2/test/router/path_recognizer_spec.ts +++ b/modules/angular2/test/router/path_recognizer_spec.ts @@ -90,5 +90,14 @@ export function main() { expect(match['allParams']).toEqual({'c': '3'}); }); }); + + describe('wildcard segment', () => { + it('should return a url path which matches the original url path', () => { + var rec = new PathRecognizer('/wild/*everything'); + var url = parser.parse('/wild/super;variable=value/anotherPartAfterSlash'); + var match = rec.recognize(url); + expect(match['urlPath']).toEqual('wild/super;variable=value/anotherPartAfterSlash'); + }); + }); }); }