# 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('section.%s' % (key,))) 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' TESTS = ( ('superproject.test', 'false'), ('options.verbose', 'true'), ('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(len(sync_data[f'{git_config.SYNC_STATE_PREFIX}main.synctime'])) 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')) if __name__ == '__main__': unittest.main()