| // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| /// @assertion Uri resolveUri(Uri reference) |
| /// Resolve reference as an URI relative to this. |
| /// |
| /// Returns the resolved URI. |
| /// |
| /// The algorithm "Transform Reference" for resolving a reference is described in |
| /// RFC-3986 Section 5. |
| /// |
| /// Updated to handle the case where the base URI is just a relative path - that |
| /// is: when it has no scheme or authority and the path does not start with a |
| /// slash. In that case, the paths are combined without removing leading "..", |
| /// and an empty path is not converted to "/". |
| /// @description Checks that this method works correctly if schema is not |
| /// provided but authority is provided |
| /// (see https://tools.ietf.org/html/rfc3986#section-5.2.4) |
| /// @author sgrekhov@unipro.ru |
| |
| import "../../../Utils/expect.dart"; |
| |
| main() { |
| var x = Uri.parse('http://login:pass@host/a/b?x=1#frag'); |
| Expect.equals(Uri.parse('http://l:p@hst/z?q'), x.resolveUri( |
| new Uri(userInfo: 'l:p', host: 'hst', path: '/z', query: 'q'))); |
| Expect.equals(Uri.parse('http://l:p@hst/z?q#f'), x.resolveUri(new Uri( |
| userInfo: 'l:p', host: 'hst', path: '/z', query: 'q', fragment: 'f'))); |
| } |