#[allow(clippy::unnecessary_wraps)]
pub fn de_test_http_error(_response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8]) -> std::result::Result<crate::operation::test::TestOutput, crate::operation::test::TestError> {
#[allow(unused_mut)]
let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body).map_err(crate::operation::test::TestError::unhandled)?;
let generic = generic_builder.build();
let error_code = match generic.code() {
Some(code) => code,
None => return Err(crate::operation::test::TestError::unhandled(generic))
};
let _error_message = generic.message().map(|msg|msg.to_owned());
Err(match error_code {
"ResourceNotFound" => crate::operation::test::TestError::ResourceNotFound({
#[allow(unused_mut)]
let mut tmp =
{
#[allow(unused_mut)]
let mut output = crate::types::error::builders::ResourceNotFoundBuilder::default();
output = crate::protocol_serde::shape_resource_not_found::de_resource_not_found_json_err(_response_body, output).map_err(crate::operation::test::TestError::unhandled)?;
let output = output.meta(generic);
output.build()
}
;
if tmp.message.is_none() {
tmp.message = _error_message;
}
tmp
}),
"InternalServerError" => crate::operation::test::TestError::InternalServerError({
#[allow(unused_mut)]
let mut tmp =
{
#[allow(unused_mut)]
let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::test::TestError::unhandled)?;
let output = output.meta(generic);
output.build()
}
;
if tmp.message.is_none() {
tmp.message = _error_message;
}
tmp
}),
_ => crate::operation::test::TestError::generic(generic)
})
}
#[allow(clippy::unnecessary_wraps)]
pub fn de_test_http_response(_response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8]) -> std::result::Result<crate::operation::test::TestOutput, crate::operation::test::TestError> {
Ok({
#[allow(unused_mut)]
let mut output = crate::operation::test::builders::TestOutputBuilder::default();
output = crate::protocol_serde::shape_test::de_test(_response_body, output).map_err(crate::operation::test::TestError::unhandled)?;
crate::serde_util::test_output_output_correct_errors(output).build().map_err(crate::operation::test::TestError::unhandled)?
})
}
pub fn ser_test_headers(
input: &crate::operation::test::TestInput,
mut builder: ::http::request::Builder
) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
if let ::std::option::Option::Some(inner_1) = &input.workspace_id {
let formatted_2 = inner_1.as_str();
let header_value = formatted_2;
let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
::aws_smithy_types::error::operation::BuildError::invalid_field("workspace_id", format!(
"`{}` cannot be used as a header value: {}",
&header_value,
err
))
})?;
builder = builder.header("x-workspace", header_value);
}
if let ::std::option::Option::Some(inner_3) = &input.org_id {
let formatted_4 = inner_3.as_str();
let header_value = formatted_4;
let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
::aws_smithy_types::error::operation::BuildError::invalid_field("org_id", format!(
"`{}` cannot be used as a header value: {}",
&header_value,
err
))
})?;
builder = builder.header("x-org-id", header_value);
}
Ok(builder)
}
pub(crate) fn de_test(value: &[u8], mut builder: crate::operation::test::builders::TestOutputBuilder) -> ::std::result::Result<crate::operation::test::builders::TestOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
let tokens = &mut tokens_owned;
::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
loop {
match tokens.next().transpose()? {
Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
match key.to_unescaped()?.as_ref() {
"fn_output" => {
builder = builder.set_fn_output(
Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?)
);
}
"function_type" => {
builder = builder.set_function_type(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
s.to_unescaped().map(|u|
crate::types::FunctionTypes::from(u.as_ref())
)
).transpose()?
);
}
"stdout" => {
builder = builder.set_stdout(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
s.to_unescaped().map(|u|
u.into_owned()
)
).transpose()?
);
}
_ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?
}
}
other => return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!("expected object key or end object, found: {:?}", other)))
}
}
if tokens.next().is_some() {
return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom("found more JSON tokens after completing parsing"));
}
Ok(builder)
}