def test_clone_git_repo_by_id_by_admin(self, rc_web_server, tmpdir):
     repo_id = Repository.get_by_repo_name(GIT_REPO).repo_id
     clone_url = rc_web_server.repo_clone_url('_%s' % repo_id)
     cmd = Command('/tmp')
     stdout, stderr = cmd.execute('git clone', clone_url, tmpdir.strpath)
     _check_proper_clone(stdout, stderr, 'git')
     cmd.assert_returncode_success()
    def test_clone_git_repo_shallow_by_admin(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        cmd = Command('/tmp')
        stdout, stderr = cmd.execute('git clone --depth=1', clone_url,
                                     tmpdir.strpath)

        assert '' == stdout
        assert 'Cloning into' in stderr
        cmd.assert_returncode_success()
def test_git_sets_default_branch_if_not_master(backend_git, tmpdir,
                                               disable_locking, rc_web_server):
    empty_repo = backend_git.create_repo()
    clone_url = rc_web_server.repo_clone_url(empty_repo.repo_name)

    cmd = Command(tmpdir.strpath)
    cmd.execute('git clone', clone_url)

    repo = GitRepository(os.path.join(tmpdir.strpath, empty_repo.repo_name))
    repo.in_memory_commit.add(FileNode('file', content=''))
    repo.in_memory_commit.commit(message='Commit on branch test',
                                 author='Automatic test',
                                 branch='test')

    repo_cmd = Command(repo.path)
    stdout, stderr = repo_cmd.execute('git push --verbose origin test')
    _check_proper_git_push(stdout,
                           stderr,
                           branch='test',
                           should_set_default_branch=True)

    stdout, stderr = cmd.execute('git clone', clone_url,
                                 empty_repo.repo_name + '-clone')
    _check_proper_clone(stdout, stderr, 'git')

    # Doing an explicit commit in order to get latest user logs on MySQL
    Session().commit()
예제 #4
0
    def test_push_on_locked_repo_by_other_user_hg(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)

        # lock repo
        r = Repository.get_by_repo_name(HG_REPO)
        # let this user actually push !
        RepoModel().grant_user_permission(repo=r,
                                          user=TEST_USER_REGULAR_LOGIN,
                                          perm='repository.write')
        Session().commit()
        Repository.lock(r, User.get_by_username(TEST_USER_ADMIN_LOGIN).user_id)

        # push fails repo is locked by other user !
        push_url = rc_web_server.repo_clone_url(HG_REPO,
                                                user=TEST_USER_REGULAR_LOGIN,
                                                passwd=TEST_USER_REGULAR_PASS)
        stdout, stderr = _add_files_and_push('hg',
                                             tmpdir.strpath,
                                             clone_url=push_url)
        msg = (
            """abort: HTTP Error 400: Repository `%s` locked by user `%s`""" %
            (HG_REPO, TEST_USER_ADMIN_LOGIN))
        assert msg in stderr
 def test_clone_existing_path_git_not_in_database_different_scm(
         self, rc_web_server, tmpdir, fs_repo_only):
     db_name = fs_repo_only('not-in-db-hg', repo_type='hg')
     clone_url = rc_web_server.repo_clone_url(db_name)
     stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                              tmpdir.strpath)
     assert 'not found' in stderr
    def test_push_unlocks_repository_hg(self, rc_web_server, tmpdir):
        # enable locking
        r = Repository.get_by_repo_name(HG_REPO)
        r.enable_locking = True
        Session().add(r)
        Session().commit()

        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute(
            'hg clone', clone_url, tmpdir.strpath)
        _check_proper_clone(stdout, stderr, 'hg')

        # check for lock repo after clone
        r = Repository.get_by_repo_name(HG_REPO)
        uid = User.get_by_username(TEST_USER_ADMIN_LOGIN).user_id
        assert r.locked[0] == uid

        # push is ok and repo is now unlocked
        stdout, stderr = _add_files_and_push(
            'hg', tmpdir.strpath, clone_url=clone_url)
        assert ('remote: Released lock on repo `%s`' % HG_REPO) in stdout
        # we need to cleanup the Session Here !
        Session.remove()
        r = Repository.get_by_repo_name(HG_REPO)
        assert r.locked == [None, None, None]
    def test_push_unlocks_repository_git(self, rc_web_server, tmpdir):

        # Note: Did a first debugging session. Seems that
        # Repository.get_locking_state is called twice. The second call
        # has the action "pull" and does not reset the lock.

        # enable locking
        r = Repository.get_by_repo_name(GIT_REPO)
        r.enable_locking = True
        Session().add(r)
        Session().commit()

        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute(
            'git clone', clone_url, tmpdir.strpath)
        _check_proper_clone(stdout, stderr, 'git')

        # check for lock repo after clone
        r = Repository.get_by_repo_name(GIT_REPO)
        assert r.locked[0] == User.get_by_username(
            TEST_USER_ADMIN_LOGIN).user_id

        # push is ok and repo is now unlocked
        stdout, stderr = _add_files_and_push(
            'git', tmpdir.strpath, clone_url=clone_url)
        _check_proper_git_push(stdout, stderr)

        # assert ('remote: Released lock on repo `%s`' % GIT_REPO) in stdout
        # we need to cleanup the Session Here !
        Session.remove()
        r = Repository.get_by_repo_name(GIT_REPO)
        assert r.locked == [None, None, None]
    def test_push_on_locked_repo_by_other_user_git(
            self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute(
            'git clone', clone_url, tmpdir.strpath)

        # lock repo
        r = Repository.get_by_repo_name(GIT_REPO)
        # let this user actually push !
        RepoModel().grant_user_permission(repo=r, user=TEST_USER_REGULAR_LOGIN,
                                          perm='repository.write')
        Session().commit()
        Repository.lock(r, User.get_by_username(TEST_USER_ADMIN_LOGIN).user_id)

        # push fails repo is locked by other user!
        push_url = rc_web_server.repo_clone_url(
            GIT_REPO,
            user=TEST_USER_REGULAR_LOGIN, passwd=TEST_USER_REGULAR_PASS)
        stdout, stderr = _add_files_and_push(
            'git', tmpdir.strpath, clone_url=push_url)

        err = 'Repository `%s` locked by user `%s`' % (
            GIT_REPO, TEST_USER_ADMIN_LOGIN)
        # err = 'RPC failed; result=22, HTTP code = 423'
        assert err in stderr
    def test_clone_existing_path_hg_not_in_database(self, rc_web_server,
                                                    tmpdir, fs_repo_only):

        db_name = fs_repo_only('not-in-db-hg', repo_type='hg')
        clone_url = rc_web_server.repo_clone_url(db_name)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)
        assert 'HTTP Error 404: Not Found' in stderr
    def test_push_back_to_wrong_url_hg(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)

        stdout, stderr = _add_files_and_push(
            'hg',
            tmpdir.strpath,
            clone_url=rc_web_server.repo_clone_url('not-existing'))

        assert 'HTTP Error 404: Not Found' in stderr
    def test_push_back_to_wrong_url_git(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                 tmpdir.strpath)

        stdout, stderr = _add_files_and_push(
            'git',
            tmpdir.strpath,
            clone_url=rc_web_server.repo_clone_url('not-existing'))

        assert 'not found' in stderr
    def test_push_new_file_git(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                 tmpdir.strpath)

        # commit some stuff into this repo
        stdout, stderr = _add_files_and_push('git',
                                             tmpdir.strpath,
                                             clone_url=clone_url)

        _check_proper_git_push(stdout, stderr)
    def test_push_new_file_hg(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)

        stdout, stderr = _add_files_and_push('hg',
                                             tmpdir.strpath,
                                             clone_url=clone_url)

        assert 'pushing to' in stdout
        assert 'size summary' in stdout
 def test_clone_after_repo_was_locked_hg(self, rc_web_server, tmpdir):
     # lock repo
     r = Repository.get_by_repo_name(HG_REPO)
     Repository.lock(r, User.get_by_username(TEST_USER_ADMIN_LOGIN).user_id)
     # pull fails since repo is locked
     clone_url = rc_web_server.repo_clone_url(HG_REPO)
     stdout, stderr = Command('/tmp').execute(
         'hg clone', clone_url, tmpdir.strpath)
     msg = ("""abort: HTTP Error 423: Repository `%s` locked by user `%s`"""
            % (HG_REPO, TEST_USER_ADMIN_LOGIN))
     assert msg in stderr
    def test_ip_restriction_hg(self, rc_web_server, tmpdir):
        user_model = UserModel()
        try:
            user_model.add_extra_ip(TEST_USER_ADMIN_LOGIN, '10.10.10.10/32')
            Session().commit()
            time.sleep(2)
            clone_url = rc_web_server.repo_clone_url(HG_REPO)
            stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                     tmpdir.strpath)
            assert 'abort: HTTP Error 403: Forbidden' in stderr
        finally:
            # release IP restrictions
            for ip in UserIpMap.getAll():
                UserIpMap.delete(ip.ip_id)
            Session().commit()

        time.sleep(2)

        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)
        _check_proper_clone(stdout, stderr, 'hg')
    def test_push_wrong_credentials_git(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                 tmpdir.strpath)

        push_url = rc_web_server.repo_clone_url(GIT_REPO,
                                                user='******',
                                                passwd='name')
        stdout, stderr = _add_files_and_push('git',
                                             tmpdir.strpath,
                                             clone_url=push_url)

        assert 'fatal: Authentication failed' in stderr
    def test_push_wrong_credentials_hg(self, rc_web_server, tmpdir):
        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)

        push_url = rc_web_server.repo_clone_url(HG_REPO,
                                                user='******',
                                                passwd='name')
        stdout, stderr = _add_files_and_push('hg',
                                             tmpdir.strpath,
                                             clone_url=push_url)

        assert 'abort: authorization failed' in stderr
    def test_clone_and_create_lock_git(self, rc_web_server, tmpdir):
        # enable locking
        r = Repository.get_by_repo_name(GIT_REPO)
        r.enable_locking = True
        Session().add(r)
        Session().commit()
        # clone
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute(
            'git clone', clone_url, tmpdir.strpath)

        # check if lock was made
        r = Repository.get_by_repo_name(GIT_REPO)
        assert r.locked[0] == User.get_by_username(
            TEST_USER_ADMIN_LOGIN).user_id
예제 #19
0
    def test_clone_after_repo_was_locked_git(self, rc_web_server, tmpdir):
        # lock repo
        r = Repository.get_by_repo_name(GIT_REPO)
        Repository.lock(r, User.get_by_username(TEST_USER_ADMIN_LOGIN).user_id)
        # pull fails since repo is locked
        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                 tmpdir.strpath)

        lock_msg = (
            'remote: ERROR: Repository `vcs_test_git` locked by user ' +
            '`test_admin`. Reason:`lock_auto`')
        assert lock_msg in stderr
        assert 'remote: Pre pull hook failed: aborting' in stderr
        assert 'fatal: remote did not send all necessary objects' in stderr
    def test_push_invalidates_cache_hg(self, rc_web_server, tmpdir):
        key = CacheKey.query().filter(CacheKey.cache_key == HG_REPO).scalar()
        if not key:
            key = CacheKey(HG_REPO, HG_REPO)

        key.cache_active = True
        Session().add(key)
        Session().commit()

        clone_url = rc_web_server.repo_clone_url(HG_REPO)
        stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                                 tmpdir.strpath)

        stdout, stderr = _add_files_and_push('hg',
                                             tmpdir.strpath,
                                             clone_url=clone_url,
                                             files_no=1)

        key = CacheKey.query().filter(CacheKey.cache_key == HG_REPO).one()
        assert key.cache_active is False
    def test_push_invalidates_cache_git(self, rc_web_server, tmpdir):
        key = CacheKey.query().filter(CacheKey.cache_key == GIT_REPO).scalar()
        if not key:
            key = CacheKey(GIT_REPO, GIT_REPO)

        key.cache_active = True
        Session().add(key)
        Session().commit()

        clone_url = rc_web_server.repo_clone_url(GIT_REPO)
        stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                 tmpdir.strpath)

        # commit some stuff into this repo
        stdout, stderr = _add_files_and_push('git',
                                             tmpdir.strpath,
                                             clone_url=clone_url,
                                             files_no=1)
        _check_proper_git_push(stdout, stderr)

        key = CacheKey.query().filter(CacheKey.cache_key == GIT_REPO).one()

        assert key.cache_active is False
    def test_ip_restriction_git(self, rc_web_server, tmpdir):
        user_model = UserModel()
        try:
            user_model.add_extra_ip(TEST_USER_ADMIN_LOGIN, '10.10.10.10/32')
            Session().commit()
            time.sleep(2)
            clone_url = rc_web_server.repo_clone_url(GIT_REPO)
            stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                                     tmpdir.strpath)
            msg = "The requested URL returned error: 403"
            assert msg in stderr
        finally:
            # release IP restrictions
            for ip in UserIpMap.getAll():
                UserIpMap.delete(ip.ip_id)
            Session().commit()

        time.sleep(2)

        cmd = Command('/tmp')
        stdout, stderr = cmd.execute('git clone', clone_url, tmpdir.strpath)
        cmd.assert_returncode_success()
        _check_proper_clone(stdout, stderr, 'git')
예제 #23
0
 def test_clone_wrong_credentials_git_ret_code(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url(GIT_REPO, passwd='bad!')
     stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                              tmpdir.strpath)
     assert 'The requested URL returned error: 403' in stderr
예제 #24
0
 def test_clone_wrong_credentials_hg_ret_code(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url(HG_REPO, passwd='bad!')
     stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                              tmpdir.strpath)
     assert 'abort: HTTP Error 403: Forbidden' in stderr
 def test_clone_hg_repo_as_git(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url(HG_REPO)
     stdout, stderr = Command('/tmp').execute('git clone', clone_url,
                                              tmpdir.strpath)
     assert 'not found' in stderr
 def test_clone_git_repo_with_group_by_admin(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url(GIT_REPO_WITH_GROUP)
     cmd = Command('/tmp')
     stdout, stderr = cmd.execute('git clone', clone_url, tmpdir.strpath)
     _check_proper_clone(stdout, stderr, 'git')
     cmd.assert_returncode_success()
 def test_clone_hg_repo_with_group_by_admin(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url(HG_REPO_WITH_GROUP)
     stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                              tmpdir.strpath)
     _check_proper_clone(stdout, stderr, 'hg')
 def test_clone_non_existing_path_hg(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url('trololo')
     stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                              tmpdir.strpath)
     assert 'HTTP Error 404: Not Found' in stderr
 def test_clone_hg_repo_by_id_by_admin(self, rc_web_server, tmpdir):
     repo_id = Repository.get_by_repo_name(HG_REPO).repo_id
     clone_url = rc_web_server.repo_clone_url('_%s' % repo_id)
     stdout, stderr = Command('/tmp').execute('hg clone', clone_url,
                                              tmpdir.strpath)
     _check_proper_clone(stdout, stderr, 'hg')
 def test_clone_non_existing_path_git(self, rc_web_server, tmpdir):
     clone_url = rc_web_server.repo_clone_url('trololo')
     stdout, stderr = Command('/tmp').execute('git clone', clone_url)
     assert 'not found' in stderr