123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213 |
- # -*- coding: utf-8 -*-
- """
- (c) 2016-2017 - Copyright Red Hat Inc
- Authors:
- Pierre-Yves Chibon <pingou@pingoured.fr>
- """
- __requires__ = ['SQLAlchemy >= 0.8']
- import pkg_resources
- import datetime
- import json
- import unittest
- import shutil
- import sys
- import tempfile
- import os
- import pygit2
- from mock import patch
- sys.path.insert(0, os.path.join(os.path.dirname(
- os.path.abspath(__file__)), '..'))
- import pagure.lib
- import tests
- from pagure.lib.repo import PagureRepo
- class PagureFlaskRepoOldUrltests(tests.Modeltests):
- """ Tests for flask app controller of pagure """
- def setUp(self):
- """ Set up the environnment, ran before every tests. """
- super(PagureFlaskRepoOldUrltests, self).setUp()
- pagure.APP.config['TESTING'] = True
- pagure.SESSION = self.session
- pagure.ui.SESSION = self.session
- pagure.ui.app.SESSION = self.session
- pagure.ui.filters.SESSION = self.session
- pagure.ui.repo.SESSION = self.session
- pagure.APP.config['OLD_VIEW_COMMIT_ENABLED'] = True
- pagure.APP.config['EMAIL_SEND'] = False
- pagure.APP.config['UPLOAD_FOLDER_PATH'] = os.path.join(
- self.path, 'releases')
- self.app = pagure.APP.test_client()
- def tearDown(self):
- """ Tear down the environnment, after every tests. """
- super(PagureFlaskRepoOldUrltests, self).tearDown()
- pagure.APP.config['EMAIL_SEND'] = False
- pagure.APP.config['OLD_VIEW_COMMIT_ENABLED'] = False
- def test_view_commit_old(self):
- """ Test the view_commit_old endpoint. """
- tests.create_projects(self.session)
- tests.create_projects_git(os.path.join(self.path, 'repos'), bare=True)
- # Add a README to the git repo - First commit
- tests.add_readme_git_repo(os.path.join(self.path, 'repos', 'test.git'))
- repo = pygit2.Repository(os.path.join(self.path, 'repos', 'test.git'))
- commit = repo.revparse_single('HEAD')
- # View first commit
- output = self.app.get('/test/%s' % commit.oid.hex)
- self.assertEqual(output.status_code, 302)
- output = self.app.get(
- '/test/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 200)
- self.assertTrue(
- '<div class="list-group" id="diff_list" style="display:none;">'
- in output.data)
- self.assertTrue(' Merged by Alice Author\n' in output.data)
- self.assertTrue(' Committed by Cecil Committer\n' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px">' +
- ' 2 </span><span style="color: #00A000; background-color: ' +
- '#ddffdd">+ Pagure</span>' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px">' +
- ' 3 </span><span style="color: #00A000; background-color: ' +
- '#ddffdd">+ ======</span>' in output.data)
- self.app = pagure.APP.test_client()
- # View first commit - with the old URL scheme
- output = self.app.get(
- '/test/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 200)
- self.assertTrue(
- '<div class="list-group" id="diff_list" style="display:none;">'
- in output.data)
- self.assertTrue(' Merged by Alice Author\n' in output.data)
- self.assertTrue(' Committed by Cecil Committer\n' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px"> 2' +
- ' </span><span style="color: #00A000; background-color: #ddffdd">' +
- '+ Pagure</span>' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px">' +
- ' 3 </span><span style="color: #00A000; background-color: ' +
- '#ddffdd">+ ======</span>' in output.data)
- # Add some content to the git repo
- tests.add_content_git_repo(os.path.join(self.path, 'repos',
- 'test.git'))
- repo = pygit2.Repository(os.path.join(self.path, 'repos', 'test.git'))
- commit = repo.revparse_single('HEAD')
- # View another commit
- output = self.app.get(
- '/test/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 200)
- self.assertTrue(
- '<div class="list-group" id="diff_list" style="display:none;">'
- in output.data)
- self.assertTrue(' Authored by Alice Author\n' in output.data)
- self.assertTrue(' Committed by Cecil Committer\n' in output.data)
- self.assertTrue(
- # new version of pygments
- '<div class="highlight" style="background: #f8f8f8"><pre style' +
- '="line-height: 125%"><span></span><span style="background-color' +
- ': #f0f0f0; padding: 0 5px 0 5px">1 </span><span style="color: ' +
- '#800080; font-weight: bold">@@ -0,0 +1,3 @@</span>' in
- output.data
- or
- # old version of pygments
- '<div class="highlight" style="background: #f8f8f8">' +
- '<pre style="line-height: 125%">' +
- '<span style="color: #800080; font-weight: bold">' +
- '@@ -0,0 +1,3 @@</span>' in output.data)
- # Add a fork of a fork
- item = pagure.lib.model.Project(
- user_id=1, # pingou
- name='test3',
- description='test project #3',
- is_fork=True,
- parent_id=1,
- hook_token='aaabbbkkk',
- )
- self.session.add(item)
- self.session.commit()
- forkedgit = os.path.join(
- self.path, 'repos', 'forks', 'pingou', 'test3.git')
- tests.add_content_git_repo(forkedgit)
- tests.add_readme_git_repo(forkedgit)
- repo = pygit2.Repository(forkedgit)
- commit = repo.revparse_single('HEAD')
- # Commit does not exist in anothe repo :)
- output = self.app.get(
- '/test/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 404)
- # View commit of fork
- output = self.app.get(
- '/fork/pingou/test3/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 200)
- self.assertTrue(
- '<div class="list-group" id="diff_list" style="display:none;">'
- in output.data)
- self.assertTrue(' Authored by Alice Author\n' in output.data)
- self.assertTrue(' Committed by Cecil Committer\n' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px"> 2' +
- ' </span><span style="color: #00A000; background-color: #ddffdd">' +
- '+ Pagure</span>' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px"> 3' +
- ' </span><span style="color: #00A000; background-color: #ddffdd">' +
- '+ ======</span>' in output.data)
- # View commit of fork - With the old URL scheme
- output = self.app.get(
- '/fork/pingou/test3/%s' % commit.oid.hex, follow_redirects=True)
- self.assertEqual(output.status_code, 200)
- self.assertTrue(
- '<div class="list-group" id="diff_list" style="display:none;">'
- in output.data)
- self.assertTrue(' Authored by Alice Author\n' in output.data)
- self.assertTrue(' Committed by Cecil Committer\n' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px"> 2' +
- ' </span><span style="color: #00A000; background-color: #ddffdd">' +
- '+ Pagure</span>' in output.data)
- self.assertTrue(
- '<span style="background-color: #f0f0f0; padding: 0 5px 0 5px"> 3' +
- ' </span><span style="color: #00A000; background-color: #ddffdd">' +
- '+ ======</span>' in output.data)
- # Try the old URL scheme with a short hash
- output = self.app.get(
- '/fork/pingou/test3/%s' % commit.oid.hex[:10],
- follow_redirects=True)
- self.assertEqual(output.status_code, 404)
- self.assertIn('<p>Project not found</p>', output.data)
- if __name__ == '__main__':
- unittest.main(verbosity=2)
|