#!/usr/bin/env python # coding=utf-8 """ (c) 2017 - Copyright Red Hat Inc Authors: Vivek Anand """ __requires__ = ['SQLAlchemy >= 0.8'] import pkg_resources from unittest.case import SkipTest import json import unittest import shutil import sys import os try: import pyclamd except ImportError: pyclamd = None import tempfile import pygit2 from mock import patch sys.path.insert(0, os.path.join(os.path.dirname( os.path.abspath(__file__)), '..')) import pagure.config import pagure.lib import tests class PagureFlaskIssuesACLtests(tests.Modeltests): """ Tests for flask issues controller of pagure for acls """ @patch('pagure.lib.git.update_git') @patch('pagure.lib.notify.send_email') def test_view_issue_no_access(self, p_send_email, p_ugt): """ Test the view_issue endpoint. when a user has no access on repo """ p_send_email.return_value = True p_ugt.return_value = True output = self.app.get('/foo/issue/1') self.assertEqual(output.status_code, 404) tests.create_projects(self.session) tests.create_projects_git( os.path.join(self.path, 'repos'), bare=True) output = self.app.get('/test/issue/1') self.assertEqual(output.status_code, 404) # Create issues to play with repo = pagure.lib.get_authorized_project(self.session, 'test') msg = pagure.lib.new_issue( session=self.session, repo=repo, title='Test issue', content='We should work on this', user='pingou', ticketfolder=None ) self.session.commit() self.assertEqual(msg.title, 'Test issue') # Add milestone repo.milestones = {'77': None} self.session.add(repo) issue = pagure.lib.search_issues( self.session, repo=repo, issueid=1 ) pagure.lib.edit_issue( self.session, issue, pagure.config.config.get('TICKETS_FOLDER'), user='pingou', milestone='77' ) self.session.add(repo) self.session.add(issue) msg = pagure.lib.set_custom_key_fields( self.session, project=repo, fields=['abc', 'xyz'], types=['boolean', 'boolean'], data=[None, None], ) self.assertEqual(msg, 'List of custom fields updated') self.session.add(repo) msg = pagure.lib.set_custom_key_value( self.session, issue=issue, key=pagure.lib.get_custom_key(self.session, repo, 'abc'), value=1 ) self.session.add(issue) self.session.commit() output = self.app.get('/test/issue/1') self.assertEqual(output.status_code, 200) # Not authentified = No edit self.assertNotIn( '', output.data) self.assertTrue( '' 'Login\n to comment on this ticket.' in output.data) user = tests.FakeUser() with tests.user_set(self.app.application, user): output = self.app.get('/test/issue/1') self.assertEqual(output.status_code, 200) # Not author nor admin = No edit self.assertNotIn( '', output.data) self.assertNotIn( '