marine-rs-sdk-test/crates/main/src/mounted_binary.rs

85 lines
3.0 KiB
Rust
Raw Normal View History

2021-02-19 17:14:50 +03:00
/*
* Copyright 2020 Fluence Labs Limited
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
use fluence_sdk_macro::fce;
use serde::Serialize;
use serde::Deserialize;
pub const SUCCESS_CODE: i32 = 0;
/// Describes result of calling a CLI service.
#[fce]
#[derive(Clone, PartialEq, Default, Eq, Debug, Serialize, Deserialize)]
2021-02-22 18:30:45 +03:00
pub struct Result {
2021-02-19 18:31:16 +03:00
/// Return process exit code or host execution error code, where SUCCESS_CODE means success.
2021-02-19 17:14:50 +03:00
pub ret_code: i32,
2021-02-19 22:50:38 +03:00
/// Contains the string representation of an error, if ret_code != SUCCESS_CODE.
pub error: String,
2021-02-19 18:31:16 +03:00
/// The data that the process wrote to stdout.
pub stdout: Vec<u8>,
2021-02-19 17:14:50 +03:00
2021-02-19 18:31:16 +03:00
/// The data that the process wrote to stderr.
pub stderr: Vec<u8>,
2021-02-19 17:14:50 +03:00
}
2021-02-19 17:45:27 +03:00
2021-02-22 18:30:45 +03:00
impl Result {
2021-02-19 18:31:16 +03:00
/// Create a new failure MountedBinaryResult from the provided ret_code.
2021-02-19 22:50:38 +03:00
pub fn from_error(ret_code: i32, error: impl Into<String>) -> Self {
2021-02-19 17:45:27 +03:00
Self {
ret_code,
2021-02-19 22:50:38 +03:00
error: error.into(),
2021-02-19 18:31:16 +03:00
stdout: Vec::new(),
stderr: Vec::new(),
2021-02-19 17:45:27 +03:00
}
}
2021-02-24 08:31:56 +03:00
2021-02-24 11:22:21 +03:00
/// Return true, if this Result represents a success result, otherwise false.
pub fn is_success(&self) -> bool {
2021-02-25 13:44:10 +03:00
self.ret_code == SUCCESS_CODE
2021-02-24 11:22:21 +03:00
}
/// This function tries to transform a result to the string representation.
/// Internally, It checks ret_code and returns either Some(Ok(stdout)) if it was SUCCESS_CODE
/// or Some(Err(error)) otherwise. None is returned if stdout or stderr contains non valid
/// UTF8 string.
pub fn into_std(self) -> Option<std::result::Result<String, String>> {
if self.ret_code == SUCCESS_CODE {
let stdout = String::from_utf8(self.stdout).ok()?;
Some(Ok(stdout))
} else {
let stderr = std::str::from_utf8(&self.stdout).ok()?;
Some(Ok(format!("error: {}, stderr: {}", self.error, stderr)))
}
}
2021-02-24 11:46:07 +03:00
/// This function tries to represent a result as a string.
2021-02-24 11:22:21 +03:00
/// Internally, It checks ret_code and returns either Some(Ok(stdout)) if it was SUCCESS_CODE
/// or Some(Err(error)) otherwise. None is returned if stdout or stderr contains non valid
/// UTF8 string.
pub fn as_std(&self) -> Option<std::result::Result<String, String>> {
2021-02-24 08:31:56 +03:00
if self.ret_code == SUCCESS_CODE {
2021-02-24 11:22:21 +03:00
let stdout = String::from_utf8(self.stdout.clone()).ok()?;
Some(Ok(stdout))
2021-02-24 08:31:56 +03:00
} else {
2021-02-24 11:22:21 +03:00
let stderr = std::str::from_utf8(&self.stdout).ok()?;
Some(Ok(format!("error: {}, stderr: {}", self.error, stderr)))
2021-02-24 08:31:56 +03:00
}
}
2021-02-19 17:45:27 +03:00
}