summaryrefslogtreecommitdiff
path: root/test/git/test_repo.py
diff options
context:
space:
mode:
authorKai Lautaportti <kai.lautaportti@hexagonit.fi>2008-09-12 22:03:56 +0300
committerKai Lautaportti <kai.lautaportti@hexagonit.fi>2008-09-12 22:03:56 +0300
commit125b4875b5035dc4f6bad4351651a4236b82baeb (patch)
tree602068aa79e32eb575b6e65a2f66ba970fa46f52 /test/git/test_repo.py
parent3131d1a5295508f583ae22788a1065144bec3cee (diff)
downloadgitpython-125b4875b5035dc4f6bad4351651a4236b82baeb.tar.gz
Added a read-only property Repo.is_dirty which reflects the status of the
working directory. A working directory is dirty if it has any uncommitted changes (in the working directory or in the index). Bare repositories are by nature always clean.
Diffstat (limited to 'test/git/test_repo.py')
-rw-r--r--test/git/test_repo.py18
1 files changed, 18 insertions, 0 deletions
diff --git a/test/git/test_repo.py b/test/git/test_repo.py
index 7550e1d6..4a5ee8ac 100644
--- a/test/git/test_repo.py
+++ b/test/git/test_repo.py
@@ -296,3 +296,21 @@ class TestRepo(object):
# # Commit.expects(:find_all).with(other_repo, ref, :max_count => 1).returns([stub()])
# delta_commits = self.repo.commit_deltas_from(other_repo)
# assert_equal(3, len(delta_commits))
+
+ def test_is_dirty_with_bare_repository(self):
+ self.repo.bare = True
+ assert_false(self.repo.is_dirty)
+
+ @patch(Git, '_call_process')
+ def test_is_dirty_with_clean_working_dir(self, git):
+ self.repo.bare = False
+ git.return_value = ''
+ assert_false(self.repo.is_dirty)
+ assert_equal(git.call_args, (('diff', 'HEAD'), {}))
+
+ @patch(Git, '_call_process')
+ def test_is_dirty_with_dirty_working_dir(self, git):
+ self.repo.bare = False
+ git.return_value = '''-aaa\n+bbb'''
+ assert_true(self.repo.is_dirty)
+ assert_equal(git.call_args, (('diff', 'HEAD'), {}))