##// END OF EJS Templates
mercurial: allow editing largefile store from web interface.
mercurial: allow editing largefile store from web interface.

File last commit:

r1421:5088d9a7 default
r1563:d4c84e02 default
Show More
test_feed.py
75 lines | 3.0 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
license: updated copyright year to 2017
r1271 # Copyright (C) 2010-2017 RhodeCode GmbH
project: added all source files and assets
r1 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
auth-tokens: updated logic of authentication to a common shared user method.
r1421 from rhodecode.model.auth_token import AuthTokenModel
project: added all source files and assets
r1 from rhodecode.model.db import User
from rhodecode.tests import *
class TestFeedController(TestController):
def test_rss(self, backend):
self.log_user()
response = self.app.get(url(controller='feed', action='rss',
repo_name=backend.repo_name))
assert response.content_type == "application/rss+xml"
assert """<rss version="2.0">""" in response
auth-tokens: updated logic of authentication to a common shared user method.
r1421 def test_rss_with_auth_token(self, backend, user_admin):
auth_token = user_admin.feed_token
project: added all source files and assets
r1 assert auth_token != ''
auth-tokens: updated logic of authentication to a common shared user method.
r1421 response = self.app.get(
url(controller='feed', action='rss',
repo_name=backend.repo_name, auth_token=auth_token,
status=200))
project: added all source files and assets
r1
assert response.content_type == "application/rss+xml"
assert """<rss version="2.0">""" in response
auth-tokens: updated logic of authentication to a common shared user method.
r1421 def test_rss_with_auth_token_of_wrong_type(self, backend, user_util):
user = user_util.create_user()
auth_token = AuthTokenModel().create(
user.user_id, 'test-token', -1, AuthTokenModel.cls.ROLE_API)
auth_token = auth_token.api_key
self.app.get(
url(controller='feed', action='rss',
repo_name=backend.repo_name, auth_token=auth_token),
status=302)
auth_token = AuthTokenModel().create(
user.user_id, 'test-token', -1, AuthTokenModel.cls.ROLE_FEED)
auth_token = auth_token.api_key
self.app.get(
url(controller='feed', action='rss',
repo_name=backend.repo_name, auth_token=auth_token),
status=200)
project: added all source files and assets
r1 def test_atom(self, backend):
self.log_user()
response = self.app.get(url(controller='feed', action='atom',
repo_name=backend.repo_name))
assert response.content_type == """application/atom+xml"""
assert """<?xml version="1.0" encoding="utf-8"?>""" in response
tag1 = '<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-us">'
tag2 = '<feed xml:lang="en-us" xmlns="http://www.w3.org/2005/Atom">'
assert tag1 in response or tag2 in response