proxmox/proxmox-api-macro/tests/types.rs
Wolfgang Bumiller 4916d5b10d api-macro: support optional return values
The return specification can now include an `optional`
field.

Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2020-12-22 07:02:47 +01:00

192 lines
5.1 KiB
Rust

//! This should test the usage of "external" types. For any unrecognized schema type we expect the
//! type's impl to provide an `pub const API_SCHEMA: &Schema`.
#![allow(dead_code)]
use proxmox::api::schema::{self, EnumEntry};
use proxmox_api_macro::api;
use anyhow::Error;
use serde::Deserialize;
use serde_json::Value;
#[api(
type: String,
description: "A string",
format: &schema::ApiStringFormat::Enum(&[
EnumEntry::new("ok", "Ok"),
EnumEntry::new("not-ok", "Not OK"),
]),
)]
//#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct OkString(String);
#[test]
fn ok_string() {
const TEST_SCHEMA: ::proxmox::api::schema::Schema =
::proxmox::api::schema::StringSchema::new("A string")
.format(&schema::ApiStringFormat::Enum(&[
EnumEntry::new("ok", "Ok"),
EnumEntry::new("not-ok", "Not OK"),
]))
.schema();
assert_eq!(TEST_SCHEMA, OkString::API_SCHEMA);
}
#[api]
/// An example of a simple struct type.
pub struct TestStruct {
/// A test string.
test_string: String,
/// An optional auto-derived value for testing:
another: Option<String>,
}
#[test]
fn test_struct() {
pub const TEST_SCHEMA: ::proxmox::api::schema::Schema =
::proxmox::api::schema::ObjectSchema::new(
"An example of a simple struct type.",
&[
(
"another",
true,
&::proxmox::api::schema::StringSchema::new(
"An optional auto-derived value for testing:",
)
.schema(),
),
(
"test_string",
false,
&::proxmox::api::schema::StringSchema::new("A test string.").schema(),
),
],
)
.schema();
assert_eq!(TEST_SCHEMA, TestStruct::API_SCHEMA);
}
#[api]
#[derive(Deserialize)]
#[serde(rename_all = "kebab-case")]
/// An example of a struct with renamed fields.
pub struct RenamedStruct {
/// A test string.
test_string: String,
/// An optional auto-derived value for testing:
#[serde(rename = "SomeOther")]
another: Option<String>,
}
#[test]
fn renamed_struct() {
const TEST_SCHEMA: ::proxmox::api::schema::Schema = ::proxmox::api::schema::ObjectSchema::new(
"An example of a struct with renamed fields.",
&[
(
"SomeOther",
true,
&::proxmox::api::schema::StringSchema::new(
"An optional auto-derived value for testing:",
)
.schema(),
),
(
"test-string",
false,
&::proxmox::api::schema::StringSchema::new("A test string.").schema(),
),
],
)
.schema();
assert_eq!(TEST_SCHEMA, RenamedStruct::API_SCHEMA);
}
#[api]
#[derive(Deserialize)]
#[serde(rename_all = "kebab-case")]
/// A selection of either 'onekind', 'another-kind' or 'selection-number-three'.
pub enum Selection {
/// The first kind.
#[serde(rename = "onekind")]
OneKind,
/// Some other kind.
AnotherKind,
/// And yet another.
SelectionNumberThree,
}
#[test]
fn selection_test() {
const TEST_SCHEMA: ::proxmox::api::schema::Schema = ::proxmox::api::schema::StringSchema::new(
"A selection of either \'onekind\', \'another-kind\' or \'selection-number-three\'.",
)
.format(&::proxmox::api::schema::ApiStringFormat::Enum(&[
EnumEntry::new("onekind", "The first kind."),
EnumEntry::new("another-kind", "Some other kind."),
EnumEntry::new("selection-number-three", "And yet another."),
]))
.schema();
assert_eq!(TEST_SCHEMA, Selection::API_SCHEMA);
}
// Initial test:
#[api(
input: {
properties: {
arg: { type: OkString },
selection: { type: Selection },
}
},
returns: { optional: true, type: Boolean },
)]
/// Check a string.
///
/// Returns: Whether the string was "ok".
pub fn string_check(arg: Value, selection: Selection) -> Result<bool, Error> {
let _ = arg;
let _ = selection;
panic!("body")
}
#[test]
fn string_check_schema_test() {
const TEST_METHOD: ::proxmox::api::ApiMethod = ::proxmox::api::ApiMethod::new(
&::proxmox::api::ApiHandler::Sync(&api_function_string_check),
&::proxmox::api::schema::ObjectSchema::new(
"Check a string.",
&[
("arg", false, &OkString::API_SCHEMA),
("selection", false, &Selection::API_SCHEMA),
],
),
)
.returns(::proxmox::api::router::ReturnType::new(
true,
&::proxmox::api::schema::BooleanSchema::new("Whether the string was \"ok\".").schema(),
))
.protected(false);
assert_eq!(TEST_METHOD, API_METHOD_STRING_CHECK);
}
#[api(
properties: {
"a-field": {
description: "Some description.",
},
},
)]
#[derive(Deserialize)]
#[serde(rename_all = "kebab-case")]
/// Some Description.
pub struct RenamedAndDescribed {
a_field: String,
}