Add tests for ruma_api! macro ensuring request/response generation ok
This commit is contained in:
parent
f00bad3895
commit
47b6adb524
@ -1,6 +1,9 @@
|
|||||||
use ruma_api::ruma_api;
|
use ruma_api::ruma_api;
|
||||||
use ruma_identifiers::UserId;
|
use ruma_identifiers::UserId;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
|
pub struct Foo;
|
||||||
|
|
||||||
ruma_api! {
|
ruma_api! {
|
||||||
metadata: {
|
metadata: {
|
||||||
description: "Does something.",
|
description: "Does something.",
|
||||||
@ -13,7 +16,7 @@ ruma_api! {
|
|||||||
|
|
||||||
request: {
|
request: {
|
||||||
#[ruma_api(body)]
|
#[ruma_api(body)]
|
||||||
pub q2: Vec<u8>,
|
pub q2: Foo,
|
||||||
|
|
||||||
#[ruma_api(path)]
|
#[ruma_api(path)]
|
||||||
pub bar: String,
|
pub bar: String,
|
||||||
@ -26,7 +29,7 @@ ruma_api! {
|
|||||||
}
|
}
|
||||||
|
|
||||||
response: {
|
response: {
|
||||||
#[ruma_api(body)]
|
#[ruma_api(raw_body)]
|
||||||
pub q2: Vec<u8>,
|
pub q2: Vec<u8>,
|
||||||
|
|
||||||
#[ruma_api(header = CONTENT_TYPE)]
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
@ -34,4 +37,83 @@ ruma_api! {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mod raw_body_request {
|
||||||
|
use ruma_api::ruma_api;
|
||||||
|
use ruma_identifiers::UserId;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
|
pub struct Foo;
|
||||||
|
|
||||||
|
ruma_api! {
|
||||||
|
metadata: {
|
||||||
|
description: "Does something.",
|
||||||
|
method: POST,
|
||||||
|
name: "my_endpoint",
|
||||||
|
path: "/_matrix/foo/:bar/",
|
||||||
|
rate_limited: false,
|
||||||
|
requires_authentication: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
request: {
|
||||||
|
#[ruma_api(raw_body)]
|
||||||
|
pub q2: Vec<u8>,
|
||||||
|
|
||||||
|
#[ruma_api(path)]
|
||||||
|
pub bar: String,
|
||||||
|
|
||||||
|
#[ruma_api(query)]
|
||||||
|
pub baz: UserId,
|
||||||
|
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
response: {
|
||||||
|
#[ruma_api(body)]
|
||||||
|
pub q2: Foo,
|
||||||
|
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mod plain {
|
||||||
|
use ruma_api::ruma_api;
|
||||||
|
use ruma_identifiers::UserId;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
|
pub struct Foo;
|
||||||
|
|
||||||
|
ruma_api! {
|
||||||
|
metadata: {
|
||||||
|
description: "Does something.",
|
||||||
|
method: POST,
|
||||||
|
name: "my_endpoint",
|
||||||
|
path: "/_matrix/foo/:bar/",
|
||||||
|
rate_limited: false,
|
||||||
|
requires_authentication: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
request: {
|
||||||
|
pub q2: Foo,
|
||||||
|
|
||||||
|
pub bar: String,
|
||||||
|
|
||||||
|
#[ruma_api(query)]
|
||||||
|
pub baz: UserId,
|
||||||
|
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
response: {
|
||||||
|
pub q2: Vec<u8>,
|
||||||
|
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn main() {}
|
fn main() {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user