|
Pierre-Yves Chibon |
a945ba |
# -*- coding: utf-8 -*-
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
"""
|
|
Pierre-Yves Chibon |
baaf54 |
(c) 2015-2018 - Copyright Red Hat Inc
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
Authors:
|
|
Pierre-Yves Chibon |
a945ba |
Pierre-Yves Chibon <pingou@pingoured.fr></pingou@pingoured.fr>
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
"""
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
67d1cc |
from __future__ import unicode_literals, absolute_import
|
|
Aurélien Bompard |
626417 |
|
|
Pierre-Yves Chibon |
b63f28 |
import datetime
|
|
Pierre-Yves Chibon |
b63f28 |
import os
|
|
Pierre-Yves Chibon |
a945ba |
import shutil
|
|
Pierre-Yves Chibon |
a945ba |
import sys
|
|
Clement Verna |
469e2c |
import tempfile
|
|
Pierre-Yves Chibon |
b63f28 |
import time
|
|
Pierre-Yves Chibon |
b63f28 |
import unittest
|
|
Pierre-Yves Chibon |
b63f28 |
|
|
Pierre-Yves Chibon |
024459 |
import pygit2
|
|
Aurélien Bompard |
626417 |
import six
|
|
Pierre-Yves Chibon |
145998 |
from mock import patch, MagicMock
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
sys.path.insert(0, os.path.join(os.path.dirname(
|
|
Pierre-Yves Chibon |
a945ba |
os.path.abspath(__file__)), '..'))
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
fe5017 |
import pagure.lib.git
|
|
Pierre-Yves Chibon |
a945ba |
import tests
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
bda7f1 |
from pagure.lib.repo import PagureRepo
|
|
Pierre-Yves Chibon |
bda7f1 |
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
fe5017 |
class PagureLibGittests(tests.Modeltests):
|
|
Pierre-Yves Chibon |
fe5017 |
""" Tests for pagure.lib.git """
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
def test_write_gitolite_acls(self):
|
|
Vivek Anand |
ffcb0c |
""" Test the write_gitolite_acls function of pagure.lib.git.
|
|
Vivek Anand |
ffcb0c |
when the new uesr is an made an admin """
|
|
Pierre-Yves Chibon |
a945ba |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
ead0df |
# Add an user to a project
|
|
Vivek Anand |
ffcb0c |
# The user will be an admin of the project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Pierre-Yves Chibon |
ead0df |
session=self.session,
|
|
Pierre-Yves Chibon |
ead0df |
project=repo,
|
|
Pierre-Yves Chibon |
a5a9ad |
new_user='foo',
|
|
Pierre-Yves Chibon |
a5a9ad |
user='pingou',
|
|
Pierre-Yves Chibon |
ead0df |
)
|
|
Pierre-Yves Chibon |
ead0df |
self.session.commit()
|
|
Pierre-Yves Chibon |
ead0df |
self.assertEqual(msg, 'User added')
|
|
Pierre-Yves Chibon |
ead0df |
# Add a forked project
|
|
Pierre-Yves Chibon |
fe5017 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
ead0df |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
ead0df |
name='test3',
|
|
Pierre-Yves Chibon |
ead0df |
description='test project #2',
|
|
farhaanbukhsh |
907098 |
is_fork=True,
|
|
Pierre-Yves Chibon |
e2259d |
parent_id=1,
|
|
Pierre-Yves Chibon |
e2259d |
hook_token='aaabbbvvv',
|
|
Pierre-Yves Chibon |
ead0df |
)
|
|
Pierre-Yves Chibon |
ead0df |
self.session.add(item)
|
|
Pierre-Yves Chibon |
ead0df |
self.session.commit()
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Jeremy Cline |
20109f |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(
|
|
Pierre-Yves Chibon |
274e60 |
self.session, configfile=outputconf, project=-1)
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
a945ba |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
a945ba |
data = stream.read()
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo test
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = foo
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
ead0df |
repo docs/test
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = foo
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
ead0df |
repo tickets/test
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = foo
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
a6701e |
repo requests/test
|
|
Pierre-Yves Chibon |
a6701e |
RW+ = pingou
|
|
Pierre-Yves Chibon |
a6701e |
RW+ = foo
|
|
Pierre-Yves Chibon |
a6701e |
|
|
Pierre-Yves Chibon |
ead0df |
repo test2
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
ead0df |
repo docs/test2
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
ead0df |
repo tickets/test2
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
a6701e |
repo requests/test2
|
|
Pierre-Yves Chibon |
a6701e |
RW+ = pingou
|
|
Pierre-Yves Chibon |
a6701e |
|
|
clime |
afed57 |
repo somenamespace/test3
|
|
clime |
afed57 |
R = @all
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo docs/somenamespace/test3
|
|
clime |
afed57 |
R = @all
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo tickets/somenamespace/test3
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo requests/somenamespace/test3
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
Pierre-Yves Chibon |
ead0df |
repo forks/pingou/test3
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
59a1eb |
repo docs/forks/pingou/test3
|
|
Pierre-Yves Chibon |
ead0df |
R = @all
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
59a1eb |
repo tickets/forks/pingou/test3
|
|
Pierre-Yves Chibon |
a6701e |
RW+ = pingou
|
|
Pierre-Yves Chibon |
a6701e |
|
|
Pierre-Yves Chibon |
59a1eb |
repo requests/forks/pingou/test3
|
|
Pierre-Yves Chibon |
ead0df |
RW+ = pingou
|
|
Pierre-Yves Chibon |
ead0df |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
ead0df |
"""
|
|
Pierre-Yves Chibon |
59a1eb |
#print data
|
|
Pierre-Yves Chibon |
ead0df |
self.assertEqual(data, exp)
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
22e4bd |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
22e4bd |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
d1fe6f |
def test_write_gitolite_acls_preconf(self):
|
|
Pierre-Yves Chibon |
d1fe6f |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Pierre-Yves Chibon |
d1fe6f |
a preconf set """
|
|
Pierre-Yves Chibon |
d1fe6f |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
d1fe6f |
preconf = os.path.join(self.path, 'header_gitolite')
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(preconf, 'w') as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
stream.write('# this is a header that is manually added')
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
145998 |
helper.write_gitolite_acls(
|
|
Pierre-Yves Chibon |
d1fe6f |
self.session,
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf,
|
|
Pierre-Yves Chibon |
274e60 |
project=-1,
|
|
Pierre-Yves Chibon |
d1fe6f |
preconf=preconf
|
|
Pierre-Yves Chibon |
d1fe6f |
)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
data = stream.read()
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
exp = """# this is a header that is manually added
|
|
Pierre-Yves Chibon |
ccb160 |
# end of header
|
|
Pierre-Yves Chibon |
d1fe6f |
repo test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
d1fe6f |
"""
|
|
Pierre-Yves Chibon |
d1fe6f |
#print data
|
|
Pierre-Yves Chibon |
ccb160 |
self.assertEqual(data.split('\n'), exp.split('\n'))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
def test_write_gitolite_acls_preconf_postconf(self):
|
|
Pierre-Yves Chibon |
d1fe6f |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Pierre-Yves Chibon |
d1fe6f |
a postconf set """
|
|
Pierre-Yves Chibon |
d1fe6f |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
preconf = os.path.join(self.path, 'header_gitolite')
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(preconf, 'w') as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
stream.write('# this is a header that is manually added')
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
postconf = os.path.join(self.path, 'footer_gitolite')
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(postconf, 'w') as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
stream.write('# end of generated configuration')
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
145998 |
helper.write_gitolite_acls(
|
|
Pierre-Yves Chibon |
d1fe6f |
self.session,
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf,
|
|
Pierre-Yves Chibon |
274e60 |
project=-1,
|
|
Pierre-Yves Chibon |
d1fe6f |
preconf=preconf,
|
|
Pierre-Yves Chibon |
d1fe6f |
postconf=postconf
|
|
Pierre-Yves Chibon |
d1fe6f |
)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
data = stream.read()
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
exp = """# this is a header that is manually added
|
|
Pierre-Yves Chibon |
ccb160 |
# end of header
|
|
Pierre-Yves Chibon |
d1fe6f |
repo test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
d1fe6f |
# end of generated configuration
|
|
Pierre-Yves Chibon |
d1fe6f |
"""
|
|
Pierre-Yves Chibon |
d1fe6f |
#print data
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertEqual(data, exp)
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
def test_write_gitolite_acls_postconf(self):
|
|
Pierre-Yves Chibon |
d1fe6f |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Pierre-Yves Chibon |
d1fe6f |
a preconf and a postconf set """
|
|
Pierre-Yves Chibon |
d1fe6f |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
d1fe6f |
postconf = os.path.join(self.path, 'footer_gitolite')
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(postconf, 'w') as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
stream.write('# end of generated configuration')
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
145998 |
helper.write_gitolite_acls(
|
|
Pierre-Yves Chibon |
d1fe6f |
self.session,
|
|
Pierre-Yves Chibon |
d1fe6f |
outputconf,
|
|
Pierre-Yves Chibon |
274e60 |
project=-1,
|
|
Pierre-Yves Chibon |
d1fe6f |
postconf=postconf
|
|
Pierre-Yves Chibon |
d1fe6f |
)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
d1fe6f |
data = stream.read()
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/test2
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo docs/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
R = @all
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo tickets/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
repo requests/somenamespace/test3
|
|
Pierre-Yves Chibon |
d1fe6f |
RW+ = pingou
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
d1fe6f |
# end of generated configuration
|
|
Pierre-Yves Chibon |
d1fe6f |
"""
|
|
Pierre-Yves Chibon |
d1fe6f |
#print data
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertEqual(data, exp)
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Pierre-Yves Chibon |
d1fe6f |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
d1fe6f |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
d1fe6f |
|
|
Patrick Uiterwijk |
faa79d |
def test_write_gitolite_acls_deploykeys(self):
|
|
Patrick Uiterwijk |
faa79d |
""" Test write_gitolite_acls function to add deploy keys. """
|
|
Patrick Uiterwijk |
faa79d |
tests.create_projects(self.session)
|
|
Patrick Uiterwijk |
faa79d |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Patrick Uiterwijk |
faa79d |
# Add two deploy keys (one readonly one push)
|
|
Pierre-Yves Chibon |
930073 |
pingou = pagure.lib.query.get_user(self.session, 'pingou')
|
|
Pierre-Yves Chibon |
930073 |
msg1 = pagure.lib.query.add_sshkey_to_project_or_user(
|
|
Patrick Uiterwijk |
faa79d |
session=self.session,
|
|
Patrick Uiterwijk |
faa79d |
project=repo,
|
|
Patrick Uiterwijk |
faa79d |
ssh_key='ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAAAgQDAzBMSIlvPRaEiLOTVInErkRIw9CzQQcnslDekAn1jFnGf+SNa1acvbTiATbCX71AA03giKrPxPH79dxcC7aDXerc6zRcKjJs6MAL9PrCjnbyxCKXRNNZU5U9X/DLaaL1b3caB+WD6OoorhS3LTEtKPX8xyjOzhf3OQSzNjhJp5Q==',
|
|
Patrick Uiterwijk |
faa79d |
pushaccess=False,
|
|
Patrick Uiterwijk |
9b237b |
creator=pingou
|
|
Patrick Uiterwijk |
faa79d |
)
|
|
Pierre-Yves Chibon |
930073 |
msg2 = pagure.lib.query.add_sshkey_to_project_or_user(
|
|
Patrick Uiterwijk |
faa79d |
session=self.session,
|
|
Patrick Uiterwijk |
faa79d |
project=repo,
|
|
Patrick Uiterwijk |
faa79d |
ssh_key='ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAAAgQC9Xwc2RDzPBhlEDARfHldGjudIVoa04tqT1JVKGQmyllTFz7Rb8CngQL3e7zyNzotnhwYKHdoiLlPkVEiDee4dWMUe48ilqId+FJZQGhyv8fu4BoFdE1AJUVylzmltbLg14VqG5gjTpXgtlrEva9arKwBMHJjRYc8ScaSn3OgyQw==',
|
|
Patrick Uiterwijk |
faa79d |
pushaccess=True,
|
|
Patrick Uiterwijk |
9b237b |
creator=pingou
|
|
Patrick Uiterwijk |
faa79d |
)
|
|
Patrick Uiterwijk |
faa79d |
self.session.commit()
|
|
Patrick Uiterwijk |
9b237b |
self.assertEqual(msg1, 'SSH key added')
|
|
Patrick Uiterwijk |
9b237b |
self.assertEqual(msg2, 'SSH key added')
|
|
Patrick Uiterwijk |
faa79d |
# Add a forked project
|
|
Patrick Uiterwijk |
faa79d |
item = pagure.lib.model.Project(
|
|
Patrick Uiterwijk |
faa79d |
user_id=1, # pingou
|
|
Patrick Uiterwijk |
faa79d |
name='test3',
|
|
Patrick Uiterwijk |
faa79d |
description='test project #2',
|
|
Patrick Uiterwijk |
faa79d |
is_fork=True,
|
|
Patrick Uiterwijk |
faa79d |
parent_id=1,
|
|
Patrick Uiterwijk |
faa79d |
hook_token='aaabbbvvv',
|
|
Patrick Uiterwijk |
faa79d |
)
|
|
Patrick Uiterwijk |
faa79d |
self.session.add(item)
|
|
Patrick Uiterwijk |
faa79d |
self.session.commit()
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Patrick Uiterwijk |
faa79d |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
self.assertTrue(os.path.exists(outputconf))
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
with open(outputconf) as stream:
|
|
Patrick Uiterwijk |
faa79d |
data = stream.read()
|
|
Patrick Uiterwijk |
faa79d |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo test
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
R = deploykey_test_1
|
|
Patrick Uiterwijk |
faa79d |
RW+ = deploykey_test_2
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo docs/test
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
R = deploykey_test_1
|
|
Patrick Uiterwijk |
faa79d |
RW+ = deploykey_test_2
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo tickets/test
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
R = deploykey_test_1
|
|
Patrick Uiterwijk |
faa79d |
RW+ = deploykey_test_2
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo requests/test
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
R = deploykey_test_1
|
|
Patrick Uiterwijk |
faa79d |
RW+ = deploykey_test_2
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo test2
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo docs/test2
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo tickets/test2
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo requests/test2
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo somenamespace/test3
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo docs/somenamespace/test3
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo tickets/somenamespace/test3
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo requests/somenamespace/test3
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo forks/pingou/test3
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo docs/forks/pingou/test3
|
|
Patrick Uiterwijk |
faa79d |
R = @all
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo tickets/forks/pingou/test3
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
repo requests/forks/pingou/test3
|
|
Patrick Uiterwijk |
faa79d |
RW+ = pingou
|
|
Patrick Uiterwijk |
faa79d |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Patrick Uiterwijk |
faa79d |
"""
|
|
Patrick Uiterwijk |
faa79d |
#print data
|
|
Patrick Uiterwijk |
faa79d |
self.assertEqual(data, exp)
|
|
Patrick Uiterwijk |
faa79d |
|
|
Patrick Uiterwijk |
faa79d |
os.unlink(outputconf)
|
|
Patrick Uiterwijk |
faa79d |
self.assertFalse(os.path.exists(outputconf))
|
|
Patrick Uiterwijk |
faa79d |
|
|
Vivek Anand |
2897c2 |
def test_write_gitolite_acls_ticket(self):
|
|
Vivek Anand |
2897c2 |
""" Test the write_gitolite_acls function of pagure.lib.git.
|
|
Vivek Anand |
2897c2 |
when the new uesr is just a ticketer """
|
|
Vivek Anand |
2897c2 |
tests.create_projects(self.session)
|
|
Vivek Anand |
2897c2 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Vivek Anand |
2897c2 |
# Add an user to a project
|
|
Vivek Anand |
2897c2 |
# The user will be an admin of the project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Vivek Anand |
2897c2 |
session=self.session,
|
|
Vivek Anand |
2897c2 |
project=repo,
|
|
Vivek Anand |
2897c2 |
new_user='foo',
|
|
Vivek Anand |
2897c2 |
user='pingou',
|
|
Vivek Anand |
2897c2 |
access='ticket'
|
|
Vivek Anand |
2897c2 |
)
|
|
Vivek Anand |
2897c2 |
self.session.commit()
|
|
Vivek Anand |
2897c2 |
self.assertEqual(msg, 'User added')
|
|
Vivek Anand |
2897c2 |
# Add a forked project
|
|
Vivek Anand |
2897c2 |
item = pagure.lib.model.Project(
|
|
Vivek Anand |
2897c2 |
user_id=1, # pingou
|
|
Vivek Anand |
2897c2 |
name='test3',
|
|
Vivek Anand |
2897c2 |
description='test project #2',
|
|
Vivek Anand |
2897c2 |
is_fork=True,
|
|
Vivek Anand |
2897c2 |
parent_id=1,
|
|
Vivek Anand |
2897c2 |
hook_token='aaabbbvvv',
|
|
Vivek Anand |
2897c2 |
)
|
|
Vivek Anand |
2897c2 |
self.session.add(item)
|
|
Vivek Anand |
2897c2 |
self.session.commit()
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Vivek Anand |
2897c2 |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
self.assertTrue(os.path.exists(outputconf))
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
with open(outputconf) as stream:
|
|
Vivek Anand |
2897c2 |
data = stream.read()
|
|
Vivek Anand |
2897c2 |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo test
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo docs/test
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo tickets/test
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo requests/test
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo test2
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo docs/test2
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo tickets/test2
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo requests/test2
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo somenamespace/test3
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo docs/somenamespace/test3
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo tickets/somenamespace/test3
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo requests/somenamespace/test3
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo forks/pingou/test3
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo docs/forks/pingou/test3
|
|
Vivek Anand |
2897c2 |
R = @all
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo tickets/forks/pingou/test3
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
repo requests/forks/pingou/test3
|
|
Vivek Anand |
2897c2 |
RW+ = pingou
|
|
Vivek Anand |
2897c2 |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Vivek Anand |
2897c2 |
"""
|
|
Vivek Anand |
2897c2 |
#print data
|
|
Vivek Anand |
2897c2 |
self.assertEqual(data, exp)
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
2897c2 |
os.unlink(outputconf)
|
|
Vivek Anand |
2897c2 |
self.assertFalse(os.path.exists(outputconf))
|
|
Vivek Anand |
2897c2 |
|
|
Vivek Anand |
994729 |
def test_write_gitolite_acls_commit(self):
|
|
Vivek Anand |
994729 |
""" Test the write_gitolite_acls function of pagure.lib.git.
|
|
Vivek Anand |
994729 |
when the new uesr is just a committer """
|
|
Vivek Anand |
994729 |
tests.create_projects(self.session)
|
|
Vivek Anand |
994729 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Vivek Anand |
994729 |
# Add an user to a project
|
|
Vivek Anand |
994729 |
# The user will be an admin of the project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Vivek Anand |
994729 |
session=self.session,
|
|
Vivek Anand |
994729 |
project=repo,
|
|
Vivek Anand |
994729 |
new_user='foo',
|
|
Vivek Anand |
994729 |
user='pingou',
|
|
Vivek Anand |
994729 |
access='commit'
|
|
Vivek Anand |
994729 |
)
|
|
Vivek Anand |
994729 |
self.session.commit()
|
|
Vivek Anand |
994729 |
self.assertEqual(msg, 'User added')
|
|
Vivek Anand |
994729 |
# Add a forked project
|
|
Vivek Anand |
994729 |
item = pagure.lib.model.Project(
|
|
Vivek Anand |
994729 |
user_id=1, # pingou
|
|
Vivek Anand |
994729 |
name='test3',
|
|
Vivek Anand |
994729 |
description='test project #2',
|
|
Vivek Anand |
994729 |
is_fork=True,
|
|
Vivek Anand |
994729 |
parent_id=1,
|
|
Vivek Anand |
994729 |
hook_token='aaabbbvvv',
|
|
Vivek Anand |
994729 |
)
|
|
Vivek Anand |
994729 |
self.session.add(item)
|
|
Vivek Anand |
994729 |
self.session.commit()
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Vivek Anand |
994729 |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
self.assertTrue(os.path.exists(outputconf))
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
with open(outputconf) as stream:
|
|
Vivek Anand |
994729 |
data = stream.read()
|
|
Vivek Anand |
994729 |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo test
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
RW+ = foo
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo docs/test
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
RW+ = foo
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo tickets/test
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
RW+ = foo
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo requests/test
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
RW+ = foo
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo test2
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo docs/test2
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo tickets/test2
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo requests/test2
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo somenamespace/test3
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo docs/somenamespace/test3
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo tickets/somenamespace/test3
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo requests/somenamespace/test3
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo forks/pingou/test3
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo docs/forks/pingou/test3
|
|
Vivek Anand |
994729 |
R = @all
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo tickets/forks/pingou/test3
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
repo requests/forks/pingou/test3
|
|
Vivek Anand |
994729 |
RW+ = pingou
|
|
Vivek Anand |
994729 |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Vivek Anand |
994729 |
"""
|
|
Vivek Anand |
994729 |
#print data
|
|
Vivek Anand |
994729 |
self.assertEqual(data, exp)
|
|
Vivek Anand |
994729 |
|
|
Vivek Anand |
994729 |
os.unlink(outputconf)
|
|
Vivek Anand |
994729 |
self.assertFalse(os.path.exists(outputconf))
|
|
Vivek Anand |
994729 |
|
|
Pierre-Yves Chibon |
4fc47a |
def test_write_gitolite_acls_groups(self):
|
|
Pierre-Yves Chibon |
4fc47a |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Vivek Anand |
b5a557 |
groups as admin
|
|
Pierre-Yves Chibon |
4fc47a |
"""
|
|
Pierre-Yves Chibon |
4fc47a |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
6f5851 |
# Add a couple of groups
|
|
Vivek Anand |
b5a557 |
# They would be admins
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Pierre-Yves Chibon |
4fc47a |
self.session,
|
|
Pierre-Yves Chibon |
4fc47a |
group_name='sysadmin',
|
|
Pierre-Yves Chibon |
ce6666 |
display_name='sysadmin group',
|
|
Pierre-Yves Chibon |
ce6666 |
description=None,
|
|
Pierre-Yves Chibon |
4fc47a |
group_type='user',
|
|
Pierre-Yves Chibon |
4fc47a |
user='pingou',
|
|
Pierre-Yves Chibon |
4fc47a |
is_admin=False,
|
|
Pierre-Yves Chibon |
d4d101 |
blacklist=[],
|
|
Pierre-Yves Chibon |
4fc47a |
)
|
|
Pierre-Yves Chibon |
4fc47a |
self.session.commit()
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertEqual(msg, 'User `pingou` added to the group `sysadmin`.')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Pierre-Yves Chibon |
6f5851 |
self.session,
|
|
Pierre-Yves Chibon |
6f5851 |
group_name='devs',
|
|
Pierre-Yves Chibon |
ce6666 |
display_name='devs group',
|
|
Pierre-Yves Chibon |
ce6666 |
description=None,
|
|
Pierre-Yves Chibon |
6f5851 |
group_type='user',
|
|
Pierre-Yves Chibon |
6f5851 |
user='pingou',
|
|
Pierre-Yves Chibon |
6f5851 |
is_admin=False,
|
|
Pierre-Yves Chibon |
d4d101 |
blacklist=[],
|
|
Pierre-Yves Chibon |
6f5851 |
)
|
|
Pierre-Yves Chibon |
6f5851 |
self.session.commit()
|
|
Pierre-Yves Chibon |
6f5851 |
self.assertEqual(msg, 'User `pingou` added to the group `devs`.')
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
6f5851 |
# Associate these groups to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Pierre-Yves Chibon |
4fc47a |
session=self.session,
|
|
Pierre-Yves Chibon |
4fc47a |
project=repo,
|
|
Pierre-Yves Chibon |
4fc47a |
new_group='sysadmin',
|
|
Pierre-Yves Chibon |
4fc47a |
user='pingou',
|
|
Pierre-Yves Chibon |
4fc47a |
)
|
|
Pierre-Yves Chibon |
4fc47a |
self.session.commit()
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertEqual(msg, 'Group added')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Pierre-Yves Chibon |
6f5851 |
session=self.session,
|
|
Pierre-Yves Chibon |
6f5851 |
project=repo,
|
|
Pierre-Yves Chibon |
6f5851 |
new_group='devs',
|
|
Pierre-Yves Chibon |
6f5851 |
user='pingou',
|
|
Pierre-Yves Chibon |
6f5851 |
)
|
|
Pierre-Yves Chibon |
6f5851 |
self.session.commit()
|
|
Pierre-Yves Chibon |
6f5851 |
self.assertEqual(msg, 'Group added')
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
# Add an user to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Pierre-Yves Chibon |
4fc47a |
session=self.session,
|
|
Pierre-Yves Chibon |
4fc47a |
project=repo,
|
|
Pierre-Yves Chibon |
4fc47a |
new_user='foo',
|
|
Pierre-Yves Chibon |
4fc47a |
user='pingou',
|
|
Pierre-Yves Chibon |
4fc47a |
)
|
|
Pierre-Yves Chibon |
4fc47a |
self.session.commit()
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertEqual(msg, 'User added')
|
|
Pierre-Yves Chibon |
4fc47a |
# Add a forked project
|
|
Pierre-Yves Chibon |
4fc47a |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
4fc47a |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
4fc47a |
name='test2',
|
|
Pierre-Yves Chibon |
4fc47a |
description='test project #2',
|
|
farhaanbukhsh |
907098 |
is_fork=True,
|
|
Pierre-Yves Chibon |
4fc47a |
parent_id=1,
|
|
Pierre-Yves Chibon |
4fc47a |
hook_token='aaabbbvvv',
|
|
Pierre-Yves Chibon |
4fc47a |
)
|
|
Pierre-Yves Chibon |
4fc47a |
self.session.add(item)
|
|
Pierre-Yves Chibon |
4fc47a |
self.session.commit()
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Jeremy Cline |
20109f |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
4fc47a |
data = stream.read()
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """@devs = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
@sysadmin = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
# end of groups
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo test
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = foo
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo docs/test
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = foo
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo tickets/test
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = foo
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo requests/test
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = foo
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo test2
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo docs/test2
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo tickets/test2
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
repo requests/test2
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
clime |
afed57 |
repo somenamespace/test3
|
|
clime |
afed57 |
R = @all
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo docs/somenamespace/test3
|
|
clime |
afed57 |
R = @all
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo tickets/somenamespace/test3
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo requests/somenamespace/test3
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo forks/pingou/test2
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo docs/forks/pingou/test2
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo tickets/forks/pingou/test2
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo requests/forks/pingou/test2
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Vivek Anand |
1edd2c |
"""
|
|
Vivek Anand |
1edd2c |
#print data
|
|
Vivek Anand |
1edd2c |
self.assertEqual(data.split('\n'), exp.split('\n'))
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
os.unlink(outputconf)
|
|
Vivek Anand |
1edd2c |
self.assertFalse(os.path.exists(outputconf))
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
def test_write_gitolite_acls_groups_ticket(self):
|
|
Vivek Anand |
1edd2c |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Vivek Anand |
1edd2c |
groups as ticketers
|
|
Vivek Anand |
1edd2c |
"""
|
|
Vivek Anand |
1edd2c |
tests.create_projects(self.session)
|
|
Vivek Anand |
1edd2c |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
# Add a couple of groups
|
|
Vivek Anand |
1edd2c |
# They would be ticketers
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Vivek Anand |
1edd2c |
self.session,
|
|
Vivek Anand |
1edd2c |
group_name='sysadmin',
|
|
Vivek Anand |
1edd2c |
display_name='sysadmin group',
|
|
Vivek Anand |
1edd2c |
description=None,
|
|
Vivek Anand |
1edd2c |
group_type='user',
|
|
Vivek Anand |
1edd2c |
user='pingou',
|
|
Vivek Anand |
1edd2c |
is_admin=False,
|
|
Vivek Anand |
1edd2c |
blacklist=[],
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
self.assertEqual(msg, 'User `pingou` added to the group `sysadmin`.')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Vivek Anand |
1edd2c |
self.session,
|
|
Vivek Anand |
1edd2c |
group_name='devs',
|
|
Vivek Anand |
1edd2c |
display_name='devs group',
|
|
Vivek Anand |
1edd2c |
description=None,
|
|
Vivek Anand |
1edd2c |
group_type='user',
|
|
Vivek Anand |
1edd2c |
user='pingou',
|
|
Vivek Anand |
1edd2c |
is_admin=False,
|
|
Vivek Anand |
1edd2c |
blacklist=[],
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
self.assertEqual(msg, 'User `pingou` added to the group `devs`.')
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
# Associate these groups to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Vivek Anand |
1edd2c |
session=self.session,
|
|
Vivek Anand |
1edd2c |
project=repo,
|
|
Vivek Anand |
1edd2c |
new_group='sysadmin',
|
|
Vivek Anand |
1edd2c |
user='pingou',
|
|
Vivek Anand |
1edd2c |
access='ticket',
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
self.assertEqual(msg, 'Group added')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Vivek Anand |
1edd2c |
session=self.session,
|
|
Vivek Anand |
1edd2c |
project=repo,
|
|
Vivek Anand |
1edd2c |
new_group='devs',
|
|
Vivek Anand |
1edd2c |
user='pingou',
|
|
Vivek Anand |
1edd2c |
access='ticket'
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
self.assertEqual(msg, 'Group added')
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
# Add an user to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Vivek Anand |
1edd2c |
session=self.session,
|
|
Vivek Anand |
1edd2c |
project=repo,
|
|
Vivek Anand |
1edd2c |
new_user='foo',
|
|
Vivek Anand |
1edd2c |
user='pingou',
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
self.assertEqual(msg, 'User added')
|
|
Vivek Anand |
1edd2c |
# Add a forked project
|
|
Vivek Anand |
1edd2c |
item = pagure.lib.model.Project(
|
|
Vivek Anand |
1edd2c |
user_id=1, # pingou
|
|
Vivek Anand |
1edd2c |
name='test2',
|
|
Vivek Anand |
1edd2c |
description='test project #2',
|
|
Vivek Anand |
1edd2c |
is_fork=True,
|
|
Vivek Anand |
1edd2c |
parent_id=1,
|
|
Vivek Anand |
1edd2c |
hook_token='aaabbbvvv',
|
|
Vivek Anand |
1edd2c |
)
|
|
Vivek Anand |
1edd2c |
self.session.add(item)
|
|
Vivek Anand |
1edd2c |
self.session.commit()
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Vivek Anand |
1edd2c |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
self.assertTrue(os.path.exists(outputconf))
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
with open(outputconf) as stream:
|
|
Vivek Anand |
1edd2c |
data = stream.read()
|
|
Vivek Anand |
1edd2c |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """@devs = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
@sysadmin = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
# end of groups
|
|
Pierre-Yves Chibon |
ccb160 |
|
|
Vivek Anand |
1edd2c |
repo test
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
RW+ = foo
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo docs/test
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
RW+ = foo
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo tickets/test
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
RW+ = foo
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo requests/test
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
RW+ = foo
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo test2
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo docs/test2
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo tickets/test2
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo requests/test2
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo somenamespace/test3
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo docs/somenamespace/test3
|
|
Vivek Anand |
1edd2c |
R = @all
|
|
Vivek Anand |
1edd2c |
RW+ = pingou
|
|
Vivek Anand |
1edd2c |
|
|
Vivek Anand |
1edd2c |
repo tickets/somenamespace/test3
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo requests/somenamespace/test3
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo forks/pingou/test2
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo docs/forks/pingou/test2
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo tickets/forks/pingou/test2
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo requests/forks/pingou/test2
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Vivek Anand |
5827c9 |
"""
|
|
Vivek Anand |
5827c9 |
#print data
|
|
Vivek Anand |
5827c9 |
self.assertEqual(data.split('\n'), exp.split('\n'))
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
os.unlink(outputconf)
|
|
Vivek Anand |
5827c9 |
self.assertFalse(os.path.exists(outputconf))
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
def test_write_gitolite_acls_groups_commit(self):
|
|
Vivek Anand |
5827c9 |
""" Test the write_gitolite_acls function of pagure.lib.git with
|
|
Vivek Anand |
5827c9 |
groups as committers
|
|
Vivek Anand |
5827c9 |
"""
|
|
Vivek Anand |
5827c9 |
tests.create_projects(self.session)
|
|
Vivek Anand |
5827c9 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
# Add a couple of groups
|
|
Vivek Anand |
5827c9 |
# They would be committers
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Vivek Anand |
5827c9 |
self.session,
|
|
Vivek Anand |
5827c9 |
group_name='sysadmin',
|
|
Vivek Anand |
5827c9 |
display_name='sysadmin group',
|
|
Vivek Anand |
5827c9 |
description=None,
|
|
Vivek Anand |
5827c9 |
group_type='user',
|
|
Vivek Anand |
5827c9 |
user='pingou',
|
|
Vivek Anand |
5827c9 |
is_admin=False,
|
|
Vivek Anand |
5827c9 |
blacklist=[],
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
self.assertEqual(msg, 'User `pingou` added to the group `sysadmin`.')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group(
|
|
Vivek Anand |
5827c9 |
self.session,
|
|
Vivek Anand |
5827c9 |
group_name='devs',
|
|
Vivek Anand |
5827c9 |
display_name='devs group',
|
|
Vivek Anand |
5827c9 |
description=None,
|
|
Vivek Anand |
5827c9 |
group_type='user',
|
|
Vivek Anand |
5827c9 |
user='pingou',
|
|
Vivek Anand |
5827c9 |
is_admin=False,
|
|
Vivek Anand |
5827c9 |
blacklist=[],
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
self.assertEqual(msg, 'User `pingou` added to the group `devs`.')
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
# Associate these groups to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Vivek Anand |
5827c9 |
session=self.session,
|
|
Vivek Anand |
5827c9 |
project=repo,
|
|
Vivek Anand |
5827c9 |
new_group='sysadmin',
|
|
Vivek Anand |
5827c9 |
user='pingou',
|
|
Vivek Anand |
5827c9 |
access='commit'
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
self.assertEqual(msg, 'Group added')
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_group_to_project(
|
|
Vivek Anand |
5827c9 |
session=self.session,
|
|
Vivek Anand |
5827c9 |
project=repo,
|
|
Vivek Anand |
5827c9 |
new_group='devs',
|
|
Vivek Anand |
5827c9 |
user='pingou',
|
|
Vivek Anand |
5827c9 |
access='commit'
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
self.assertEqual(msg, 'Group added')
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
# Add an user to a project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Vivek Anand |
5827c9 |
session=self.session,
|
|
Vivek Anand |
5827c9 |
project=repo,
|
|
Vivek Anand |
5827c9 |
new_user='foo',
|
|
Vivek Anand |
5827c9 |
user='pingou',
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
self.assertEqual(msg, 'User added')
|
|
Vivek Anand |
5827c9 |
# Add a forked project
|
|
Vivek Anand |
5827c9 |
item = pagure.lib.model.Project(
|
|
Vivek Anand |
5827c9 |
user_id=1, # pingou
|
|
Vivek Anand |
5827c9 |
name='test2',
|
|
Vivek Anand |
5827c9 |
description='test project #2',
|
|
Vivek Anand |
5827c9 |
is_fork=True,
|
|
Vivek Anand |
5827c9 |
parent_id=1,
|
|
Vivek Anand |
5827c9 |
hook_token='aaabbbvvv',
|
|
Vivek Anand |
5827c9 |
)
|
|
Vivek Anand |
5827c9 |
self.session.add(item)
|
|
Vivek Anand |
5827c9 |
self.session.commit()
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Vivek Anand |
5827c9 |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
self.assertTrue(os.path.exists(outputconf))
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
with open(outputconf) as stream:
|
|
Vivek Anand |
5827c9 |
data = stream.read()
|
|
Vivek Anand |
5827c9 |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """@devs = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
@sysadmin = pingou
|
|
Pierre-Yves Chibon |
ccb160 |
# end of groups
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo test
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
RW+ = foo
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo docs/test
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
RW+ = foo
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo tickets/test
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
RW+ = foo
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo requests/test
|
|
Pierre-Yves Chibon |
a3901b |
RW+ = @devs @sysadmin
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
RW+ = foo
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo test2
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo docs/test2
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo tickets/test2
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo requests/test2
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo somenamespace/test3
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo docs/somenamespace/test3
|
|
Vivek Anand |
5827c9 |
R = @all
|
|
Vivek Anand |
5827c9 |
RW+ = pingou
|
|
Vivek Anand |
5827c9 |
|
|
Vivek Anand |
5827c9 |
repo tickets/somenamespace/test3
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
clime |
afed57 |
repo requests/somenamespace/test3
|
|
clime |
afed57 |
RW+ = pingou
|
|
clime |
afed57 |
|
|
Pierre-Yves Chibon |
4fc47a |
repo forks/pingou/test2
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
59a1eb |
repo docs/forks/pingou/test2
|
|
Pierre-Yves Chibon |
4fc47a |
R = @all
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
59a1eb |
repo tickets/forks/pingou/test2
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
59a1eb |
repo requests/forks/pingou/test2
|
|
Pierre-Yves Chibon |
4fc47a |
RW+ = pingou
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
4fc47a |
"""
|
|
Pierre-Yves Chibon |
59a1eb |
#print data
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertEqual(data.split('\n'), exp.split('\n'))
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
4fc47a |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
4fc47a |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
4fc47a |
|
|
Pierre-Yves Chibon |
499752 |
def test_write_gitolite_project_pr_only(self):
|
|
Pierre-Yves Chibon |
499752 |
""" Test the write_gitolite_acls function of pagure.lib.git.
|
|
Pierre-Yves Chibon |
499752 |
when the project enforces the PR approach.
|
|
Pierre-Yves Chibon |
499752 |
"""
|
|
Pierre-Yves Chibon |
499752 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query._get_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
499752 |
# Make the project enforce the PR workflow
|
|
Pierre-Yves Chibon |
499752 |
settings = repo.settings
|
|
Pierre-Yves Chibon |
499752 |
settings['pull_request_access_only'] = True
|
|
Pierre-Yves Chibon |
499752 |
repo.settings = settings
|
|
Pierre-Yves Chibon |
499752 |
self.session.add(repo)
|
|
Pierre-Yves Chibon |
499752 |
self.session.commit()
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
# Add an user to a project
|
|
Pierre-Yves Chibon |
499752 |
# The user will be an admin of the project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Pierre-Yves Chibon |
499752 |
session=self.session,
|
|
Pierre-Yves Chibon |
499752 |
project=repo,
|
|
Pierre-Yves Chibon |
499752 |
new_user='foo',
|
|
Pierre-Yves Chibon |
499752 |
user='pingou',
|
|
Pierre-Yves Chibon |
499752 |
)
|
|
Pierre-Yves Chibon |
499752 |
self.session.commit()
|
|
Pierre-Yves Chibon |
499752 |
self.assertEqual(msg, 'User added')
|
|
Pierre-Yves Chibon |
499752 |
# Add a forked project
|
|
Pierre-Yves Chibon |
499752 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
499752 |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
499752 |
name='test3',
|
|
Pierre-Yves Chibon |
499752 |
description='test project #2',
|
|
Pierre-Yves Chibon |
499752 |
is_fork=True,
|
|
Pierre-Yves Chibon |
499752 |
parent_id=1,
|
|
Pierre-Yves Chibon |
499752 |
hook_token='aaabbbvvv',
|
|
Pierre-Yves Chibon |
499752 |
)
|
|
Pierre-Yves Chibon |
499752 |
self.session.add(item)
|
|
Pierre-Yves Chibon |
499752 |
self.session.commit()
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
499752 |
data = stream.read()
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo docs/test
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/test
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/test
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo test2
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/test2
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/test2
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/test2
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
499752 |
"""
|
|
Pierre-Yves Chibon |
499752 |
#print data
|
|
Pierre-Yves Chibon |
499752 |
self.assertEqual(data, exp)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
499752 |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
b130e5 |
@patch.dict('pagure.config.config', {'PR_ONLY': True})
|
|
Pierre-Yves Chibon |
499752 |
def test_write_gitolite_global_pr_only(self):
|
|
Pierre-Yves Chibon |
499752 |
""" Test the write_gitolite_acls function of pagure.lib.git.
|
|
Pierre-Yves Chibon |
73f4b5 |
when the pagure instance enforces the PR approach.
|
|
Pierre-Yves Chibon |
499752 |
"""
|
|
Pierre-Yves Chibon |
499752 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query._get_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
897409 |
self.assertFalse(repo.settings['pull_request_access_only'])
|
|
Pierre-Yves Chibon |
897409 |
|
|
Pierre-Yves Chibon |
499752 |
# Add an user to a project
|
|
Pierre-Yves Chibon |
499752 |
# The user will be an admin of the project
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_user_to_project(
|
|
Pierre-Yves Chibon |
499752 |
session=self.session,
|
|
Pierre-Yves Chibon |
499752 |
project=repo,
|
|
Pierre-Yves Chibon |
499752 |
new_user='foo',
|
|
Pierre-Yves Chibon |
499752 |
user='pingou',
|
|
Pierre-Yves Chibon |
499752 |
)
|
|
Pierre-Yves Chibon |
499752 |
self.session.commit()
|
|
Pierre-Yves Chibon |
499752 |
self.assertEqual(msg, 'User added')
|
|
Pierre-Yves Chibon |
499752 |
# Add a forked project
|
|
Pierre-Yves Chibon |
499752 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
499752 |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
499752 |
name='test3',
|
|
Pierre-Yves Chibon |
499752 |
description='test project #2',
|
|
Pierre-Yves Chibon |
499752 |
is_fork=True,
|
|
Pierre-Yves Chibon |
499752 |
parent_id=1,
|
|
Pierre-Yves Chibon |
499752 |
hook_token='aaabbbvvv',
|
|
Pierre-Yves Chibon |
499752 |
)
|
|
Pierre-Yves Chibon |
499752 |
self.session.add(item)
|
|
Pierre-Yves Chibon |
499752 |
self.session.commit()
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
outputconf = os.path.join(self.path, 'test_gitolite.conf')
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.write_gitolite_acls(self.session, outputconf, project=-1)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
self.assertTrue(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
with open(outputconf) as stream:
|
|
Pierre-Yves Chibon |
499752 |
data = stream.read()
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
ccb160 |
exp = """repo docs/test
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/test
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/test
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
RW+ = foo
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/test2
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/test2
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/test2
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/somenamespace/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo docs/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
R = @all
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo tickets/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
repo requests/forks/pingou/test3
|
|
Pierre-Yves Chibon |
499752 |
RW+ = pingou
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
ccb160 |
# end of body
|
|
Pierre-Yves Chibon |
499752 |
"""
|
|
Pierre-Yves Chibon |
499752 |
#print data
|
|
Pierre-Yves Chibon |
499752 |
self.assertEqual(data, exp)
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
499752 |
os.unlink(outputconf)
|
|
Pierre-Yves Chibon |
499752 |
self.assertFalse(os.path.exists(outputconf))
|
|
Pierre-Yves Chibon |
499752 |
|
|
Pierre-Yves Chibon |
fe5017 |
@patch('pagure.lib.notify.send_email')
|
|
Patrick Uiterwijk |
b4c473 |
def test_update_git(self, email_f):
|
|
Pierre-Yves Chibon |
fe5017 |
""" Test the update_git of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
c009bb |
email_f.return_value = True
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
# Create project
|
|
Pierre-Yves Chibon |
fe5017 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
c009bb |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
c009bb |
name='test_ticket_repo',
|
|
Pierre-Yves Chibon |
c009bb |
description='test project for ticket',
|
|
Pierre-Yves Chibon |
e2259d |
hook_token='aaabbbwww',
|
|
Pierre-Yves Chibon |
c009bb |
)
|
|
Pierre-Yves Chibon |
c009bb |
self.session.add(item)
|
|
Pierre-Yves Chibon |
c009bb |
self.session.commit()
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
# Create repo
|
|
Slavek Kabrda |
adea20 |
self.gitrepo = os.path.join(self.path, 'repos', 'tickets',
|
|
Patrick Uiterwijk |
170974 |
'test_ticket_repo.git')
|
|
Patrick Uiterwijk |
170974 |
pygit2.init_repository(self.gitrepo, bare=True)
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test_ticket_repo')
|
|
Pierre-Yves Chibon |
c009bb |
# Create an issue to play with
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.new_issue(
|
|
Pierre-Yves Chibon |
c009bb |
session=self.session,
|
|
Pierre-Yves Chibon |
c009bb |
repo=repo,
|
|
Pierre-Yves Chibon |
c009bb |
title='Test issue',
|
|
Pierre-Yves Chibon |
c009bb |
content='We should work on this',
|
|
Pierre-Yves Chibon |
c009bb |
user='pingou',
|
|
Pierre-Yves Chibon |
c009bb |
)
|
|
Pierre-Yves Chibon |
11d78c |
self.assertEqual(msg.title, 'Test issue')
|
|
Pierre-Yves Chibon |
930073 |
issue = pagure.lib.query.search_issues(self.session, repo, issueid=1)
|
|
Patrick Uiterwijk |
3f97f6 |
pagure.lib.git.update_git(issue, repo).get()
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
repo = pygit2.Repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
c009bb |
commit = repo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
# Use patch to validate the repo
|
|
Slavek Kabrda |
adea20 |
commit_patch = pagure.lib.git.commit_to_patch(repo, commit)
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
fe5017 |
From: pagure <pagure></pagure>
|
|
Pierre-Yves Chibon |
e64141 |
Subject: Updated issue <hash>: Test issue</hash>
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
---
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
diff --git a/123 b/456
|
|
Pierre-Yves Chibon |
c009bb |
new file mode 100644
|
|
Pierre-Yves Chibon |
c009bb |
index 0000000..60f7480
|
|
Pierre-Yves Chibon |
c009bb |
--- /dev/null
|
|
Pierre-Yves Chibon |
c009bb |
+++ b/456
|
|
Clement Verna |
81c130 |
@@ -0,0 +1,29 @@
|
|
Pierre-Yves Chibon |
2e900f |
+{
|
|
Pierre-Yves Chibon |
2e900f |
+ "assignee": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "blocks": [],
|
|
Pierre-Yves Chibon |
a71f76 |
+ "close_status": null,
|
|
Vivek Anand |
d7285b |
+ "closed_at": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "comments": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "content": "We should work on this",
|
|
Pierre-Yves Chibon |
022564 |
+ "custom_fields": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "date_created": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "depends": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "id": 1,
|
|
Mark Reynolds |
23b4d2 |
+ "last_updated": null,
|
|
Pierre-Yves Chibon |
725fca |
+ "milestone": null,
|
|
Pierre-Yves Chibon |
b5c8b4 |
+ "priority": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "private": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "status": "Open",
|
|
Pierre-Yves Chibon |
2e900f |
+ "tags": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "title": "Test issue",
|
|
Pierre-Yves Chibon |
2e900f |
+ "user": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "default_email": "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "emails": [
|
|
Pierre-Yves Chibon |
2e900f |
+ "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "foo@pingou.com"
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
+ "fullname": "PY C",
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "pingou"
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+}
|
|
Pierre-Yves Chibon |
c009bb |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
"""
|
|
Pierre-Yves Chibon |
c009bb |
npatch = []
|
|
Slavek Kabrda |
adea20 |
for row in commit_patch.split('\n'):
|
|
Pierre-Yves Chibon |
c009bb |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
c009bb |
continue
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('From '):
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('diff --git '):
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split(' ')
|
|
Pierre-Yves Chibon |
c009bb |
row[2] = 'a/123'
|
|
Pierre-Yves Chibon |
c009bb |
row[3] = 'b/456'
|
|
Pierre-Yves Chibon |
c009bb |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
e64141 |
elif 'Updated issue' in row:
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split()
|
|
Pierre-Yves Chibon |
c009bb |
row[3] = '<hash>:'</hash>
|
|
Pierre-Yves Chibon |
c009bb |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
c009bb |
elif 'date_created' in row:
|
|
Pierre-Yves Chibon |
2e900f |
t = row.split(': ')[0]
|
|
Pierre-Yves Chibon |
2e900f |
row = '%s: null,' % t
|
|
Mark Reynolds |
23b4d2 |
elif 'last_updated' in row:
|
|
Mark Reynolds |
23b4d2 |
t = row.split(': ')[0]
|
|
Mark Reynolds |
23b4d2 |
row = '%s: null,' % t
|
|
Vivek Anand |
d7285b |
elif 'closed_at' in row:
|
|
Vivek Anand |
d7285b |
t = row.split(': ')[0]
|
|
Vivek Anand |
d7285b |
row = '%s: null,' % t
|
|
Clement Verna |
81c130 |
elif 'closed_by' in row:
|
|
Clement Verna |
81c130 |
continue
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('index 00'):
|
|
Pierre-Yves Chibon |
c009bb |
row = 'index 0000000..60f7480'
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('+++ b/'):
|
|
Pierre-Yves Chibon |
c009bb |
row = '+++ b/456'
|
|
Pierre-Yves Chibon |
c009bb |
npatch.append(row)
|
|
Slavek Kabrda |
adea20 |
commit_patch = '\n'.join(npatch)
|
|
Slavek Kabrda |
adea20 |
#print commit_patch
|
|
Slavek Kabrda |
adea20 |
self.assertEqual(commit_patch, exp)
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
b63f28 |
# Enforce having a different last_updated field
|
|
Pierre-Yves Chibon |
b63f28 |
# This is required as the test run fine and fast with sqlite but is
|
|
Pierre-Yves Chibon |
b63f28 |
# much slower with postgresql so we end-up with an updated
|
|
Pierre-Yves Chibon |
b63f28 |
# last_updated in postgresql but not with sqlite
|
|
Pierre-Yves Chibon |
b63f28 |
time.sleep(1)
|
|
Pierre-Yves Chibon |
b63f28 |
|
|
Pierre-Yves Chibon |
c009bb |
# Test again after adding a comment
|
|
Slavek Kabrda |
adea20 |
# We need to make sure we wait for worker to commit the comment
|
|
Patrick Uiterwijk |
3f97f6 |
with patch('pagure.lib.git._maybe_wait', tests.definitely_wait):
|
|
Pierre-Yves Chibon |
930073 |
msg = pagure.lib.query.add_issue_comment(
|
|
Slavek Kabrda |
adea20 |
session=self.session,
|
|
Slavek Kabrda |
adea20 |
issue=issue,
|
|
Slavek Kabrda |
adea20 |
comment='Hey look a comment!',
|
|
Slavek Kabrda |
adea20 |
user='foo',
|
|
Slavek Kabrda |
adea20 |
)
|
|
Pierre-Yves Chibon |
c009bb |
self.session.commit()
|
|
Pierre-Yves Chibon |
c009bb |
self.assertEqual(msg, 'Comment added')
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
# Use patch to validate the repo
|
|
Pierre-Yves Chibon |
c009bb |
repo = pygit2.Repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
c009bb |
commit = repo.revparse_single('HEAD')
|
|
Slavek Kabrda |
adea20 |
commit_patch = pagure.lib.git.commit_to_patch(repo, commit)
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
fe5017 |
From: pagure <pagure></pagure>
|
|
Pierre-Yves Chibon |
e64141 |
Subject: Updated issue <hash>: Test issue</hash>
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
---
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
diff --git a/123 b/456
|
|
Pierre-Yves Chibon |
c009bb |
index 458821a..77674a8
|
|
Pierre-Yves Chibon |
c009bb |
--- a/123
|
|
Pierre-Yves Chibon |
c009bb |
+++ b/456
|
|
Clement Verna |
81c130 |
@@ -4,13 +4,32 @@
|
|
Pierre-Yves Chibon |
a71f76 |
"close_status": null,
|
|
Vivek Anand |
d7285b |
"closed_at": null,
|
|
Pierre-Yves Chibon |
2e900f |
- "comments": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "comments": [
|
|
Pierre-Yves Chibon |
2e900f |
+ {
|
|
Pierre-Yves Chibon |
2e900f |
+ "comment": "Hey look a comment!",
|
|
Pierre-Yves Chibon |
2e900f |
+ "date_created": null,
|
|
Pierre-Yves Chibon |
e64141 |
+ "edited_on": null,
|
|
Pierre-Yves Chibon |
e64141 |
+ "editor": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "id": 1,
|
|
Pierre-Yves Chibon |
bda7f1 |
+ "notification": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "parent": null,
|
|
LubomĂr SedlĂ¡Å™ |
59889e |
+ "reactions": {},
|
|
Pierre-Yves Chibon |
2e900f |
+ "user": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "default_email": "foo@bar.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "emails": [
|
|
Pierre-Yves Chibon |
2e900f |
+ "foo@bar.com"
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
+ "fullname": "foo bar",
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "foo"
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
"content": "We should work on this",
|
|
Pierre-Yves Chibon |
e5e9eb |
"custom_fields": [],
|
|
Pierre-Yves Chibon |
2e900f |
"date_created": null,
|
|
Pierre-Yves Chibon |
b63f28 |
"depends": [],
|
|
Pierre-Yves Chibon |
b63f28 |
"id": 1,
|
|
Pierre-Yves Chibon |
b63f28 |
- "last_updated": "<date>",</date>
|
|
Pierre-Yves Chibon |
b63f28 |
+ "last_updated": "<date>",</date>
|
|
Pierre-Yves Chibon |
b63f28 |
"milestone": null,
|
|
Pierre-Yves Chibon |
b63f28 |
"priority": null,
|
|
Pierre-Yves Chibon |
b63f28 |
"private": false,
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Pierre-Yves Chibon |
c009bb |
"""
|
|
Pierre-Yves Chibon |
c009bb |
npatch = []
|
|
Slavek Kabrda |
adea20 |
for row in commit_patch.split('\n'):
|
|
Pierre-Yves Chibon |
c009bb |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
c009bb |
continue
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('From '):
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('diff --git '):
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split(' ')
|
|
Pierre-Yves Chibon |
c009bb |
row[2] = 'a/123'
|
|
Pierre-Yves Chibon |
c009bb |
row[3] = 'b/456'
|
|
Pierre-Yves Chibon |
c009bb |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
e64141 |
elif 'Updated issue' in row:
|
|
Pierre-Yves Chibon |
c009bb |
row = row.split()
|
|
Pierre-Yves Chibon |
c009bb |
row[3] = '<hash>:'</hash>
|
|
Pierre-Yves Chibon |
c009bb |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
c009bb |
elif 'date_created' in row:
|
|
Vivek Anand |
d7285b |
t = row.split(': ')[0]
|
|
Vivek Anand |
d7285b |
row = '%s: null,' % t
|
|
Vivek Anand |
d7285b |
elif 'closed_at' in row:
|
|
Pierre-Yves Chibon |
2e900f |
t = row.split(': ')[0]
|
|
Pierre-Yves Chibon |
2e900f |
row = '%s: null,' % t
|
|
Clement Verna |
81c130 |
elif 'closed_by' in row:
|
|
Clement Verna |
81c130 |
continue
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('index'):
|
|
Pierre-Yves Chibon |
c009bb |
row = 'index 458821a..77674a8'
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('--- a/'):
|
|
Pierre-Yves Chibon |
c009bb |
row = '--- a/123'
|
|
Pierre-Yves Chibon |
c009bb |
elif row.startswith('+++ b/'):
|
|
Pierre-Yves Chibon |
c009bb |
row = '+++ b/456'
|
|
Pierre-Yves Chibon |
b63f28 |
elif 'last_updated' in row:
|
|
Pierre-Yves Chibon |
b63f28 |
t = row.split(': ')[0]
|
|
Pierre-Yves Chibon |
b63f28 |
row = '%s: "<date>",' % t</date>
|
|
Pierre-Yves Chibon |
c009bb |
npatch.append(row)
|
|
Slavek Kabrda |
adea20 |
commit_patch = '\n'.join(npatch)
|
|
Slavek Kabrda |
adea20 |
# print commit_patch
|
|
Slavek Kabrda |
adea20 |
self.assertEqual(commit_patch, exp)
|
|
Pierre-Yves Chibon |
c009bb |
|
|
Patrick Uiterwijk |
b4c473 |
def test_clean_git(self):
|
|
Pierre-Yves Chibon |
e88bd7 |
""" Test the clean_git method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
e88bd7 |
self.test_update_git()
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Slavek Kabrda |
adea20 |
gitpath = os.path.join(self.path, 'repos', 'tickets',
|
|
Slavek Kabrda |
adea20 |
'test_ticket_repo.git')
|
|
Pierre-Yves Chibon |
e88bd7 |
gitrepo = pygit2.init_repository(gitpath, bare=True)
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Pierre-Yves Chibon |
e88bd7 |
# Get the uid of the ticket created
|
|
Pierre-Yves Chibon |
e88bd7 |
commit = gitrepo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
e88bd7 |
patch = pagure.lib.git.commit_to_patch(gitrepo, commit)
|
|
Pierre-Yves Chibon |
e88bd7 |
hash_file = None
|
|
Pierre-Yves Chibon |
e88bd7 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
e88bd7 |
if row.startswith('+++ b/'):
|
|
Pierre-Yves Chibon |
e88bd7 |
hash_file = row.split('+++ b/')[-1]
|
|
Pierre-Yves Chibon |
e88bd7 |
break
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Pierre-Yves Chibon |
e88bd7 |
# The only file in git is the one of that ticket
|
|
Pierre-Yves Chibon |
e88bd7 |
files = [entry.name for entry in commit.tree]
|
|
Pierre-Yves Chibon |
e88bd7 |
self.assertEqual(files, [hash_file])
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test_ticket_repo')
|
|
Pierre-Yves Chibon |
930073 |
issue = pagure.lib.query.search_issues(self.session, repo, issueid=1)
|
|
Patrick Uiterwijk |
3f97f6 |
pagure.lib.git.clean_git(repo, issue.repotype, issue.uid).get()
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Pierre-Yves Chibon |
e88bd7 |
# No more files in the git repo
|
|
Pierre-Yves Chibon |
e88bd7 |
commit = gitrepo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
e88bd7 |
files = [entry.name for entry in commit.tree]
|
|
Pierre-Yves Chibon |
e88bd7 |
self.assertEqual(files, [])
|
|
Pierre-Yves Chibon |
e88bd7 |
|
|
Pierre-Yves Chibon |
c070b4 |
@patch('pagure.lib.notify.send_email')
|
|
Patrick Uiterwijk |
b4c473 |
def test_update_git_requests(self, email_f):
|
|
Pierre-Yves Chibon |
c070b4 |
""" Test the update_git of pagure.lib.git for pull-requests. """
|
|
Pierre-Yves Chibon |
c070b4 |
email_f.return_value = True
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
# Create project
|
|
Pierre-Yves Chibon |
c070b4 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
c070b4 |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
c070b4 |
name='test_ticket_repo',
|
|
Pierre-Yves Chibon |
c070b4 |
description='test project for ticket',
|
|
Pierre-Yves Chibon |
e2259d |
hook_token='aaabbbxxx',
|
|
Pierre-Yves Chibon |
c070b4 |
)
|
|
Pierre-Yves Chibon |
c070b4 |
self.session.add(item)
|
|
Pierre-Yves Chibon |
c070b4 |
self.session.commit()
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
# Create repo
|
|
Slavek Kabrda |
adea20 |
self.gitrepo = os.path.join(self.path, 'repos', 'requests',
|
|
Patrick Uiterwijk |
170974 |
'test_ticket_repo.git')
|
|
Patrick Uiterwijk |
170974 |
pygit2.init_repository(self.gitrepo, bare=True)
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
a3fe59 |
# Create a PR to play with
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test_ticket_repo')
|
|
Farhaan Bukhsh |
72e9db |
# Create an issue to play with
|
|
Pierre-Yves Chibon |
930073 |
req = pagure.lib.query.new_pull_request(
|
|
Pierre-Yves Chibon |
c070b4 |
session=self.session,
|
|
Pierre-Yves Chibon |
c070b4 |
repo_from=repo,
|
|
Pierre-Yves Chibon |
c070b4 |
branch_from='feature',
|
|
Pierre-Yves Chibon |
c070b4 |
repo_to=repo,
|
|
Pierre-Yves Chibon |
c070b4 |
branch_to='master',
|
|
Pierre-Yves Chibon |
c070b4 |
title='test PR',
|
|
Pierre-Yves Chibon |
c070b4 |
user='pingou',
|
|
Pierre-Yves Chibon |
c070b4 |
requestuid='foobar',
|
|
Pierre-Yves Chibon |
c070b4 |
requestid=None,
|
|
Pierre-Yves Chibon |
ff2972 |
status='Open',
|
|
Pierre-Yves Chibon |
c070b4 |
notify=True
|
|
Pierre-Yves Chibon |
c070b4 |
)
|
|
Pierre-Yves Chibon |
f9c5f9 |
self.assertEqual(req.id, 1)
|
|
Pierre-Yves Chibon |
f9c5f9 |
self.assertEqual(req.title, 'test PR')
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
request = repo.requests[0]
|
|
Pierre-Yves Chibon |
c070b4 |
self.assertEqual(request.title, 'test PR')
|
|
Patrick Uiterwijk |
3f97f6 |
pagure.lib.git.update_git(request, request.project).get()
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
repo = pygit2.Repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
c070b4 |
commit = repo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
# Use patch to validate the repo
|
|
Pierre-Yves Chibon |
c070b4 |
patch = pagure.lib.git.commit_to_patch(repo, commit)
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
c070b4 |
From: pagure <pagure></pagure>
|
|
Pierre-Yves Chibon |
e64141 |
Subject: Updated pull-request <hash>: test PR</hash>
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
---
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
diff --git a/123 b/456
|
|
Pierre-Yves Chibon |
c070b4 |
new file mode 100644
|
|
Pierre-Yves Chibon |
c070b4 |
index 0000000..60f7480
|
|
Pierre-Yves Chibon |
c070b4 |
--- /dev/null
|
|
Pierre-Yves Chibon |
c070b4 |
+++ b/456
|
|
Pierre-Yves Chibon |
4eda2c |
@@ -0,0 +1,146 @@
|
|
Pierre-Yves Chibon |
2e900f |
+{
|
|
Pierre-Yves Chibon |
2e900f |
+ "assignee": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "branch": "master",
|
|
Pierre-Yves Chibon |
2e900f |
+ "branch_from": "feature",
|
|
Pierre-Yves Chibon |
f21734 |
+ "cached_merge_status": "unknown",
|
|
Pierre-Yves Chibon |
bf72a2 |
+ "closed_at": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "closed_by": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "comments": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "commit_start": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "commit_stop": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "date_created": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "id": 1,
|
|
Pierre-Yves Chibon |
10ca8a |
+ "initial_comment": null,
|
|
Mark Reynolds |
23b4d2 |
+ "last_updated": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "project": {
|
|
Matt Prahl |
6bf79a |
+ "access_groups": {
|
|
Matt Prahl |
6bf79a |
+ "admin": [],
|
|
Matt Prahl |
6bf79a |
+ "commit": [],
|
|
Matt Prahl |
6bf79a |
+ "ticket": []
|
|
Matt Prahl |
6bf79a |
+ },
|
|
Matt Prahl |
6bf79a |
+ "access_users": {
|
|
Matt Prahl |
6bf79a |
+ "admin": [],
|
|
Matt Prahl |
6bf79a |
+ "commit": [],
|
|
Matt Prahl |
6bf79a |
+ "owner": [
|
|
Matt Prahl |
6bf79a |
+ "pingou"
|
|
Matt Prahl |
6bf79a |
+ ],
|
|
Matt Prahl |
6bf79a |
+ "ticket": []
|
|
Matt Prahl |
6bf79a |
+ },
|
|
Pierre-Yves Chibon |
f254bf |
+ "close_status": [],
|
|
Pierre-Yves Chibon |
022564 |
+ "custom_keys": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "date_created": null,
|
|
Clement Verna |
cd6e30 |
+ "date_modified": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "description": "test project for ticket",
|
|
Pierre-Yves Chibon |
c9e619 |
+ "fullname": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
2e900f |
+ "id": 1,
|
|
Pierre-Yves Chibon |
f254bf |
+ "milestones": {},
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
733a9d |
+ "namespace": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "parent": null,
|
|
Pierre-Yves Chibon |
14bde2 |
+ "priorities": {},
|
|
Pierre-Yves Chibon |
2e900f |
+ "settings": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "Enforce_signed-off_commits_in_pull-request": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Minimum_score_to_merge_pull-request": -1,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Only_assignee_can_merge_pull-request": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Web-hooks": null,
|
|
Pierre-Yves Chibon |
1709b9 |
+ "always_merge": false,
|
|
Pierre-Yves Chibon |
98d023 |
+ "disable_non_fast-forward_merges": false,
|
|
Pierre-Yves Chibon |
9d1556 |
+ "fedmsg_notifications": true,
|
|
Pierre-Yves Chibon |
2e900f |
+ "issue_tracker": true,
|
|
Pierre-Yves Chibon |
b59748 |
+ "issue_tracker_read_only": false,
|
|
Pierre-Yves Chibon |
d0e87d |
+ "issues_default_to_private": false,
|
|
Pierre-Yves Chibon |
4eda2c |
+ "mqtt_notifications": true,
|
|
Pierre-Yves Chibon |
baaf54 |
+ "notify_on_commit_flag": false,
|
|
Pierre-Yves Chibon |
baaf54 |
+ "notify_on_pull-request_flag": false,
|
|
Pierre-Yves Chibon |
3821e6 |
+ "open_metadata_access_to_all": false,
|
|
Pierre-Yves Chibon |
e994c4 |
+ "project_documentation": false,
|
|
Pierre-Yves Chibon |
499752 |
+ "pull_request_access_only": false,
|
|
Pierre-Yves Chibon |
960e1e |
+ "pull_requests": true,
|
|
Slavek Kabrda |
c8fc0d |
+ "stomp_notifications": true
|
|
Pierre-Yves Chibon |
2e900f |
+ },
|
|
Pierre-Yves Chibon |
a30916 |
+ "tags": [],
|
|
Pierre-Yves Chibon |
421aa4 |
+ "url_path": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
2e900f |
+ "user": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "default_email": "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "emails": [
|
|
Pierre-Yves Chibon |
2e900f |
+ "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "foo@pingou.com"
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
+ "fullname": "PY C",
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "pingou"
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+ },
|
|
Pierre-Yves Chibon |
ee5445 |
+ "remote_git": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "repo_from": {
|
|
Matt Prahl |
6bf79a |
+ "access_groups": {
|
|
Matt Prahl |
6bf79a |
+ "admin": [],
|
|
Matt Prahl |
6bf79a |
+ "commit": [],
|
|
Matt Prahl |
6bf79a |
+ "ticket": []
|
|
Matt Prahl |
6bf79a |
+ },
|
|
Matt Prahl |
6bf79a |
+ "access_users": {
|
|
Matt Prahl |
6bf79a |
+ "admin": [],
|
|
Matt Prahl |
6bf79a |
+ "commit": [],
|
|
Matt Prahl |
6bf79a |
+ "owner": [
|
|
Matt Prahl |
6bf79a |
+ "pingou"
|
|
Matt Prahl |
6bf79a |
+ ],
|
|
Matt Prahl |
6bf79a |
+ "ticket": []
|
|
Matt Prahl |
6bf79a |
+ },
|
|
Pierre-Yves Chibon |
f254bf |
+ "close_status": [],
|
|
Pierre-Yves Chibon |
022564 |
+ "custom_keys": [],
|
|
Pierre-Yves Chibon |
2e900f |
+ "date_created": null,
|
|
Clement Verna |
cd6e30 |
+ "date_modified": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "description": "test project for ticket",
|
|
Pierre-Yves Chibon |
c9e619 |
+ "fullname": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
2e900f |
+ "id": 1,
|
|
Pierre-Yves Chibon |
f254bf |
+ "milestones": {},
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
733a9d |
+ "namespace": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "parent": null,
|
|
Pierre-Yves Chibon |
14bde2 |
+ "priorities": {},
|
|
Pierre-Yves Chibon |
2e900f |
+ "settings": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "Enforce_signed-off_commits_in_pull-request": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Minimum_score_to_merge_pull-request": -1,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Only_assignee_can_merge_pull-request": false,
|
|
Pierre-Yves Chibon |
2e900f |
+ "Web-hooks": null,
|
|
Pierre-Yves Chibon |
1709b9 |
+ "always_merge": false,
|
|
Pierre-Yves Chibon |
98d023 |
+ "disable_non_fast-forward_merges": false,
|
|
Pierre-Yves Chibon |
9d1556 |
+ "fedmsg_notifications": true,
|
|
Pierre-Yves Chibon |
2e900f |
+ "issue_tracker": true,
|
|
Pierre-Yves Chibon |
b59748 |
+ "issue_tracker_read_only": false,
|
|
Pierre-Yves Chibon |
d0e87d |
+ "issues_default_to_private": false,
|
|
Pierre-Yves Chibon |
4eda2c |
+ "mqtt_notifications": true,
|
|
Pierre-Yves Chibon |
baaf54 |
+ "notify_on_commit_flag": false,
|
|
Pierre-Yves Chibon |
baaf54 |
+ "notify_on_pull-request_flag": false,
|
|
Pierre-Yves Chibon |
3821e6 |
+ "open_metadata_access_to_all": false,
|
|
Pierre-Yves Chibon |
e994c4 |
+ "project_documentation": false,
|
|
Pierre-Yves Chibon |
499752 |
+ "pull_request_access_only": false,
|
|
Pierre-Yves Chibon |
960e1e |
+ "pull_requests": true,
|
|
Slavek Kabrda |
c8fc0d |
+ "stomp_notifications": true
|
|
Pierre-Yves Chibon |
2e900f |
+ },
|
|
Pierre-Yves Chibon |
a30916 |
+ "tags": [],
|
|
Pierre-Yves Chibon |
421aa4 |
+ "url_path": "test_ticket_repo",
|
|
Pierre-Yves Chibon |
2e900f |
+ "user": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "default_email": "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "emails": [
|
|
Pierre-Yves Chibon |
2e900f |
+ "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "foo@pingou.com"
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
+ "fullname": "PY C",
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "pingou"
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+ },
|
|
Pierre-Yves Chibon |
2e900f |
+ "status": "Open",
|
|
Pierre-Yves Chibon |
2233c1 |
+ "threshold_reached": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "title": "test PR",
|
|
Pierre-Yves Chibon |
2e900f |
+ "uid": "foobar",
|
|
Pierre-Yves Chibon |
44258a |
+ "updated_on": null,
|
|
Pierre-Yves Chibon |
2e900f |
+ "user": {
|
|
Pierre-Yves Chibon |
2e900f |
+ "default_email": "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "emails": [
|
|
Pierre-Yves Chibon |
2e900f |
+ "bar@pingou.com",
|
|
Pierre-Yves Chibon |
2e900f |
+ "foo@pingou.com"
|
|
Pierre-Yves Chibon |
2e900f |
+ ],
|
|
Pierre-Yves Chibon |
2e900f |
+ "fullname": "PY C",
|
|
Pierre-Yves Chibon |
2e900f |
+ "name": "pingou"
|
|
Pierre-Yves Chibon |
2e900f |
+ }
|
|
Pierre-Yves Chibon |
2e900f |
+}
|
|
Pierre-Yves Chibon |
c070b4 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
c070b4 |
"""
|
|
Pierre-Yves Chibon |
c070b4 |
npatch = []
|
|
Pierre-Yves Chibon |
c070b4 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
c070b4 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
c070b4 |
continue
|
|
Pierre-Yves Chibon |
c070b4 |
elif row.startswith('From '):
|
|
Pierre-Yves Chibon |
c070b4 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
c070b4 |
elif row.startswith('diff --git '):
|
|
Pierre-Yves Chibon |
c070b4 |
row = row.split(' ')
|
|
Pierre-Yves Chibon |
c070b4 |
row[2] = 'a/123'
|
|
Pierre-Yves Chibon |
c070b4 |
row[3] = 'b/456'
|
|
Pierre-Yves Chibon |
c070b4 |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
e64141 |
elif 'Updated pull-request' in row:
|
|
Pierre-Yves Chibon |
c070b4 |
row = row.split()
|
|
Pierre-Yves Chibon |
c070b4 |
row[3] = '<hash>:'</hash>
|
|
Pierre-Yves Chibon |
c070b4 |
row = ' '.join(row)
|
|
Pierre-Yves Chibon |
c070b4 |
elif 'date_created' in row:
|
|
Pierre-Yves Chibon |
2e900f |
t = row.split(': ')[0]
|
|
Pierre-Yves Chibon |
2e900f |
row = '%s: null,' % t
|
|
Clement Verna |
cd6e30 |
elif 'date_modified' in row:
|
|
Clement Verna |
cd6e30 |
t = row.split(': ')[0]
|
|
Clement Verna |
cd6e30 |
row = '%s: null,' % t
|
|
Mark Reynolds |
23b4d2 |
elif 'last_updated' in row:
|
|
Mark Reynolds |
23b4d2 |
t = row.split(': ')[0]
|
|
Mark Reynolds |
23b4d2 |
row = '%s: null,' % t
|
|
Pierre-Yves Chibon |
44258a |
elif 'updated_on' in row:
|
|
Pierre-Yves Chibon |
44258a |
t = row.split(': ')[0]
|
|
Pierre-Yves Chibon |
44258a |
row = '%s: null,' % t
|
|
Pierre-Yves Chibon |
c070b4 |
elif row.startswith('index 00'):
|
|
Pierre-Yves Chibon |
c070b4 |
row = 'index 0000000..60f7480'
|
|
Pierre-Yves Chibon |
c070b4 |
elif row.startswith('+++ b/'):
|
|
Pierre-Yves Chibon |
c070b4 |
row = '+++ b/456'
|
|
Pierre-Yves Chibon |
c070b4 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
c070b4 |
patch = '\n'.join(npatch)
|
|
Aurélien Bompard |
626417 |
print(patch)
|
|
Pierre-Yves Chibon |
c070b4 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
c070b4 |
|
|
Pierre-Yves Chibon |
0a1494 |
def test_update_ticket_from_git_no_priority(self):
|
|
Pierre-Yves Chibon |
0a1494 |
""" Test the update_ticket_from_git method from pagure.lib.git. """
|
|
Pierre-Yves Chibon |
0a1494 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
0a1494 |
# Before
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(len(repo.issues), 0)
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues, [])
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
0a1494 |
data = {
|
|
Pierre-Yves Chibon |
0a1494 |
"status": "Open", "title": "foo", "comments": [],
|
|
Pierre-Yves Chibon |
0a1494 |
"content": "bar", "date_created": "1426500263",
|
|
Pierre-Yves Chibon |
0a1494 |
"user": {
|
|
Pierre-Yves Chibon |
0a1494 |
"name": "pingou", "emails": ["pingou@fedoraproject.org"]},
|
|
Pierre-Yves Chibon |
0a1494 |
"milestone": "Next Release",
|
|
Pierre-Yves Chibon |
0a1494 |
"priority": 1,
|
|
Pierre-Yves Chibon |
0a1494 |
}
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
a3901b |
# Invalid project
|
|
Pierre-Yves Chibon |
7a6733 |
self.assertRaises(
|
|
Pierre-Yves Chibon |
7a6733 |
pagure.exceptions.PagureException,
|
|
Pierre-Yves Chibon |
7a6733 |
pagure.lib.git.update_ticket_from_git,
|
|
Pierre-Yves Chibon |
7a6733 |
self.session,
|
|
Pierre-Yves Chibon |
7a6733 |
reponame='foobar',
|
|
Pierre-Yves Chibon |
7a6733 |
namespace=None,
|
|
Pierre-Yves Chibon |
7a6733 |
username=None,
|
|
Pierre-Yves Chibon |
7a6733 |
issue_uid='foobar',
|
|
Pierre-Yves Chibon |
b7eec1 |
json_data=data,
|
|
Pierre-Yves Chibon |
b7eec1 |
agent='pingou',
|
|
Pierre-Yves Chibon |
7a6733 |
)
|
|
Pierre-Yves Chibon |
7a6733 |
|
|
Pierre-Yves Chibon |
46750b |
# Create the issue
|
|
Pierre-Yves Chibon |
7a6733 |
data = {
|
|
Pierre-Yves Chibon |
7a6733 |
"status": "Open", "title": "foo", "comments": [],
|
|
Pierre-Yves Chibon |
7a6733 |
"content": "bar", "date_created": "1426500263",
|
|
Pierre-Yves Chibon |
7a6733 |
"user": {
|
|
Pierre-Yves Chibon |
7a6733 |
"name": "pingou", "emails": ["pingou@fedoraproject.org"]},
|
|
Pierre-Yves Chibon |
7a6733 |
"milestone": "Next Release",
|
|
Pierre-Yves Chibon |
7a6733 |
}
|
|
Pierre-Yves Chibon |
7a6733 |
|
|
Pierre-Yves Chibon |
46750b |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
46750b |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
46750b |
)
|
|
Pierre-Yves Chibon |
46750b |
self.session.commit()
|
|
Pierre-Yves Chibon |
46750b |
|
|
Pierre-Yves Chibon |
46750b |
# Edit the issue
|
|
Pierre-Yves Chibon |
7a6733 |
data = {
|
|
Pierre-Yves Chibon |
7a6733 |
"status": "Open", "title": "foo", "comments": [],
|
|
Pierre-Yves Chibon |
7a6733 |
"content": "bar", "date_created": "1426500263",
|
|
Pierre-Yves Chibon |
7a6733 |
"user": {
|
|
Pierre-Yves Chibon |
7a6733 |
"name": "pingou", "emails": ["pingou@fedoraproject.org"]},
|
|
Pierre-Yves Chibon |
7a6733 |
"milestone": "Next Release",
|
|
Pierre-Yves Chibon |
7a6733 |
"priority": 1,
|
|
Pierre-Yves Chibon |
7a6733 |
}
|
|
Pierre-Yves Chibon |
7a6733 |
|
|
Pierre-Yves Chibon |
0a1494 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
0a1494 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
0a1494 |
)
|
|
Pierre-Yves Chibon |
0a1494 |
self.session.commit()
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
0a1494 |
# Data contained a priority but not the project, so bailing
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(len(repo.issues), 1)
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].id, 1)
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].uid, 'foobar')
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].title, 'foo')
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].depending_text, [])
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].blocking_text, [])
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].milestone, 'Next Release')
|
|
Pierre-Yves Chibon |
0a1494 |
self.assertEqual(repo.issues[0].priority, None)
|
|
Pierre-Yves Chibon |
75b7f9 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
75b7f9 |
repo.milestones,
|
|
Aurélien Bompard |
626417 |
{'Next Release': {'active': True, 'date': None}})
|
|
Pierre-Yves Chibon |
0a1494 |
|
|
Pierre-Yves Chibon |
b7eec1 |
@patch('pagure.lib.notify.send_email', MagicMock(return_value=True))
|
|
Pierre-Yves Chibon |
b7eec1 |
def test_update_ticket_from_git_close_ticket(self):
|
|
Pierre-Yves Chibon |
b7eec1 |
""" Test the update_ticket_from_git method from pagure.lib.git. """
|
|
Pierre-Yves Chibon |
b7eec1 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
# Before
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(len(repo.issues), 0)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues, [])
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
# Create the issue
|
|
Pierre-Yves Chibon |
b7eec1 |
data = {
|
|
Pierre-Yves Chibon |
b7eec1 |
"status": "Open",
|
|
Pierre-Yves Chibon |
b7eec1 |
"title": "foo",
|
|
Pierre-Yves Chibon |
b7eec1 |
"comments": [],
|
|
Pierre-Yves Chibon |
b7eec1 |
"content": "bar",
|
|
Pierre-Yves Chibon |
b7eec1 |
"date_created": "1426500263",
|
|
Pierre-Yves Chibon |
b7eec1 |
"user": {
|
|
Pierre-Yves Chibon |
b7eec1 |
"name": "foo",
|
|
Pierre-Yves Chibon |
b7eec1 |
"emails": ["foo@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
b7eec1 |
},
|
|
Pierre-Yves Chibon |
b7eec1 |
"milestone": "Next Release",
|
|
Pierre-Yves Chibon |
b7eec1 |
}
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
b7eec1 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
b7eec1 |
)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.session.commit()
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
# Edit the issue
|
|
Pierre-Yves Chibon |
b7eec1 |
data = {
|
|
Pierre-Yves Chibon |
b7eec1 |
"status": "Closed",
|
|
Pierre-Yves Chibon |
b7eec1 |
"close_status": "Fixed",
|
|
Pierre-Yves Chibon |
b7eec1 |
"title": "foo",
|
|
Pierre-Yves Chibon |
b7eec1 |
"comments": [],
|
|
Pierre-Yves Chibon |
b7eec1 |
"content": "bar",
|
|
Pierre-Yves Chibon |
b7eec1 |
"date_created": "1426500263",
|
|
Pierre-Yves Chibon |
b7eec1 |
"user": {
|
|
Pierre-Yves Chibon |
b7eec1 |
"name": "foo",
|
|
Pierre-Yves Chibon |
b7eec1 |
"emails": ["foo@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
b7eec1 |
},
|
|
Pierre-Yves Chibon |
b7eec1 |
"milestone": "Next Release",
|
|
Pierre-Yves Chibon |
b7eec1 |
}
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
b7eec1 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
b7eec1 |
)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.session.commit()
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(len(repo.issues), 1)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].id, 1)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].uid, 'foobar')
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].title, 'foo')
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].depending_text, [])
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].blocking_text, [])
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].milestone, 'Next Release')
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].priority, None)
|
|
Pierre-Yves Chibon |
75b7f9 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
75b7f9 |
repo.milestones,
|
|
Aurélien Bompard |
626417 |
{'Next Release': {'active': True, 'date': None}})
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].status, 'Closed')
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(repo.issues[0].close_status, 'Fixed')
|
|
Pierre-Yves Chibon |
323e55 |
self.assertIsNotNone(repo.issues[0].closed_at)
|
|
Pierre-Yves Chibon |
b7eec1 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
b7eec1 |
repo.issues[0].comments[-1].comment,
|
|
Pierre-Yves Chibon |
b7eec1 |
'**Metadata Update from @pingou**:\n'
|
|
Pierre-Yves Chibon |
b7eec1 |
'- Issue close_status updated to: Fixed\n'
|
|
Pierre-Yves Chibon |
b7eec1 |
'- Issue status updated to: Closed (was: Open)'
|
|
Pierre-Yves Chibon |
b7eec1 |
)
|
|
Pierre-Yves Chibon |
b7eec1 |
|
|
Pierre-Yves Chibon |
2bf847 |
def test_update_ticket_from_git(self):
|
|
Pierre-Yves Chibon |
fe5017 |
""" Test the update_ticket_from_git method from pagure.lib.git. """
|
|
Pierre-Yves Chibon |
2bf847 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
0a1494 |
# Set some priorities to the project
|
|
Pierre-Yves Chibon |
0a1494 |
repo.priorities = {'1': 'High', '2': 'Normal'}
|
|
Pierre-Yves Chibon |
0a1494 |
self.session.add(repo)
|
|
Pierre-Yves Chibon |
0a1494 |
self.session.commit()
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
# Before
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(len(repo.issues), 0)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues, [])
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
data = {
|
|
Pierre-Yves Chibon |
2bf847 |
"status": "Open", "title": "foo", "comments": [],
|
|
Pierre-Yves Chibon |
2bf847 |
"content": "bar", "date_created": "1426500263",
|
|
Pierre-Yves Chibon |
2bf847 |
"user": {
|
|
Pierre-Yves Chibon |
2bf847 |
"name": "pingou", "emails": ["pingou@fedoraproject.org"]},
|
|
Clement Verna |
b30f33 |
"milestone": "Next Release",
|
|
Mark Reynolds |
7974f7 |
"priority": 1,
|
|
Pierre-Yves Chibon |
2bf847 |
}
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertRaises(
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.exceptions.PagureException,
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_ticket_from_git,
|
|
Pierre-Yves Chibon |
2bf847 |
self.session,
|
|
Pierre-Yves Chibon |
2bf847 |
reponame='foobar',
|
|
Pierre-Yves Chibon |
5abfd2 |
namespace=None,
|
|
Pierre-Yves Chibon |
2bf847 |
username=None,
|
|
Pierre-Yves Chibon |
2bf847 |
issue_uid='foobar',
|
|
Pierre-Yves Chibon |
b7eec1 |
json_data=data,
|
|
Pierre-Yves Chibon |
b7eec1 |
agent='pingou',
|
|
Pierre-Yves Chibon |
2bf847 |
)
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
5abfd2 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
2bf847 |
)
|
|
Pierre-Yves Chibon |
2bf847 |
self.session.commit()
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
# After 1 insertion
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(len(repo.issues), 1)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].id, 1)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].uid, 'foobar')
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].title, 'foo')
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].depending_text, [])
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].blocking_text, [])
|
|
Clement Verna |
b30f33 |
self.assertEqual(repo.issues[0].milestone, 'Next Release')
|
|
Mark Reynolds |
7974f7 |
self.assertEqual(repo.issues[0].priority, 1)
|
|
Pierre-Yves Chibon |
323e55 |
self.assertIsNone(repo.issues[0].closed_at)
|
|
Pierre-Yves Chibon |
75b7f9 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
75b7f9 |
repo.milestones,
|
|
Aurélien Bompard |
626417 |
{'Next Release': {'active': True, 'date': None}})
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
data["title"] = "fake issue for tests"
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
5abfd2 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
2bf847 |
)
|
|
Pierre-Yves Chibon |
2bf847 |
self.session.commit()
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
# After edit
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(len(repo.issues), 1)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].id, 1)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].uid, 'foobar')
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].title, 'fake issue for tests')
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].depending_text, [])
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].blocking_text, [])
|
|
Mark Reynolds |
7974f7 |
self.assertEqual(repo.issues[0].priority, 1)
|
|
Pierre-Yves Chibon |
323e55 |
self.assertIsNone(repo.issues[0].closed_at)
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
data = {
|
|
Pierre-Yves Chibon |
fe5017 |
"status": "Open", "title": "Rename pagure", "private": False,
|
|
Pierre-Yves Chibon |
2bf847 |
"content": "This is too much of a conflict with the book",
|
|
Pierre-Yves Chibon |
2bf847 |
"user": {
|
|
Pierre-Yves Chibon |
ec853d |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
ec853d |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
2bf847 |
"emails": ["pingou@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
2bf847 |
},
|
|
Pierre-Yves Chibon |
2bf847 |
"id": 20,
|
|
Pierre-Yves Chibon |
2bf847 |
"blocks": [1],
|
|
Pierre-Yves Chibon |
2bf847 |
"depends": [3, 4],
|
|
Pierre-Yves Chibon |
2bf847 |
"date_created": "1426595224",
|
|
Clement Verna |
b30f33 |
"milestone": "Future",
|
|
Mark Reynolds |
7974f7 |
"priority": 1,
|
|
Pierre-Yves Chibon |
2bf847 |
"comments": [
|
|
Pierre-Yves Chibon |
2bf847 |
{
|
|
Pierre-Yves Chibon |
2bf847 |
"comment": "Nirik:\r\n\r\n- sourceforge++ \r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitmaker\r\n- mastergit \r\n- hostomatic\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitcorp\r\n- git-keiretsu \r\n- gitbuffet\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"cogitator\r\n- cogitate\r\n\r\nrandomuser:\r\n\r\n- "
|
|
Aurélien Bompard |
626417 |
"COLLABORATRON5000\r\n- git-sm\\u00f6rg\\u00e5sbord\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"thislittlegittywenttomarket\r\n- git-o-rama\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitsundheit",
|
|
Pierre-Yves Chibon |
2bf847 |
"date_created": "1426595224", "id": 250, "parent": None,
|
|
Pierre-Yves Chibon |
2bf847 |
"user": {
|
|
Pierre-Yves Chibon |
2bf847 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
2bf847 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
2bf847 |
"emails": ["pingou@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
2bf847 |
}
|
|
Pierre-Yves Chibon |
2bf847 |
},
|
|
Pierre-Yves Chibon |
2bf847 |
{
|
|
Pierre-Yves Chibon |
2bf847 |
"comment": "Nirik:\r\n\r\n- sourceforge++ \r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitmaker\r\n- mastergit \r\n- hostomatic\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitcorp\r\n- git-keiretsu \r\n- gitbuffet\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"cogitator\r\n- cogitate\r\n\r\nrandomuser:\r\n\r\n- "
|
|
Aurélien Bompard |
626417 |
"COLLABORATRON5000\r\n- git-sm\\u00f6rg\\u00e5sbord\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"thislittlegittywenttomarket\r\n- git-o-rama\r\n- "
|
|
Pierre-Yves Chibon |
2bf847 |
"gitsundheit",
|
|
Pierre-Yves Chibon |
2bf847 |
"date_created": "1426595340", "id": 324, "parent": None,
|
|
Pierre-Yves Chibon |
2bf847 |
"user": {
|
|
Pierre-Yves Chibon |
2bf847 |
"fullname": "Ralph Bean",
|
|
Pierre-Yves Chibon |
2bf847 |
"name": "ralph",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "ralph@fedoraproject.org",
|
|
Pierre-Yves Chibon |
2bf847 |
"emails": ["ralph@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
2bf847 |
}
|
|
Pierre-Yves Chibon |
2bf847 |
}
|
|
Pierre-Yves Chibon |
2bf847 |
]
|
|
Pierre-Yves Chibon |
2bf847 |
}
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_ticket_from_git(
|
|
Pierre-Yves Chibon |
5abfd2 |
self.session, reponame='test', namespace=None, username=None,
|
|
Pierre-Yves Chibon |
b7eec1 |
issue_uid='foobar2', json_data=data, agent='pingou',
|
|
Pierre-Yves Chibon |
2bf847 |
)
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
2bf847 |
# After second insertion
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(len(repo.issues), 2)
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].uid, 'foobar')
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[0].title, 'fake issue for tests')
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].depending_text, [20])
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[0].blocking_text, [])
|
|
Pierre-Yves Chibon |
323e55 |
self.assertIsNone(repo.issues[0].closed_at)
|
|
Pierre-Yves Chibon |
2bf847 |
# New one
|
|
Pierre-Yves Chibon |
2bf847 |
self.assertEqual(repo.issues[1].uid, 'foobar2')
|
|
Pierre-Yves Chibon |
fe5017 |
self.assertEqual(repo.issues[1].title, 'Rename pagure')
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[1].depending_text, [])
|
|
Pierre-Yves Chibon |
215f54 |
self.assertEqual(repo.issues[1].blocking_text, [1])
|
|
Clement Verna |
b30f33 |
self.assertEqual(repo.issues[1].milestone, 'Future')
|
|
Pierre-Yves Chibon |
323e55 |
self.assertIsNone(repo.issues[1].closed_at)
|
|
Aurélien Bompard |
f61bb3 |
self.assertDictEqual(
|
|
Pierre-Yves Chibon |
75b7f9 |
repo.milestones,
|
|
Pierre-Yves Chibon |
75b7f9 |
{
|
|
Aurélien Bompard |
626417 |
'Future': {'active': True, 'date': None},
|
|
Aurélien Bompard |
626417 |
'Next Release': {'active': True, 'date': None}
|
|
Pierre-Yves Chibon |
75b7f9 |
}
|
|
Pierre-Yves Chibon |
75b7f9 |
)
|
|
Pierre-Yves Chibon |
2bf847 |
|
|
Pierre-Yves Chibon |
f692f5 |
def test_update_request_from_git(self):
|
|
Pierre-Yves Chibon |
fe5017 |
""" Test the update_request_from_git method from pagure.lib.git. """
|
|
Pierre-Yves Chibon |
f692f5 |
tests.create_projects(self.session)
|
|
Jeremy Cline |
20109f |
tests.create_projects_git(os.path.join(self.path, 'repos'))
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query._get_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
930073 |
namespaced_repo = pagure.lib.query._get_project(self.session, 'test3', namespace='somenamespace')
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
# Before
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests), 0)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests, [])
|
|
clime |
afed57 |
self.assertEqual(len(namespaced_repo.requests), 0)
|
|
clime |
afed57 |
self.assertEqual(namespaced_repo.requests, [])
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
data = {
|
|
Pierre-Yves Chibon |
f692f5 |
"status": True,
|
|
Pierre-Yves Chibon |
f692f5 |
"uid": "d4182a2ac2d541d884742d3037c26e56",
|
|
Pierre-Yves Chibon |
4dd52c |
"project": {
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426500194",
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
700d02 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
700d02 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 1,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"commit_stop": "eface8e13bc2a08a3fb22af9a72a8c90e36b8b89",
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
f692f5 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": ["pingou@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 7,
|
|
Pierre-Yves Chibon |
f692f5 |
"comments": [
|
|
Pierre-Yves Chibon |
f692f5 |
{
|
|
Pierre-Yves Chibon |
f692f5 |
"comment": "really?",
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
f692f5 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": ["pingou@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426843778",
|
|
Pierre-Yves Chibon |
f692f5 |
"commit": "fa72f315373ec5f98f2b08c8ffae3645c97aaad2",
|
|
Pierre-Yves Chibon |
f692f5 |
"line": 5,
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 1,
|
|
Pierre-Yves Chibon |
f692f5 |
"filename": "test"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
{
|
|
Pierre-Yves Chibon |
f692f5 |
"comment": "Again ?",
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
f692f5 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
f692f5 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426866781",
|
|
Pierre-Yves Chibon |
f692f5 |
"commit": "94ebaf900161394059478fd88aec30e59092a1d7",
|
|
Pierre-Yves Chibon |
f692f5 |
"line": 5,
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 2,
|
|
Pierre-Yves Chibon |
f692f5 |
"filename": "test2"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
{
|
|
Pierre-Yves Chibon |
f692f5 |
"comment": "Should be fine in fact",
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
f692f5 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
f692f5 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426866950",
|
|
Pierre-Yves Chibon |
f692f5 |
"commit": "94ebaf900161394059478fd88aec30e59092a1d7",
|
|
Pierre-Yves Chibon |
f692f5 |
"line": 5,
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 3,
|
|
Pierre-Yves Chibon |
f692f5 |
"filename": "test2"
|
|
Pierre-Yves Chibon |
f692f5 |
}
|
|
Pierre-Yves Chibon |
f692f5 |
],
|
|
Pierre-Yves Chibon |
f692f5 |
"branch_from": "master",
|
|
Pierre-Yves Chibon |
f692f5 |
"title": "test request",
|
|
Pierre-Yves Chibon |
f692f5 |
"commit_start": "788efeaaf86bde8618f594a8181abb402e1dd904",
|
|
Pierre-Yves Chibon |
f692f5 |
"repo_from": {
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": {
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426500194",
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 1,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426843440",
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "fake user",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "fake",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "fake@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"fake@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 6,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"branch": "master",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426843732"
|
|
Pierre-Yves Chibon |
f692f5 |
}
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertRaises(
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.exceptions.PagureException,
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_request_from_git,
|
|
Pierre-Yves Chibon |
f692f5 |
self.session,
|
|
Pierre-Yves Chibon |
f692f5 |
reponame='foobar',
|
|
Pierre-Yves Chibon |
5abfd2 |
namespace=None,
|
|
Pierre-Yves Chibon |
f692f5 |
username=None,
|
|
Pierre-Yves Chibon |
f692f5 |
request_uid='d4182a2ac2d541d884742d3037c26e56',
|
|
Pierre-Yves Chibon |
f692f5 |
json_data=data,
|
|
Pierre-Yves Chibon |
f692f5 |
)
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_request_from_git(
|
|
Pierre-Yves Chibon |
f692f5 |
self.session,
|
|
Pierre-Yves Chibon |
f692f5 |
reponame='test',
|
|
Pierre-Yves Chibon |
5abfd2 |
namespace=None,
|
|
Pierre-Yves Chibon |
f692f5 |
username=None,
|
|
Pierre-Yves Chibon |
f692f5 |
request_uid='d4182a2ac2d541d884742d3037c26e56',
|
|
Pierre-Yves Chibon |
f692f5 |
json_data=data,
|
|
Pierre-Yves Chibon |
f692f5 |
)
|
|
Pierre-Yves Chibon |
f692f5 |
self.session.commit()
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
# After 1 st insertion
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests), 1)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[0].id, 7)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
f692f5 |
repo.requests[0].uid, 'd4182a2ac2d541d884742d3037c26e56')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[0].title, 'test request')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests[0].comments), 3)
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
data = {
|
|
Pierre-Yves Chibon |
f692f5 |
"status": True,
|
|
Pierre-Yves Chibon |
f692f5 |
"uid": "d4182a2ac2d541d884742d3037c26e57",
|
|
Pierre-Yves Chibon |
4dd52c |
"project": {
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426500194",
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
700d02 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
700d02 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 1,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"commit_stop": "eface8e13bc2a08a3fb22af9a72a8c90e36b8b89",
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
f692f5 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
ec853d |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": ["pingou@fedoraproject.org"]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 4,
|
|
Pierre-Yves Chibon |
f692f5 |
"comments": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"branch_from": "master",
|
|
Pierre-Yves Chibon |
f692f5 |
"title": "test request #2",
|
|
Pierre-Yves Chibon |
f692f5 |
"commit_start": "788efeaaf86bde8618f594a8181abb402e1dd904",
|
|
Pierre-Yves Chibon |
f692f5 |
"repo_from": {
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": {
|
|
Pierre-Yves Chibon |
f692f5 |
"parent": None,
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426500194",
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "Pierre-YvesChibon",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "pingou",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "pingou@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"pingou@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 1,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
719bdd |
"settings": {
|
|
Pierre-Yves Chibon |
719bdd |
"issue_tracker": True,
|
|
Pierre-Yves Chibon |
719bdd |
"project_documentation": True,
|
|
Pierre-Yves Chibon |
719bdd |
"pull_requests": True,
|
|
Pierre-Yves Chibon |
719bdd |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"name": "test",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426843440",
|
|
Pierre-Yves Chibon |
022564 |
"custom_keys": [],
|
|
Pierre-Yves Chibon |
a30916 |
"tags": [],
|
|
Pierre-Yves Chibon |
f692f5 |
"user": {
|
|
Pierre-Yves Chibon |
700d02 |
"fullname": "fake user",
|
|
Pierre-Yves Chibon |
700d02 |
"name": "fake",
|
|
Pierre-Yves Chibon |
700d02 |
"default_email": "fake@fedoraproject.org",
|
|
Pierre-Yves Chibon |
f692f5 |
"emails": [
|
|
Pierre-Yves Chibon |
700d02 |
"fake@fedoraproject.org"
|
|
Pierre-Yves Chibon |
f692f5 |
]
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"project_docs": True,
|
|
Pierre-Yves Chibon |
f692f5 |
"id": 6,
|
|
Pierre-Yves Chibon |
f692f5 |
"description": "test project"
|
|
Pierre-Yves Chibon |
f692f5 |
},
|
|
Pierre-Yves Chibon |
f692f5 |
"branch": "master",
|
|
Pierre-Yves Chibon |
f692f5 |
"date_created": "1426843745"
|
|
Pierre-Yves Chibon |
f692f5 |
}
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
fe5017 |
pagure.lib.git.update_request_from_git(
|
|
Pierre-Yves Chibon |
f692f5 |
self.session,
|
|
Pierre-Yves Chibon |
f692f5 |
reponame='test',
|
|
Pierre-Yves Chibon |
5abfd2 |
namespace=None,
|
|
Pierre-Yves Chibon |
f692f5 |
username=None,
|
|
Pierre-Yves Chibon |
f692f5 |
request_uid='d4182a2ac2d541d884742d3037c26e57',
|
|
Pierre-Yves Chibon |
f692f5 |
json_data=data,
|
|
Pierre-Yves Chibon |
f692f5 |
)
|
|
Pierre-Yves Chibon |
f692f5 |
self.session.commit()
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
Pierre-Yves Chibon |
f692f5 |
# After 2 nd insertion
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests), 2)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[0].id, 7)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
f692f5 |
repo.requests[0].uid, 'd4182a2ac2d541d884742d3037c26e56')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[0].title, 'test request')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests[0].comments), 3)
|
|
Pierre-Yves Chibon |
f692f5 |
# 2 entry
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[1].id, 4)
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(
|
|
Pierre-Yves Chibon |
f692f5 |
repo.requests[1].uid, 'd4182a2ac2d541d884742d3037c26e57')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(repo.requests[1].title, 'test request #2')
|
|
Pierre-Yves Chibon |
f692f5 |
self.assertEqual(len(repo.requests[1].comments), 0)
|
|
Pierre-Yves Chibon |
f692f5 |
|
|
clime |
afed57 |
data = {
|
|
clime |
afed57 |
"status": True,
|
|
clime |
afed57 |
"uid": "d4182a2ac2d541d884742d3037c26e58",
|
|
clime |
afed57 |
"project": {
|
|
clime |
afed57 |
"parent": None,
|
|
clime |
afed57 |
"name": "test3",
|
|
clime |
afed57 |
"custom_keys": [],
|
|
clime |
afed57 |
"namespace": "somenamespace",
|
|
clime |
afed57 |
"date_created": "1426500194",
|
|
clime |
afed57 |
"tags": [],
|
|
clime |
afed57 |
"user": {
|
|
clime |
afed57 |
"fullname": "Pierre-YvesChibon",
|
|
clime |
afed57 |
"name": "pingou",
|
|
clime |
afed57 |
"default_email": "pingou@fedoraproject.org",
|
|
clime |
afed57 |
"emails": [
|
|
clime |
afed57 |
"pingou@fedoraproject.org"
|
|
clime |
afed57 |
]
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"settings": {
|
|
clime |
afed57 |
"issue_tracker": True,
|
|
clime |
afed57 |
"project_documentation": True,
|
|
clime |
afed57 |
"pull_requests": True,
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"id": 3,
|
|
clime |
afed57 |
"description": "namespaced test project"
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"commit_stop": "eface8e13bc2a08a3fb22af9a72a8c90e36b8b89",
|
|
clime |
afed57 |
"user": {
|
|
clime |
afed57 |
"fullname": "Pierre-YvesChibon",
|
|
clime |
afed57 |
"name": "pingou",
|
|
clime |
afed57 |
"default_email": "pingou@fedoraproject.org",
|
|
clime |
afed57 |
"emails": ["pingou@fedoraproject.org"]
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"id": 5,
|
|
clime |
afed57 |
"comments": [],
|
|
clime |
afed57 |
"branch_from": "master",
|
|
clime |
afed57 |
"title": "test request to namespaced repo",
|
|
clime |
afed57 |
"commit_start": "788efeaaf86bde8618f594a8181abb402e1dd904",
|
|
clime |
afed57 |
"repo_from": {
|
|
clime |
afed57 |
"parent": {
|
|
clime |
afed57 |
"parent": None,
|
|
clime |
afed57 |
"name": "test",
|
|
clime |
afed57 |
"custom_keys": [],
|
|
clime |
afed57 |
"date_created": "1426500194",
|
|
clime |
afed57 |
"tags": [],
|
|
clime |
afed57 |
"user": {
|
|
clime |
afed57 |
"fullname": "Pierre-YvesChibon",
|
|
clime |
afed57 |
"name": "pingou",
|
|
clime |
afed57 |
"default_email": "pingou@fedoraproject.org",
|
|
clime |
afed57 |
"emails": [
|
|
clime |
afed57 |
"pingou@fedoraproject.org"
|
|
clime |
afed57 |
]
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"settings": {
|
|
clime |
afed57 |
"issue_tracker": True,
|
|
clime |
afed57 |
"project_documentation": True,
|
|
clime |
afed57 |
"pull_requests": True,
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"id": 1,
|
|
clime |
afed57 |
"description": "test project"
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"settings": {
|
|
clime |
afed57 |
"issue_tracker": True,
|
|
clime |
afed57 |
"project_documentation": True,
|
|
clime |
afed57 |
"pull_requests": True,
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"name": "test",
|
|
clime |
afed57 |
"date_created": "1426843440",
|
|
clime |
afed57 |
"custom_keys": [],
|
|
clime |
afed57 |
"tags": [],
|
|
clime |
afed57 |
"user": {
|
|
clime |
afed57 |
"fullname": "fake user",
|
|
clime |
afed57 |
"name": "fake",
|
|
clime |
afed57 |
"default_email": "fake@fedoraproject.org",
|
|
clime |
afed57 |
"emails": [
|
|
clime |
afed57 |
"fake@fedoraproject.org"
|
|
clime |
afed57 |
]
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"project_docs": True,
|
|
clime |
afed57 |
"id": 6,
|
|
clime |
afed57 |
"description": "test project"
|
|
clime |
afed57 |
},
|
|
clime |
afed57 |
"branch": "master",
|
|
clime |
afed57 |
"date_created": "1426843745"
|
|
clime |
afed57 |
}
|
|
clime |
afed57 |
pagure.lib.git.update_request_from_git(
|
|
clime |
afed57 |
self.session,
|
|
clime |
afed57 |
reponame='test3',
|
|
clime |
afed57 |
namespace='somenamespace',
|
|
clime |
afed57 |
username=None,
|
|
clime |
afed57 |
request_uid='d4182a2ac2d541d884742d3037c26e58',
|
|
clime |
afed57 |
json_data=data,
|
|
clime |
afed57 |
)
|
|
clime |
afed57 |
self.session.commit()
|
|
clime |
afed57 |
|
|
clime |
afed57 |
self.assertEqual(len(namespaced_repo.requests), 1)
|
|
clime |
afed57 |
self.assertEqual(namespaced_repo.requests[0].id, 5)
|
|
clime |
afed57 |
self.assertEqual(
|
|
clime |
afed57 |
namespaced_repo.requests[0].uid,
|
|
clime |
afed57 |
'd4182a2ac2d541d884742d3037c26e58'
|
|
clime |
afed57 |
)
|
|
clime |
afed57 |
self.assertEqual(
|
|
clime |
afed57 |
namespaced_repo.requests[0].title,
|
|
clime |
afed57 |
'test request to namespaced repo'
|
|
clime |
afed57 |
)
|
|
clime |
afed57 |
|
|
Patrick Uiterwijk |
b4c473 |
def test_read_git_lines(self):
|
|
Pierre-Yves Chibon |
858b9d |
""" Test the read_git_lines method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
858b9d |
self.test_update_git()
|
|
Pierre-Yves Chibon |
858b9d |
|
|
Slavek Kabrda |
adea20 |
gitrepo = os.path.join(self.path, 'repos', 'tickets', 'test_ticket_repo.git')
|
|
Pierre-Yves Chibon |
858b9d |
output = pagure.lib.git.read_git_lines(
|
|
Pierre-Yves Chibon |
858b9d |
['log', '-1', "--pretty='%s'"], gitrepo)
|
|
Pierre-Yves Chibon |
858b9d |
self.assertEqual(len(output), 1)
|
|
Pierre-Yves Chibon |
858b9d |
self.assertTrue(
|
|
Pierre-Yves Chibon |
e64141 |
output[0].startswith("'Updated issue ")
|
|
Pierre-Yves Chibon |
858b9d |
)
|
|
Pierre-Yves Chibon |
858b9d |
self.assertTrue(
|
|
Pierre-Yves Chibon |
858b9d |
output[0].endswith(": Test issue'")
|
|
Pierre-Yves Chibon |
858b9d |
)
|
|
Pierre-Yves Chibon |
858b9d |
|
|
Pierre-Yves Chibon |
858b9d |
# Keeping the new line symbol
|
|
Pierre-Yves Chibon |
858b9d |
output = pagure.lib.git.read_git_lines(
|
|
Pierre-Yves Chibon |
858b9d |
['log', '-1', "--pretty='%s'"], gitrepo, keepends=True)
|
|
Pierre-Yves Chibon |
858b9d |
self.assertEqual(len(output), 1)
|
|
Pierre-Yves Chibon |
858b9d |
self.assertTrue(
|
|
Pierre-Yves Chibon |
858b9d |
output[0].endswith(": Test issue'\n")
|
|
Pierre-Yves Chibon |
858b9d |
)
|
|
Pierre-Yves Chibon |
858b9d |
|
|
Patrick Uiterwijk |
b4c473 |
def test_get_revs_between(self):
|
|
Pierre-Yves Chibon |
32fce0 |
""" Test the get_revs_between method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
32fce0 |
|
|
Pierre-Yves Chibon |
32fce0 |
self.test_update_git()
|
|
Pierre-Yves Chibon |
32fce0 |
|
|
Slavek Kabrda |
adea20 |
gitrepo = os.path.join(self.path, 'repos', 'tickets', 'test_ticket_repo.git')
|
|
Pierre-Yves Chibon |
32fce0 |
output = pagure.lib.git.read_git_lines(
|
|
Pierre-Yves Chibon |
32fce0 |
['log', '-3', "--pretty='%H'"], gitrepo)
|
|
Pierre-Yves Chibon |
32fce0 |
self.assertEqual(len(output), 2)
|
|
Pierre-Yves Chibon |
32fce0 |
from_hash = output[1].replace("'", '')
|
|
Pierre-Yves Chibon |
32fce0 |
|
|
Clement Verna |
1901d5 |
# Case 1, repo BASE is null and HEAD is equal to from_hash
|
|
Clement Verna |
1901d5 |
to_hash = '0'
|
|
Pierre-Yves Chibon |
32fce0 |
output1 = pagure.lib.git.get_revs_between(
|
|
Clement Verna |
f202e4 |
to_hash, from_hash, gitrepo, 'refs/heads/master')
|
|
Clement Verna |
990b72 |
self.assertEqual(output1, [from_hash])
|
|
Pierre-Yves Chibon |
32fce0 |
|
|
Clement Verna |
1901d5 |
# Case 2, get revs between two commits (to_hash, from_hash)
|
|
Clement Verna |
1901d5 |
to_hash = output[0].replace("'", '')
|
|
Pierre-Yves Chibon |
32fce0 |
output2 = pagure.lib.git.get_revs_between(
|
|
Clement Verna |
f202e4 |
to_hash, from_hash, gitrepo, 'refs/heads/master')
|
|
Pierre-Yves Chibon |
32fce0 |
self.assertEqual(output2, [to_hash])
|
|
Pierre-Yves Chibon |
32fce0 |
|
|
Clement Verna |
1901d5 |
# Case 3, get revs between two commits (from_hash, to_hash)
|
|
Clement Verna |
1901d5 |
output3 = pagure.lib.git.get_revs_between(
|
|
Clement Verna |
f202e4 |
from_hash, to_hash, gitrepo, 'refs/heads/master')
|
|
Clement Verna |
1901d5 |
self.assertEqual(output3, [to_hash])
|
|
Clement Verna |
1901d5 |
|
|
Clement Verna |
469e2c |
# Case 4, get revs between two commits on two different branches
|
|
Clement Verna |
469e2c |
newgitrepo = tempfile.mkdtemp(prefix='pagure-')
|
|
Clement Verna |
469e2c |
newrepo = pygit2.clone_repository(gitrepo, newgitrepo)
|
|
Clement Verna |
469e2c |
newrepo.create_branch('feature', newrepo.head.get_object())
|
|
Clement Verna |
469e2c |
|
|
Clement Verna |
469e2c |
with open(os.path.join(newgitrepo, 'sources'), 'w') as stream:
|
|
Clement Verna |
469e2c |
stream.write('foo\n bar')
|
|
Clement Verna |
469e2c |
newrepo.index.add('sources')
|
|
Clement Verna |
469e2c |
newrepo.index.write()
|
|
Clement Verna |
469e2c |
|
|
Clement Verna |
469e2c |
# Commits the files added
|
|
Clement Verna |
469e2c |
tree = newrepo.index.write_tree()
|
|
Clement Verna |
469e2c |
author = pygit2.Signature(
|
|
Clement Verna |
469e2c |
'Alice Author', 'alice@authors.tld')
|
|
Clement Verna |
469e2c |
committer = pygit2.Signature(
|
|
Clement Verna |
469e2c |
'Cecil Committer', 'cecil@committers.tld')
|
|
Clement Verna |
469e2c |
newrepo.create_commit(
|
|
Clement Verna |
469e2c |
'refs/heads/feature', # the name of the reference to update
|
|
Clement Verna |
469e2c |
author,
|
|
Clement Verna |
469e2c |
committer,
|
|
Clement Verna |
469e2c |
'Add sources file for testing',
|
|
Clement Verna |
469e2c |
# binary string representing the tree object ID
|
|
Clement Verna |
469e2c |
tree,
|
|
Clement Verna |
469e2c |
# list of binary strings representing parents of the new commit
|
|
Clement Verna |
469e2c |
[to_hash]
|
|
Clement Verna |
469e2c |
)
|
|
Clement Verna |
469e2c |
branch_commit = newrepo.revparse_single('refs/heads/feature')
|
|
Clement Verna |
469e2c |
|
|
Clement Verna |
469e2c |
# Push to origin
|
|
Clement Verna |
469e2c |
ori_remote = newrepo.remotes[0]
|
|
Clement Verna |
469e2c |
PagureRepo.push(ori_remote, 'refs/heads/feature')
|
|
Clement Verna |
469e2c |
|
|
Clement Verna |
469e2c |
# Remove the clone
|
|
Clement Verna |
469e2c |
shutil.rmtree(newgitrepo)
|
|
Clement Verna |
469e2c |
|
|
Clement Verna |
469e2c |
output4 = pagure.lib.git.get_revs_between(
|
|
Clement Verna |
f202e4 |
'0', branch_commit.oid.hex, gitrepo, 'refs/heads/feature')
|
|
Clement Verna |
469e2c |
self.assertEqual(output4, [branch_commit.oid.hex])
|
|
Clement Verna |
469e2c |
|
|
Patrick Uiterwijk |
b4c473 |
def test_get_author(self):
|
|
Pierre-Yves Chibon |
ad3d68 |
""" Test the get_author method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
84cd98 |
|
|
Pierre-Yves Chibon |
84cd98 |
self.test_update_git()
|
|
Pierre-Yves Chibon |
84cd98 |
|
|
Slavek Kabrda |
adea20 |
gitrepo = os.path.join(self.path, 'repos', 'tickets', 'test_ticket_repo.git')
|
|
Pierre-Yves Chibon |
84cd98 |
output = pagure.lib.git.read_git_lines(
|
|
Pierre-Yves Chibon |
84cd98 |
['log', '-3', "--pretty='%H'"], gitrepo)
|
|
Pierre-Yves Chibon |
84cd98 |
self.assertEqual(len(output), 2)
|
|
Pierre-Yves Chibon |
84cd98 |
for githash in output:
|
|
Pierre-Yves Chibon |
84cd98 |
githash = githash.replace("'", '')
|
|
Pierre-Yves Chibon |
ad3d68 |
output = pagure.lib.git.get_author(githash, gitrepo)
|
|
Pierre-Yves Chibon |
84cd98 |
self.assertEqual(output, 'pagure')
|
|
Pierre-Yves Chibon |
84cd98 |
|
|
Pierre-Yves Chibon |
ad3d68 |
def get_author_email(self):
|
|
Pierre-Yves Chibon |
ad3d68 |
""" Test the get_author_email method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
f69b11 |
|
|
Pierre-Yves Chibon |
f69b11 |
self.test_update_git()
|
|
Pierre-Yves Chibon |
f69b11 |
|
|
Patrick Uiterwijk |
170974 |
gitrepo = os.path.join(self.path, 'tickets', 'test_ticket_repo.git')
|
|
Pierre-Yves Chibon |
f69b11 |
output = pagure.lib.git.read_git_lines(
|
|
Pierre-Yves Chibon |
f69b11 |
['log', '-3', "--pretty='%H'"], gitrepo)
|
|
Pierre-Yves Chibon |
f69b11 |
self.assertEqual(len(output), 2)
|
|
Pierre-Yves Chibon |
f69b11 |
for githash in output:
|
|
Pierre-Yves Chibon |
f69b11 |
githash = githash.replace("'", '')
|
|
Pierre-Yves Chibon |
ad3d68 |
output = pagure.lib.git.get_author_email(githash, gitrepo)
|
|
Pierre-Yves Chibon |
f69b11 |
self.assertEqual(output, 'pagure')
|
|
Pierre-Yves Chibon |
f69b11 |
|
|
Pierre-Yves Chibon |
cf28b3 |
def test_get_repo_name(self):
|
|
Pierre-Yves Chibon |
cf28b3 |
""" Test the get_repo_name method of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
cf28b3 |
|
|
Patrick Uiterwijk |
4012dc |
def runtest(reponame, *path):
|
|
Patrick Uiterwijk |
4012dc |
gitrepo = os.path.join(self.path, 'repos', *path)
|
|
Patrick Uiterwijk |
4012dc |
os.makedirs(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
repo_name = pagure.lib.git.get_repo_name(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
self.assertEqual(repo_name, reponame)
|
|
Pierre-Yves Chibon |
cf28b3 |
|
|
Patrick Uiterwijk |
4012dc |
runtest('test_ticket_repo', 'tickets', 'test_ticket_repo.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('test', 'test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('foo.test', 'foo.test.git')
|
|
Pierre-Yves Chibon |
cf28b3 |
|
|
Pierre-Yves Chibon |
a7c15a |
def test_get_username(self):
|
|
Pierre-Yves Chibon |
a7c15a |
""" Test the get_username method of pagure.lib.git. """
|
|
Patrick Uiterwijk |
4012dc |
def runtest(username, *path):
|
|
Patrick Uiterwijk |
4012dc |
gitrepo = os.path.join(self.path, 'repos', *path)
|
|
Patrick Uiterwijk |
4012dc |
os.makedirs(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
repo_username = pagure.lib.git.get_username(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
self.assertEqual(repo_username, username)
|
|
Patrick Uiterwijk |
4012dc |
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'tickets', 'test_ticket_repo.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('pingou', 'forks', 'pingou', 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('pingou', 'forks', 'pingou', 'bar/foo.test.git')
|
|
Pierre-Yves Chibon |
826fb9 |
|
|
Pierre-Yves Chibon |
0eb3ee |
def test_get_repo_namespace(self):
|
|
Pierre-Yves Chibon |
0eb3ee |
""" Test the get_repo_namespace method of pagure.lib.git. """
|
|
Patrick Uiterwijk |
4012dc |
def runtest(namespace, *path):
|
|
Patrick Uiterwijk |
4012dc |
gitrepo = os.path.join(self.path, 'repos', *path)
|
|
Patrick Uiterwijk |
4012dc |
if not os.path.exists(gitrepo):
|
|
Patrick Uiterwijk |
4012dc |
os.makedirs(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
repo_namespace = pagure.lib.git.get_repo_namespace(gitrepo)
|
|
Patrick Uiterwijk |
4012dc |
self.assertEqual(repo_namespace, namespace)
|
|
Patrick Uiterwijk |
4012dc |
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'test_ticket_repo.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('foo/bar/baz', 'foo', 'bar', 'baz', 'test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest(None, 'forks', 'user', 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('bar', 'forks', 'user', 'bar', 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('ns/bar', 'forks', 'user', 'ns', 'bar', 'foo.test.git')
|
|
Patrick Uiterwijk |
4012dc |
runtest('bar', 'forks', 'user', 'bar', 'foo.test.git')
|
|
Pierre-Yves Chibon |
0eb3ee |
|
|
Vivek Anand |
763ae5 |
def test_update_custom_fields_from_json(self):
|
|
Vivek Anand |
763ae5 |
""" Test the update_custom_fields_from_json method of lib.git """
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
tests.create_projects(self.session)
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query._get_project(self.session, 'test')
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
# Create issues to play with
|
|
Pierre-Yves Chibon |
930073 |
pagure.lib.query.new_issue(
|
|
Vivek Anand |
763ae5 |
session=self.session,
|
|
Vivek Anand |
763ae5 |
repo=repo,
|
|
Vivek Anand |
763ae5 |
title='Test issue',
|
|
Vivek Anand |
763ae5 |
content='We should work on this',
|
|
Vivek Anand |
763ae5 |
user='pingou',
|
|
Vivek Anand |
763ae5 |
issue_uid='someuid'
|
|
Vivek Anand |
763ae5 |
)
|
|
Vivek Anand |
763ae5 |
self.session.commit()
|
|
Vivek Anand |
763ae5 |
|
|
Pierre-Yves Chibon |
930073 |
issue = pagure.lib.query.get_issue_by_uid(self.session, 'someuid')
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
# Fake json data, currently without custom_fields
|
|
Vivek Anand |
763ae5 |
# This should bring no new custom_fields to the issue
|
|
Vivek Anand |
763ae5 |
json_data = {
|
|
Vivek Anand |
763ae5 |
"status": "Open",
|
|
Vivek Anand |
763ae5 |
"title": "Test issue",
|
|
Vivek Anand |
763ae5 |
"private": False,
|
|
Vivek Anand |
763ae5 |
"content": "We should work on this",
|
|
Vivek Anand |
763ae5 |
"user": {
|
|
Vivek Anand |
763ae5 |
"fullname": "PY C",
|
|
Vivek Anand |
763ae5 |
"name": "pingou",
|
|
Vivek Anand |
763ae5 |
"default_email": "bar@pingou.com",
|
|
Vivek Anand |
763ae5 |
"emails": ["bar@pingou.com"]
|
|
Vivek Anand |
763ae5 |
},
|
|
Vivek Anand |
763ae5 |
"id": 1,
|
|
Vivek Anand |
763ae5 |
"blocks": [],
|
|
Vivek Anand |
763ae5 |
"depends": [],
|
|
Vivek Anand |
763ae5 |
"date_created": "1234567",
|
|
Vivek Anand |
763ae5 |
"comments": [],
|
|
Vivek Anand |
763ae5 |
}
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
pagure.lib.git.update_custom_field_from_json(
|
|
Pierre-Yves Chibon |
a18547 |
self.session, repo, issue, json_data)
|
|
Vivek Anand |
763ae5 |
|
|
Pierre-Yves Chibon |
930073 |
updated_issue = pagure.lib.query.get_issue_by_uid(self.session, 'someuid')
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
self.assertEqual(updated_issue.to_json().get('custom_fields'), [])
|
|
Vivek Anand |
763ae5 |
custom_fields = [
|
|
Vivek Anand |
763ae5 |
{
|
|
Vivek Anand |
763ae5 |
"name": "custom1",
|
|
Vivek Anand |
763ae5 |
"key_type": "text",
|
|
Vivek Anand |
763ae5 |
"value": "value1",
|
|
Pierre-Yves Chibon |
cb755e |
"key_data": None,
|
|
Vivek Anand |
763ae5 |
},
|
|
Vivek Anand |
763ae5 |
{
|
|
Vivek Anand |
763ae5 |
"name": "custom2",
|
|
Vivek Anand |
763ae5 |
"key_type": "text",
|
|
Vivek Anand |
763ae5 |
"value": "value2",
|
|
Pierre-Yves Chibon |
cb755e |
"key_data": None,
|
|
Vivek Anand |
763ae5 |
}
|
|
Vivek Anand |
763ae5 |
]
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
# Again, Fake the json data but, with custom_fields in it
|
|
Vivek Anand |
763ae5 |
# The updated issue should have the custom_fields as
|
|
Vivek Anand |
763ae5 |
# was in the json_data
|
|
Vivek Anand |
763ae5 |
json_data = {
|
|
Vivek Anand |
763ae5 |
"status": "Open",
|
|
Vivek Anand |
763ae5 |
"title": "Test issue",
|
|
Vivek Anand |
763ae5 |
"private": False,
|
|
Vivek Anand |
763ae5 |
"content": "We should work on this",
|
|
Vivek Anand |
763ae5 |
"user": {
|
|
Vivek Anand |
763ae5 |
"fullname": "PY C",
|
|
Vivek Anand |
763ae5 |
"name": "pingou",
|
|
Vivek Anand |
763ae5 |
"default_email": "bar@pingou.com",
|
|
Vivek Anand |
763ae5 |
"emails": ["bar@pingou.com"]
|
|
Vivek Anand |
763ae5 |
},
|
|
Vivek Anand |
763ae5 |
"id": 1,
|
|
Vivek Anand |
763ae5 |
"blocks": [],
|
|
Vivek Anand |
763ae5 |
"depends": [],
|
|
Vivek Anand |
763ae5 |
"date_created": "1234567",
|
|
Vivek Anand |
763ae5 |
"comments": [],
|
|
Vivek Anand |
763ae5 |
"custom_fields": custom_fields,
|
|
Vivek Anand |
763ae5 |
}
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
pagure.lib.git.update_custom_field_from_json(
|
|
Pierre-Yves Chibon |
a18547 |
self.session, repo, issue, json_data)
|
|
Vivek Anand |
763ae5 |
|
|
Pierre-Yves Chibon |
930073 |
updated_issue = pagure.lib.query.get_issue_by_uid(self.session, 'someuid')
|
|
Vivek Anand |
763ae5 |
|
|
Vivek Anand |
763ae5 |
custom_fields_of_issue = updated_issue.to_json().get('custom_fields')
|
|
Vivek Anand |
763ae5 |
self.assertEqual(custom_fields_of_issue, custom_fields)
|
|
Pierre-Yves Chibon |
0eb3ee |
|
|
Pierre-Yves Chibon |
a3fe59 |
@patch('pagure.lib.notify.send_email')
|
|
Pierre-Yves Chibon |
a3fe59 |
@patch('pagure.lib.git.update_git')
|
|
Pierre-Yves Chibon |
a3fe59 |
def test_merge_pull_request_no_master(self, email_f, up_git):
|
|
Pierre-Yves Chibon |
a3fe59 |
""" Test the merge_pull_request function when there are no master
|
|
Pierre-Yves Chibon |
a3fe59 |
branch in the repo. """
|
|
Pierre-Yves Chibon |
a3fe59 |
email_f.return_value = True
|
|
Pierre-Yves Chibon |
a3fe59 |
up_git.return_value = True
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
a3fe59 |
gitfolder = os.path.join(self.path, 'repos')
|
|
Pierre-Yves Chibon |
a3fe59 |
docfolder = os.path.join(self.path, 'docs')
|
|
Pierre-Yves Chibon |
a3fe59 |
ticketfolder = os.path.join(self.path, 'tickets')
|
|
Pierre-Yves Chibon |
a3fe59 |
requestfolder = os.path.join(self.path, 'requests')
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
a3fe59 |
# Create project
|
|
Pierre-Yves Chibon |
a3fe59 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
a3fe59 |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
a3fe59 |
name='test',
|
|
Pierre-Yves Chibon |
a3fe59 |
description='test project',
|
|
Pierre-Yves Chibon |
a3fe59 |
hook_token='aaabbbwww',
|
|
Pierre-Yves Chibon |
a3fe59 |
)
|
|
Pierre-Yves Chibon |
a3fe59 |
self.session.add(item)
|
|
Pierre-Yves Chibon |
a3fe59 |
self.session.commit()
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
a3fe59 |
gitrepo = os.path.join(gitfolder, repo.path)
|
|
Pierre-Yves Chibon |
a3fe59 |
docrepo = os.path.join(docfolder, repo.path)
|
|
Pierre-Yves Chibon |
a3fe59 |
ticketrepo = os.path.join(ticketfolder, repo.path)
|
|
Pierre-Yves Chibon |
a3fe59 |
requestrepo = os.path.join(requestfolder, repo.path)
|
|
Pierre-Yves Chibon |
a3fe59 |
os.makedirs(os.path.join(self.path, 'repos', 'forks', 'foo'))
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
a3fe59 |
self.gitrepo = os.path.join(self.path, 'repos', 'test.git')
|
|
Pierre-Yves Chibon |
a3fe59 |
os.makedirs(self.gitrepo)
|
|
Pierre-Yves Chibon |
a3fe59 |
repo_obj = pygit2.init_repository(self.gitrepo, bare=True)
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
a3fe59 |
# Fork the project
|
|
Pierre-Yves Chibon |
930073 |
task = pagure.lib.query.fork_project(
|
|
Pierre-Yves Chibon |
a3fe59 |
session=self.session,
|
|
Pierre-Yves Chibon |
a3fe59 |
user='foo',
|
|
Pierre-Yves Chibon |
a3fe59 |
repo=repo,
|
|
Pierre-Yves Chibon |
a3fe59 |
)
|
|
Pierre-Yves Chibon |
a3fe59 |
self.session.commit()
|
|
Aurélien Bompard |
a7f281 |
self.assertEqual(task.get(),
|
|
Pierre-Yves Chibon |
b130e5 |
{'endpoint': 'ui_ns.view_repo',
|
|
Patrick Uiterwijk |
170974 |
'repo': 'test',
|
|
Patrick Uiterwijk |
170974 |
'username': 'foo',
|
|
Patrick Uiterwijk |
170974 |
'namespace': None})
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
a3fe59 |
# Create repo, with some content
|
|
Pierre-Yves Chibon |
a3fe59 |
self.gitrepo = os.path.join(
|
|
Pierre-Yves Chibon |
a3fe59 |
self.path, 'repos', 'forks', 'foo', 'test.git')
|
|
Pierre-Yves Chibon |
a3fe59 |
tests.add_content_git_repo(self.gitrepo, branch='feature')
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
930073 |
fork_repo = pagure.lib.query.get_authorized_project(self.session, 'test', user='foo')
|
|
Pierre-Yves Chibon |
a3fe59 |
# Create a PR to play with
|
|
Pierre-Yves Chibon |
930073 |
req = pagure.lib.query.new_pull_request(
|
|
Pierre-Yves Chibon |
a3fe59 |
session=self.session,
|
|
Pierre-Yves Chibon |
a3fe59 |
repo_from=fork_repo,
|
|
Pierre-Yves Chibon |
a3fe59 |
branch_from='feature',
|
|
Pierre-Yves Chibon |
a3fe59 |
repo_to=repo,
|
|
Pierre-Yves Chibon |
a3fe59 |
branch_to='master',
|
|
Pierre-Yves Chibon |
a3fe59 |
title='test PR',
|
|
Pierre-Yves Chibon |
a3fe59 |
user='pingou',
|
|
Pierre-Yves Chibon |
a3fe59 |
requestuid='foobar',
|
|
Pierre-Yves Chibon |
a3fe59 |
requestid=None,
|
|
Pierre-Yves Chibon |
a3fe59 |
status='Open',
|
|
Pierre-Yves Chibon |
a3fe59 |
notify=True
|
|
Pierre-Yves Chibon |
a3fe59 |
)
|
|
Pierre-Yves Chibon |
a3fe59 |
self.assertEqual(req.id, 1)
|
|
Pierre-Yves Chibon |
a3fe59 |
self.assertEqual(req.title, 'test PR')
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
d972d9 |
# `master` branch not found
|
|
Pierre-Yves Chibon |
59f36c |
msg = pagure.lib.git.merge_pull_request(
|
|
Pierre-Yves Chibon |
a3fe59 |
self.session,
|
|
Pierre-Yves Chibon |
a3fe59 |
request=req,
|
|
Pierre-Yves Chibon |
a3fe59 |
username='pingou',
|
|
Pierre-Yves Chibon |
a3fe59 |
domerge=False
|
|
Pierre-Yves Chibon |
a3fe59 |
)
|
|
Pierre-Yves Chibon |
59f36c |
self.assertEqual(msg, 'FFORWARD')
|
|
Pierre-Yves Chibon |
a3fe59 |
|
|
Pierre-Yves Chibon |
99d493 |
@patch('pagure.lib.notify.send_email')
|
|
Pierre-Yves Chibon |
99d493 |
@patch('pagure.lib.git.update_git')
|
|
Pierre-Yves Chibon |
99d493 |
def test_merge_pull_request_closed(self, email_f, up_git):
|
|
Pierre-Yves Chibon |
99d493 |
""" Test the merge_pull_request function when the PR was already
|
|
Pierre-Yves Chibon |
99d493 |
closed/merged. """
|
|
Pierre-Yves Chibon |
99d493 |
email_f.return_value = True
|
|
Pierre-Yves Chibon |
99d493 |
up_git.return_value = True
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
gitfolder = os.path.join(self.path, 'repos')
|
|
Pierre-Yves Chibon |
99d493 |
docfolder = os.path.join(self.path, 'docs')
|
|
Pierre-Yves Chibon |
99d493 |
ticketfolder = os.path.join(self.path, 'tickets')
|
|
Pierre-Yves Chibon |
99d493 |
requestfolder = os.path.join(self.path, 'requests')
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
# Create project
|
|
Pierre-Yves Chibon |
99d493 |
item = pagure.lib.model.Project(
|
|
Pierre-Yves Chibon |
99d493 |
user_id=1, # pingou
|
|
Pierre-Yves Chibon |
99d493 |
name='test',
|
|
Pierre-Yves Chibon |
99d493 |
description='test project',
|
|
Pierre-Yves Chibon |
99d493 |
hook_token='aaabbbwww',
|
|
Pierre-Yves Chibon |
99d493 |
)
|
|
Pierre-Yves Chibon |
99d493 |
self.session.add(item)
|
|
Pierre-Yves Chibon |
99d493 |
self.session.commit()
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
930073 |
repo = pagure.lib.query.get_authorized_project(self.session, 'test')
|
|
Pierre-Yves Chibon |
99d493 |
os.makedirs(os.path.join(self.path, 'repos', 'forks', 'foo'))
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
self.gitrepo = os.path.join(self.path, 'repos', 'test.git')
|
|
Pierre-Yves Chibon |
99d493 |
os.makedirs(self.gitrepo)
|
|
Pierre-Yves Chibon |
99d493 |
repo_obj = pygit2.init_repository(self.gitrepo, bare=True)
|
|
Pierre-Yves Chibon |
99d493 |
tests.add_content_git_repo(self.gitrepo, branch='master')
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
# Fork the project
|
|
Pierre-Yves Chibon |
930073 |
task = pagure.lib.query.fork_project(
|
|
Pierre-Yves Chibon |
99d493 |
session=self.session,
|
|
Pierre-Yves Chibon |
99d493 |
user='foo',
|
|
Pierre-Yves Chibon |
99d493 |
repo=repo,
|
|
Pierre-Yves Chibon |
99d493 |
)
|
|
Pierre-Yves Chibon |
99d493 |
self.session.commit()
|
|
Aurélien Bompard |
a7f281 |
self.assertEqual(task.get(),
|
|
Pierre-Yves Chibon |
b130e5 |
{'endpoint': 'ui_ns.view_repo',
|
|
Pierre-Yves Chibon |
99d493 |
'repo': 'test',
|
|
Pierre-Yves Chibon |
99d493 |
'username': 'foo',
|
|
Pierre-Yves Chibon |
99d493 |
'namespace': None})
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
# Create repo, with some content
|
|
Pierre-Yves Chibon |
99d493 |
self.gitrepo = os.path.join(
|
|
Pierre-Yves Chibon |
99d493 |
self.path, 'repos', 'forks', 'foo', 'test.git')
|
|
Pierre-Yves Chibon |
99d493 |
tests.add_content_git_repo(self.gitrepo, branch='feature')
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
930073 |
fork_repo = pagure.lib.query.get_authorized_project(self.session, 'test', user='foo')
|
|
Pierre-Yves Chibon |
99d493 |
# Create a PR to play with
|
|
Pierre-Yves Chibon |
930073 |
req = pagure.lib.query.new_pull_request(
|
|
Pierre-Yves Chibon |
99d493 |
session=self.session,
|
|
Pierre-Yves Chibon |
99d493 |
repo_from=fork_repo,
|
|
Pierre-Yves Chibon |
99d493 |
branch_from='feature',
|
|
Pierre-Yves Chibon |
99d493 |
repo_to=repo,
|
|
Pierre-Yves Chibon |
99d493 |
branch_to='master',
|
|
Pierre-Yves Chibon |
99d493 |
title='test PR',
|
|
Pierre-Yves Chibon |
99d493 |
user='pingou',
|
|
Pierre-Yves Chibon |
99d493 |
requestuid='foobar',
|
|
Pierre-Yves Chibon |
99d493 |
requestid=None,
|
|
Pierre-Yves Chibon |
99d493 |
status='Open',
|
|
Pierre-Yves Chibon |
99d493 |
notify=True
|
|
Pierre-Yves Chibon |
99d493 |
)
|
|
Pierre-Yves Chibon |
99d493 |
self.assertEqual(req.id, 1)
|
|
Pierre-Yves Chibon |
99d493 |
self.assertEqual(req.title, 'test PR')
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
# Close the PR before we ask to merge it
|
|
Pierre-Yves Chibon |
99d493 |
req.status = 'Closed'
|
|
Pierre-Yves Chibon |
99d493 |
req.closed_by_id = 2 # id:2 == foo
|
|
Pierre-Yves Chibon |
99d493 |
req.closed_at = datetime.datetime(2017, 10, 20, 12, 32, 10)
|
|
Pierre-Yves Chibon |
99d493 |
self.session.add(req)
|
|
Pierre-Yves Chibon |
99d493 |
self.session.commit()
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
99d493 |
# PR already closed
|
|
Aurélien Bompard |
626417 |
six.assertRaisesRegex(
|
|
Aurélien Bompard |
626417 |
self,
|
|
Pierre-Yves Chibon |
99d493 |
pagure.exceptions.PagureException,
|
|
Pierre-Yves Chibon |
99d493 |
'This pull-request was merged or closed by foo',
|
|
Pierre-Yves Chibon |
99d493 |
pagure.lib.git.merge_pull_request,
|
|
Pierre-Yves Chibon |
99d493 |
self.session,
|
|
Pierre-Yves Chibon |
99d493 |
request=req,
|
|
Pierre-Yves Chibon |
99d493 |
username='pingou',
|
|
Pierre-Yves Chibon |
99d493 |
domerge=False
|
|
Pierre-Yves Chibon |
99d493 |
)
|
|
Pierre-Yves Chibon |
99d493 |
|
|
Pierre-Yves Chibon |
be6a91 |
@patch('subprocess.Popen')
|
|
Pierre-Yves Chibon |
be6a91 |
def test_generate_gitolite_acls(self, popen):
|
|
Pierre-Yves Chibon |
be6a91 |
""" Test calling generate_gitolite_acls. """
|
|
Pierre-Yves Chibon |
be6a91 |
pagure.SESSION = self.session
|
|
Pierre-Yves Chibon |
be6a91 |
pagure.lib.git.SESSION = self.session
|
|
Pierre-Yves Chibon |
b130e5 |
pagure.config.config['GITOLITE_HOME'] = '/tmp'
|
|
Pierre-Yves Chibon |
be6a91 |
|
|
Pierre-Yves Chibon |
145998 |
proc = MagicMock()
|
|
Pierre-Yves Chibon |
145998 |
proc.communicate.return_value = (1, 2)
|
|
Pierre-Yves Chibon |
145998 |
proc.returncode = 0
|
|
Pierre-Yves Chibon |
145998 |
popen.return_value = proc
|
|
Pierre-Yves Chibon |
145998 |
helper = pagure.lib.git_auth.get_git_auth_helper('gitolite3')
|
|
Pierre-Yves Chibon |
274e60 |
helper.generate_acls(project=None)
|
|
Pierre-Yves Chibon |
be6a91 |
popen.assert_called_with(
|
|
Pierre-Yves Chibon |
be6a91 |
'HOME=/tmp gitolite compile && '
|
|
Pierre-Yves Chibon |
be6a91 |
'HOME=/tmp gitolite trigger POST_COMPILE',
|
|
Pierre-Yves Chibon |
be6a91 |
cwd='/tmp', shell=True, stderr=-1, stdout=-1
|
|
Pierre-Yves Chibon |
be6a91 |
)
|
|
Pierre-Yves Chibon |
be6a91 |
|
|
Slavek Kabrda |
595b6f |
def test_is_forced_push_new_branch(self):
|
|
Slavek Kabrda |
595b6f |
self.assertFalse(
|
|
Slavek Kabrda |
595b6f |
pagure.lib.git.is_forced_push(
|
|
Slavek Kabrda |
595b6f |
'0000000000000000000000000000000000000000',
|
|
Slavek Kabrda |
595b6f |
'^0e6e0b6c931d65ee22f67205a53933d841c6eeff',
|
|
Slavek Kabrda |
595b6f |
'path/is/not/important'
|
|
Slavek Kabrda |
595b6f |
)
|
|
Slavek Kabrda |
595b6f |
)
|
|
Slavek Kabrda |
595b6f |
|
|
Slavek Kabrda |
197fa2 |
@patch("pagure.utils.get_repo_path")
|
|
Slavek Kabrda |
197fa2 |
def test_update_pull_ref(self, get_repo_path):
|
|
Slavek Kabrda |
197fa2 |
fake_pr = MagicMock()
|
|
Slavek Kabrda |
197fa2 |
fake_pr.uid = "1234567"
|
|
Slavek Kabrda |
197fa2 |
fake_pr.branch_from = "master"
|
|
Slavek Kabrda |
197fa2 |
fake_pr.id = 6
|
|
Slavek Kabrda |
197fa2 |
fake_pr.user = MagicMock()
|
|
Slavek Kabrda |
197fa2 |
fake_pr.user.user = "pingou"
|
|
Slavek Kabrda |
197fa2 |
fake_pr.project = "doesnt_matter_mocked_out"
|
|
Slavek Kabrda |
197fa2 |
projects = tests.create_projects_git(
|
|
Slavek Kabrda |
197fa2 |
os.path.join(self.path, "repos"),
|
|
Slavek Kabrda |
197fa2 |
bare=True
|
|
Slavek Kabrda |
197fa2 |
)
|
|
Slavek Kabrda |
197fa2 |
tests.add_content_git_repo(projects[0])
|
|
Slavek Kabrda |
197fa2 |
tests.add_content_git_repo(projects[1])
|
|
Slavek Kabrda |
197fa2 |
orig = pygit2.Repository(projects[0])
|
|
Slavek Kabrda |
197fa2 |
fork = pygit2.Repository(projects[1])
|
|
Slavek Kabrda |
197fa2 |
get_repo_path.return_value = projects[0]
|
|
Slavek Kabrda |
197fa2 |
|
|
Slavek Kabrda |
197fa2 |
# make sure that creating works the first time
|
|
Slavek Kabrda |
197fa2 |
pagure.lib.git.update_pull_ref(fake_pr, fork)
|
|
Slavek Kabrda |
197fa2 |
oldhex = fork.references["refs/heads/master"].get_object().hex
|
|
Slavek Kabrda |
197fa2 |
self.assertEqual(
|
|
Slavek Kabrda |
197fa2 |
orig.references["refs/pull/6/head"].get_object().hex,
|
|
Slavek Kabrda |
197fa2 |
oldhex,
|
|
Slavek Kabrda |
197fa2 |
)
|
|
Slavek Kabrda |
197fa2 |
|
|
Slavek Kabrda |
197fa2 |
# make sure that updating works correctly
|
|
Slavek Kabrda |
197fa2 |
tests.add_content_git_repo(projects[1], append="foobar")
|
|
Slavek Kabrda |
197fa2 |
newhex = fork.references["refs/heads/master"].get_object().hex
|
|
Slavek Kabrda |
197fa2 |
self.assertNotEqual(oldhex, newhex)
|
|
Slavek Kabrda |
197fa2 |
pagure.lib.git.update_pull_ref(fake_pr, fork)
|
|
Slavek Kabrda |
197fa2 |
self.assertEqual(
|
|
Slavek Kabrda |
197fa2 |
orig.references["refs/pull/6/head"].get_object().hex,
|
|
Slavek Kabrda |
197fa2 |
newhex,
|
|
Slavek Kabrda |
197fa2 |
)
|
|
Slavek Kabrda |
197fa2 |
|
|
Slavek Kabrda |
197fa2 |
# make sure the function works fine even if there's a leftover
|
|
Slavek Kabrda |
197fa2 |
# ref from previous failed run of the function
|
|
Slavek Kabrda |
197fa2 |
with patch("pygit2.remote.RemoteCollection.delete"):
|
|
Slavek Kabrda |
197fa2 |
pagure.lib.git.update_pull_ref(fake_pr, fork)
|
|
Slavek Kabrda |
197fa2 |
self.assertIsNotNone(fork.remotes["pingou_1234567"])
|
|
Slavek Kabrda |
197fa2 |
tests.add_content_git_repo(projects[1], append="foobarbaz")
|
|
Slavek Kabrda |
197fa2 |
newesthex = fork.references["refs/heads/master"].get_object().hex
|
|
Slavek Kabrda |
197fa2 |
self.assertNotEqual(newhex, newesthex)
|
|
Slavek Kabrda |
197fa2 |
pagure.lib.git.update_pull_ref(fake_pr, fork)
|
|
Slavek Kabrda |
197fa2 |
self.assertEqual(
|
|
Slavek Kabrda |
197fa2 |
orig.references["refs/pull/6/head"].get_object().hex,
|
|
Slavek Kabrda |
197fa2 |
newesthex,
|
|
Slavek Kabrda |
197fa2 |
)
|
|
Slavek Kabrda |
197fa2 |
|
|
Pierre-Yves Chibon |
a945ba |
|
|
Pierre-Yves Chibon |
86e455 |
class PagureLibGitCommitToPatchtests(tests.Modeltests):
|
|
Pierre-Yves Chibon |
86e455 |
""" Tests for pagure.lib.git """
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
maxDiff = None
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def setUp(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Set up the environment for the tests. """
|
|
Pierre-Yves Chibon |
86e455 |
super(PagureLibGitCommitToPatchtests, self).setUp()
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
# Create a git repo to play with
|
|
Pierre-Yves Chibon |
86e455 |
self.gitrepo = os.path.join(self.path, 'repos', 'test_repo.git')
|
|
Pierre-Yves Chibon |
86e455 |
os.makedirs(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
# Create a file in that git repo
|
|
Pierre-Yves Chibon |
86e455 |
with open(os.path.join(self.gitrepo, 'sources'), 'w') as stream:
|
|
Pierre-Yves Chibon |
86e455 |
stream.write('foo\n bar')
|
|
Pierre-Yves Chibon |
86e455 |
repo.index.add('sources')
|
|
Pierre-Yves Chibon |
86e455 |
repo.index.write()
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
# Commits the files added
|
|
Pierre-Yves Chibon |
86e455 |
tree = repo.index.write_tree()
|
|
Pierre-Yves Chibon |
86e455 |
author = pygit2.Signature(
|
|
Pierre-Yves Chibon |
86e455 |
'Alice Author', 'alice@authors.tld')
|
|
Pierre-Yves Chibon |
86e455 |
committer = pygit2.Signature(
|
|
Pierre-Yves Chibon |
86e455 |
'Cecil Committer', 'cecil@committers.tld')
|
|
Pierre-Yves Chibon |
86e455 |
repo.create_commit(
|
|
Pierre-Yves Chibon |
86e455 |
'refs/heads/master', # the name of the reference to update
|
|
Pierre-Yves Chibon |
86e455 |
author,
|
|
Pierre-Yves Chibon |
86e455 |
committer,
|
|
Pierre-Yves Chibon |
86e455 |
'Add sources file for testing',
|
|
Pierre-Yves Chibon |
86e455 |
# binary string representing the tree object ID
|
|
Pierre-Yves Chibon |
86e455 |
tree,
|
|
Pierre-Yves Chibon |
86e455 |
# list of binary strings representing parents of the new commit
|
|
Pierre-Yves Chibon |
86e455 |
[]
|
|
Pierre-Yves Chibon |
86e455 |
)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
self.first_commit = repo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
# Edit the sources file again
|
|
Pierre-Yves Chibon |
86e455 |
with open(os.path.join(self.gitrepo, 'sources'), 'w') as stream:
|
|
Pierre-Yves Chibon |
86e455 |
stream.write('foo\n bar\nbaz\n boose')
|
|
Pierre-Yves Chibon |
86e455 |
repo.index.add('sources')
|
|
Pierre-Yves Chibon |
86e455 |
repo.index.write()
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
# Commits the files added
|
|
Pierre-Yves Chibon |
86e455 |
tree = repo.index.write_tree()
|
|
Pierre-Yves Chibon |
86e455 |
author = pygit2.Signature(
|
|
Pierre-Yves Chibon |
86e455 |
'Alice Author', 'alice@authors.tld')
|
|
Pierre-Yves Chibon |
86e455 |
committer = pygit2.Signature(
|
|
Pierre-Yves Chibon |
86e455 |
'Cecil Committer', 'cecil@committers.tld')
|
|
Pierre-Yves Chibon |
86e455 |
repo.create_commit(
|
|
Pierre-Yves Chibon |
86e455 |
'refs/heads/master', # the name of the reference to update
|
|
Pierre-Yves Chibon |
86e455 |
author,
|
|
Pierre-Yves Chibon |
86e455 |
committer,
|
|
Pierre-Yves Chibon |
86e455 |
'Add baz and boose to the sources\n\n There are more objects to '
|
|
Pierre-Yves Chibon |
86e455 |
'consider',
|
|
Pierre-Yves Chibon |
86e455 |
# binary string representing the tree object ID
|
|
Pierre-Yves Chibon |
86e455 |
tree,
|
|
Pierre-Yves Chibon |
86e455 |
# list of binary strings representing parents of the new commit
|
|
Pierre-Yves Chibon |
86e455 |
[self.first_commit.oid.hex]
|
|
Pierre-Yves Chibon |
86e455 |
)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
self.second_commit = repo.revparse_single('HEAD')
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_first_commit(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(repo, self.first_commit)
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
86e455 |
From: Alice Author <alice@authors.tld></alice@authors.tld>
|
|
Pierre-Yves Chibon |
86e455 |
Subject: Add sources file for testing
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
---
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_single_commit(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(repo, self.second_commit)
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
86e455 |
From: Alice Author <alice@authors.tld></alice@authors.tld>
|
|
Pierre-Yves Chibon |
86e455 |
Subject: Add baz and boose to the sources
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
There are more objects to consider
|
|
Pierre-Yves Chibon |
86e455 |
---
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_2_commits(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, [self.first_commit, self.second_commit])
|
|
Karsten Hopp |
b310af |
exp = r"""Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
86e455 |
From: Alice Author <alice@authors.tld></alice@authors.tld>
|
|
Pierre-Yves Chibon |
86e455 |
Subject: [PATCH 1/2] Add sources file for testing
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
---
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
Mon Sep 17 00:00:00 2001
|
|
Pierre-Yves Chibon |
86e455 |
From: Alice Author <alice@authors.tld></alice@authors.tld>
|
|
Pierre-Yves Chibon |
86e455 |
Subject: [PATCH 2/2] Add baz and boose to the sources
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
There are more objects to consider
|
|
Pierre-Yves Chibon |
86e455 |
---
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_first_commit_diff(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, self.first_commit, diff_view=True)
|
|
Karsten Hopp |
b310af |
exp = r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_single_commit_diff(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, self.second_commit, diff_view=True)
|
|
Karsten Hopp |
b310af |
exp = r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_two_commits_diff(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, [self.first_commit, self.second_commit], diff_view=True)
|
|
Karsten Hopp |
b310af |
exp = r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(patch, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_first_commit_diff_separated(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patches = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, self.first_commit, diff_view=True, separated=True)
|
|
Karsten Hopp |
b310af |
exp = r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
output = []
|
|
Pierre-Yves Chibon |
86e455 |
for patch in patches:
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
output.append(patch)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(output, [exp])
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_single_commit_diff_separated(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patches = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, self.second_commit, diff_view=True, separated=True)
|
|
Karsten Hopp |
b310af |
exp = r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""
|
|
Pierre-Yves Chibon |
86e455 |
output = []
|
|
Pierre-Yves Chibon |
86e455 |
for patch in patches:
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
output.append(patch)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(output, [exp])
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
def test_commit_to_patch_two_commits_diff_separated(self):
|
|
Pierre-Yves Chibon |
86e455 |
""" Test the commit_to_patch function of pagure.lib.git. """
|
|
Pierre-Yves Chibon |
86e455 |
repo = pygit2.init_repository(self.gitrepo)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patches = pagure.lib.git.commit_to_patch(
|
|
Pierre-Yves Chibon |
86e455 |
repo, [self.first_commit, self.second_commit], diff_view=True,
|
|
Pierre-Yves Chibon |
86e455 |
separated=True)
|
|
Karsten Hopp |
b310af |
exp = [r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
new file mode 100644
|
|
Pierre-Yves Chibon |
86e455 |
index 0000000..9f44358
|
|
Pierre-Yves Chibon |
86e455 |
--- /dev/null
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -0,0 +1,2 @@
|
|
Pierre-Yves Chibon |
86e455 |
+foo
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
""",
|
|
Karsten Hopp |
b310af |
r"""diff --git a/sources b/sources
|
|
Pierre-Yves Chibon |
86e455 |
index 9f44358..2a552bb 100644
|
|
Pierre-Yves Chibon |
86e455 |
--- a/sources
|
|
Pierre-Yves Chibon |
86e455 |
+++ b/sources
|
|
Pierre-Yves Chibon |
86e455 |
@@ -1,2 +1,4 @@
|
|
Pierre-Yves Chibon |
86e455 |
foo
|
|
Pierre-Yves Chibon |
86e455 |
- bar
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
+ bar
|
|
Pierre-Yves Chibon |
86e455 |
+baz
|
|
Pierre-Yves Chibon |
86e455 |
+ boose
|
|
Pierre-Yves Chibon |
86e455 |
\ No newline at end of file
|
|
Pierre-Yves Chibon |
86e455 |
"""]
|
|
Pierre-Yves Chibon |
86e455 |
output = []
|
|
Pierre-Yves Chibon |
86e455 |
for patch in patches:
|
|
Pierre-Yves Chibon |
86e455 |
npatch = []
|
|
Pierre-Yves Chibon |
86e455 |
for row in patch.split('\n'):
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('Date:'):
|
|
Pierre-Yves Chibon |
86e455 |
continue
|
|
Pierre-Yves Chibon |
86e455 |
if row.startswith('From '):
|
|
Pierre-Yves Chibon |
86e455 |
row = row.split(' ', 2)[2]
|
|
Pierre-Yves Chibon |
86e455 |
npatch.append(row)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
patch = '\n'.join(npatch)
|
|
Pierre-Yves Chibon |
86e455 |
output.append(patch)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
self.assertEqual(output, exp)
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
86e455 |
|
|
Pierre-Yves Chibon |
a945ba |
if __name__ == '__main__':
|
|
Pierre-Yves Chibon |
be6a91 |
unittest.main(verbosity=2)
|