# Copyright (C) 2010 Chris Jerdonek (cjerdonek@webkit.org) # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE # DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. """Unit tests for main.py.""" import os import unittest from main import change_directory from webkitpy.style_references import LogTesting class ChangeDirectoryTest(unittest.TestCase): """Tests change_directory().""" _original_directory = "/original" _checkout_root = "/WebKit" class _MockOs(object): """A mock os module for unit testing.""" def __init__(self, test_case): self._test_case = test_case self._current_directory = \ ChangeDirectoryTest._original_directory def chdir(self, current_directory): self._current_directory = current_directory def assertCurrentDirectory(self, expected_directory): self._test_case.assertEquals(expected_directory, self._current_directory) def setUp(self): self._log = LogTesting.setUp(self) self._mock_os = self._MockOs(self) def tearDown(self): self._log.tearDown() # This method is a convenient wrapper for change_working_directory() that # passes the mock_os for this unit testing class. def _change_directory(self, paths, checkout_root): return change_directory(paths=paths, checkout_root=checkout_root, mock_os=self._mock_os) def _assert_result(self, actual_return_value, expected_return_value, expected_log_messages, expected_current_directory): self.assertEquals(actual_return_value, expected_return_value) self._log.assertMessages(expected_log_messages) self._mock_os.assertCurrentDirectory(expected_current_directory) def test_checkout_root_none_paths_none(self): self.assertRaises(Exception, self._change_directory, checkout_root=None, paths=None) self._log.assertMessages([]) self._mock_os.assertCurrentDirectory(self._original_directory) def test_checkout_root_none(self): paths = self._change_directory(checkout_root=None, paths=["path1"]) log_messages = [ """WARNING: WebKit checkout root not found: Path-dependent style checks may not work correctly. See the help documentation for more info. """] self._assert_result(paths, ["path1"], log_messages, self._original_directory) def test_paths_none(self): paths = self._change_directory(checkout_root=self._checkout_root, paths=None) self._assert_result(paths, None, [], self._checkout_root) def test_paths_convertible(self): paths=["/WebKit/foo1.txt", "/WebKit/foo2.txt"] paths = self._change_directory(checkout_root=self._checkout_root, paths=paths) self._assert_result(paths, ["foo1.txt", "foo2.txt"], [], self._checkout_root) def test_with_scm_paths_unconvertible(self): paths=["/WebKit/foo1.txt", "/outside/foo2.txt"] paths = self._change_directory(checkout_root=self._checkout_root, paths=paths) log_messages = [ """WARNING: Path-dependent style checks may not work correctly: One of the given paths is outside the WebKit checkout of the current working directory: Path: /outside/foo2.txt Checkout root: /WebKit Pass only files below the checkout root to ensure correct results. See the help documentation for more info. """] self._assert_result(paths, paths, log_messages, self._original_directory)