| /* |
| * 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 specified |
| * (see https://tools.ietf.org/html/rfc3986#section-5.2.2) |
| * @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('https:'), x.resolveUri(new Uri(scheme: 'https'))); |
| Expect.equals(Uri.parse('https://l:p@h/p'), |
| x.resolveUri(new Uri(scheme: 'https', userInfo: 'l:p', host: 'h', |
| path: 'p'))); |
| Expect.equals(Uri.parse('https://l:p@h/p?q'), |
| x.resolveUri(new Uri(scheme: 'https', userInfo: 'l:p', host: 'h', |
| path: 'p', query: 'q'))); |
| Expect.equals(Uri.parse('https://l:p@h/p?q#f'), |
| x.resolveUri(new Uri(scheme: 'https', userInfo: 'l:p', host: 'h', |
| path: 'p', query: 'q', fragment: 'f'))); |
| } |