1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
// status.rs
// *************************************************************************
// * Copyright (C) 2019 Daniel Mueller (deso@posteo.net) *
// * *
// * This program is free software: you can redistribute it and/or modify *
// * it under the terms of the GNU General Public License as published by *
// * the Free Software Foundation, either version 3 of the License, or *
// * (at your option) any later version. *
// * *
// * This program is distributed in the hope that it will be useful, *
// * but WITHOUT ANY WARRANTY; without even the implied warranty of *
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
// * GNU General Public License for more details. *
// * *
// * You should have received a copy of the GNU General Public License *
// * along with this program. If not, see <http://www.gnu.org/licenses/>. *
// *************************************************************************
use super::*;
use crate::tests::nitrocli;
// This test acts as verification that conversion of Error::Error
// variants into the proper exit code works properly.
#[test_device]
fn not_found_raw() {
let (rc, out, err) = nitrocli::run(NO_DEV, &["status"]);
assert_ne!(rc, 0);
assert_eq!(out, b"");
assert_eq!(err, b"Nitrokey device not found\n");
}
#[test_device]
fn not_found() {
let res = nitrocli::handle(NO_DEV, &["status"]);
assert_eq!(res.unwrap_str_err(), "Nitrokey device not found");
}
#[test_device]
fn output(device: nitrokey::DeviceWrapper) -> crate::Result<()> {
let re = regex::Regex::new(
r#"^Status:
model: (Pro|Storage)
serial number: 0x[[:xdigit:]]{8}
firmware version: \d+.\d+
user retry count: [0-3]
admin retry count: [0-3]
$"#,
)
.unwrap();
let out = nitrocli::handle(Some(device), &["status"])?;
assert!(re.is_match(&out), out);
Ok(())
}
|