Example #1
0
 def test_repo_get_log(self):
     factory = RepoFactory(self.repo_store, num_commits=4)
     factory.build()
     commits_from = factory.commits[2].hex
     resp = self.app.get('/repo/{}/log/{}'.format(
         self.repo_path, commits_from))
     self.assertEqual(3, len(resp.json))
Example #2
0
 def test_repo_detect_merges_missing_target(self):
     """A non-existent target OID returns HTTP 404."""
     factory = RepoFactory(self.repo_store)
     resp = self.app.post_json('/repo/{}/detect-merges/{}'.format(
         self.repo_path, factory.nonexistent_oid()),
         {'sources': []}, expect_errors=True)
     self.assertEqual(404, resp.status_code)
Example #3
0
 def test_repo_get_non_commit(self):
     """Trying to get a non-commit returns HTTP 404."""
     factory = RepoFactory(self.repo_store, num_commits=1)
     factory.build()
     tree_oid = factory.repo[factory.commits[0]].tree.hex
     resp = self.app.get('/repo/{}/commits/{}'.format(
         self.repo_path, tree_oid), expect_errors=True)
     self.assertEqual(404, resp.status_code)
Example #4
0
 def test_repo_get_non_unicode_log(self):
     """Ensure that non-unicode data is discarded."""
     factory = RepoFactory(self.repo_store)
     message = '\xe9\xe9\xe9'  # latin-1
     oid = factory.add_commit(message, 'foo.py')
     resp = self.app.get('/repo/{}/log/{}'.format(self.repo_path, oid))
     self.assertEqual(message.decode('utf-8', 'replace'),
                      resp.json[0]['message'])
Example #5
0
 def test_repo_get_log_with_limit(self):
     """Ensure the commit log can filtered by limit."""
     factory = RepoFactory(self.repo_store, num_commits=10)
     repo = factory.build()
     head = repo.head.target
     resp = self.app.get('/repo/{}/log/{}?limit=5'.format(
         self.repo_path, head))
     self.assertEqual(5, len(resp.json))
Example #6
0
 def test_repo_alternates_objects_shared(self):
     """Ensure objects are shared from alternate repo."""
     factory = RepoFactory(self.repo_path)
     commit_oid = factory.add_commit("foo", "foobar.txt")
     new_repo_path = os.path.join(self.repo_store, uuid.uuid4().hex)
     repo_path_with_alt = store.init_repo(new_repo_path, alternate_repo_paths=[factory.repo.path])
     repo_with_alt = open_repo(repo_path_with_alt)
     self.assertEqual(commit_oid.hex, repo_with_alt.get(commit_oid).hex)
Example #7
0
    def test_repo_diff_merge_empty(self):
        """Ensure that diffing two identical commits returns an empty string
        as the patch, not None."""
        repo = RepoFactory(self.repo_store)
        c1 = repo.add_commit('foo\n', 'blah.txt')

        resp = self.app.get('/repo/{}/compare-merge/{}:{}'.format(
            self.repo_path, c1, c1))
        self.assertEqual('', resp.json_body['patch'])
Example #8
0
    def test_repo_get(self):
        """The GET method on a repository returns its properties."""
        factory = RepoFactory(self.repo_store, num_branches=2, num_commits=1)
        factory.build()
        factory.repo.set_head('refs/heads/branch-0')

        resp = self.app.get('/repo/{}'.format(self.repo_path))
        self.assertEqual(200, resp.status_code)
        self.assertEqual({'default_branch': 'refs/heads/branch-0'}, resp.json)
Example #9
0
    def test_repo_diff_commits(self):
        """Ensure expected commits objects are returned in diff."""
        repo = RepoFactory(self.repo_store)
        c1_oid = repo.add_commit('foo', 'foobar.txt')
        c2_oid = repo.add_commit('bar', 'foobar.txt', parents=[c1_oid])

        path = '/repo/{}/compare/{}..{}'.format(self.repo_path, c1_oid, c2_oid)
        resp = self.app.get(path)
        self.assertIn(c1_oid.hex, resp.json['commits'][0]['sha1'])
        self.assertIn(c2_oid.hex, resp.json['commits'][1]['sha1'])
Example #10
0
    def test_repo_compare_commits(self):
        """Ensure expected changes exist in diff patch."""
        repo = RepoFactory(self.repo_store)
        c1_oid = repo.add_commit('foo', 'foobar.txt')
        c2_oid = repo.add_commit('bar', 'foobar.txt', parents=[c1_oid])

        path = '/repo/{}/compare/{}..{}'.format(self.repo_path, c1_oid, c2_oid)
        resp = self.app.get(path)
        self.assertIn('-foo', resp.body)
        self.assertIn('+bar', resp.body)
Example #11
0
    def test_repo_get_unicode_ref(self):
        factory = RepoFactory(self.repo_store)
        commit_oid = factory.add_commit('foo', 'foobar.txt')
        tag_name = u'☃'.encode('utf-8')
        tag_message = u'☃'.encode('utf-8')
        factory.add_tag(tag_name, tag_message, commit_oid)

        tag = 'refs/tags/{}'.format(tag_name)
        resp = self.get_ref(tag)
        self.assertTrue(tag.decode('utf-8') in resp)
Example #12
0
    def test_repo_get_commit(self):
        factory = RepoFactory(self.repo_store)
        message = 'Computers make me angry.'
        commit_oid = factory.add_commit(message, 'foobar.txt')

        resp = self.app.get('/repo/{}/commits/{}'.format(
            self.repo_path, commit_oid.hex))
        commit_resp = resp.json
        self.assertEqual(commit_oid.hex, commit_resp['sha1'])
        self.assertEqual(message, commit_resp['message'])
Example #13
0
    def test_repo_get_default_branch_missing(self):
        """default_branch is returned even if that branch has been deleted."""
        factory = RepoFactory(self.repo_store, num_branches=2, num_commits=1)
        factory.build()
        factory.repo.set_head('refs/heads/branch-0')
        factory.repo.lookup_reference('refs/heads/branch-0').delete()

        resp = self.app.get('/repo/{}'.format(self.repo_path))
        self.assertEqual(200, resp.status_code)
        self.assertEqual({'default_branch': 'refs/heads/branch-0'}, resp.json)
Example #14
0
    def test_repo_get_commit_collection(self):
        """Ensure commits can be returned in bulk."""
        factory = RepoFactory(self.repo_store, num_commits=10)
        factory.build()
        bulk_commits = {'commits': [c.hex for c in factory.commits[0::2]]}

        resp = self.app.post_json('/repo/{}/commits'.format(
            self.repo_path), bulk_commits)
        self.assertEqual(5, len(resp.json))
        self.assertEqual(bulk_commits['commits'][0], resp.json[0]['sha1'])
Example #15
0
 def test_repo_get_log_with_stop(self):
     """Ensure the commit log can be filtered by a stop commit."""
     factory = RepoFactory(self.repo_store, num_commits=10)
     repo = factory.build()
     stop_commit = factory.commits[4]
     excluded_commit = factory.commits[5]
     head = repo.head.target
     resp = self.app.get('/repo/{}/log/{}?stop={}'.format(
         self.repo_path, head, stop_commit))
     self.assertEqual(5, len(resp.json))
     self.assertNotIn(excluded_commit, resp.json)
Example #16
0
    def test_repo_diff_non_unicode_commits(self):
        """Ensure non utf-8 chars are handled but stripped from diff."""
        factory = RepoFactory(self.repo_store)
        message = 'not particularly sensible latin-1: \xe9\xe9\xe9.'
        oid = factory.add_commit(message, 'foo.py')
        oid2 = factory.add_commit('a sensible commit message', 'foo.py', [oid])

        resp = self.app.get('/repo/{}/compare/{}..{}'.format(
            self.repo_path, oid, oid2))
        self.assertEqual(resp.json['commits'][0]['message'],
                         message.decode('utf-8', 'replace'))
Example #17
0
    def test_ignore_non_unicode_refs(self):
        """Ensure non-unicode refs are dropped from ref collection."""
        factory = RepoFactory(self.repo_store)
        commit_oid = factory.add_commit('foo', 'foobar.txt')
        tag = '\xe9\xe9\xe9'  # latin-1
        tag_message = 'tag message'
        factory.add_tag(tag, tag_message, commit_oid)

        resp = self.app.get('/repo/{}/refs'.format(self.repo_path))
        refs = resp.json
        self.assertEqual(1, len(refs.keys()))
Example #18
0
 def test_repo_detect_merges_missing_source(self):
     """A non-existent source commit is ignored."""
     factory = RepoFactory(self.repo_store)
     # A---B
     a = factory.add_commit('a\n', 'file')
     b = factory.add_commit('b\n', 'file', parents=[a])
     resp = self.app.post_json('/repo/{}/detect-merges/{}'.format(
         self.repo_path, b),
         {'sources': [factory.nonexistent_oid()]})
     self.assertEqual(200, resp.status_code)
     self.assertEqual({}, resp.json)
Example #19
0
 def test_repo_repack_verify_pack(self):
     """Ensure commit exists in pack."""
     factory = RepoFactory(self.repo_store)
     oid = factory.add_commit('foo', 'foobar.txt')
     resp = self.app.post_json('/repo/{}/repack'.format(self.repo_path),
                               {'prune': True, 'single': True})
     for filename in factory.packs:
         pack = os.path.join(factory.pack_dir, filename)
     out = subprocess.check_output(['git', 'verify-pack', pack, '-v'])
     self.assertEqual(200, resp.status_code)
     self.assertIn(oid.hex, out)
Example #20
0
    def test_allow_unicode_refs(self):
        """Ensure unicode refs are included in ref collection."""
        factory = RepoFactory(self.repo_store)
        commit_oid = factory.add_commit('foo', 'foobar.txt')
        tag = u'おいしいイカ'.encode('utf-8')
        tag_message = u'かわいい タコ'.encode('utf-8')
        factory.add_tag(tag, tag_message, commit_oid)

        resp = self.app.get('/repo/{}/refs'.format(self.repo_path))
        refs = resp.json
        self.assertEqual(2, len(refs.keys()))
Example #21
0
    def test_repo_patch_default_branch(self):
        """A repository's default branch ("HEAD") can be changed."""
        factory = RepoFactory(self.repo_store, num_branches=2, num_commits=1)
        factory.build()
        factory.repo.set_head('refs/heads/branch-0')
        self.assertReferencesEqual(factory.repo, 'refs/heads/branch-0', 'HEAD')

        resp = self.app.patch_json(
            '/repo/{}'.format(self.repo_path),
            {'default_branch': 'refs/heads/branch-1'})
        self.assertEqual(204, resp.status_code)
        self.assertReferencesEqual(factory.repo, 'refs/heads/branch-1', 'HEAD')
Example #22
0
    def test_repo_get_unicode_log(self):
        factory = RepoFactory(self.repo_store)
        message = u'나는 김치 사랑'.encode('utf-8')
        message2 = u'(╯°□°)╯︵ ┻━┻'.encode('utf-8')
        oid = factory.add_commit(message, '자장면/짜장면.py')
        oid2 = factory.add_commit(message2, '엄마야!.js', [oid])

        resp = self.app.get('/repo/{}/log/{}'.format(self.repo_path, oid2))
        self.assertEqual(message2.decode('utf-8', 'replace'),
                         resp.json[0]['message'])
        self.assertEqual(message.decode('utf-8', 'replace'),
                         resp.json[1]['message'])
Example #23
0
    def test_cross_repo_diff_invalid_commit(self):
        """Cross repo diff with an invalid commit returns HTTP 404."""
        factory = RepoFactory(self.repo_store)
        c1 = factory.add_commit('foo', 'foobar.txt')

        repo2_name = uuid.uuid4().hex
        RepoFactory(
            os.path.join(self.repo_root, repo2_name), clone_from=factory)
        c2 = factory.add_commit('bar', 'foobar.txt', parents=[c1])

        resp = self.app.get('/repo/{}:{}/diff/{}:{}'.format(
            self.repo_path, repo2_name, c2, 'invalid'), expect_errors=True)
        self.assertEqual(404, resp.status_code)
Example #24
0
 def test_repo_get_log_signatures(self):
     """Ensure signatures are correct."""
     factory = RepoFactory(self.repo_store)
     committer = factory.makeSignature(u'村上 春樹'.encode('utf-8'),
                                       u'tsukuru@猫の町.co.jp'.encode('utf-8'),
                                       encoding='utf-8')
     author = factory.makeSignature(
         u'Владимир Владимирович Набоков'.encode('utf-8'),
         u'Набоко@zembla.ru'.encode('utf-8'), encoding='utf-8')
     oid = factory.add_commit('Obfuscate colophon.', 'path.foo',
                              author=author, committer=committer)
     resp = self.app.get('/repo/{}/log/{}'.format(self.repo_path, oid))
     self.assertEqual(author.name, resp.json[0]['author']['name'])
Example #25
0
    def test_cross_repo_merge_diff(self):
        """Merge diff can be requested across 2 repositories."""
        factory = RepoFactory(self.repo_store)
        c1 = factory.add_commit('foo', 'foobar.txt')

        repo2_name = uuid.uuid4().hex
        factory2 = RepoFactory(
            os.path.join(self.repo_root, repo2_name), clone_from=factory)
        c2 = factory.add_commit('bar', 'foobar.txt', parents=[c1])
        c3 = factory2.add_commit('baz', 'foobar.txt', parents=[c1])

        resp = self.app.get('/repo/{}:{}/compare-merge/{}:{}'.format(
            self.repo_path, repo2_name, c2, c3))
        self.assertIn('-bar', resp.json['patch'])
Example #26
0
 def test_repo_detect_merges_unmerged(self):
     """An unmerged commit is not returned."""
     factory = RepoFactory(self.repo_store)
     # A---B
     #  \
     #   C
     a = factory.add_commit('a\n', 'file')
     b = factory.add_commit('b\n', 'file', parents=[a])
     c = factory.add_commit('c\n', 'file', parents=[a])
     resp = self.app.post_json('/repo/{}/detect-merges/{}'.format(
         self.repo_path, b),
         {'sources': [c.hex]})
     self.assertEqual(200, resp.status_code)
     self.assertEqual({}, resp.json)
Example #27
0
    def test_repo_diff_unicode_commits(self):
        """Ensure expected utf-8 commits objects are returned in diff."""
        factory = RepoFactory(self.repo_store)
        message = u'屋漏偏逢连夜雨'.encode('utf-8')
        message2 = u'说曹操,曹操到'.encode('utf-8')
        oid = factory.add_commit(message, 'foo.py')
        oid2 = factory.add_commit(message2, 'bar.py', [oid])

        resp = self.app.get('/repo/{}/compare/{}..{}'.format(
            self.repo_path, oid, oid2))
        self.assertEqual(resp.json['commits'][0]['message'],
                         message.decode('utf-8'))
        self.assertEqual(resp.json['commits'][1]['message'],
                         message2.decode('utf-8'))
Example #28
0
 def test_repo_detect_merges_pulled(self):
     """Commits that were pulled (fast-forward) are their own merge
     points."""
     factory = RepoFactory(self.repo_store)
     # A---B---C
     a = factory.add_commit('a\n', 'file')
     b = factory.add_commit('b\n', 'file', parents=[a])
     c = factory.add_commit('c\n', 'file', parents=[b])
     # The start commit would never be the source of a merge proposal,
     # but include it anyway to test boundary conditions.
     resp = self.app.post_json('/repo/{}/detect-merges/{}'.format(
         self.repo_path, c),
         {'sources': [a.hex, b.hex, c.hex]})
     self.assertEqual(200, resp.status_code)
     self.assertEqual({a.hex: a.hex, b.hex: b.hex, c.hex: c.hex}, resp.json)
Example #29
0
    def test_repo_get_commit_collection_ignores_errors(self):
        """Non-existent OIDs and non-commits in a collection are ignored."""
        factory = RepoFactory(self.repo_store, num_commits=10)
        factory.build()
        bulk_commits = {
            'commits': [
                factory.commits[0].hex,
                factory.repo[factory.commits[0]].tree.hex,
                factory.nonexistent_oid(),
                ],
            }

        resp = self.app.post_json(
            '/repo/{}/commits'.format(self.repo_path), bulk_commits)
        self.assertEqual(1, len(resp.json))
        self.assertEqual(bulk_commits['commits'][0], resp.json[0]['sha1'])
Example #30
0
    def test_repo_init_with_clone(self):
        """Repo can be initialised with optional clone."""
        factory = RepoFactory(self.repo_store, num_commits=2)
        factory.build()
        new_repo_path = uuid.uuid1().hex
        resp = self.app.post_json('/repo', {'repo_path': new_repo_path,
                                            'clone_from': self.repo_path,
                                            'clone_refs': True})
        repo1_revlist = get_revlist(factory.repo)
        clone_from = resp.json['repo_url'].split('/')[-1]
        repo2 = open_repo(os.path.join(self.repo_root, clone_from))
        repo2_revlist = get_revlist(repo2)

        self.assertEqual(repo1_revlist, repo2_revlist)
        self.assertEqual(200, resp.status_code)
        self.assertIn(new_repo_path, resp.json['repo_url'])