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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
use thiserror::Error;
use crate::external;
use crate::external::Vcs;
use crate::lints::lib::Lints;
pub fn set_status(lints: Lints, vcs: &mut dyn Vcs, status: bool) -> Result<(), Error> {
lints
.config_keys()
.into_iter()
.try_for_each(|lint| vcs.set_str(&lint, &status.to_string()))?;
Ok(())
}
#[cfg(test)]
mod tests_can_enable_lints_via_a_command {
use std::collections::{BTreeMap, BTreeSet};
use pretty_assertions::assert_eq;
use crate::external::InMemory;
use crate::lints::cmd::set_status::set_status;
use crate::lints::lib::{Lint, Lints};
#[test]
fn we_can_enable_lints() {
let mut strings = BTreeMap::new();
strings.insert("mit.lint.pivotal-tracker-id-missing".into(), "false".into());
let mut config = InMemory::new(&mut strings);
let mut lints = BTreeSet::new();
lints.insert(Lint::PivotalTrackerIdMissing);
set_status(Lints::new(lints), &mut config, true).unwrap();
let expected = "true".to_string();
let actual = strings
.get("mit.lint.pivotal-tracker-id-missing")
.unwrap()
.clone();
assert_eq!(expected, actual);
}
#[test]
fn we_can_disable_lints() {
let mut strings = BTreeMap::new();
strings.insert("mit.lint.pivotal-tracker-id-missing".into(), "true".into());
let mut config = InMemory::new(&mut strings);
let mut lints = BTreeSet::new();
lints.insert(Lint::PivotalTrackerIdMissing);
set_status(Lints::new(lints), &mut config, false).unwrap();
let expected = "false".to_string();
let actual = strings
.get("mit.lint.pivotal-tracker-id-missing")
.unwrap()
.clone();
assert_eq!(expected, actual);
}
}
#[derive(Error, Debug)]
pub enum Error {
#[error("could not set lint status: {0}")]
VcsIo(#[from] external::Error),
}