Rocket/core/codegen/tests/ui-fail-nightly/route-path-bad-syntax.stderr
Sergio Benitez 51ed332127 Make trailing slashes significant during routing.
This commit modifies request routing in a backwards incompatible manner.
The change is summarized as: trailing slashes are now significant and
never transparently disregarded. This has the following implications,
all representing behavior that differs from that before this change:

  * Route URIs with trailing slashes (`/foo/`, `/<a>/`) are legal.
  * A request `/foo/` is routed to route `/foo/` but not `/foo`.
  * Similarly, a request `/bar/` is routed to `/<a>/` but not `/<a>`.
  * A request `/bar/foo` is not routed to `/<a>/<b>/<c..>`.

A new `AdHoc::uri_normalizer()` fairing was added that recovers the
previous behavior.

In addition to the above, the `Options::NormalizeDirs` `FileServer`
option is now enabled by default to remain consistent with the above
changes and reduce breaking changes at the `FileServer` level.
2023-04-10 12:40:39 -07:00

243 lines
6.1 KiB
Plaintext

error: invalid route URI: expected token '/' but found 'a' at index 0
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:5:8
|
5 | #[get("a")]
| ^
|
= help: expected URI in origin form: "/path/<param>"
error: invalid route URI: unexpected EOF: expected token '/' at index 0
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:8:8
|
8 | #[get("")]
| ^
|
= help: expected URI in origin form: "/path/<param>"
error: invalid route URI: expected token '/' but found 'a' at index 0
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:11:8
|
11 | #[get("a/b/c")]
| ^
|
= help: expected URI in origin form: "/path/<param>"
error: route URIs cannot contain empty segments
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:14:10
|
14 | #[get("/a///b")]
| ^^
|
= note: expected "/a/b", found "/a///b"
error: route URIs cannot contain empty segments
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:17:13
|
17 | #[get("/?bat&&")]
| ^^
|
= note: expected "/?bat", found "/?bat&&"
error: route URIs cannot contain empty segments
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:20:13
|
20 | #[get("/?bat&&")]
| ^^
|
= note: expected "/?bat", found "/?bat&&"
error: route URIs cannot contain empty segments
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:23:12
|
23 | #[get("/a/b//")]
| ^^
|
= note: expected "/a/b/", found "/a/b//"
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:42:10
|
42 | #[get("/<name>")]
| ^^^^
|
note: expected argument named `name` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:43:6
|
43 | fn h0(_name: usize) {}
| ^^^^^^^^^^^^^^
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:45:12
|
45 | #[get("/a?<r>")]
| ^
|
note: expected argument named `r` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:46:6
|
46 | fn h1() {}
| ^^
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:48:23
|
48 | #[post("/a", data = "<test>")]
| ^^^^
|
note: expected argument named `test` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:49:6
|
49 | fn h2() {}
| ^^
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:51:10
|
51 | #[get("/<_r>")]
| ^^
|
note: expected argument named `_r` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:52:6
|
52 | fn h3() {}
| ^^
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:54:10
|
54 | #[get("/<_r>/<b>")]
| ^^
|
note: expected argument named `_r` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:55:6
|
55 | fn h4() {}
| ^^
error: unused parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:54:15
|
54 | #[get("/<_r>/<b>")]
| ^
|
note: expected argument named `b` here
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:55:6
|
55 | fn h4() {}
| ^^
error: invalid identifier: `foo_.`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:60:10
|
60 | #[get("/<foo_.>")]
| ^^^^^
|
= help: dynamic parameters must be valid identifiers
= help: did you mean `<foo_>`?
error: invalid identifier: `foo*`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:63:10
|
63 | #[get("/<foo*>")]
| ^^^^
|
= help: dynamic parameters must be valid identifiers
= help: did you mean `<foo>`?
error: invalid identifier: `!`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:66:10
|
66 | #[get("/<!>")]
| ^
|
= help: dynamic parameters must be valid identifiers
= help: did you mean `<param>`?
error: invalid identifier: `name>:<id`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:69:10
|
69 | #[get("/<name>:<id>")]
| ^^^^^^^^^
|
= help: dynamic parameters must be valid identifiers
= help: did you mean `<nameid>`?
error: unexpected static parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:74:20
|
74 | #[get("/", data = "foo")]
| ^^^
|
= help: parameter must be dynamic: `<foo>`
error: parameter cannot be trailing
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:77:20
|
77 | #[get("/", data = "<foo..>")]
| ^^^^^^^
|
= help: did you mean `<foo>`?
warning: `segment` starts with `<` but does not end with `>`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:80:20
|
80 | #[get("/", data = "<foo")]
| ^^^^
|
= help: perhaps you meant the dynamic parameter `<foo>`?
error: unexpected static parameter
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:80:20
|
80 | #[get("/", data = "<foo")]
| ^^^^
|
= help: parameter must be dynamic: `<foo>`
error: invalid identifier: `test `
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:83:21
|
83 | #[get("/", data = "<test >")]
| ^^^^^
|
= help: dynamic parameters must be valid identifiers
= help: did you mean `<test>`?
error: handler arguments must be named
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:89:7
|
89 | fn k0(_: usize) {}
| ^^^^^^^^
|
= help: to name an ignored handler argument, use `_name`
error: parameters cannot be empty
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:93:9
|
93 | #[get("/<>")]
| ^^
warning: `segment` starts with `<` but does not end with `>`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:96:9
|
96 | #[get("/<id><")]
| ^^^^^
|
= help: perhaps you meant the dynamic parameter `<id>`?
warning: `segment` starts with `<` but does not end with `>`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:99:9
|
99 | #[get("/<<<<id><")]
| ^^^^^^^^
|
= help: perhaps you meant the dynamic parameter `<id>`?
warning: `segment` starts with `<` but does not end with `>`
--> tests/ui-fail-nightly/route-path-bad-syntax.rs:102:9
|
102 | #[get("/<>name><")]
| ^^^^^^^^
|
= help: perhaps you meant the dynamic parameter `<name>`?