summaryrefslogtreecommitdiffstats
path: root/tests/test_project.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test_project.py')
-rw-r--r--tests/test_project.py74
1 files changed, 74 insertions, 0 deletions
diff --git a/tests/test_project.py b/tests/test_project.py
index 9b289e11..77126dff 100644
--- a/tests/test_project.py
+++ b/tests/test_project.py
@@ -18,11 +18,30 @@
18 18
19from __future__ import print_function 19from __future__ import print_function
20 20
21import contextlib
22import os
23import shutil
24import subprocess
25import tempfile
21import unittest 26import unittest
22 27
28import git_config
23import project 29import project
24 30
25 31
32@contextlib.contextmanager
33def TempGitTree():
34 """Create a new empty git checkout for testing."""
35 # TODO(vapier): Convert this to tempfile.TemporaryDirectory once we drop
36 # Python 2 support entirely.
37 try:
38 tempdir = tempfile.mkdtemp(prefix='repo-tests')
39 subprocess.check_call(['git', 'init'], cwd=tempdir)
40 yield tempdir
41 finally:
42 shutil.rmtree(tempdir)
43
44
26class RepoHookShebang(unittest.TestCase): 45class RepoHookShebang(unittest.TestCase):
27 """Check shebang parsing in RepoHook.""" 46 """Check shebang parsing in RepoHook."""
28 47
@@ -60,3 +79,58 @@ class RepoHookShebang(unittest.TestCase):
60 for shebang, interp in DATA: 79 for shebang, interp in DATA:
61 self.assertEqual(project.RepoHook._ExtractInterpFromShebang(shebang), 80 self.assertEqual(project.RepoHook._ExtractInterpFromShebang(shebang),
62 interp) 81 interp)
82
83
84class FakeProject(object):
85 """A fake for Project for basic functionality."""
86
87 def __init__(self, worktree):
88 self.worktree = worktree
89 self.gitdir = os.path.join(worktree, '.git')
90 self.name = 'fakeproject'
91 self.work_git = project.Project._GitGetByExec(
92 self, bare=False, gitdir=self.gitdir)
93 self.bare_git = project.Project._GitGetByExec(
94 self, bare=True, gitdir=self.gitdir)
95 self.config = git_config.GitConfig.ForRepository(gitdir=self.gitdir)
96
97
98class ReviewableBranchTests(unittest.TestCase):
99 """Check ReviewableBranch behavior."""
100
101 def test_smoke(self):
102 """A quick run through everything."""
103 with TempGitTree() as tempdir:
104 fakeproj = FakeProject(tempdir)
105
106 # Generate some commits.
107 with open(os.path.join(tempdir, 'readme'), 'w') as fp:
108 fp.write('txt')
109 fakeproj.work_git.add('readme')
110 fakeproj.work_git.commit('-mAdd file')
111 fakeproj.work_git.checkout('-b', 'work')
112 fakeproj.work_git.rm('-f', 'readme')
113 fakeproj.work_git.commit('-mDel file')
114
115 # Start off with the normal details.
116 rb = project.ReviewableBranch(
117 fakeproj, fakeproj.config.GetBranch('work'), 'master')
118 self.assertEqual('work', rb.name)
119 self.assertEqual(1, len(rb.commits))
120 self.assertIn('Del file', rb.commits[0])
121 d = rb.unabbrev_commits
122 self.assertEqual(1, len(d))
123 short, long = next(iter(d.items()))
124 self.assertTrue(long.startswith(short))
125 self.assertTrue(rb.base_exists)
126 # Hard to assert anything useful about this.
127 self.assertTrue(rb.date)
128
129 # Now delete the tracking branch!
130 fakeproj.work_git.branch('-D', 'master')
131 rb = project.ReviewableBranch(
132 fakeproj, fakeproj.config.GetBranch('work'), 'master')
133 self.assertEqual(0, len(rb.commits))
134 self.assertFalse(rb.base_exists)
135 # Hard to assert anything useful about this.
136 self.assertTrue(rb.date)