##// END OF EJS Templates
added warning on sqlite when using migration....
added warning on sqlite when using migration. Sqlite prior to 3.7 series are known to not support some migration changes like table renames. Thus are failing.

File last commit:

r1824:89efedac beta
r1835:971ce5e2 beta
Show More
_test_concurency.py
211 lines | 6.1 KiB | text/x-python | PythonLexer
Some code cleanups and fixes
r1628 # -*- coding: utf-8 -*-
"""
rhodecode.tests.test_hg_operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Test suite for making push/pull operations
:created_on: Dec 30, 2010
2012 copyrights
r1824 :author: marcink
:copyright: (C) 2010-2012 Marcin Kuzminski <marcin@python-works.com>
Some code cleanups and fixes
r1628 :license: GPLv3, see COPYING for more details.
"""
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import os
import sys
import shutil
import logging
from os.path import join as jn
from os.path import dirname as dn
from tempfile import _RandomNameSequence
from subprocess import Popen, PIPE
from paste.deploy import appconfig
from pylons import config
from sqlalchemy import engine_from_config
from rhodecode.lib.utils import add_cache
from rhodecode.model import init_model
from rhodecode.model import meta
from rhodecode.model.db import User, Repository
from rhodecode.lib.auth import get_crypt_password
from rhodecode.tests import TESTS_TMP_PATH, NEW_HG_REPO, HG_REPO
from rhodecode.config.environment import load_environment
rel_path = dn(dn(dn(os.path.abspath(__file__))))
conf = appconfig('config:development.ini', relative_to=rel_path)
load_environment(conf.global_conf, conf.local_conf)
add_cache(conf)
USER = 'test_admin'
PASS = 'test12'
another major refactoring with session management
r1734 HOST = 'hg.local'
test concurency script updates...
r1666 METHOD = 'pull'
Some code cleanups and fixes
r1628 DEBUG = True
log = logging.getLogger(__name__)
class Command(object):
def __init__(self, cwd):
self.cwd = cwd
def execute(self, cmd, *args):
"""Runs command on the system with given ``args``.
"""
command = cmd + ' ' + ' '.join(args)
log.debug('Executing %s' % command)
if DEBUG:
print command
p = Popen(command, shell=True, stdout=PIPE, stderr=PIPE, cwd=self.cwd)
stdout, stderr = p.communicate()
if DEBUG:
print stdout, stderr
return stdout, stderr
def get_session():
engine = engine_from_config(conf, 'sqlalchemy.db1.')
init_model(engine)
commit less models...
r1749 sa = meta.Session
Some code cleanups and fixes
r1628 return sa
def create_test_user(force=True):
print 'creating test user'
sa = get_session()
user = sa.query(User).filter(User.username == USER).scalar()
if force and user is not None:
print 'removing current user'
for repo in sa.query(Repository).filter(Repository.user == user).all():
sa.delete(repo)
sa.delete(user)
sa.commit()
if user is None or force:
print 'creating new one'
new_usr = User()
new_usr.username = USER
new_usr.password = get_crypt_password(PASS)
new_usr.email = 'mail@mail.com'
new_usr.name = 'test'
new_usr.lastname = 'lasttestname'
new_usr.active = True
new_usr.admin = True
sa.add(new_usr)
sa.commit()
print 'done'
def create_test_repo(force=True):
print 'creating test repo'
from rhodecode.model.repo import RepoModel
sa = get_session()
user = sa.query(User).filter(User.username == USER).scalar()
if user is None:
raise Exception('user not found')
repo = sa.query(Repository).filter(Repository.repo_name == HG_REPO).scalar()
if repo is None:
print 'repo not found creating'
form_data = {'repo_name':HG_REPO,
'repo_type':'hg',
'private':False,
'clone_uri':'' }
rm = RepoModel(sa)
rm.base_path = '/home/hg'
rm.create(form_data, user)
print 'done'
def set_anonymous_access(enable=True):
sa = get_session()
user = sa.query(User).filter(User.username == 'default').one()
user.active = enable
sa.add(user)
sa.commit()
def get_anonymous_access():
sa = get_session()
return sa.query(User).filter(User.username == 'default').one().active
#==============================================================================
# TESTS
#==============================================================================
test concurency script updates...
r1666 def test_clone_with_credentials(no_errors=False, repo=HG_REPO, method=METHOD,
seq=None):
Some code cleanups and fixes
r1628 cwd = path = jn(TESTS_TMP_PATH, repo)
test concurency script updates...
r1666 if seq == None:
seq = _RandomNameSequence().next()
Some code cleanups and fixes
r1628
try:
shutil.rmtree(path, ignore_errors=True)
os.makedirs(path)
#print 'made dirs %s' % jn(path)
except OSError:
raise
test concurency script updates...
r1666 clone_url = 'http://%(user)s:%(pass)s@%(host)s/%(cloned_repo)s' % \
Some code cleanups and fixes
r1628 {'user':USER,
'pass':PASS,
'host':HOST,
test concurency script updates...
r1666 'cloned_repo':repo, }
Some code cleanups and fixes
r1628
test concurency script updates...
r1666 dest = path + seq
if method == 'pull':
stdout, stderr = Command(cwd).execute('hg', method, '--cwd', dest, clone_url)
else:
stdout, stderr = Command(cwd).execute('hg', method, clone_url, dest)
Some code cleanups and fixes
r1628
test concurency script updates...
r1666 if no_errors is False:
assert """adding file changes""" in stdout, 'no messages about cloning'
assert """abort""" not in stderr , 'got error from clone'
Some code cleanups and fixes
r1628
if __name__ == '__main__':
try:
create_test_user(force=False)
test concurency script updates...
r1666 seq = None
import time
Some code cleanups and fixes
r1628
implements #285: Implemented non changeable urls for clone url, and web views
r1813 try:
METHOD = sys.argv[3]
except:
pass
test concurency script updates...
r1666 if METHOD == 'pull':
seq = _RandomNameSequence().next()
test_clone_with_credentials(repo=sys.argv[1], method='clone',
seq=seq)
s = time.time()
implements #285: Implemented non changeable urls for clone url, and web views
r1813 for i in range(1, int(sys.argv[2]) + 1):
test concurency script updates...
r1666 print 'take', i
test_clone_with_credentials(repo=sys.argv[1], method=METHOD,
seq=seq)
print 'time taken %.3f' % (time.time() - s)
Some code cleanups and fixes
r1628 except Exception, e:
test concurency script updates...
r1666 raise
Some code cleanups and fixes
r1628 sys.exit('stop on %s' % e)