Add tests for ruma_api! macro ensuring request/response generation ok

This commit is contained in:
Devin Ragotzy 2020-07-28 18:55:02 -04:00
parent f00bad3895
commit 47b6adb524

View File

@ -1,6 +1,9 @@
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.",
@ -13,6 +16,46 @@ ruma_api! {
request: {
#[ruma_api(body)]
pub q2: Foo,
#[ruma_api(path)]
pub bar: String,
#[ruma_api(query)]
pub baz: UserId,
#[ruma_api(header = CONTENT_TYPE)]
pub world: String,
}
response: {
#[ruma_api(raw_body)]
pub q2: Vec<u8>,
#[ruma_api(header = CONTENT_TYPE)]
pub world: String,
}
}
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)]
@ -27,11 +70,50 @@ ruma_api! {
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() {}