updatehub_package_schema/
copy.rs1use crate::definitions::{
6 Filesystem, InstallIfDifferent, TargetFormat, TargetPermissions, TargetType,
7};
8use serde::Deserialize;
9use std::path::PathBuf;
10
11#[derive(Clone, Deserialize, PartialEq, Eq, Debug)]
12#[serde(rename_all = "kebab-case")]
13pub struct Copy {
14 pub filename: String,
15 pub filesystem: Filesystem,
16 pub size: u64,
17 pub sha256sum: String,
18 #[serde(flatten)]
19 pub target_type: TargetType,
20 pub target_path: PathBuf,
21
22 pub install_if_different: Option<InstallIfDifferent>,
23 #[serde(flatten)]
24 pub target_permissions: TargetPermissions,
25 #[serde(default)]
26 pub compressed: bool,
27 #[serde(default)]
28 pub required_uncompressed_size: u64,
29 #[serde(flatten, default)]
30 pub target_format: TargetFormat,
31 #[serde(default)]
32 pub mount_options: String,
33}
34
35#[test]
36fn deserialize() {
37 use pretty_assertions::assert_eq;
38 use serde_json::json;
39
40 assert_eq!(
41 super::Object::Copy(Box::new(Copy {
42 filename: "etc/passwd".to_string(),
43 filesystem: Filesystem::Btrfs,
44 size: 1024,
45 sha256sum: "cfe2be1c64b0387500853de0f48303e3de7b1c6f1508dc719eeafa0d41c36722"
46 .to_string(),
47 target_type: TargetType::Device(PathBuf::from("/dev/sda")),
48 target_path: PathBuf::from("/etc/passwd"),
49
50 install_if_different: Some(InstallIfDifferent::CheckSum),
51 target_permissions: TargetPermissions::default(),
52 compressed: false,
53 required_uncompressed_size: 0,
54 target_format: TargetFormat::default(),
55 mount_options: String::default(),
56 })),
57 serde_json::from_value::<super::Object>(json!({
58 "mode": "copy",
59 "filename": "etc/passwd",
60 "size": 1024,
61 "sha256sum": "cfe2be1c64b0387500853de0f48303e3de7b1c6f1508dc719eeafa0d41c36722",
62 "install-if-different": "sha256sum",
63 "filesystem": "btrfs",
64 "target-type": "device",
65 "target": "/dev/sda",
66 "target-path": "/etc/passwd"
67 }))
68 .unwrap()
69 );
70}