當前位置: 首頁>>代碼示例>>Python>>正文


Python github3.GitHubError方法代碼示例

本文整理匯總了Python中github3.GitHubError方法的典型用法代碼示例。如果您正苦於以下問題:Python github3.GitHubError方法的具體用法?Python github3.GitHubError怎麽用?Python github3.GitHubError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github3的用法示例。


在下文中一共展示了github3.GitHubError方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_get_session__authenticate_with_exceptions

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def test_get_session__authenticate_with_exceptions(
            self, mock_path, mock_prompt, mock_getpass, mock_authorize):
        mock_path.isfile.return_value = False

        mock_response = MockResponse(content='', status_code=401)
        mock_authorize.side_effect = GitHubError(mock_response)
        self.assertRaises(exceptions.FarcyException, helpers.get_session)

        self.assertTrue(mock_prompt.called)
        self.assertTrue(mock_getpass.called)

        mock_response = MockResponse(content='', status_code=101)
        mock_authorize.side_effect = GitHubError(mock_response)
        self.assertRaises(GitHubError, helpers.get_session)

        mock_authorize.side_effect = TypeError
        self.assertRaises(TypeError, helpers.get_session) 
開發者ID:appfolio,項目名稱:farcy,代碼行數:19,代碼來源:test_helpers.py

示例2: test_feature_branch_merge_github_error

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def test_feature_branch_merge_github_error(self):
        self._mock_repo()
        self._mock_branch(self.branch)
        self.mock_pulls()
        branch_name = "feature/a-test"
        branches = []
        branches.append(self._get_expected_branch(branch_name))
        branches = self._mock_branches(branches)
        self._mock_compare(
            base=branches[1]["name"],
            head=self.project_config.repo_commit,
            files=[{"filename": "test.txt"}],
        )
        self._mock_merge(http.client.INTERNAL_SERVER_ERROR)
        task = self._create_task()
        with self.assertRaises(GitHubError):
            task() 
開發者ID:SFDO-Tooling,項目名稱:CumulusCI,代碼行數:19,代碼來源:test_merge.py

示例3: get_commits

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def get_commits(self, repo_owner, repo_name):
        from github3 import GitHubError
        attempts = self.__retries
        while attempts:
            try:
                # github handler
                g = self.get_github_handler()
                if not g:
                    raise Exception("No github handler")

                repo = g.repository(repo_owner, repo_name)
                commits = repo.iter_commits()  # [commit for commit in repo.iter_commits()]
                # for commit in commits:
                #    print commits[0].to_json()['commit']['committer']['date']
                return repo, commits

            except GitHubError as ghe:
                if str(ghe.code) == '403':
                    logger.error("get_tags: %s", str(ghe))
                    attempts -= 1
                    continue
                else:
                    logger.error("get_tags: %s, giving up!", str(ghe))
                    break

            # timed out
            except utils.TimeoutException as te:
                logger.error("Error getting github repo commits for repo %s: %s", repo_name, str(te))
                # try again
                attempts -= 1
                continue

            except Exception as e:
                logger.error("Failed to get github repo commits for repo %s: %s", repo_name, str(e))
                return None

        logger.error("Giving up on getting github repo releases for repo %s!", repo_name)
        return None 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:40,代碼來源:github.py

示例4: get_tags

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def get_tags(self, repo_owner, repo_name):
        from github3 import GitHubError
        attempts = self.__retries
        while attempts:
            try:
                # github handler
                g = self.get_github_handler()
                if not g:
                    raise Exception("No github handler")

                repo = g.repository(repo_owner, repo_name)
                if not repo:
                    logger.error("repo doesn't exist: %s/%s, giving up!", repo_owner, repo_name)
                    break

                tags = repo.iter_tags()
                return repo, tags

            except GitHubError as ghe:
                if str(ghe.code) == '403':
                    logger.error("get_tags: %s", str(ghe))
                    attempts -= 1
                    continue
                else:
                    logger.error("get_tags: %s, giving up!", str(ghe))
                    break

            # timed out
            except utils.TimeoutException as te:
                logger.error("Error getting github repo tags for repo %s: %s", repo_name, str(te))
                # try again
                attempts -= 1
                continue

            except Exception as e:
                logger.error("Failed to get github repo tags for repo %s: %s", repo_name, str(e))
                return None, None

        logger.error("Giving up on getting github repo releases for repo %s!", repo_name)
        return None, None 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:42,代碼來源:github.py

示例5: test_get_session__from_credentials_file__handled_exception

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def test_get_session__from_credentials_file__handled_exception(
            self, mock_path, mock_open, mock_is_starred, mock_stderr,
            mock_prompt, mock_getpass, mock_authorize):
        mock_path.expanduser.return_value = 'mock_path'
        mock_path.isfile.return_value = True
        mock_open.return_value = MagicMock(spec=IOBase)

        mock_response = MockResponse(content='', status_code=401)
        mock_is_starred.side_effect = GitHubError(mock_response)
        self.assertTrue(isinstance(helpers.get_session(), GitHub))
        self.assertTrue(mock_stderr.write.called)
        self.assertTrue(mock_prompt.called)
        self.assertTrue(mock_getpass.called)
        self.assertTrue(mock_open.called) 
開發者ID:appfolio,項目名稱:farcy,代碼行數:16,代碼來源:test_helpers.py

示例6: _assign_repo

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def _assign_repo(repo_name, members=[]):
    """
    (PRIVATE method, use the repomanager instead) Creates the repository and adds the members as
    contributors, idempotently.

    """
    if config.github_read_only_mode:
        raise RuntimeError("Cannot assign repo because of GitHub read-only mode")
    github = _get_github_admin()
    fq_repo_name = "%s/%s" % (config.github_organization, repo_name)
    organization = github.organization(config.github_organization)
    try:
        repo = organization.create_repo(repo_name, private=config.github_private_repos)
    except github3.GitHubError as e:
        if e.args and hasattr(e.args[0], "status_code") and e.args[0].status_code == 422:
            repo = github.repository(config.github_organization, repo_name)
            assert repo, "Unable to get repository object for GitHub (check API key permissions?)"
        else:
            raise

    collaborators = {user.login for user in repo.iter_collaborators()}

    for member in members:
        if member not in collaborators:
            successfully_added = repo.add_collaborator(member)
            assert successfully_added, "Unable to add member %s to %s" % (repr(member),
                                                                          repr(fq_repo_name)) 
開發者ID:octobear2,項目名稱:ob2,代碼行數:29,代碼來源:github_api.py

示例7: authorize_token

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def authorize_token(user):
    config = read_config()
    if config.get('GitHub', 'token'):
        print("The token already exists.")
        sys.exit()

    password = getpass('Password for {0}: '.format(user))

    note = 'OCA (odoo community association) Maintainers Tools'
    note_url = 'https://github.com/OCA/maintainers-tools'
    scopes = ['repo', 'read:org', 'write:org', 'admin:org']

    try:
        # Python 2
        prompt = raw_input
    except NameError:
        # Python 3
        prompt = input

    def two_factor_prompt():
        code = ''
        while not code:
            # The user could accidentally press Enter before being ready,
            # let's protect them from doing that.
            code = prompt('Enter 2FA code: ')
        return code
    try:
        auth = github3.authorize(user, password, scopes, note, note_url,
                                 two_factor_callback=two_factor_prompt)
    except github3.GitHubError as err:
        if err.code == 422:
            for error in err.errors:
                if error['code'] == 'already_exists':
                    msg = ("The 'OCA (odoo community association) Maintainers "
                           "Tools' token already exists. You will find it at "
                           "https://github.com/settings/tokens and can "
                           "revoke it or set the token manually in the "
                           "configuration file.")
                    sys.exit(msg)
        raise

    config.set("GitHub", "token", auth.token)
    write_config(config)
    print("Token stored in configuration file") 
開發者ID:OCA,項目名稱:maintainer-tools,代碼行數:46,代碼來源:github_login.py

示例8: get_tags_commits

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def get_tags_commits(self, repo_owner, repo_name, insertdb=False, gh_id=None):
        from github3 import GitHubError
        attempts = self.__retries
        repo = None
        tags_commits = []
        count = 0

        # for large repos we limit querying the server
        while attempts or (main.MAX_REPO_TAGS_QUERY and count < main.MAX_REPO_TAGS_QUERY):
            idx = 0
            try:
                # github handler
                g = self.get_github_handler()
                if not g:
                    raise Exception("No github handler")

                repo = g.repository(repo_owner, repo_name)
                if not repo:
                    logger.error("repo doesn't exist: %s/%s, giving up!", repo_owner, repo_name)
                    break

                for tag in repo.iter_tags():

                    # for large repos we limit querying the server
                    if main.MAX_REPO_TAGS_QUERY and idx > main.MAX_REPO_TAGS_QUERY:
                        break
                    if idx <= count:
                        idx += 1
                        continue
                    else:
                        tags_commits.append((tag, repo.commit(tag.to_json()['commit']['sha'])))
                        idx += 1
                        count += 1

                # insertdb
                if insertdb:
                    self.insert_tags_db(gh_id=gh_id, repo_owner=repo_owner, repo_name=repo_name,
                                        tags_commits=tags_commits)
                return repo, tags_commits

            except GitHubError as ghe:
                if str(ghe.code) == '403':
                    logger.error("get_tags_commits count %d idx %d: %s", count, idx, str(ghe))
                    attempts -= 1
                    continue
                else:
                    logger.error("get_tags_commits count %d idx %d: %s, giving up!", count, idx, str(ghe))
                    break

            except Exception as e:
                logger.error("failed to get tags for repo %s after collecting %d tags: %s", repo_name, count, str(e))
                return None, None

        logger.error("Giving up on collecting tags/commits for repo %s after %d tags/commits", repo_name, count)
        return repo, tags_commits 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:57,代碼來源:github.py

示例9: _merge

# 需要導入模塊: import github3 [as 別名]
# 或者: from github3 import GitHubError [as 別名]
def _merge(self, branch, source, commit, children=None):
        if not children:
            children = []
        branch_type = "branch"
        if children:
            branch_type = "parent branch"
        if self.options["children_only"]:
            branch_type = "child branch"

        compare = self.repo.compare_commits(branch, commit)
        if not compare or not compare.files:
            self.logger.info(
                "Skipping {} {}: no file diffs found".format(branch_type, branch)
            )
            return

        try:
            self.repo.merge(branch, commit)
            self.logger.info(
                "Merged {} commits into {} {}".format(
                    compare.behind_by, branch_type, branch
                )
            )
            if children and not self.options["children_only"]:
                self.logger.info("  Skipping merge into the following child branches:")
                for child in children:
                    self.logger.info("    {}".format(child.name))

        except GitHubError as e:
            if e.code != http.client.CONFLICT:
                raise

            if branch in self.existing_prs:
                self.logger.info(
                    "Merge conflict on {} {}: merge PR already exists".format(
                        branch_type, branch
                    )
                )
                return

            pull = self.repo.create_pull(
                title="Merge {} into {}".format(source, branch),
                base=branch,
                head=source,
                body="This pull request was automatically generated because "
                "an automated merge hit a merge conflict",
            )

            self.logger.info(
                "Merge conflict on {} {}: created pull request #{}".format(
                    branch_type, branch, pull.number
                )
            ) 
開發者ID:SFDO-Tooling,項目名稱:CumulusCI,代碼行數:55,代碼來源:merge.py


注:本文中的github3.GitHubError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。