# Copyright (C) 2009 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """Unittests for the git_config.py module.""" import os import tempfile import unittest import git_config def fixture(*paths): """Return a path relative to test/fixtures.""" return os.path.join(os.path.dirname(__file__), "fixtures", *paths) class GitConfigReadOnlyTests(unittest.TestCase): """Read-only tests of the GitConfig class.""" def setUp(self): """Create a GitConfig object using the test.gitconfig fixture.""" config_fixture = fixture("test.gitconfig") self.config = git_config.GitConfig(config_fixture) def test_GetString_with_empty_config_values(self): """ Test config entries with no value. [section] empty """ val = self.config.GetString("section.empty") self.assertEqual(val, None) def test_GetString_with_true_value(self): """ Test config entries with a string value. [section] nonempty = true """ val = self.config.GetString("section.nonempty") self.assertEqual(val, "true") def test_GetString_from_missing_file(self): """ Test missing config file """ config_fixture = fixture("not.present.gitconfig") config = git_config.GitConfig(config_fixture) val = config.GetString("empty") self.assertEqual(val, None) def test_GetBoolean_undefined(self): """Test GetBoolean on key that doesn't exist.""" self.assertIsNone(self.config.GetBoolean("section.missing")) def test_GetBoolean_invalid(self): """Test GetBoolean on invalid boolean value.""" self.assertIsNone(self.config.GetBoolean("section.boolinvalid")) def test_GetBoolean_true(self): """Test GetBoolean on valid true boolean.""" self.assertTrue(self.config.GetBoolean("section.booltrue")) def test_GetBoolean_false(self): """Test GetBoolean on valid false boolean.""" self.assertFalse(self.config.GetBoolean("section.boolfalse")) def test_GetInt_undefined(self): """Test GetInt on key that doesn't exist.""" self.assertIsNone(self.config.GetInt("section.missing")) def test_GetInt_invalid(self): """Test GetInt on invalid integer value.""" self.assertIsNone(self.config.GetBoolean("section.intinvalid")) def test_GetInt_valid(self): """Test GetInt on valid integers.""" TESTS = ( ("inthex", 16), ("inthexk", 16384), ("int", 10), ("intk", 10240), ("intm", 10485760), ("intg", 10737418240), ) for key, value in TESTS: self.assertEqual(value, self.config.GetInt(f"section.{key}")) class GitConfigReadWriteTests(unittest.TestCase): """Read/write tests of the GitConfig class.""" def setUp(self): self.tmpfile = tempfile.NamedTemporaryFile() self.config = self.get_config() def get_config(self): """Get a new GitConfig instance.""" return git_config.GitConfig(self.tmpfile.name) def test_SetString(self): """Test SetString behavior.""" # Set a value. self.assertIsNone(self.config.GetString("foo.bar")) self.config.SetString("foo.bar", "val") self.assertEqual("val", self.config.GetString("foo.bar")) # Make sure the value was actually written out. config = self.get_config() self.assertEqual("val", config.GetString("foo.bar")) # Update the value. self.config.SetString("foo.bar", "valll") self.assertEqual("valll", self.config.GetString("foo.bar")) config = self.get_config() self.assertEqual("valll", config.GetString("foo.bar")) # Delete the value. self.config.SetString("foo.bar", None) self.assertIsNone(self.config.GetString("foo.bar")) config = self.get_config() self.assertIsNone(config.GetString("foo.bar")) def test_SetBoolean(self): """Test SetBoolean behavior.""" # Set a true value. self.assertIsNone(self.config.GetBoolean("foo.bar")) for val in (True, 1): self.config.SetBoolean("foo.bar", val) self.assertTrue(self.config.GetBoolean("foo.bar")) # Make sure the value was actually written out. config = self.get_config() self.assertTrue(config.GetBoolean("foo.bar")) self.assertEqual("true", config.GetString("foo.bar")) # Set a false value. for val in (False, 0): self.config.SetBoolean("foo.bar", val) self.assertFalse(self.config.GetBoolean("foo.bar")) # Make sure the value was actually written out. config = self.get_config() self.assertFalse(config.GetBoolean("foo.bar")) self.assertEqual("false", config.GetString("foo.bar")) # Delete the value. self.config.SetBoolean("foo.bar", None) self.assertIsNone(self.config.GetBoolean("foo.bar")) config = self.get_config() self.assertIsNone(config.GetBoolean("foo.bar")) def test_GetSyncAnalysisStateData(self): """Test config entries with a sync state analysis data.""" superproject_logging_data = {} superproject_logging_data["test"] = False options = type("options", (object,), {})() options.verbose = "true" options.mp_update = "false" TESTS = ( ("superproject.test", "false"), ("options.verbose", "true"), ("options.mpupdate", "false"), ("main.version", "1"), ) self.config.UpdateSyncAnalysisState(options, superproject_logging_data) sync_data = self.config.GetSyncAnalysisStateData() for key, value in TESTS: self.assertEqual( sync_data[f"{git_config.SYNC_STATE_PREFIX}{key}"], value ) self.assertTrue( sync_data[f"{git_config.SYNC_STATE_PREFIX}main.synctime"] )