summaryrefslogtreecommitdiffstats
path: root/tests/set.rs
diff options
context:
space:
mode:
authorRyan Leckey <ryan@launchbadge.com>2017-06-03 01:22:38 -0700
committerRyan Leckey <ryan@launchbadge.com>2017-06-03 01:22:38 -0700
commit43c141f87a0167e50802f097cf04896258acb5e6 (patch)
tree799cc797eecf5e699322fbb55debdf75f576a7c0 /tests/set.rs
parent0a478cf075cc93ede4f631a5be4502e2da2f0cf7 (diff)
Add many more tests
Diffstat (limited to 'tests/set.rs')
-rw-r--r--tests/set.rs40
1 files changed, 40 insertions, 0 deletions
diff --git a/tests/set.rs b/tests/set.rs
new file mode 100644
index 0000000..a575138
--- /dev/null
+++ b/tests/set.rs
@@ -0,0 +1,40 @@
+extern crate config;
+
+use config::*;
+
+#[test]
+fn test_set_scalar() {
+ let mut c = Config::default();
+
+ c.set("value", true).unwrap();
+
+ assert_eq!(c.get("value").ok(), Some(true));
+}
+
+#[test]
+fn test_set_scalar_default() {
+ let mut c = Config::default();
+
+ c.merge(File::new("tests/Settings", FileFormat::Toml))
+ .unwrap();
+
+ c.set_default("debug", false).unwrap();
+ c.set_default("staging", false).unwrap();
+
+ assert_eq!(c.get("debug").ok(), Some(true));
+ assert_eq!(c.get("staging").ok(), Some(false));
+}
+
+#[test]
+fn test_set_scalar_path() {
+ let mut c = Config::default();
+
+ c.merge(File::new("tests/Settings", FileFormat::Toml))
+ .unwrap();
+
+ c.set_default("place.favorite", true).unwrap();
+ c.set_default("place.blocked", true).unwrap();
+
+ assert_eq!(c.get("place.favorite").ok(), Some(false));
+ assert_eq!(c.get("place.blocked").ok(), Some(true));
+}