Skip to content

Commit

Permalink
gpio: Use PathBuf for socket paths instead of Strings
Browse files Browse the repository at this point in the history
Signed-off-by: Bilal Elmoussaoui <[email protected]>
  • Loading branch information
bilelmoussaoui committed Sep 15, 2023
1 parent f5e6bc8 commit 67bf380
Showing 1 changed file with 14 additions and 14 deletions.
28 changes: 14 additions & 14 deletions crates/gpio/src/backend.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,10 @@
// SPDX-License-Identifier: Apache-2.0 or BSD-3-Clause

use log::{error, info, warn};
use std::num::ParseIntError;
use std::process::exit;
use std::sync::{Arc, RwLock};
use std::thread::{spawn, JoinHandle};
use std::{num::ParseIntError, path::PathBuf};

use clap::Parser;
use thiserror::Error as ThisError;
Expand Down Expand Up @@ -50,7 +50,7 @@ pub(crate) enum Error {
struct GpioArgs {
/// Location of vhost-user Unix domain socket. This is suffixed by 0,1,2..socket_count-1.
#[clap(short, long)]
socket_path: String,
socket_path: PathBuf,

/// Number of guests (sockets) to connect to.
#[clap(short = 'c', long, default_value_t = 1)]
Expand Down Expand Up @@ -104,7 +104,7 @@ impl TryFrom<&str> for DeviceConfig {

#[derive(PartialEq, Debug)]
struct GpioConfiguration {
socket_path: String,
socket_path: PathBuf,
socket_count: usize,
devices: DeviceConfig,
}
Expand Down Expand Up @@ -139,7 +139,7 @@ fn start_backend<D: 'static + GpioDevice + Send + Sync>(args: GpioArgs) -> Resul
let mut handles = Vec::new();

for i in 0..config.socket_count {
let socket = config.socket_path.to_owned() + &i.to_string();
let socket = config.socket_path.join(i.to_string());
let device_num = config.devices.inner[i];

let handle: JoinHandle<Result<()>> = spawn(move || loop {
Expand Down Expand Up @@ -218,9 +218,9 @@ mod tests {
}
}

fn get_cmd_args(path: &str, devices: &str, count: usize) -> GpioArgs {
fn get_cmd_args(path: PathBuf, devices: &str, count: usize) -> GpioArgs {
GpioArgs {
socket_path: path.to_string(),
socket_path: path,
socket_count: count,
device_list: devices.to_string(),
}
Expand All @@ -238,24 +238,24 @@ mod tests {

#[test]
fn test_gpio_parse_failure() {
let socket_name = "vgpio.sock";
let socket_name = PathBuf::from("vgpio.sock");

// Invalid device number
let cmd_args = get_cmd_args(socket_name, "1:4d:5", 3);
let cmd_args = get_cmd_args(socket_name.clone(), "1:4d:5", 3);
assert_matches!(
GpioConfiguration::try_from(cmd_args).unwrap_err(),
Error::ParseFailure(e) if e == "4d".parse::<u32>().unwrap_err()
);

// Zero socket count
let cmd_args = get_cmd_args(socket_name, "1:4", 0);
let cmd_args = get_cmd_args(socket_name.clone(), "1:4", 0);
assert_matches!(
GpioConfiguration::try_from(cmd_args).unwrap_err(),
Error::SocketCountInvalid(0)
);

// Duplicate client address: 4
let cmd_args = get_cmd_args(socket_name, "1:4:5:6:4", 5);
let cmd_args = get_cmd_args(socket_name.clone(), "1:4:5:6:4", 5);
assert_matches!(
GpioConfiguration::try_from(cmd_args).unwrap_err(),
Error::DeviceDuplicate(4)
Expand All @@ -271,16 +271,16 @@ mod tests {

#[test]
fn test_gpio_parse_successful() {
let socket_name = "vgpio.sock";
let socket_name = PathBuf::from("vgpio.sock");

// Match expected and actual configuration
let cmd_args = get_cmd_args(socket_name, "1:4:32:21:5", 5);
let cmd_args = get_cmd_args(socket_name.clone(), "1:4:32:21:5", 5);
let config = GpioConfiguration::try_from(cmd_args).unwrap();

let expected_devices = DeviceConfig::new_with(vec![1, 4, 32, 21, 5]);
let expected_config = GpioConfiguration {
socket_count: 5,
socket_path: String::from(socket_name),
socket_path: socket_name,
devices: expected_devices,
};

Expand All @@ -290,7 +290,7 @@ mod tests {
#[test]
fn test_gpio_fail_listener() {
// This will fail the listeners and thread will panic.
let socket_name = "~/path/not/present/gpio";
let socket_name = PathBuf::from("~/path/not/present/gpio");
let cmd_args = get_cmd_args(socket_name, "1:4:3:5", 4);

assert_matches!(
Expand Down

0 comments on commit 67bf380

Please sign in to comment.