From 4843622503247b75f04cd061a7825350d0ffe99b Mon Sep 17 00:00:00 2001 From: Simon Brandhof Date: Fri, 6 Jul 2012 14:42:40 +0200 Subject: API: add Settings#getStringLines(String key) --- .../java/org/sonar/api/config/SettingsTest.java | 73 ++++++++++++++++++++-- 1 file changed, 67 insertions(+), 6 deletions(-) (limited to 'sonar-plugin-api/src/test/java/org') diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/config/SettingsTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/config/SettingsTest.java index fe01f365560..e821ff6a8c0 100644 --- a/sonar-plugin-api/src/test/java/org/sonar/api/config/SettingsTest.java +++ b/sonar-plugin-api/src/test/java/org/sonar/api/config/SettingsTest.java @@ -32,12 +32,13 @@ public class SettingsTest { private PropertyDefinitions definitions; @Properties({ - @Property(key = "hello", name = "Hello", defaultValue = "world"), - @Property(key = "date", name = "Date", defaultValue = "2010-05-18"), - @Property(key = "boolean", name = "Boolean", defaultValue = "true"), - @Property(key = "falseboolean", name = "False Boolean", defaultValue = "false"), - @Property(key = "integer", name = "Integer", defaultValue = "12345"), - @Property(key = "array", name = "Array", defaultValue = "one,two,three") + @Property(key = "hello", name = "Hello", defaultValue = "world"), + @Property(key = "date", name = "Date", defaultValue = "2010-05-18"), + @Property(key = "datetime", name = "DateTime", defaultValue = "2010-05-18T15:50:45+0100"), + @Property(key = "boolean", name = "Boolean", defaultValue = "true"), + @Property(key = "falseboolean", name = "False Boolean", defaultValue = "false"), + @Property(key = "integer", name = "Integer", defaultValue = "12345"), + @Property(key = "array", name = "Array", defaultValue = "one,two,three") }) static class Init { } @@ -94,6 +95,14 @@ public class SettingsTest { assertThat(settings.getDate("unknown")).isNull(); } + @Test + public void testGetDateTime() { + Settings settings = new Settings(definitions); + assertThat(settings.getDateTime("datetime").getDate()).isEqualTo(18); + assertThat(settings.getDateTime("datetime").getMonth()).isEqualTo(4); + assertThat(settings.getDateTime("datetime").getMinutes()).isEqualTo(50); + } + @Test public void testGetArray() { Settings settings = new Settings(definitions); @@ -162,4 +171,56 @@ public class SettingsTest { assertThat(target.getString("foo")).isEqualTo("bar"); assertThat(target.getString("new")).isNull(); } + + @Test + public void getStringLines_no_value() { + assertThat(new Settings().getStringLines("foo")).hasSize(0); + } + + @Test + public void getStringLines_single_line() { + Settings settings = new Settings(); + settings.setProperty("foo", "the line"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"the line"}); + } + + @Test + public void getStringLines_linux() { + Settings settings = new Settings(); + settings.setProperty("foo", "one\ntwo"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"one", "two"}); + + settings.setProperty("foo", "one\ntwo\n"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"one", "two"}); + } + + @Test + public void getStringLines_windows() { + Settings settings = new Settings(); + settings.setProperty("foo", "one\r\ntwo"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"one", "two"}); + + settings.setProperty("foo", "one\r\ntwo\r\n"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"one", "two"}); + } + + @Test + public void getStringLines_mix() { + Settings settings = new Settings(); + settings.setProperty("foo", "one\r\ntwo\nthree"); + assertThat(settings.getStringLines("foo")).isEqualTo(new String[]{"one", "two", "three"}); + } + + @Test + public void getKeysStartingWith() { + Settings settings = new Settings(); + settings.setProperty("sonar.jdbc.url", "foo"); + settings.setProperty("sonar.jdbc.username", "bar"); + settings.setProperty("sonar.security", "admin"); + + assertThat(settings.getKeysStartingWith("sonar")).containsOnly("sonar.jdbc.url", "sonar.jdbc.username", "sonar.security"); + assertThat(settings.getKeysStartingWith("sonar.jdbc")).containsOnly("sonar.jdbc.url", "sonar.jdbc.username"); + assertThat(settings.getKeysStartingWith("other")).hasSize(0); + + } } -- cgit v1.2.3