123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 |
- """Tests for reading and writing configuration files."""
- from cStringIO import StringIO
- from dulwich.config import (
- ConfigDict,
- ConfigFile,
- StackedConfig,
- _check_section_name,
- _check_variable_name,
- _format_string,
- _escape_value,
- _parse_string,
- _unescape_value,
- )
- from dulwich.tests import TestCase
- class ConfigFileTests(TestCase):
- def from_file(self, text):
- return ConfigFile.from_file(StringIO(text))
- def test_empty(self):
- ConfigFile()
- def test_eq(self):
- self.assertEqual(ConfigFile(), ConfigFile())
- def test_default_config(self):
- cf = self.from_file("""[core]
- repositoryformatversion = 0
- filemode = true
- bare = false
- logallrefupdates = true
- """)
- self.assertEqual(ConfigFile({("core", ): {
- "repositoryformatversion": "0",
- "filemode": "true",
- "bare": "false",
- "logallrefupdates": "true"}}), cf)
- def test_from_file_empty(self):
- cf = self.from_file("")
- self.assertEqual(ConfigFile(), cf)
- def test_empty_line_before_section(self):
- cf = self.from_file("\n[section]\n")
- self.assertEqual(ConfigFile({("section", ): {}}), cf)
- def test_comment_before_section(self):
- cf = self.from_file("# foo\n[section]\n")
- self.assertEqual(ConfigFile({("section", ): {}}), cf)
- def test_comment_after_section(self):
- cf = self.from_file("[section] # foo\n")
- self.assertEqual(ConfigFile({("section", ): {}}), cf)
- def test_comment_after_variable(self):
- cf = self.from_file("[section]\nbar= foo # a comment\n")
- self.assertEqual(ConfigFile({("section", ): {"bar": "foo"}}), cf)
- def test_from_file_section(self):
- cf = self.from_file("[core]\nfoo = bar\n")
- self.assertEqual("bar", cf.get(("core", ), "foo"))
- self.assertEqual("bar", cf.get(("core", "foo"), "foo"))
- def test_from_file_section_case_insensitive(self):
- cf = self.from_file("[cOre]\nfOo = bar\n")
- self.assertEqual("bar", cf.get(("core", ), "foo"))
- self.assertEqual("bar", cf.get(("core", "foo"), "foo"))
- def test_from_file_with_mixed_quoted(self):
- cf = self.from_file("[core]\nfoo = \"bar\"la\n")
- self.assertEqual("barla", cf.get(("core", ), "foo"))
- def test_from_file_with_open_quoted(self):
- self.assertRaises(ValueError,
- self.from_file, "[core]\nfoo = \"bar\n")
- def test_from_file_with_quotes(self):
- cf = self.from_file(
- "[core]\n"
- 'foo = " bar"\n')
- self.assertEqual(" bar", cf.get(("core", ), "foo"))
- def test_from_file_with_interrupted_line(self):
- cf = self.from_file(
- "[core]\n"
- 'foo = bar\\\n'
- ' la\n')
- self.assertEqual("barla", cf.get(("core", ), "foo"))
- def test_from_file_with_boolean_setting(self):
- cf = self.from_file(
- "[core]\n"
- 'foo\n')
- self.assertEqual("true", cf.get(("core", ), "foo"))
- def test_from_file_subsection(self):
- cf = self.from_file("[branch \"foo\"]\nfoo = bar\n")
- self.assertEqual("bar", cf.get(("branch", "foo"), "foo"))
- def test_from_file_subsection_invalid(self):
- self.assertRaises(ValueError,
- self.from_file, "[branch \"foo]\nfoo = bar\n")
- def test_from_file_subsection_not_quoted(self):
- cf = self.from_file("[branch.foo]\nfoo = bar\n")
- self.assertEqual("bar", cf.get(("branch", "foo"), "foo"))
- def test_write_to_file_empty(self):
- c = ConfigFile()
- f = StringIO()
- c.write_to_file(f)
- self.assertEqual("", f.getvalue())
- def test_write_to_file_section(self):
- c = ConfigFile()
- c.set(("core", ), "foo", "bar")
- f = StringIO()
- c.write_to_file(f)
- self.assertEqual("[core]\nfoo = bar\n", f.getvalue())
- def test_write_to_file_subsection(self):
- c = ConfigFile()
- c.set(("branch", "blie"), "foo", "bar")
- f = StringIO()
- c.write_to_file(f)
- self.assertEqual("[branch \"blie\"]\nfoo = bar\n", f.getvalue())
- def test_same_line(self):
- cf = self.from_file("[branch.foo] foo = bar\n")
- self.assertEqual("bar", cf.get(("branch", "foo"), "foo"))
- class ConfigDictTests(TestCase):
- def test_get_set(self):
- cd = ConfigDict()
- self.assertRaises(KeyError, cd.get, "foo", "core")
- cd.set(("core", ), "foo", "bla")
- self.assertEqual("bla", cd.get(("core", ), "foo"))
- cd.set(("core", ), "foo", "bloe")
- self.assertEqual("bloe", cd.get(("core", ), "foo"))
- def test_get_boolean(self):
- cd = ConfigDict()
- cd.set(("core", ), "foo", "true")
- self.assertTrue(cd.get_boolean(("core", ), "foo"))
- cd.set(("core", ), "foo", "false")
- self.assertFalse(cd.get_boolean(("core", ), "foo"))
- cd.set(("core", ), "foo", "invalid")
- self.assertRaises(ValueError, cd.get_boolean, ("core", ), "foo")
- def test_dict(self):
- cd = ConfigDict()
- cd.set(("core", ), "foo", "bla")
- cd.set(("core2", ), "foo", "bloe")
- self.assertEqual([("core2", ), ("core", )], cd.keys())
- self.assertEqual(cd[("core", )], {'foo': 'bla'})
- cd['a'] = 'b'
- self.assertEqual(cd['a'], 'b')
- class StackedConfigTests(TestCase):
- def test_default_backends(self):
- StackedConfig.default_backends()
- class UnescapeTests(TestCase):
- def test_nothing(self):
- self.assertEqual("", _unescape_value(""))
- def test_tab(self):
- self.assertEqual("\tbar\t", _unescape_value("\\tbar\\t"))
- def test_newline(self):
- self.assertEqual("\nbar\t", _unescape_value("\\nbar\\t"))
- def test_quote(self):
- self.assertEqual("\"foo\"", _unescape_value("\\\"foo\\\""))
- class EscapeValueTests(TestCase):
- def test_nothing(self):
- self.assertEqual("foo", _escape_value("foo"))
- def test_backslash(self):
- self.assertEqual("foo\\\\", _escape_value("foo\\"))
- def test_newline(self):
- self.assertEqual("foo\\n", _escape_value("foo\n"))
- class FormatStringTests(TestCase):
- def test_quoted(self):
- self.assertEqual('" foo"', _format_string(" foo"))
- self.assertEqual('"\\tfoo"', _format_string("\tfoo"))
- def test_not_quoted(self):
- self.assertEqual('foo', _format_string("foo"))
- self.assertEqual('foo bar', _format_string("foo bar"))
- class ParseStringTests(TestCase):
- def test_quoted(self):
- self.assertEqual(' foo', _parse_string('" foo"'))
- self.assertEqual('\tfoo', _parse_string('"\\tfoo"'))
- def test_not_quoted(self):
- self.assertEqual('foo', _parse_string("foo"))
- self.assertEqual('foo bar', _parse_string("foo bar"))
- class CheckVariableNameTests(TestCase):
- def test_invalid(self):
- self.assertFalse(_check_variable_name("foo "))
- self.assertFalse(_check_variable_name("bar,bar"))
- self.assertFalse(_check_variable_name("bar.bar"))
- def test_valid(self):
- self.assertTrue(_check_variable_name("FOO"))
- self.assertTrue(_check_variable_name("foo"))
- self.assertTrue(_check_variable_name("foo-bar"))
- class CheckSectionNameTests(TestCase):
- def test_invalid(self):
- self.assertFalse(_check_section_name("foo "))
- self.assertFalse(_check_section_name("bar,bar"))
- def test_valid(self):
- self.assertTrue(_check_section_name("FOO"))
- self.assertTrue(_check_section_name("foo"))
- self.assertTrue(_check_section_name("foo-bar"))
- self.assertTrue(_check_section_name("bar.bar"))
|