Blame tests/test_pagure_flask_api_fork.py

Pierre-Yves Chibon c71c2d
# -*- coding: utf-8 -*-
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
"""
Pierre-Yves Chibon c71c2d
 (c) 2015 - Copyright Red Hat Inc
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
 Authors:
Pierre-Yves Chibon c71c2d
   Pierre-Yves Chibon <pingou@pingoured.fr></pingou@pingoured.fr>
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
"""
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 67d1cc
from __future__ import unicode_literals, absolute_import
Aurélien Bompard 626417
Pierre-Yves Chibon c71c2d
import datetime
Pierre-Yves Chibon c71c2d
import unittest
Pierre-Yves Chibon c71c2d
import shutil
Pierre-Yves Chibon c71c2d
import sys
Pierre-Yves Chibon c71c2d
import os
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
import json
Pierre-Yves Chibon 9811e6
from mock import patch, MagicMock
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
sys.path.insert(
Pierre-Yves Chibon 73d120
    0, os.path.join(os.path.dirname(os.path.abspath(__file__)), "..")
Pierre-Yves Chibon 73d120
)
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 930073
import pagure.lib.query
Lenka Segura 3d9cf6
import pagure.default_config
Pierre-Yves Chibon c71c2d
import tests
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
class PagureFlaskApiForktests(tests.Modeltests):
Pierre-Yves Chibon c71c2d
    """ Tests for the flask API of pagure for issue """
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c27d61
    maxDiff = None
Pierre-Yves Chibon c27d61
Pierre-Yves Chibon c71c2d
    def setUp(self):
Pierre-Yves Chibon c71c2d
        """ Set up the environnment, ran before every tests. """
Pierre-Yves Chibon c71c2d
        super(PagureFlaskApiForktests, self).setUp()
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
        pagure.config.config["REQUESTS_FOLDER"] = None
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon fe796e
    def test_api_pull_request_views_pr_disabled(self):
Pierre-Yves Chibon fe796e
        """ Test the api_pull_request_views method of the flask api when PR
Pierre-Yves Chibon fe796e
        are disabled. """
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        tests.create_projects(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon fe796e
            session=self.session,
Pierre-Yves Chibon fe796e
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon fe796e
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon fe796e
        self.session.commit()
Pierre-Yves Chibon fe796e
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon fe796e
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon fe796e
        repo.settings = settings
Pierre-Yves Chibon fe796e
        self.session.add(repo)
Pierre-Yves Chibon fe796e
        self.session.commit()
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests")
Pierre-Yves Chibon fe796e
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon fe796e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon fe796e
        self.assertDictEqual(
Pierre-Yves Chibon fe796e
            data,
Pierre-Yves Chibon fe796e
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon fe796e
    def test_api_pull_request_views_pr_closed(self):
Pierre-Yves Chibon fe796e
        """ Test the api_pull_request_views method of the flask api to list
Pierre-Yves Chibon fe796e
        the closed PRs. """
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        tests.create_projects(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon fe796e
            session=self.session,
Pierre-Yves Chibon fe796e
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon fe796e
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon fe796e
        self.session.commit()
Pierre-Yves Chibon fe796e
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=closed")
Pierre-Yves Chibon fe796e
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon fe796e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        for k in ["first", "last"]:
Pierre-Yves Chibon 73d120
            self.assertIsNotNone(data["pagination"][k])
Pierre-Yves Chibon 73d120
            data["pagination"][k] = "http://localhost..."
Pierre-Yves Chibon fe796e
        self.assertDictEqual(
Pierre-Yves Chibon fe796e
            data,
Pierre-Yves Chibon fe796e
            {
Pierre-Yves Chibon 73d120
                "args": {
Pierre-Yves Chibon 73d120
                    "assignee": None,
Pierre-Yves Chibon 73d120
                    "author": None,
Pierre-Yves Chibon 73d120
                    "page": 1,
Pierre-Yves Chibon 73d120
                    "per_page": 20,
Pierre-Yves Chibon 73d120
                    "status": "closed",
Karsten Hopp 566852
                },
Pierre-Yves Chibon 73d120
                "pagination": {
Pierre-Yves Chibon 73d120
                    "first": "http://localhost...",
Pierre-Yves Chibon 73d120
                    "last": "http://localhost...",
Pierre-Yves Chibon 73d120
                    "next": None,
Pierre-Yves Chibon 73d120
                    "page": 1,
Pierre-Yves Chibon 73d120
                    "pages": 0,
Pierre-Yves Chibon 73d120
                    "per_page": 20,
Pierre-Yves Chibon 73d120
                    "prev": None,
Karsten Hopp 566852
                },
Pierre-Yves Chibon 73d120
                "requests": [],
Pierre-Yves Chibon 73d120
                "total_requests": 0,
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        # Close the PR and try again
Pierre-Yves Chibon 930073
        pagure.lib.query.close_pull_request(
Pierre-Yves Chibon 73d120
            self.session, request=req, user="pingou", merged=False
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=closed")
Pierre-Yves Chibon fe796e
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon fe796e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon fe796e
        self.assertEqual(
Pierre-Yves Chibon dd03b1
            sorted(data.keys()),
Pierre-Yves Chibon 73d120
            ["args", "pagination", "requests", "total_requests"],
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon fe796e
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data["args"],
Karsten Hopp 566852
            {
Pierre-Yves Chibon 73d120
                "assignee": None,
Pierre-Yves Chibon 73d120
                "author": None,
Pierre-Yves Chibon 73d120
                "page": 1,
Pierre-Yves Chibon 73d120
                "per_page": 20,
Pierre-Yves Chibon 73d120
                "status": "closed",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(data["total_requests"], 1)
Pierre-Yves Chibon fe796e
Lenka Segura 96f2fe
        # Create two closed pull-requests
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 96f2fe
        pagure.lib.query.new_pull_request(
Lenka Segura 96f2fe
            session=self.session,
Lenka Segura 96f2fe
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Lenka Segura 96f2fe
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="closed pullrequest by user foo on repo test",
Pierre-Yves Chibon 73d120
            user="foo",
Pierre-Yves Chibon 73d120
            status="Closed",
Lenka Segura 96f2fe
        )
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 96f2fe
        pagure.lib.query.new_pull_request(
Lenka Segura 96f2fe
            session=self.session,
Lenka Segura 96f2fe
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Lenka Segura 96f2fe
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="closed pullrequest by user pingou on repo test",
Pierre-Yves Chibon 73d120
            user="pingou",
Lenka Segura 96f2fe
            status="Closed",
Lenka Segura 96f2fe
        )
Lenka Segura 96f2fe
        self.session.commit()
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 96f2fe
        pagure.lib.query.new_pull_request(
Lenka Segura 96f2fe
            session=self.session,
Lenka Segura 96f2fe
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Lenka Segura 96f2fe
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="merged pullrequest by user pingou on repo test",
Pierre-Yves Chibon 73d120
            user="pingou",
Lenka Segura 96f2fe
            status="Merged",
Lenka Segura 96f2fe
        )
Lenka Segura 96f2fe
        self.session.commit()
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 96f2fe
        pagure.lib.query.new_pull_request(
Lenka Segura 96f2fe
            session=self.session,
Lenka Segura 96f2fe
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Lenka Segura 96f2fe
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="merged pullrequest by user foo on repo test",
Pierre-Yves Chibon 73d120
            user="foo",
Pierre-Yves Chibon 73d120
            status="Merged",
Lenka Segura 96f2fe
        )
Lenka Segura 96f2fe
        self.session.commit()
Lenka Segura 96f2fe
Lenka Segura 96f2fe
        # Test the API view of closed pull-requests
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=closed")
Lenka Segura 96f2fe
        self.assertEqual(output.status_code, 200)
Lenka Segura 96f2fe
        data = json.loads(output.get_data(as_text=True))
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        self.assertEqual(len(data["requests"]), 3)
Lenka Segura 96f2fe
        self.assertEqual(
Lenka Segura 96f2fe
            sorted(data.keys()),
Pierre-Yves Chibon 73d120
            ["args", "pagination", "requests", "total_requests"],
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        for req in data["requests"]:
Pierre-Yves Chibon 73d120
            self.assertEqual(req["status"], "Closed")
Pierre-Yves Chibon 73d120
        self.assertEqual(data["args"]["status"], "closed")
Pierre-Yves Chibon 73d120
        self.assertEqual(data["args"]["page"], 1)
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        self.assertEqual(data["total_requests"], 3)
Lenka Segura 96f2fe
Lenka Segura 96f2fe
        # Test the API view of merged pull-requests
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=merged")
Lenka Segura 96f2fe
        self.assertEqual(output.status_code, 200)
Lenka Segura 96f2fe
        data = json.loads(output.get_data(as_text=True))
Lenka Segura 96f2fe
Pierre-Yves Chibon 73d120
        self.assertEqual(len(data["requests"]), 2)
Lenka Segura 96f2fe
        self.assertEqual(
Lenka Segura 96f2fe
            sorted(data.keys()),
Pierre-Yves Chibon 73d120
            ["args", "pagination", "requests", "total_requests"],
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        for req in data["requests"]:
Pierre-Yves Chibon 73d120
            self.assertEqual(req["status"], "Merged")
Pierre-Yves Chibon 73d120
        self.assertEqual(data["args"]["status"], "merged")
Pierre-Yves Chibon 73d120
        self.assertEqual(data["args"]["page"], 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(data["total_requests"], 2)
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon fe796e
    def test_api_pull_request_views_all_pr(self):
Pierre-Yves Chibon fe796e
        """ Test the api_pull_request_views method of the flask api to list
Pierre-Yves Chibon fe796e
        all PRs. """
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        tests.create_projects(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens(self.session)
Pierre-Yves Chibon fe796e
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon fe796e
            session=self.session,
Pierre-Yves Chibon fe796e
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon fe796e
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon fe796e
        self.session.commit()
Pierre-Yves Chibon fe796e
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=all")
Pierre-Yves Chibon fe796e
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon fe796e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon fe796e
        self.assertEqual(
Pierre-Yves Chibon dd03b1
            sorted(data.keys()),
Pierre-Yves Chibon 73d120
            ["args", "pagination", "requests", "total_requests"],
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon fe796e
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data["args"],
Karsten Hopp 566852
            {
Pierre-Yves Chibon 73d120
                "assignee": None,
Pierre-Yves Chibon 73d120
                "author": None,
Pierre-Yves Chibon 73d120
                "page": 1,
Pierre-Yves Chibon 73d120
                "per_page": 20,
Pierre-Yves Chibon 73d120
                "status": "all",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(data["total_requests"], 1)
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon fe796e
        # Close the PR and try again
Pierre-Yves Chibon 930073
        pagure.lib.query.close_pull_request(
Pierre-Yves Chibon 73d120
            self.session, request=req, user="pingou", merged=False
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests?status=all")
Pierre-Yves Chibon fe796e
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon fe796e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon fe796e
        self.assertEqual(
Pierre-Yves Chibon dd03b1
            sorted(data.keys()),
Pierre-Yves Chibon 73d120
            ["args", "pagination", "requests", "total_requests"],
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon fe796e
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data["args"],
Karsten Hopp 566852
            {
Pierre-Yves Chibon 73d120
                "assignee": None,
Pierre-Yves Chibon 73d120
                "author": None,
Pierre-Yves Chibon 73d120
                "page": 1,
Pierre-Yves Chibon 73d120
                "per_page": 20,
Pierre-Yves Chibon 73d120
                "status": "all",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon fe796e
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(data["total_requests"], 1)
Pierre-Yves Chibon fe796e
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 7cc2d4
    def test_api_pull_request_views(self, send_email):
Pierre-Yves Chibon ad85b9
        """ Test the api_pull_request_views method of the flask api. """
Pierre-Yves Chibon 7cc2d4
        send_email.return_value = True
Pierre-Yves Chibon 7cc2d4
Pierre-Yves Chibon ad85b9
        tests.create_projects(self.session)
Pierre-Yves Chibon ad85b9
        tests.create_tokens(self.session)
Pierre-Yves Chibon ad85b9
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon ad85b9
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon ad85b9
            session=self.session,
Pierre-Yves Chibon ad85b9
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon ad85b9
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon ad85b9
        )
Pierre-Yves Chibon ad85b9
        self.session.commit()
Pierre-Yves Chibon f9c5f9
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon ad85b9
        # Invalid repo
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/foo/pull-requests")
Pierre-Yves Chibon ad85b9
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon ad85b9
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon ad85b9
        )
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon ad85b9
        # List pull-requests
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests")
Pierre-Yves Chibon ad85b9
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data["requests"][0]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["uid"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["requests"][0]["last_updated"] = "1431414800"
Pierre-Yves Chibon 73d120
        for k in ["first", "last"]:
Pierre-Yves Chibon 73d120
            self.assertIsNotNone(data["pagination"][k])
Pierre-Yves Chibon 73d120
            data["pagination"][k] = "http://localhost..."
Matt Prahl 6bf79a
        expected_data = {
Matt Prahl 6bf79a
            "args": {
Pierre-Yves Chibon 316f15
                "assignee": None,
Pierre-Yves Chibon 316f15
                "author": None,
Karsten Hopp 566852
                "page": 1,
Karsten Hopp 566852
                "per_page": 20,
Pierre-Yves Chibon 73d120
                "status": True,
Matt Prahl 6bf79a
            },
Pierre-Yves Chibon 73d120
            "pagination": {
Pierre-Yves Chibon 73d120
                "first": "http://localhost...",
Pierre-Yves Chibon 73d120
                "last": "http://localhost...",
Pierre-Yves Chibon 73d120
                "next": None,
Pierre-Yves Chibon 73d120
                "page": 1,
Pierre-Yves Chibon 73d120
                "pages": 1,
Pierre-Yves Chibon 73d120
                "per_page": 20,
Pierre-Yves Chibon 73d120
                "prev": None,
Karsten Hopp 566852
            },
Pierre-Yves Chibon 73d120
            "requests": [
Pierre-Yves Chibon 73d120
                {
Pierre-Yves Chibon 73d120
                    "assignee": None,
Pierre-Yves Chibon 73d120
                    "branch": "master",
Pierre-Yves Chibon 73d120
                    "branch_from": "master",
Pierre-Yves Chibon 73d120
                    "cached_merge_status": "unknown",
Pierre-Yves Chibon 73d120
                    "closed_at": None,
Pierre-Yves Chibon 73d120
                    "closed_by": None,
Pierre-Yves Chibon 73d120
                    "comments": [],
Pierre-Yves Chibon 73d120
                    "commit_start": None,
Pierre-Yves Chibon 73d120
                    "commit_stop": None,
Pierre-Yves Chibon ad85b9
                    "date_created": "1431414800",
Pierre-Yves Chibon ad85b9
                    "id": 1,
Pierre-Yves Chibon 73d120
                    "initial_comment": None,
Pierre-Yves Chibon 73d120
                    "last_updated": "1431414800",
Pierre-Yves Chibon 73d120
                    "project": {
Pierre-Yves Chibon 73d120
                        "access_groups": {
Pierre-Yves Chibon 73d120
                            "admin": [],
Pierre-Yves Chibon 73d120
                            "commit": [],
Pierre-Yves Chibon 73d120
                            "ticket": [],
Pierre-Yves Chibon 73d120
                        },
Pierre-Yves Chibon 73d120
                        "access_users": {
Pierre-Yves Chibon 73d120
                            "admin": [],
Pierre-Yves Chibon 73d120
                            "commit": [],
Pierre-Yves Chibon 73d120
                            "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                            "ticket": [],
Pierre-Yves Chibon 73d120
                        },
Pierre-Yves Chibon 73d120
                        "close_status": [
Pierre-Yves Chibon 73d120
                            "Invalid",
Pierre-Yves Chibon 73d120
                            "Insufficient data",
Pierre-Yves Chibon 73d120
                            "Fixed",
Pierre-Yves Chibon 73d120
                            "Duplicate",
Pierre-Yves Chibon 73d120
                        ],
Pierre-Yves Chibon 73d120
                        "custom_keys": [],
Pierre-Yves Chibon 73d120
                        "date_created": "1431414800",
Pierre-Yves Chibon 73d120
                        "date_modified": "1431414800",
Pierre-Yves Chibon 73d120
                        "description": "test project #1",
Pierre-Yves Chibon 73d120
                        "fullname": "test",
Pierre-Yves Chibon 73d120
                        "url_path": "test",
Pierre-Yves Chibon 73d120
                        "id": 1,
Pierre-Yves Chibon 73d120
                        "milestones": {},
Pierre-Yves Chibon 73d120
                        "name": "test",
Pierre-Yves Chibon 73d120
                        "namespace": None,
Pierre-Yves Chibon 73d120
                        "parent": None,
Pierre-Yves Chibon 73d120
                        "priorities": {},
Pierre-Yves Chibon 73d120
                        "tags": [],
Pierre-Yves Chibon 73d120
                        "user": {"fullname": "PY C", "name": "pingou"},
Matt Prahl 6bf79a
                    },
Pierre-Yves Chibon 73d120
                    "remote_git": None,
Pierre-Yves Chibon 73d120
                    "repo_from": {
Pierre-Yves Chibon 73d120
                        "access_groups": {
Pierre-Yves Chibon 73d120
                            "admin": [],
Pierre-Yves Chibon 73d120
                            "commit": [],
Pierre-Yves Chibon 73d120
                            "ticket": [],
Pierre-Yves Chibon 73d120
                        },
Pierre-Yves Chibon 73d120
                        "access_users": {
Pierre-Yves Chibon 73d120
                            "admin": [],
Pierre-Yves Chibon 73d120
                            "commit": [],
Pierre-Yves Chibon 73d120
                            "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                            "ticket": [],
Pierre-Yves Chibon 73d120
                        },
Pierre-Yves Chibon 73d120
                        "close_status": [
Pierre-Yves Chibon 73d120
                            "Invalid",
Pierre-Yves Chibon 73d120
                            "Insufficient data",
Pierre-Yves Chibon 73d120
                            "Fixed",
Pierre-Yves Chibon 73d120
                            "Duplicate",
Pierre-Yves Chibon 73d120
                        ],
Pierre-Yves Chibon 73d120
                        "custom_keys": [],
Pierre-Yves Chibon 73d120
                        "date_created": "1431414800",
Pierre-Yves Chibon 73d120
                        "date_modified": "1431414800",
Pierre-Yves Chibon 73d120
                        "description": "test project #1",
Pierre-Yves Chibon 73d120
                        "fullname": "test",
Pierre-Yves Chibon 73d120
                        "url_path": "test",
Pierre-Yves Chibon 73d120
                        "id": 1,
Pierre-Yves Chibon 73d120
                        "milestones": {},
Pierre-Yves Chibon 73d120
                        "name": "test",
Pierre-Yves Chibon 73d120
                        "namespace": None,
Pierre-Yves Chibon 73d120
                        "parent": None,
Pierre-Yves Chibon 73d120
                        "priorities": {},
Pierre-Yves Chibon 73d120
                        "tags": [],
Pierre-Yves Chibon 73d120
                        "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "status": "Open",
Pierre-Yves Chibon a30916
                    "tags": [],
Pierre-Yves Chibon 73d120
                    "threshold_reached": None,
Pierre-Yves Chibon 73d120
                    "title": "test pull-request",
Pierre-Yves Chibon 73d120
                    "uid": "1431414800",
Pierre-Yves Chibon 73d120
                    "updated_on": "1431414800",
Pierre-Yves Chibon 73d120
                    "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon ad85b9
                }
Pierre-Yves Chibon 73d120
            ],
Pierre-Yves Chibon 73d120
            "total_requests": 1,
Matt Prahl 6bf79a
        }
Matt Prahl 6bf79a
        self.assertDictEqual(data, expected_data)
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon ad85b9
        # Access Pull-Request authenticated
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-requests", headers=headers)
Pierre-Yves Chibon ad85b9
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data2 = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data2["requests"][0]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["uid"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["requests"][0]["last_updated"] = "1431414800"
Pierre-Yves Chibon 73d120
        for k in ["first", "last"]:
Pierre-Yves Chibon 73d120
            self.assertIsNotNone(data["pagination"][k])
Pierre-Yves Chibon 73d120
            data2["pagination"][k] = "http://localhost..."
Pierre-Yves Chibon ad85b9
        self.assertDictEqual(data, data2)
Pierre-Yves Chibon ad85b9
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_view_pr_disabled(self, send_email):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_view method of the flask api. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 7cc2d4
    def test_api_pull_request_view(self, send_email):
Pierre-Yves Chibon c71c2d
        """ Test the api_pull_request_view method of the flask api. """
Pierre-Yves Chibon 7cc2d4
        send_email.return_value = True
Pierre-Yves Chibon c71c2d
        tests.create_projects(self.session)
Pierre-Yves Chibon c71c2d
        tests.create_tokens(self.session)
Pierre-Yves Chibon c71c2d
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon c71c2d
            session=self.session,
Pierre-Yves Chibon c71c2d
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon c71c2d
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon c71c2d
        )
Pierre-Yves Chibon c71c2d
        self.session.commit()
Pierre-Yves Chibon f9c5f9
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
        # Invalid repo
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/foo/pull-request/1")
Pierre-Yves Chibon c71c2d
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c71c2d
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon c71c2d
        )
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
        # Invalid issue for this repo
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test2/pull-request/1")
Pierre-Yves Chibon c71c2d
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c71c2d
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon c71c2d
        )
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
        # Valid issue
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon c71c2d
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["uid"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["last_updated"] = "1431414800"
Matt Prahl 6bf79a
        expected_data = {
Matt Prahl 6bf79a
            "assignee": None,
Matt Prahl 6bf79a
            "branch": "master",
Matt Prahl 6bf79a
            "branch_from": "master",
Pierre-Yves Chibon f21734
            "cached_merge_status": "unknown",
Matt Prahl 6bf79a
            "closed_at": None,
Matt Prahl 6bf79a
            "closed_by": None,
Matt Prahl 6bf79a
            "comments": [],
Matt Prahl 6bf79a
            "commit_start": None,
Matt Prahl 6bf79a
            "commit_stop": None,
Matt Prahl 6bf79a
            "date_created": "1431414800",
Matt Prahl 6bf79a
            "id": 1,
Matt Prahl 6bf79a
            "initial_comment": None,
Matt Prahl 6bf79a
            "last_updated": "1431414800",
Matt Prahl 6bf79a
            "project": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Matt Prahl 6bf79a
                "access_users": {
Matt Prahl 6bf79a
                    "admin": [],
Matt Prahl 6bf79a
                    "commit": [],
Matt Prahl 6bf79a
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Matt Prahl 6bf79a
                },
Pierre-Yves Chibon f254bf
                "close_status": [
Matt Prahl 6bf79a
                    "Invalid",
Matt Prahl 6bf79a
                    "Insufficient data",
Matt Prahl 6bf79a
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Pierre-Yves Chibon f254bf
                ],
Pierre-Yves Chibon 022564
                "custom_keys": [],
Pierre-Yves Chibon c71c2d
                "date_created": "1431414800",
Clement Verna cd6e30
                "date_modified": "1431414800",
Pierre-Yves Chibon c71c2d
                "description": "test project #1",
Pierre-Yves Chibon c9e619
                "fullname": "test",
Pierre-Yves Chibon 469e24
                "url_path": "test",
Pierre-Yves Chibon c71c2d
                "id": 1,
Pierre-Yves Chibon f254bf
                "milestones": {},
Pierre-Yves Chibon c71c2d
                "name": "test",
Pierre-Yves Chibon 733a9d
                "namespace": None,
Pierre-Yves Chibon c71c2d
                "parent": None,
Pierre-Yves Chibon 14bde2
                "priorities": {},
Pierre-Yves Chibon a30916
                "tags": [],
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Matt Prahl 6bf79a
            },
Matt Prahl 6bf79a
            "remote_git": None,
Matt Prahl 6bf79a
            "repo_from": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Matt Prahl 6bf79a
                "access_users": {
Matt Prahl 6bf79a
                    "admin": [],
Matt Prahl 6bf79a
                    "commit": [],
Matt Prahl 6bf79a
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Pierre-Yves Chibon 73d120
                },
Matt Prahl 6bf79a
                "close_status": [
Matt Prahl 6bf79a
                    "Invalid",
Matt Prahl 6bf79a
                    "Insufficient data",
Matt Prahl 6bf79a
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Pierre-Yves Chibon 73d120
                ],
Pierre-Yves Chibon 73d120
                "custom_keys": [],
Pierre-Yves Chibon 73d120
                "date_created": "1431414800",
Pierre-Yves Chibon 73d120
                "date_modified": "1431414800",
Pierre-Yves Chibon 73d120
                "description": "test project #1",
Pierre-Yves Chibon 73d120
                "fullname": "test",
Pierre-Yves Chibon 73d120
                "url_path": "test",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "milestones": {},
Pierre-Yves Chibon 73d120
                "name": "test",
Pierre-Yves Chibon 73d120
                "namespace": None,
Pierre-Yves Chibon 73d120
                "parent": None,
Pierre-Yves Chibon 73d120
                "priorities": {},
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Matt Prahl 6bf79a
            },
Matt Prahl 6bf79a
            "status": "Open",
Pierre-Yves Chibon 31a638
            "tags": [],
Pierre-Yves Chibon 2233c1
            "threshold_reached": None,
Matt Prahl 6bf79a
            "title": "test pull-request",
Matt Prahl 6bf79a
            "uid": "1431414800",
Matt Prahl 6bf79a
            "updated_on": "1431414800",
Pierre-Yves Chibon 73d120
            "user": {"fullname": "PY C", "name": "pingou"},
Matt Prahl 6bf79a
        }
Matt Prahl 6bf79a
        self.assertDictEqual(data, expected_data)
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon c71c2d
        # Access Pull-Request authenticated
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1", headers=headers)
Pierre-Yves Chibon c71c2d
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data2 = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data2["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["uid"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["last_updated"] = "1431414800"
Pierre-Yves Chibon c71c2d
        self.assertDictEqual(data, data2)
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Slavek Kabrda 1a6e21
    def test_api_pull_request_by_uid_view(self, send_email):
Slavek Kabrda 1a6e21
        """ Test the api_pull_request_by_uid_view method of the flask api. """
Slavek Kabrda 1a6e21
        send_email.return_value = True
Slavek Kabrda 1a6e21
        tests.create_projects(self.session)
Slavek Kabrda 1a6e21
        tests.create_tokens(self.session)
Slavek Kabrda 1a6e21
        tests.create_tokens_acl(self.session)
Slavek Kabrda 1a6e21
Slavek Kabrda 1a6e21
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Slavek Kabrda 1a6e21
            session=self.session,
Slavek Kabrda 1a6e21
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Slavek Kabrda 1a6e21
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Slavek Kabrda 1a6e21
        )
Slavek Kabrda 1a6e21
        self.session.commit()
Slavek Kabrda 1a6e21
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Slavek Kabrda 1a6e21
        uid = req.uid
Slavek Kabrda 1a6e21
Slavek Kabrda 1a6e21
        # Invalid request
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/pull-requests/{}".format(uid + "aaa"))
Slavek Kabrda 1a6e21
        self.assertEqual(output.status_code, 404)
Slavek Kabrda 1a6e21
        data = json.loads(output.get_data(as_text=True))
Slavek Kabrda 1a6e21
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Slavek Kabrda 1a6e21
        )
Slavek Kabrda 1a6e21
Slavek Kabrda 1a6e21
        # Valid issue
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/pull-requests/{}".format(uid))
Slavek Kabrda 1a6e21
        self.assertEqual(output.status_code, 200)
Slavek Kabrda 1a6e21
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data["last_updated"] = "1431414800"
Slavek Kabrda 1a6e21
        expected_data = {
Slavek Kabrda 1a6e21
            "assignee": None,
Slavek Kabrda 1a6e21
            "branch": "master",
Slavek Kabrda 1a6e21
            "branch_from": "master",
Slavek Kabrda 1a6e21
            "cached_merge_status": "unknown",
Slavek Kabrda 1a6e21
            "closed_at": None,
Slavek Kabrda 1a6e21
            "closed_by": None,
Slavek Kabrda 1a6e21
            "comments": [],
Slavek Kabrda 1a6e21
            "commit_start": None,
Slavek Kabrda 1a6e21
            "commit_stop": None,
Slavek Kabrda 1a6e21
            "date_created": "1431414800",
Slavek Kabrda 1a6e21
            "id": 1,
Slavek Kabrda 1a6e21
            "initial_comment": None,
Slavek Kabrda 1a6e21
            "last_updated": "1431414800",
Slavek Kabrda 1a6e21
            "project": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Slavek Kabrda 1a6e21
                "access_users": {
Slavek Kabrda 1a6e21
                    "admin": [],
Slavek Kabrda 1a6e21
                    "commit": [],
Slavek Kabrda 1a6e21
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Slavek Kabrda 1a6e21
                },
Slavek Kabrda 1a6e21
                "close_status": [
Slavek Kabrda 1a6e21
                    "Invalid",
Slavek Kabrda 1a6e21
                    "Insufficient data",
Slavek Kabrda 1a6e21
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Slavek Kabrda 1a6e21
                ],
Slavek Kabrda 1a6e21
                "custom_keys": [],
Slavek Kabrda 1a6e21
                "date_created": "1431414800",
Slavek Kabrda 1a6e21
                "date_modified": "1431414800",
Slavek Kabrda 1a6e21
                "description": "test project #1",
Slavek Kabrda 1a6e21
                "fullname": "test",
Slavek Kabrda 1a6e21
                "url_path": "test",
Slavek Kabrda 1a6e21
                "id": 1,
Slavek Kabrda 1a6e21
                "milestones": {},
Slavek Kabrda 1a6e21
                "name": "test",
Slavek Kabrda 1a6e21
                "namespace": None,
Slavek Kabrda 1a6e21
                "parent": None,
Slavek Kabrda 1a6e21
                "priorities": {},
Slavek Kabrda 1a6e21
                "tags": [],
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Slavek Kabrda 1a6e21
            },
Slavek Kabrda 1a6e21
            "remote_git": None,
Slavek Kabrda 1a6e21
            "repo_from": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Slavek Kabrda 1a6e21
                "access_users": {
Slavek Kabrda 1a6e21
                    "admin": [],
Slavek Kabrda 1a6e21
                    "commit": [],
Slavek Kabrda 1a6e21
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Pierre-Yves Chibon 73d120
                },
Slavek Kabrda 1a6e21
                "close_status": [
Slavek Kabrda 1a6e21
                    "Invalid",
Slavek Kabrda 1a6e21
                    "Insufficient data",
Slavek Kabrda 1a6e21
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Pierre-Yves Chibon 73d120
                ],
Pierre-Yves Chibon 73d120
                "custom_keys": [],
Pierre-Yves Chibon 73d120
                "date_created": "1431414800",
Pierre-Yves Chibon 73d120
                "date_modified": "1431414800",
Pierre-Yves Chibon 73d120
                "description": "test project #1",
Pierre-Yves Chibon 73d120
                "fullname": "test",
Pierre-Yves Chibon 73d120
                "url_path": "test",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "milestones": {},
Pierre-Yves Chibon 73d120
                "name": "test",
Pierre-Yves Chibon 73d120
                "namespace": None,
Pierre-Yves Chibon 73d120
                "parent": None,
Pierre-Yves Chibon 73d120
                "priorities": {},
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Slavek Kabrda 1a6e21
            },
Slavek Kabrda 1a6e21
            "status": "Open",
Pierre-Yves Chibon 31a638
            "tags": [],
Pierre-Yves Chibon 2233c1
            "threshold_reached": None,
Slavek Kabrda 1a6e21
            "title": "test pull-request",
Slavek Kabrda 1a6e21
            "uid": uid,
Slavek Kabrda 1a6e21
            "updated_on": "1431414800",
Pierre-Yves Chibon 73d120
            "user": {"fullname": "PY C", "name": "pingou"},
Slavek Kabrda 1a6e21
        }
Slavek Kabrda 1a6e21
        self.assertDictEqual(data, expected_data)
Slavek Kabrda 1a6e21
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Slavek Kabrda 1a6e21
Slavek Kabrda 1a6e21
        # Access Pull-Request authenticated
Pierre-Yves Chibon 73d120
        output = self.app.get(
Pierre-Yves Chibon 73d120
            "/api/0/pull-requests/{}".format(uid), headers=headers
Pierre-Yves Chibon 73d120
        )
Slavek Kabrda 1a6e21
        self.assertEqual(output.status_code, 200)
Slavek Kabrda 1a6e21
        data2 = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data2["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["project"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["project"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["repo_from"]["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["repo_from"]["date_modified"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["date_created"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["updated_on"] = "1431414800"
Pierre-Yves Chibon 73d120
        data2["last_updated"] = "1431414800"
Slavek Kabrda 1a6e21
        self.assertDictEqual(data, data2)
Slavek Kabrda 1a6e21
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_close_pr_disabled(self, send_email):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_close method of the flask api. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 7cc2d4
    def test_api_pull_request_close(self, send_email):
Pierre-Yves Chibon 209c7e
        """ Test the api_pull_request_close method of the flask api. """
Pierre-Yves Chibon 7cc2d4
        send_email.return_value = True
Pierre-Yves Chibon 7cc2d4
Pierre-Yves Chibon 209c7e
        tests.create_projects(self.session)
Pierre-Yves Chibon 209c7e
        tests.create_tokens(self.session)
Pierre-Yves Chibon 209c7e
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon 209c7e
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 209c7e
            session=self.session,
Pierre-Yves Chibon 209c7e
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 209c7e
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 209c7e
        )
Pierre-Yves Chibon 209c7e
        self.session.commit()
Pierre-Yves Chibon f9c5f9
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon 209c7e
        # Invalid project
Pierre-Yves Chibon 209c7e
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 209c7e
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 209c7e
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon 209c7e
        )
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon 209c7e
        # Valid token, wrong project
Pierre-Yves Chibon 209c7e
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 209c7e
        self.assertEqual(output.status_code, 401)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertEqual(
Pierre-Yves Chibon 73d120
            pagure.api.APIERROR.EINVALIDTOK.name, data["error_code"]
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(pagure.api.APIERROR.EINVALIDTOK.value, data["error"])
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon f12b4a
        # Invalid PR
Pierre-Yves Chibon f12b4a
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/2/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon f12b4a
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon f12b4a
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon f12b4a
        # Create a token for foo for this project
Pierre-Yves Chibon f12b4a
        item = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="foobar_token",
Pierre-Yves Chibon f12b4a
            user_id=2,
Pierre-Yves Chibon f12b4a
            project_id=1,
Pierre-Yves Chibon 73d120
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
        self.session.add(item)
Pierre-Yves Chibon f12b4a
        self.session.commit()
Pierre-Yves Chibon c02e60
Pierre-Yves Chibon c02e60
        # Allow the token to close PR
Pierre-Yves Chibon 930073
        acls = pagure.lib.query.get_acls(self.session)
Pierre-Yves Chibon b11d54
        for acl in acls:
Pierre-Yves Chibon 73d120
            if acl.name == "pull_request_close":
Pierre-Yves Chibon b11d54
                break
Pierre-Yves Chibon f12b4a
        item = pagure.lib.model.TokenAcl(
Pierre-Yves Chibon 73d120
            token_id="foobar_token", acl_id=acl.id
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
        self.session.add(item)
Pierre-Yves Chibon f12b4a
        self.session.commit()
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token foobar_token"}
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon f12b4a
        # User not admin
Pierre-Yves Chibon f12b4a
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon f12b4a
        self.assertEqual(output.status_code, 403)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon f12b4a
        self.assertDictEqual(
Pierre-Yves Chibon f12b4a
            data,
Pierre-Yves Chibon f12b4a
            {
Pierre-Yves Chibon 73d120
                "error": "You are not allowed to merge/close pull-request "
Pierre-Yves Chibon 73d120
                "for this project",
Pierre-Yves Chibon 73d120
                "error_code": "ENOPRCLOSE",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon 209c7e
        # Close PR
Pierre-Yves Chibon 209c7e
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/close", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 209c7e
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Pull-request closed!"})
Pierre-Yves Chibon 209c7e
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_merge_pr_disabled(self, send_email):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_merge method of the flask api when PR
Pierre-Yves Chibon 417805
        are disabled. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_merge_only_assigned(self, send_email):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_merge method of the flask api when
Pierre-Yves Chibon 417805
        only assignee can merge the PR and the PR isn't assigned. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Only_assignee_can_merge_pull-request"] = True
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 403)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "This request must be assigned to be merged",
Pierre-Yves Chibon 73d120
                "error_code": "ENOTASSIGNED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_merge_only_assigned_not_assignee(
Pierre-Yves Chibon 73d120
        self, send_email
Pierre-Yves Chibon 73d120
    ):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_merge method of the flask api when
Pierre-Yves Chibon 417805
        only assignee can merge the PR and the PR isn't assigned to the
Pierre-Yves Chibon 417805
        user asking to merge. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 73d120
        req.assignee = pagure.lib.query.search_user(self.session, "foo")
Pierre-Yves Chibon 417805
        self.session.add(req)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Only_assignee_can_merge_pull-request"] = True
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 403)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Only the assignee can merge this review",
Pierre-Yves Chibon 73d120
                "error_code": "ENOTASSIGNEE",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_pull_request_merge_minimal_score(self, send_email):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_merge method of the flask api when
Pierre-Yves Chibon 417805
        a PR requires a certain minimal score to be merged. """
Pierre-Yves Chibon 417805
        send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Minimum_score_to_merge_pull-request"] = 2
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 403)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "This request does not have the minimum review "
Pierre-Yves Chibon 73d120
                "score necessary to be merged",
Pierre-Yves Chibon 73d120
                "error_code": "EPRSCORE",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Patrick Uiterwijk 02a7cc
    def test_api_pull_request_merge(self, send_email):
Pierre-Yves Chibon a9c964
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 7cc2d4
        send_email.return_value = True
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon a9c964
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon a9c964
        tests.create_tokens(self.session)
Pierre-Yves Chibon a9c964
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon a9c964
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon a9c964
            session=self.session,
Pierre-Yves Chibon a9c964
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon a9c964
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon a9c964
        )
Pierre-Yves Chibon a9c964
        self.session.commit()
Pierre-Yves Chibon f9c5f9
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon a9c964
        # Invalid project
Pierre-Yves Chibon a9c964
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon a9c964
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon a9c964
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon a9c964
        )
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon a9c964
        # Valid token, wrong project
Pierre-Yves Chibon a9c964
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon a9c964
        self.assertEqual(output.status_code, 401)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertEqual(
Pierre-Yves Chibon 73d120
            pagure.api.APIERROR.EINVALIDTOK.name, data["error_code"]
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(pagure.api.APIERROR.EINVALIDTOK.value, data["error"])
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon f12b4a
        # Invalid PR
Pierre-Yves Chibon f12b4a
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/2/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon f12b4a
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon f12b4a
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon f12b4a
        # Create a token for foo for this project
Pierre-Yves Chibon f12b4a
        item = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="foobar_token",
Pierre-Yves Chibon f12b4a
            user_id=2,
Pierre-Yves Chibon f12b4a
            project_id=1,
Pierre-Yves Chibon 73d120
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
        self.session.add(item)
Pierre-Yves Chibon f12b4a
        self.session.commit()
Pierre-Yves Chibon c02e60
Pierre-Yves Chibon c02e60
        # Allow the token to merge PR
Pierre-Yves Chibon 930073
        acls = pagure.lib.query.get_acls(self.session)
Pierre-Yves Chibon b11d54
        for acl in acls:
Pierre-Yves Chibon 73d120
            if acl.name == "pull_request_merge":
Pierre-Yves Chibon b11d54
                break
Pierre-Yves Chibon f12b4a
        item = pagure.lib.model.TokenAcl(
Pierre-Yves Chibon 73d120
            token_id="foobar_token", acl_id=acl.id
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
        self.session.add(item)
Pierre-Yves Chibon dea6ca
        self.session.commit()
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token foobar_token"}
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # User not admin
Pierre-Yves Chibon dea6ca
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        self.assertEqual(output.status_code, 403)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon dea6ca
        self.assertDictEqual(
Pierre-Yves Chibon dea6ca
            data,
Pierre-Yves Chibon dea6ca
            {
Pierre-Yves Chibon 73d120
                "error": "You are not allowed to merge/close pull-request "
Pierre-Yves Chibon 73d120
                "for this project",
Pierre-Yves Chibon 73d120
                "error_code": "ENOPRCLOSE",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Merge PR
Pierre-Yves Chibon dea6ca
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Changes merged!"})
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 457b8e
    def test_api_pull_request_merge_conflicting(self, send_email):
Pierre-Yves Chibon 457b8e
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 457b8e
        send_email.return_value = True
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        tests.create_projects(self.session)
Pierre-Yves Chibon 457b8e
        tests.add_content_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git")
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        # Fork
Pierre-Yves Chibon 73d120
        project = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 457b8e
        task = pagure.lib.query.fork_project(
Pierre-Yves Chibon 73d120
            session=self.session, user="pingou", repo=project
Pierre-Yves Chibon 457b8e
        )
Pierre-Yves Chibon 457b8e
        self.session.commit()
Pierre-Yves Chibon 457b8e
        self.assertEqual(
Pierre-Yves Chibon 457b8e
            task.get(),
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "endpoint": "ui_ns.view_repo",
Pierre-Yves Chibon 73d120
                "repo": "test",
Pierre-Yves Chibon 73d120
                "namespace": None,
Pierre-Yves Chibon 73d120
                "username": "pingou",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        # Add content to the fork
Pierre-Yves Chibon 457b8e
        tests.add_content_to_git(
Pierre-Yves Chibon 457b8e
            os.path.join(self.path, "repos", "forks", "pingou", "test.git"),
Pierre-Yves Chibon 73d120
            filename="foobar",
Pierre-Yves Chibon 73d120
            content="content from the fork",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        # Add content to the main repo, so they conflict
Pierre-Yves Chibon 457b8e
        tests.add_content_to_git(
Pierre-Yves Chibon 457b8e
            os.path.join(self.path, "repos", "test.git"),
Pierre-Yves Chibon 73d120
            filename="foobar",
Pierre-Yves Chibon 73d120
            content="content from the main repo",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 73d120
        project = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 457b8e
        fork = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test", user="pingou"
Pierre-Yves Chibon 457b8e
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        tests.create_tokens(self.session)
Pierre-Yves Chibon 457b8e
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        # Create the pull-request to close
Pierre-Yves Chibon 457b8e
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 457b8e
            session=self.session,
Pierre-Yves Chibon 457b8e
            repo_from=fork,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 457b8e
            repo_to=project,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 457b8e
        )
Pierre-Yves Chibon 457b8e
        self.session.commit()
Pierre-Yves Chibon 457b8e
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 457b8e
        # Merge PR
Pierre-Yves Chibon 457b8e
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 457b8e
        self.assertEqual(output.status_code, 409)
Pierre-Yves Chibon 457b8e
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 457b8e
        self.assertDictEqual(
Pierre-Yves Chibon 457b8e
            data,
Pierre-Yves Chibon 457b8e
            {
Pierre-Yves Chibon 73d120
                "error": "This pull-request conflicts and thus cannot be merged",
Pierre-Yves Chibon 73d120
                "error_code": "EPRCONFLICTS",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 457b8e
        )
Pierre-Yves Chibon 457b8e
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Patrick Uiterwijk 02a7cc
    def test_api_pull_request_merge_user_token(self, send_email):
Pierre-Yves Chibon dea6ca
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon dea6ca
        send_email.return_value = True
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        tests.create_tokens(self.session, project_id=None)
Pierre-Yves Chibon dea6ca
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon dea6ca
            session=self.session,
Pierre-Yves Chibon dea6ca
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon dea6ca
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
        self.session.commit()
Pierre-Yves Chibon dea6ca
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Invalid project
Pierre-Yves Chibon dea6ca
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon dea6ca
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Valid token, invalid PR
Pierre-Yves Chibon dea6ca
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon dea6ca
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Valid token, invalid PR - other project
Pierre-Yves Chibon dea6ca
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/2/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon dea6ca
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon dea6ca
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Create a token for foo for this project
Pierre-Yves Chibon dea6ca
        item = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="foobar_token",
Pierre-Yves Chibon dea6ca
            user_id=2,
Pierre-Yves Chibon dea6ca
            project_id=1,
Pierre-Yves Chibon 73d120
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
        self.session.add(item)
Pierre-Yves Chibon dea6ca
        self.session.commit()
Pierre-Yves Chibon dea6ca
Pierre-Yves Chibon dea6ca
        # Allow the token to merge PR
Pierre-Yves Chibon 930073
        acls = pagure.lib.query.get_acls(self.session)
Pierre-Yves Chibon dea6ca
        acl = None
Pierre-Yves Chibon dea6ca
        for acl in acls:
Pierre-Yves Chibon 73d120
            if acl.name == "pull_request_merge":
Pierre-Yves Chibon dea6ca
                break
Pierre-Yves Chibon dea6ca
        item = pagure.lib.model.TokenAcl(
Pierre-Yves Chibon 73d120
            token_id="foobar_token", acl_id=acl.id
Pierre-Yves Chibon dea6ca
        )
Pierre-Yves Chibon dea6ca
        self.session.add(item)
Pierre-Yves Chibon f12b4a
        self.session.commit()
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token foobar_token"}
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon f12b4a
        # User not admin
Pierre-Yves Chibon f12b4a
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon f12b4a
        self.assertEqual(output.status_code, 403)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon f12b4a
        self.assertDictEqual(
Pierre-Yves Chibon f12b4a
            data,
Pierre-Yves Chibon f12b4a
            {
Pierre-Yves Chibon 73d120
                "error": "You are not allowed to merge/close pull-request "
Pierre-Yves Chibon 73d120
                "for this project",
Pierre-Yves Chibon 73d120
                "error_code": "ENOPRCLOSE",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon f12b4a
        )
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon f12b4a
Pierre-Yves Chibon f12b4a
        # Merge PR
Pierre-Yves Chibon a9c964
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/merge", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon a9c964
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Changes merged!"})
Pierre-Yves Chibon a9c964
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 4eb5ad
    def test_api_pull_request_add_comment(self, mockemail):
Pierre-Yves Chibon 9ba77b
        """ Test the api_pull_request_add_comment method of the flask api. """
Pierre-Yves Chibon 4eb5ad
        mockemail.return_value = True
Pierre-Yves Chibon 4eb5ad
Pierre-Yves Chibon 9ba77b
        tests.create_projects(self.session)
Pierre-Yves Chibon 9ba77b
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9ba77b
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Invalid project
Pierre-Yves Chibon 9ba77b
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9ba77b
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon 9ba77b
        )
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Valid token, wrong project
Pierre-Yves Chibon 9ba77b
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(output.status_code, 401)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertEqual(
Pierre-Yves Chibon 73d120
            pagure.api.APIERROR.EINVALIDTOK.name, data["error_code"]
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(pagure.api.APIERROR.EINVALIDTOK.value, data["error"])
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # No input
Pierre-Yves Chibon 9ba77b
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9ba77b
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon 9ba77b
        )
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 9ba77b
            session=self.session,
Pierre-Yves Chibon 9ba77b
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 9ba77b
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 9ba77b
        )
Pierre-Yves Chibon 9ba77b
        self.session.commit()
Pierre-Yves Chibon f9c5f9
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Check comments before
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(len(request.comments), 0)
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 73d120
        data = {"title": "test issue"}
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Incomplete request
Pierre-Yves Chibon 9ba77b
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9ba77b
        self.assertDictEqual(
Pierre-Yves Chibon 9ba77b
            data,
Pierre-Yves Chibon 9ba77b
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": {"comment": ["This field is required."]},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9ba77b
        )
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # No change
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(len(request.comments), 0)
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting question"}
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # Valid request
Pierre-Yves Chibon 9ba77b
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 9ba77b
        # One comment added
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9ba77b
        self.assertEqual(len(request.comments), 1)
Pierre-Yves Chibon 9ba77b
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 417805
    def test_api_pull_request_add_comment_wrong_user(self):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_add_comment method of the flask api
Pierre-Yves Chibon 417805
        when the user is not found in the DB. """
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session, project_id=None)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting question"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Valid request
Pierre-Yves Chibon 73d120
        with patch(
Pierre-Yves Chibon 73d120
            "pagure.lib.query.add_pull_request_comment",
Pierre-Yves Chibon 73d120
            side_effect=pagure.exceptions.PagureException("error"),
Pierre-Yves Chibon 73d120
        ):
Pierre-Yves Chibon 417805
            output = self.app.post(
Pierre-Yves Chibon 73d120
                "/api/0/test/pull-request/1/comment",
Pierre-Yves Chibon 73d120
                data=data,
Pierre-Yves Chibon 73d120
                headers=headers,
Pierre-Yves Chibon 73d120
            )
Pierre-Yves Chibon 417805
            self.assertEqual(output.status_code, 400)
Pierre-Yves Chibon 417805
            data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
            self.assertDictEqual(
Pierre-Yves Chibon 73d120
                data, {"error": "error", "error_code": "ENOCODE"}
Pierre-Yves Chibon 417805
            )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 417805
    def test_api_pull_request_add_comment_pr_disabled(self):
Pierre-Yves Chibon 417805
        """ Test the api_pull_request_add_comment method of the flask api
Pierre-Yves Chibon 417805
        when PRs are disabled. """
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session, project_id=None)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting question"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Valid request
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # no comment added
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(len(request.comments), 0)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 1dfd94
    def test_api_pull_request_add_comment_user_token(self, mockemail):
Pierre-Yves Chibon 1dfd94
        """ Test the api_pull_request_add_comment method of the flask api. """
Pierre-Yves Chibon 1dfd94
        mockemail.return_value = True
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        tests.create_projects(self.session)
Pierre-Yves Chibon 1dfd94
        tests.create_tokens(self.session, project_id=None)
Pierre-Yves Chibon 1dfd94
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Invalid project
Pierre-Yves Chibon 1dfd94
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 1dfd94
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon 1dfd94
        )
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Valid token, invalid request
Pierre-Yves Chibon 1dfd94
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 1dfd94
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon 1dfd94
        )
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Valid token, invalid request in another project
Pierre-Yves Chibon 1dfd94
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 1dfd94
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon 1dfd94
        )
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Create a pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 73d120
        forked_repo = pagure.lib.query.get_authorized_project(
Pierre-Yves Chibon 73d120
            self.session, "test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 1dfd94
            session=self.session,
Pierre-Yves Chibon 1dfd94
            repo_from=forked_repo,
Pierre-Yves Chibon 73d120
            branch_from="master",
Pierre-Yves Chibon 1dfd94
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 1dfd94
        )
Pierre-Yves Chibon 1dfd94
        self.session.commit()
Pierre-Yves Chibon 1dfd94
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Check comments before
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(len(request.comments), 0)
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 73d120
        data = {"title": "test issue"}
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Incomplete request
Pierre-Yves Chibon 1dfd94
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 1dfd94
        self.assertDictEqual(
Pierre-Yves Chibon 1dfd94
            data,
Pierre-Yves Chibon 1dfd94
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": {"comment": ["This field is required."]},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 1dfd94
        )
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # No change
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(len(request.comments), 0)
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting question"}
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # Valid request
Pierre-Yves Chibon 1dfd94
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 1dfd94
        # One comment added
Aurélien Bompard 13bcde
        self.session.commit()
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 1dfd94
        self.assertEqual(len(request.comments), 1)
Pierre-Yves Chibon 1dfd94
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 417805
    def test_api_subscribe_pull_request_pr_disabled(self, p_send_email):
Pierre-Yves Chibon 417805
        """ Test the api_subscribe_pull_request method of the flask api. """
Pierre-Yves Chibon 417805
        p_send_email.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 417805
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 417805
        repo.settings = settings
Pierre-Yves Chibon 417805
        self.session.add(repo)
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Invalid project
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git")
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 73d120
    def test_api_subscribe_pull_request_invalid_token(
Pierre-Yves Chibon 73d120
        self, p_send_email, p_ugt
Pierre-Yves Chibon 73d120
    ):
Pierre-Yves Chibon 417805
        """ Test the api_subscribe_pull_request method of the flask api. """
Pierre-Yves Chibon 417805
        p_send_email.return_value = True
Pierre-Yves Chibon 417805
        p_ugt.return_value = True
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        item = pagure.lib.model.User(
Pierre-Yves Chibon 73d120
            user="bar",
Pierre-Yves Chibon 73d120
            fullname="bar foo",
Pierre-Yves Chibon 73d120
            password="foo",
Pierre-Yves Chibon 73d120
            default_email="bar@bar.com",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.add(item)
Pierre-Yves Chibon 73d120
        item = pagure.lib.model.UserEmail(user_id=3, email="bar@bar.com")
Pierre-Yves Chibon 417805
        self.session.add(item)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        tests.create_projects(self.session)
Pierre-Yves Chibon 417805
        tests.create_tokens(self.session, user_id=3, project_id=2)
Pierre-Yves Chibon 417805
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Create pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 417805
            session=self.session,
Pierre-Yves Chibon 417805
            repo_from=repo,
Pierre-Yves Chibon 73d120
            branch_from="feature",
Pierre-Yves Chibon 417805
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
        self.session.commit()
Pierre-Yves Chibon 417805
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        # Check subscribtion before
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 417805
        data = {}
Pierre-Yves Chibon 417805
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 401)
Pierre-Yves Chibon 417805
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 417805
        self.assertDictEqual(
Pierre-Yves Chibon 417805
            data,
Pierre-Yves Chibon 417805
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or expired token. Please visit "
Pierre-Yves Chibon 73d120
                "http://localhost.localdomain/settings#api-keys to get or "
Pierre-Yves Chibon 73d120
                "renew your API token.",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDTOK",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 417805
        )
Pierre-Yves Chibon 417805
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git")
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 4f5301
    def test_api_subscribe_pull_request(self, p_send_email, p_ugt):
Pierre-Yves Chibon 4f5301
        """ Test the api_subscribe_pull_request method of the flask api. """
Pierre-Yves Chibon 4f5301
        p_send_email.return_value = True
Pierre-Yves Chibon 4f5301
        p_ugt.return_value = True
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        item = pagure.lib.model.User(
Pierre-Yves Chibon 73d120
            user="bar",
Pierre-Yves Chibon 73d120
            fullname="bar foo",
Pierre-Yves Chibon 73d120
            password="foo",
Pierre-Yves Chibon 73d120
            default_email="bar@bar.com",
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
        self.session.add(item)
Pierre-Yves Chibon 73d120
        item = pagure.lib.model.UserEmail(user_id=3, email="bar@bar.com")
Pierre-Yves Chibon 4f5301
        self.session.add(item)
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        self.session.commit()
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        tests.create_projects(self.session)
Pierre-Yves Chibon 4f5301
        tests.create_tokens(self.session, user_id=3)
Pierre-Yves Chibon 4f5301
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Invalid project
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foo/pull-request/1/subscribe", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Valid token, wrong project
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/1/subscribe", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 417805
        self.assertEqual(output.status_code, 401)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertEqual(
Pierre-Yves Chibon 73d120
            pagure.api.APIERROR.EINVALIDTOK.name, data["error_code"]
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(pagure.api.APIERROR.EINVALIDTOK.value, data["error"])
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # No input
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Create pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 4f5301
            session=self.session,
Pierre-Yves Chibon 4f5301
            repo_from=repo,
Pierre-Yves Chibon 73d120
            branch_from="feature",
Pierre-Yves Chibon 4f5301
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
        self.session.commit()
Pierre-Yves Chibon 4f5301
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Check subscribtion before
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Unsubscribe - no changes
Pierre-Yves Chibon 4f5301
        data = {}
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
        data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 4f5301
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "message": "You are no longer watching this pull-request",
Pierre-Yves Chibon 73d120
                "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                "user": "bar",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        data = {}
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
        data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 4f5301
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "message": "You are no longer watching this pull-request",
Pierre-Yves Chibon 73d120
                "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                "user": "bar",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # No change
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Subscribe
Pierre-Yves Chibon 73d120
        data = {"status": True}
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
        data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 4f5301
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "message": "You are now watching this pull-request",
Pierre-Yves Chibon 73d120
                "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                "user": "bar",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Subscribe - no changes
Pierre-Yves Chibon 73d120
        data = {"status": True}
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
        data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 4f5301
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "message": "You are now watching this pull-request",
Pierre-Yves Chibon 73d120
                "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                "user": "bar",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou", "bar"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 4f5301
        # Unsubscribe
Pierre-Yves Chibon 4f5301
        data = {}
Pierre-Yves Chibon 4f5301
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/subscribe", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
        data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 4f5301
        self.assertDictEqual(
Pierre-Yves Chibon 4f5301
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "message": "You are no longer watching this pull-request",
Pierre-Yves Chibon 73d120
                "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                "user": "bar",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 4f5301
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 4f5301
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git")
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email")
Pierre-Yves Chibon 335a73
    def test_api_subscribe_pull_request_logged_in(self, p_send_email, p_ugt):
Pierre-Yves Chibon 335a73
        """ Test the api_subscribe_pull_request method of the flask api
Pierre-Yves Chibon 335a73
        when the user is logged in via the UI. """
Pierre-Yves Chibon 335a73
        p_send_email.return_value = True
Pierre-Yves Chibon 335a73
        p_ugt.return_value = True
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        item = pagure.lib.model.User(
Pierre-Yves Chibon 73d120
            user="bar",
Pierre-Yves Chibon 73d120
            fullname="bar foo",
Pierre-Yves Chibon 73d120
            password="foo",
Pierre-Yves Chibon 73d120
            default_email="bar@bar.com",
Pierre-Yves Chibon 335a73
        )
Pierre-Yves Chibon 335a73
        self.session.add(item)
Pierre-Yves Chibon 73d120
        item = pagure.lib.model.UserEmail(user_id=3, email="bar@bar.com")
Pierre-Yves Chibon 335a73
        self.session.add(item)
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        self.session.commit()
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        tests.create_projects(self.session)
Pierre-Yves Chibon 335a73
        tests.create_tokens(self.session, user_id=3)
Pierre-Yves Chibon 335a73
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        # Create pull-request
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon 335a73
            session=self.session,
Pierre-Yves Chibon 335a73
            repo_from=repo,
Pierre-Yves Chibon 73d120
            branch_from="feature",
Pierre-Yves Chibon 335a73
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon 335a73
        )
Pierre-Yves Chibon 335a73
        self.session.commit()
Pierre-Yves Chibon 335a73
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        # Check subscribtion before
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 335a73
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        # Subscribe
Pierre-Yves Chibon 73d120
        user = tests.FakeUser(username="foo")
Pierre-Yves Chibon 335a73
        with tests.user_set(self.app.application, user):
Pierre-Yves Chibon 73d120
            data = {"status": True}
Pierre-Yves Chibon 335a73
            output = self.app.post(
Pierre-Yves Chibon 73d120
                "/api/0/test/pull-request/1/subscribe", data=data
Pierre-Yves Chibon 73d120
            )
Pierre-Yves Chibon 335a73
            self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 335a73
            data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon e2c468
            data["avatar_url"] = "https://seccdn.libravatar.org/avatar/..."
Pierre-Yves Chibon 335a73
            self.assertDictEqual(
Pierre-Yves Chibon 335a73
                data,
Pierre-Yves Chibon 73d120
                {
Pierre-Yves Chibon 73d120
                    "message": "You are now watching this pull-request",
Pierre-Yves Chibon 73d120
                    "avatar_url": "https://seccdn.libravatar.org/avatar/...",
Pierre-Yves Chibon 73d120
                    "user": "foo",
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 335a73
            )
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 335a73
        # Check subscribtions after
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        request = pagure.lib.query.search_pull_requests(
Pierre-Yves Chibon 73d120
            self.session, project_id=1, requestid=1
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 335a73
        self.assertEqual(
Pierre-Yves Chibon 930073
            pagure.lib.query.get_watch_list(self.session, request),
Pierre-Yves Chibon 73d120
            set(["pingou", "foo"]),
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 335a73
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_invalid_project(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        not the project doesn't exist.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/foobar/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_missing_title(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        not title is submitted.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": {"title": ["This field is required."]},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_missing_branch_to(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        not branch to is submitted.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": {"branch_to": ["This field is required."]},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_missing_branch_from(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        not branch from is submitted.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": {"branch_from": ["This field is required."]},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_pr_disabled(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        the parent repo disabled pull-requests.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        # Check the behavior if the project disabled the issue tracker
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 9811e6
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["pull_requests"] = False
Pierre-Yves Chibon 9811e6
        repo.settings = settings
Pierre-Yves Chibon 9811e6
        self.session.add(repo)
Pierre-Yves Chibon 9811e6
        self.session.commit()
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 404)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Pull-Request have been deactivated for this project",
Pierre-Yves Chibon 73d120
                "error_code": "EPULLREQUESTSDISABLED",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_signed_pr(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        the parent repo enforces signed-off pull-requests.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        # Check the behavior if the project disabled the issue tracker
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 9811e6
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Enforce_signed-off_commits_in_pull-request"] = True
Pierre-Yves Chibon 9811e6
        repo.settings = settings
Pierre-Yves Chibon 9811e6
        self.session.add(repo)
Pierre-Yves Chibon 9811e6
        self.session.commit()
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "This repo enforces that all commits are signed "
Pierre-Yves Chibon 73d120
                "off by their author.",
Pierre-Yves Chibon 73d120
                "error_code": "ENOSIGNEDOFF",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_invalid_branch_from(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        the branch from does not exist.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        # Check the behavior if the project disabled the issue tracker
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 9811e6
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Enforce_signed-off_commits_in_pull-request"] = True
Pierre-Yves Chibon 9811e6
        repo.settings = settings
Pierre-Yves Chibon 9811e6
        self.session.add(repo)
Pierre-Yves Chibon 9811e6
        self.session.commit()
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "foobarbaz",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": "Branch foobarbaz does not exist",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 625a97
    def test_api_pull_request_open_invalid_token(self):
Pierre-Yves Chibon 625a97
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 625a97
        queried with an invalid token.
Pierre-Yves Chibon 625a97
        """
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 625a97
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 625a97
        tests.create_tokens(self.session)
Pierre-Yves Chibon 625a97
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 625a97
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "foobarbaz",
Pierre-Yves Chibon 625a97
        }
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 625a97
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test2/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 625a97
        self.assertEqual(output.status_code, 401)
Pierre-Yves Chibon 625a97
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 625a97
        self.assertDictEqual(
Pierre-Yves Chibon 625a97
            data,
Pierre-Yves Chibon 625a97
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or expired token. Please visit "
Pierre-Yves Chibon 73d120
                "http://localhost.localdomain/settings#api-keys to get or "
Pierre-Yves Chibon 73d120
                "renew your API token.",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDTOK",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 625a97
        )
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 625a97
    def test_api_pull_request_open_invalid_access(self):
Pierre-Yves Chibon 625a97
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 625a97
        the user opening the PR doesn't have commit access.
Pierre-Yves Chibon 625a97
        """
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 625a97
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 625a97
        tests.create_tokens(self.session, user_id=2)
Pierre-Yves Chibon 625a97
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 625a97
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "foobarbaz",
Pierre-Yves Chibon 625a97
        }
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 625a97
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 625a97
        self.assertEqual(output.status_code, 401)
Pierre-Yves Chibon 625a97
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 625a97
        self.assertDictEqual(
Pierre-Yves Chibon 625a97
            data,
Pierre-Yves Chibon 625a97
            {
Pierre-Yves Chibon 73d120
                "error": "You do not have sufficient permissions to "
Pierre-Yves Chibon 73d120
                "perform this action",
Pierre-Yves Chibon 73d120
                "error_code": "ENOTHIGHENOUGH",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 625a97
        )
Pierre-Yves Chibon 625a97
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 9811e6
    def test_api_pull_request_open_invalid_branch_to(self):
Pierre-Yves Chibon 9811e6
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 9811e6
        the branch to does not exist.
Pierre-Yves Chibon 9811e6
        """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        # Check the behavior if the project disabled the issue tracker
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 9811e6
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Enforce_signed-off_commits_in_pull-request"] = True
Pierre-Yves Chibon 9811e6
        repo.settings = settings
Pierre-Yves Chibon 9811e6
        self.session.add(repo)
Pierre-Yves Chibon 9811e6
        self.session.commit()
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "foobarbaz",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 400)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "error": "Invalid or incomplete input submitted",
Pierre-Yves Chibon 73d120
                "error_code": "EINVALIDREQ",
Pierre-Yves Chibon 73d120
                "errors": "Branch foobarbaz could not be found in the "
Pierre-Yves Chibon 73d120
                "target repo",
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Lenka Segura 3d9cf6
    def test_api_pull_request_open_project_token_different_project(self):
Lenka Segura 3d9cf6
        """Test the api_pull_request_create method with the project token
Lenka Segura 3d9cf6
        of a different project - fails"""
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
        tests.create_tokens(self.session, project_id=2)
Lenka Segura 3d9cf6
        tests.create_tokens_acl(self.session)
Lenka Segura 3d9cf6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token foo_token"}
Lenka Segura 3d9cf6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test of PR",
Pierre-Yves Chibon 73d120
            "inicial comment": "Some readme adjustment",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Lenka Segura 3d9cf6
        }
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
        self.assertEqual(output.status_code, 401)
Lenka Segura 3d9cf6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Lenka Segura 3d9cf6
    def test_api_pull_request_open_user_token_invalid_acls(self):
Lenka Segura 3d9cf6
        """Test the api_pull_request_create method with the user token, but with
Lenka Segura 3d9cf6
        no acls for opening pull request - fails"""
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
        tests.create_tokens(self.session, project_id=None)
Pierre-Yves Chibon 73d120
        for acl in (
Pierre-Yves Chibon 73d120
            "create_project",
Pierre-Yves Chibon 73d120
            "fork_project",
Pierre-Yves Chibon 73d120
            "modify_project",
Pierre-Yves Chibon 73d120
            "update_watch_status",
Pierre-Yves Chibon 73d120
        ):
Lenka Segura 3d9cf6
            tests.create_tokens_acl(self.session, acl_name=acl)
Lenka Segura 3d9cf6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Lenka Segura 3d9cf6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test of PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Some readme adjustment",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 73d120
        }
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
        self.assertEqual(output.status_code, 401)
Lenka Segura 3d9cf6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Lenka Segura 3d9cf6
    def test_api_pull_request_open_from_branch_to_origin(self):
Lenka Segura 3d9cf6
        """Test the api_pull_request_create method from a fork to a master,
Lenka Segura 3d9cf6
       with project token of a origin with all the acls"""
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects(
Pierre-Yves Chibon 73d120
            self.session, is_fork=True, hook_token_suffix="foo"
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
        project_query = self.session.query(pagure.lib.model.Project)
Pierre-Yves Chibon 73d120
        for project in project_query.filter_by(name="test").all():
Lenka Segura 3d9cf6
            if project.parent_id == None:
Lenka Segura 3d9cf6
                parent = project
Lenka Segura 3d9cf6
            else:
Lenka Segura 3d9cf6
                child = project
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "forks", "pingou", "test.git"),
Pierre-Yves Chibon 73d120
            branch="branch",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "forks", "pingou", "test.git"),
Pierre-Yves Chibon 73d120
            branch="branch",
Pierre-Yves Chibon 73d120
        )
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        # Create tokens
Lenka Segura 3d9cf6
        parent_token = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="iamparenttoken",
Lenka Segura 3d9cf6
            user_id=parent.user_id,
Lenka Segura 3d9cf6
            project_id=parent.id,
Pierre-Yves Chibon 73d120
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Lenka Segura 3d9cf6
        )
Lenka Segura 3d9cf6
        self.session.add(parent_token)
Lenka Segura 3d9cf6
Lenka Segura 3d9cf6
        fork_token = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="iamforktoken",
Lenka Segura 3d9cf6
            user_id=child.user_id,
Lenka Segura 3d9cf6
            project_id=child.id,
Pierre-Yves Chibon 73d120
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Lenka Segura 3d9cf6
        )
Lenka Segura 3d9cf6
        self.session.add(fork_token)
Lenka Segura 3d9cf6
        self.session.commit()
Lenka Segura 3d9cf6
Pierre-Yves Chibon 73d120
        tests.create_tokens_acl(self.session, token_id="iamparenttoken")
Lenka Segura 3d9cf6
        for acl in pagure.default_config.CROSS_PROJECT_ACLS:
Pierre-Yves Chibon 73d120
            tests.create_tokens_acl(
Pierre-Yves Chibon 73d120
                self.session, token_id="iamforktoken", acl_name=acl
Pierre-Yves Chibon 73d120
            )
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token iamforktoken"}
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "war of tomatoes",
Pierre-Yves Chibon 73d120
            "initial_comment": "the manifest",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "branch",
Pierre-Yves Chibon 6fa4b3
            "repo_from": "test",
Pierre-Yves Chibon 6fa4b3
            "repo_from_username": "pingou",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 6fa4b3
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 9811e6
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    def test_api_pull_request_open(self):
Pierre-Yves Chibon 73d120
        """ Test the api_pull_request_create method of the flask api. """
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        tests.create_tokens(self.session)
Pierre-Yves Chibon 9811e6
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 9811e6
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 9811e6
        }
Pierre-Yves Chibon 9811e6
Pierre-Yves Chibon 9811e6
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 9811e6
        self.assertEqual(output.status_code, 200)
Aurélien Bompard 626417
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data["project"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["project"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["uid"] = "e8b68df8711648deac67c3afed15a798"
Pierre-Yves Chibon 73d120
        data["commit_start"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["commit_stop"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["last_updated"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["updated_on"] = "1516348115"
Pierre-Yves Chibon 9811e6
        self.assertDictEqual(
Pierre-Yves Chibon 9811e6
            data,
Pierre-Yves Chibon 9811e6
            {
Pierre-Yves Chibon 73d120
                "assignee": None,
Pierre-Yves Chibon 73d120
                "branch": "master",
Pierre-Yves Chibon 73d120
                "branch_from": "test",
Pierre-Yves Chibon 73d120
                "cached_merge_status": "unknown",
Pierre-Yves Chibon 73d120
                "closed_at": None,
Pierre-Yves Chibon 73d120
                "closed_by": None,
Pierre-Yves Chibon 73d120
                "comments": [],
Pierre-Yves Chibon 73d120
                "commit_start": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
                "commit_stop": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
                "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
                "last_updated": "1516348115",
Pierre-Yves Chibon 73d120
                "project": {
Pierre-Yves Chibon 73d120
                    "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                    "access_users": {
Pierre-Yves Chibon 73d120
                        "admin": [],
Pierre-Yves Chibon 73d120
                        "commit": [],
Pierre-Yves Chibon 73d120
                        "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                        "ticket": [],
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "close_status": [
Pierre-Yves Chibon 73d120
                        "Invalid",
Pierre-Yves Chibon 73d120
                        "Insufficient data",
Pierre-Yves Chibon 73d120
                        "Fixed",
Pierre-Yves Chibon 73d120
                        "Duplicate",
Pierre-Yves Chibon 73d120
                    ],
Pierre-Yves Chibon 73d120
                    "custom_keys": [],
Pierre-Yves Chibon 73d120
                    "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                    "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                    "description": "test project #1",
Pierre-Yves Chibon 73d120
                    "fullname": "test",
Pierre-Yves Chibon 73d120
                    "id": 1,
Pierre-Yves Chibon 73d120
                    "milestones": {},
Pierre-Yves Chibon 73d120
                    "name": "test",
Pierre-Yves Chibon 73d120
                    "namespace": None,
Pierre-Yves Chibon 73d120
                    "parent": None,
Pierre-Yves Chibon 73d120
                    "priorities": {},
Pierre-Yves Chibon 73d120
                    "tags": [],
Pierre-Yves Chibon 73d120
                    "url_path": "test",
Pierre-Yves Chibon 73d120
                    "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "remote_git": None,
Pierre-Yves Chibon 73d120
                "repo_from": {
Pierre-Yves Chibon 73d120
                    "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                    "access_users": {
Pierre-Yves Chibon 73d120
                        "admin": [],
Pierre-Yves Chibon 73d120
                        "commit": [],
Pierre-Yves Chibon 73d120
                        "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                        "ticket": [],
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "close_status": [
Pierre-Yves Chibon 73d120
                        "Invalid",
Pierre-Yves Chibon 73d120
                        "Insufficient data",
Pierre-Yves Chibon 73d120
                        "Fixed",
Pierre-Yves Chibon 73d120
                        "Duplicate",
Pierre-Yves Chibon 73d120
                    ],
Pierre-Yves Chibon 73d120
                    "custom_keys": [],
Pierre-Yves Chibon 73d120
                    "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                    "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                    "description": "test project #1",
Pierre-Yves Chibon 73d120
                    "fullname": "test",
Pierre-Yves Chibon 73d120
                    "id": 1,
Pierre-Yves Chibon 73d120
                    "milestones": {},
Pierre-Yves Chibon 73d120
                    "name": "test",
Pierre-Yves Chibon 73d120
                    "namespace": None,
Pierre-Yves Chibon 73d120
                    "parent": None,
Pierre-Yves Chibon 73d120
                    "priorities": {},
Pierre-Yves Chibon 73d120
                    "tags": [],
Pierre-Yves Chibon 73d120
                    "url_path": "test",
Pierre-Yves Chibon 73d120
                    "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "status": "Open",
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "threshold_reached": None,
Pierre-Yves Chibon 73d120
                "title": "Test PR",
Pierre-Yves Chibon 73d120
                "uid": "e8b68df8711648deac67c3afed15a798",
Pierre-Yves Chibon 73d120
                "updated_on": "1516348115",
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    def test_api_pull_request_open_missing_initial_comment(self):
Pierre-Yves Chibon 73d120
        """ Test the api_pull_request_create method of the flask api when
Pierre-Yves Chibon 73d120
        not initial comment is submitted.
Pierre-Yves Chibon 73d120
        """
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.create_tokens(self.session)
Pierre-Yves Chibon 73d120
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 73d120
        }
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 73d120
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        data["project"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["project"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["uid"] = "e8b68df8711648deac67c3afed15a798"
Pierre-Yves Chibon 73d120
        data["commit_start"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["commit_stop"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["last_updated"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["updated_on"] = "1516348115"
Pierre-Yves Chibon 73d120
        self.assertDictEqual(
Pierre-Yves Chibon 73d120
            data,
Pierre-Yves Chibon 73d120
            {
Pierre-Yves Chibon 73d120
                "assignee": None,
Pierre-Yves Chibon 73d120
                "branch": "master",
Pierre-Yves Chibon 73d120
                "branch_from": "test",
Pierre-Yves Chibon 73d120
                "cached_merge_status": "unknown",
Pierre-Yves Chibon 73d120
                "closed_at": None,
Pierre-Yves Chibon 73d120
                "closed_by": None,
Pierre-Yves Chibon 73d120
                "comments": [],
Pierre-Yves Chibon 73d120
                "commit_start": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
                "commit_stop": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
                "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "initial_comment": None,
Pierre-Yves Chibon 73d120
                "last_updated": "1516348115",
Pierre-Yves Chibon 73d120
                "project": {
Pierre-Yves Chibon 73d120
                    "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                    "access_users": {
Pierre-Yves Chibon 73d120
                        "admin": [],
Pierre-Yves Chibon 73d120
                        "commit": [],
Pierre-Yves Chibon 73d120
                        "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                        "ticket": [],
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "close_status": [
Pierre-Yves Chibon 73d120
                        "Invalid",
Pierre-Yves Chibon 73d120
                        "Insufficient data",
Pierre-Yves Chibon 73d120
                        "Fixed",
Pierre-Yves Chibon 73d120
                        "Duplicate",
Pierre-Yves Chibon 73d120
                    ],
Pierre-Yves Chibon 73d120
                    "custom_keys": [],
Pierre-Yves Chibon 73d120
                    "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                    "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                    "description": "test project #1",
Pierre-Yves Chibon 73d120
                    "fullname": "test",
Pierre-Yves Chibon 73d120
                    "id": 1,
Pierre-Yves Chibon 73d120
                    "milestones": {},
Pierre-Yves Chibon 73d120
                    "name": "test",
Pierre-Yves Chibon 73d120
                    "namespace": None,
Pierre-Yves Chibon 73d120
                    "parent": None,
Pierre-Yves Chibon 73d120
                    "priorities": {},
Pierre-Yves Chibon 73d120
                    "tags": [],
Pierre-Yves Chibon 73d120
                    "url_path": "test",
Pierre-Yves Chibon 73d120
                    "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "remote_git": None,
Pierre-Yves Chibon 73d120
                "repo_from": {
Pierre-Yves Chibon 73d120
                    "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                    "access_users": {
Pierre-Yves Chibon 73d120
                        "admin": [],
Pierre-Yves Chibon 73d120
                        "commit": [],
Pierre-Yves Chibon 73d120
                        "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                        "ticket": [],
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "close_status": [
Pierre-Yves Chibon 73d120
                        "Invalid",
Pierre-Yves Chibon 73d120
                        "Insufficient data",
Pierre-Yves Chibon 73d120
                        "Fixed",
Pierre-Yves Chibon 73d120
                        "Duplicate",
Pierre-Yves Chibon 73d120
                    ],
Pierre-Yves Chibon 73d120
                    "custom_keys": [],
Pierre-Yves Chibon 73d120
                    "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                    "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                    "description": "test project #1",
Pierre-Yves Chibon 73d120
                    "fullname": "test",
Pierre-Yves Chibon 73d120
                    "id": 1,
Pierre-Yves Chibon 73d120
                    "milestones": {},
Pierre-Yves Chibon 73d120
                    "name": "test",
Pierre-Yves Chibon 73d120
                    "namespace": None,
Pierre-Yves Chibon 73d120
                    "parent": None,
Pierre-Yves Chibon 73d120
                    "priorities": {},
Pierre-Yves Chibon 73d120
                    "tags": [],
Pierre-Yves Chibon 73d120
                    "url_path": "test",
Pierre-Yves Chibon 73d120
                    "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "status": "Open",
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "threshold_reached": None,
Pierre-Yves Chibon 73d120
                "title": "Test PR",
Pierre-Yves Chibon 73d120
                "uid": "e8b68df8711648deac67c3afed15a798",
Pierre-Yves Chibon 73d120
                "updated_on": "1516348115",
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
class PagureFlaskApiForkPRDiffStatstests(tests.Modeltests):
Pierre-Yves Chibon 73d120
    """ Tests for the flask API of pagure for the diff stats endpoint of PRs
Pierre-Yves Chibon 73d120
    """
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
    maxDiff = None
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
    def setUp(self):
Pierre-Yves Chibon 73d120
        """ Set up the environnment, ran before every tests. """
Pierre-Yves Chibon 73d120
        super(PagureFlaskApiForkPRDiffStatstests, self).setUp()
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
        pagure.config.config["REQUESTS_FOLDER"] = None
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 73d120
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), ncommits=5
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon c67f41
        # Create the pull-request to close
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon 930073
        req = pagure.lib.query.new_pull_request(
Pierre-Yves Chibon c67f41
            session=self.session,
Pierre-Yves Chibon c67f41
            repo_from=repo,
Pierre-Yves Chibon 73d120
            branch_from="test",
Pierre-Yves Chibon c67f41
            repo_to=repo,
Pierre-Yves Chibon 73d120
            branch_to="master",
Pierre-Yves Chibon 73d120
            title="test pull-request",
Pierre-Yves Chibon 73d120
            user="pingou",
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
        self.session.commit()
Pierre-Yves Chibon c67f41
        self.assertEqual(req.id, 1)
Pierre-Yves Chibon 73d120
        self.assertEqual(req.title, "test pull-request")
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon c67f41
    def test_api_pull_request_diffstats_no_repo(self):
Pierre-Yves Chibon c67f41
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/invalid/pull-request/404/diffstats")
Pierre-Yves Chibon c67f41
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon c67f41
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c67f41
        self.assertEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Project not found", "error_code": "ENOPROJECT"}
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon c67f41
    def test_api_pull_request_diffstats_no_pr(self):
Pierre-Yves Chibon c67f41
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/404/diffstats")
Pierre-Yves Chibon c67f41
        self.assertEqual(output.status_code, 404)
Pierre-Yves Chibon c67f41
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c67f41
        self.assertEqual(
Pierre-Yves Chibon 73d120
            data, {"error": "Pull-Request not found", "error_code": "ENOREQ"}
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon c67f41
    def test_api_pull_request_diffstats_file_modified(self):
Pierre-Yves Chibon c67f41
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1/diffstats")
Pierre-Yves Chibon c67f41
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon c67f41
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c67f41
        self.assertEqual(
Pierre-Yves Chibon c67f41
            data,
Pierre-Yves Chibon c67f41
            {
Pierre-Yves Chibon 73d120
                "sources": {
Pierre-Yves Chibon 73d120
                    "lines_added": 10,
Pierre-Yves Chibon 73d120
                    "lines_removed": 0,
Pierre-Yves Chibon f6a6e0
                    "new_id": "540916fbd3d825d14cc0c0b2397606fda69379ce",
Pierre-Yves Chibon f6a6e0
                    "old_id": "265f133a7c94ede4cb183dd808219c5bf9e08f87",
Pierre-Yves Chibon 73d120
                    "old_path": "sources",
Pierre-Yves Chibon 73d120
                    "status": "M",
Pierre-Yves Chibon c67f41
                }
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon c67f41
    def test_api_pull_request_diffstats_file_added_mofidied(self):
Pierre-Yves Chibon c67f41
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon c67f41
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), ncommits=5
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon c67f41
        tests.add_readme_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"),
Pierre-Yves Chibon 73d120
            readme_name="README.md",
Pierre-Yves Chibon 73d120
            branch="test",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon c67f41
        self.assertEqual(len(repo.requests), 1)
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1/diffstats")
Pierre-Yves Chibon c67f41
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon c67f41
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c67f41
        self.assertTrue(
Pierre-Yves Chibon 73d120
            data
Pierre-Yves Chibon 73d120
            in [
Pierre-Yves Chibon c67f41
                {
Pierre-Yves Chibon 73d120
                    "README.md": {
Pierre-Yves Chibon 73d120
                        "lines_added": 5,
Pierre-Yves Chibon 73d120
                        "lines_removed": 0,
Pierre-Yves Chibon 73d120
                        "new_id": "bd913ea153650b94f33f53e5164c36a28b761bf4",
Pierre-Yves Chibon 73d120
                        "old_id": "0000000000000000000000000000000000000000",
Pierre-Yves Chibon 73d120
                        "old_path": "README.md",
Pierre-Yves Chibon 73d120
                        "status": "A",
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "sources": {
Pierre-Yves Chibon 73d120
                        "lines_added": 5,
Pierre-Yves Chibon 73d120
                        "lines_removed": 0,
Pierre-Yves Chibon 73d120
                        "new_id": "540916fbd3d825d14cc0c0b2397606fda69379ce",
Pierre-Yves Chibon 73d120
                        "old_id": "293500070b9dfc6ab66e31383f8f7fccf6a95fe2",
Pierre-Yves Chibon 73d120
                        "old_path": "sources",
Pierre-Yves Chibon 73d120
                        "status": "M",
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon c67f41
                },
Pierre-Yves Chibon c67f41
                {
Pierre-Yves Chibon 73d120
                    "README.md": {
Pierre-Yves Chibon 73d120
                        "lines_added": 5,
Pierre-Yves Chibon 73d120
                        "lines_removed": 0,
Pierre-Yves Chibon 73d120
                        "new_id": "bd913ea153650b94f33f53e5164c36a28b761bf4",
Pierre-Yves Chibon 73d120
                        "old_id": "0000000000000000000000000000000000000000",
Pierre-Yves Chibon 73d120
                        "old_path": "README.md",
Pierre-Yves Chibon 73d120
                        "status": "A",
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                    "sources": {
Pierre-Yves Chibon 73d120
                        "lines_added": 10,
Pierre-Yves Chibon 73d120
                        "lines_removed": 0,
Pierre-Yves Chibon 73d120
                        "new_id": "540916fbd3d825d14cc0c0b2397606fda69379ce",
Pierre-Yves Chibon 73d120
                        "old_id": "265f133a7c94ede4cb183dd808219c5bf9e08f87",
Pierre-Yves Chibon 73d120
                        "old_path": "sources",
Pierre-Yves Chibon 73d120
                        "status": "M",
Pierre-Yves Chibon 73d120
                    },
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon c67f41
            ]
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.git.update_git", MagicMock(return_value=True))
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon c67f41
    def test_api_pull_request_diffstats_file_modified_deleted(self):
Pierre-Yves Chibon c67f41
        """ Test the api_pull_request_merge method of the flask api. """
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon c67f41
        self.assertEqual(len(repo.requests), 1)
Pierre-Yves Chibon c67f41
        pagure.lib.tasks.update_pull_request(repo.requests[0].uid)
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon c67f41
        tests.add_readme_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"),
Pierre-Yves Chibon 73d120
            readme_name="README.md",
Pierre-Yves Chibon 73d120
            branch="test",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon c67f41
        tests.remove_file_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"),
Pierre-Yves Chibon 73d120
            filename="sources",
Pierre-Yves Chibon 73d120
            branch="test",
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query.get_authorized_project(self.session, "test")
Pierre-Yves Chibon c67f41
        self.assertEqual(len(repo.requests), 1)
Pierre-Yves Chibon c67f41
        pagure.lib.tasks.update_pull_request(repo.requests[0].uid)
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1/diffstats")
Pierre-Yves Chibon c67f41
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon c67f41
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon c67f41
        self.assertEqual(
Pierre-Yves Chibon c67f41
            data,
Pierre-Yves Chibon c67f41
            {
Pierre-Yves Chibon 73d120
                "README.md": {
Pierre-Yves Chibon 73d120
                    "lines_added": 5,
Pierre-Yves Chibon 73d120
                    "lines_removed": 0,
Pierre-Yves Chibon 73d120
                    "new_id": "bd913ea153650b94f33f53e5164c36a28b761bf4",
Pierre-Yves Chibon 73d120
                    "old_id": "0000000000000000000000000000000000000000",
Pierre-Yves Chibon 73d120
                    "old_path": "README.md",
Pierre-Yves Chibon 73d120
                    "status": "A",
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "sources": {
Pierre-Yves Chibon 73d120
                    "lines_added": 0,
Pierre-Yves Chibon 73d120
                    "lines_removed": 5,
Pierre-Yves Chibon 73d120
                    "new_id": "0000000000000000000000000000000000000000",
Pierre-Yves Chibon 73d120
                    "old_id": "265f133a7c94ede4cb183dd808219c5bf9e08f87",
Pierre-Yves Chibon 73d120
                    "old_path": "sources",
Pierre-Yves Chibon 73d120
                    "status": "D",
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon c67f41
        )
Pierre-Yves Chibon c67f41
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 2233c1
class PagureApiThresholdReachedTests(tests.Modeltests):
Pierre-Yves Chibon 2233c1
    """ Test the behavior of the threshold_reached value returned by the API.
Pierre-Yves Chibon 2233c1
    """
Pierre-Yves Chibon 73d120
Pierre-Yves Chibon 2233c1
    maxDiff = None
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def _clean_data(self, data):
Pierre-Yves Chibon 73d120
        data["project"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["project"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["repo_from"]["date_modified"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["uid"] = "e8b68df8711648deac67c3afed15a798"
Pierre-Yves Chibon 73d120
        data["commit_start"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["commit_stop"] = "114f1b468a5f05e635fcb6394273f3f907386eab"
Pierre-Yves Chibon 73d120
        data["date_created"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["last_updated"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["updated_on"] = "1516348115"
Pierre-Yves Chibon 73d120
        data["comments"] = []  # Let's not check the comments
Pierre-Yves Chibon 2233c1
        return data
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
    @patch("pagure.lib.notify.send_email", MagicMock(return_value=True))
Pierre-Yves Chibon 2233c1
    def setUp(self):
Pierre-Yves Chibon 2233c1
        """ Set up the environment for the tests. """
Pierre-Yves Chibon 2233c1
        super(PagureApiThresholdReachedTests, self).setUp()
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        tests.create_projects(self.session)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(os.path.join(self.path, "repos"), bare=True)
Pierre-Yves Chibon 73d120
        tests.create_projects_git(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "requests"), bare=True
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 73d120
        tests.add_readme_git_repo(os.path.join(self.path, "repos", "test.git"))
Pierre-Yves Chibon 73d120
        tests.add_commit_git_repo(
Pierre-Yves Chibon 73d120
            os.path.join(self.path, "repos", "test.git"), branch="test"
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        tests.create_tokens(self.session)
Pierre-Yves Chibon 2233c1
        tests.create_tokens_acl(self.session)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        # Add a token for user `foo`
Pierre-Yves Chibon 2233c1
        item = pagure.lib.model.Token(
Pierre-Yves Chibon 73d120
            id="aaabbbcccddd_foo",
Pierre-Yves Chibon 2233c1
            user_id=2,
Pierre-Yves Chibon 2233c1
            project_id=1,
Pierre-Yves Chibon 2233c1
            expiration=datetime.datetime.utcnow()
Pierre-Yves Chibon 73d120
            + datetime.timedelta(days=30),
Pierre-Yves Chibon 2233c1
        )
Pierre-Yves Chibon 2233c1
        self.session.add(item)
Pierre-Yves Chibon 2233c1
        self.session.commit()
Pierre-Yves Chibon 2233c1
        tests.create_tokens_acl(self.session, token_id="aaabbbcccddd_foo")
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        # Add a minimal required score:
Pierre-Yves Chibon 73d120
        repo = pagure.lib.query._get_project(self.session, "test")
Pierre-Yves Chibon 2233c1
        settings = repo.settings
Pierre-Yves Chibon 73d120
        settings["Minimum_score_to_merge_pull-request"] = 2
Pierre-Yves Chibon 2233c1
        repo.settings = settings
Pierre-Yves Chibon 2233c1
        self.session.add(repo)
Pierre-Yves Chibon 2233c1
        self.session.commit()
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 2233c1
        data = {
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "branch_to": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 2233c1
        }
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/new", headers=headers, data=data
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        self.expected_data = {
Pierre-Yves Chibon 73d120
            "assignee": None,
Pierre-Yves Chibon 73d120
            "branch": "master",
Pierre-Yves Chibon 73d120
            "branch_from": "test",
Pierre-Yves Chibon 73d120
            "cached_merge_status": "unknown",
Pierre-Yves Chibon 73d120
            "closed_at": None,
Pierre-Yves Chibon 73d120
            "closed_by": None,
Pierre-Yves Chibon 73d120
            "comments": [],
Pierre-Yves Chibon 73d120
            "commit_start": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
            "commit_stop": "114f1b468a5f05e635fcb6394273f3f907386eab",
Pierre-Yves Chibon 73d120
            "date_created": "1516348115",
Pierre-Yves Chibon 73d120
            "id": 1,
Pierre-Yves Chibon 73d120
            "initial_comment": "Nothing much, the changes speak for themselves",
Pierre-Yves Chibon 73d120
            "last_updated": "1516348115",
Pierre-Yves Chibon 73d120
            "project": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                "access_users": {
Pierre-Yves Chibon 73d120
                    "admin": [],
Pierre-Yves Chibon 73d120
                    "commit": [],
Pierre-Yves Chibon 73d120
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "close_status": [
Pierre-Yves Chibon 73d120
                    "Invalid",
Pierre-Yves Chibon 73d120
                    "Insufficient data",
Pierre-Yves Chibon 73d120
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Pierre-Yves Chibon 73d120
                ],
Pierre-Yves Chibon 73d120
                "custom_keys": [],
Pierre-Yves Chibon 73d120
                "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                "description": "test project #1",
Pierre-Yves Chibon 73d120
                "fullname": "test",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "milestones": {},
Pierre-Yves Chibon 73d120
                "name": "test",
Pierre-Yves Chibon 73d120
                "namespace": None,
Pierre-Yves Chibon 73d120
                "parent": None,
Pierre-Yves Chibon 73d120
                "priorities": {},
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "url_path": "test",
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 73d120
            "remote_git": None,
Pierre-Yves Chibon 73d120
            "repo_from": {
Pierre-Yves Chibon 73d120
                "access_groups": {"admin": [], "commit": [], "ticket": []},
Pierre-Yves Chibon 73d120
                "access_users": {
Pierre-Yves Chibon 73d120
                    "admin": [],
Pierre-Yves Chibon 73d120
                    "commit": [],
Pierre-Yves Chibon 73d120
                    "owner": ["pingou"],
Pierre-Yves Chibon 73d120
                    "ticket": [],
Pierre-Yves Chibon 73d120
                },
Pierre-Yves Chibon 73d120
                "close_status": [
Pierre-Yves Chibon 73d120
                    "Invalid",
Pierre-Yves Chibon 73d120
                    "Insufficient data",
Pierre-Yves Chibon 73d120
                    "Fixed",
Pierre-Yves Chibon 73d120
                    "Duplicate",
Pierre-Yves Chibon 73d120
                ],
Pierre-Yves Chibon 73d120
                "custom_keys": [],
Pierre-Yves Chibon 73d120
                "date_created": "1516348115",
Pierre-Yves Chibon 73d120
                "date_modified": "1516348115",
Pierre-Yves Chibon 73d120
                "description": "test project #1",
Pierre-Yves Chibon 73d120
                "fullname": "test",
Pierre-Yves Chibon 73d120
                "id": 1,
Pierre-Yves Chibon 73d120
                "milestones": {},
Pierre-Yves Chibon 73d120
                "name": "test",
Pierre-Yves Chibon 73d120
                "namespace": None,
Pierre-Yves Chibon 73d120
                "parent": None,
Pierre-Yves Chibon 73d120
                "priorities": {},
Pierre-Yves Chibon 73d120
                "tags": [],
Pierre-Yves Chibon 73d120
                "url_path": "test",
Pierre-Yves Chibon 73d120
                "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 73d120
            },
Pierre-Yves Chibon 73d120
            "status": "Open",
Pierre-Yves Chibon 31a638
            "tags": [],
Pierre-Yves Chibon 73d120
            "threshold_reached": None,
Pierre-Yves Chibon 73d120
            "title": "Test PR",
Pierre-Yves Chibon 73d120
            "uid": "e8b68df8711648deac67c3afed15a798",
Pierre-Yves Chibon 73d120
            "updated_on": "1516348115",
Pierre-Yves Chibon 73d120
            "user": {"fullname": "PY C", "name": "pingou"},
Pierre-Yves Chibon 2233c1
        }
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_no_comments(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has no comments.
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        # Check the PR with 0 comment:
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = False
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_one_comments(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has one comment.
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
        # Check the PR with 1 comment:
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting solution :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = False
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_two_comments_one_person(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has two comments
Pierre-Yves Chibon 2233c1
        but from the same person.
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
        # Add two comments from the same user:
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting solution :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "Indeed it is :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = False
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_two_comments_two_persons(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has two comments
Pierre-Yves Chibon 2233c1
        from two different persons.
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
        # Add two comments from two users:
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting solution :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd_foo"}
Pierre-Yves Chibon 73d120
        data = {"comment": "Indeed it is :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 73d120
        data["comments"] = []  # Let's not check the comments
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = True
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_three_comments_two_persons_changed_to_no(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has three
Pierre-Yves Chibon 2233c1
        comments from two person among which one changed their mind from
Pierre-Yves Chibon 2233c1
        +1 to -1.
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
        # Add three comments from two users:
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting solution :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd_foo"}
Pierre-Yves Chibon 73d120
        data = {"comment": "Indeed it is :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
        data = {
Pierre-Yves Chibon 73d120
            "comment": "Nevermind the bug is elsewhere in fact :thumbsdown:"
Pierre-Yves Chibon 2233c1
        }
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 73d120
        data["comments"] = []  # Let's not check the comments
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = False
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 2233c1
    def test_api_pull_request_three_comments_two_persons_changed_to_yes(self):
Pierre-Yves Chibon 2233c1
        """ Check the value of threshold_reach when the PR has three
Pierre-Yves Chibon 2233c1
        comments from two person among which one changed their mind from
Pierre-Yves Chibon 2233c1
        -1 to +1
Pierre-Yves Chibon 2233c1
        """
Pierre-Yves Chibon 2233c1
        # Add three comments from two users:
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd"}
Pierre-Yves Chibon 73d120
        data = {"comment": "This is a very interesting solution :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        headers = {"Authorization": "token aaabbbcccddd_foo"}
Pierre-Yves Chibon 73d120
        data = {"comment": "I think the bug is elsewhere :thumbsdown:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        data = {"comment": "Nevermind it is here :thumbsup:"}
Pierre-Yves Chibon 2233c1
        output = self.app.post(
Pierre-Yves Chibon 73d120
            "/api/0/test/pull-request/1/comment", data=data, headers=headers
Pierre-Yves Chibon 73d120
        )
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 73d120
        self.assertDictEqual(data, {"message": "Comment added"})
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon 73d120
        output = self.app.get("/api/0/test/pull-request/1")
Pierre-Yves Chibon 2233c1
        self.assertEqual(output.status_code, 200)
Pierre-Yves Chibon 2233c1
        data = json.loads(output.get_data(as_text=True))
Pierre-Yves Chibon 2233c1
        data = self._clean_data(data)
Pierre-Yves Chibon 73d120
        data["comments"] = []  # Let's not check the comments
Pierre-Yves Chibon 2233c1
        self.expected_data["threshold_reached"] = True
Pierre-Yves Chibon 2233c1
        self.assertDictEqual(data, self.expected_data)
Pierre-Yves Chibon 2233c1
Pierre-Yves Chibon c71c2d
Pierre-Yves Chibon 73d120
if __name__ == "__main__":
Pierre-Yves Chibon 393f31
    unittest.main(verbosity=2)