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


Python github.GitHub方法代碼示例

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


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

示例1: update

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def update(send_email=True):
    # Update the DB with the GitHub repo data
    for repo in config.github_repos:
        github.update_library_data(config.github_user, repo)

    # Update the DB with Package Manager data
    pm.update_package_manager_data(config.package_manager_urls)

    # Export tables as CSV if config file indicates to do so
    if config.export_github:
        db.export_table_to_csv(GitHubData)
    if config['export_tables']['PackageManagers']:
        db.export_table_to_csv(PackageManagerData)

    if not send_email:
        return

    # Send an email update
    sg.send_email(config.to_email,
                  config.from_email,
                  config.email_subject,
                  config.email_body) 
開發者ID:sendgrid,項目名稱:open-source-library-data-collector,代碼行數:24,代碼來源:app.py

示例2: cron

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def cron(testing=False):
    """Script to run from cron for Sampleplatform."""
    from mod_ci.controllers import start_platforms, kvm_processor, TestPlatform
    from flask import current_app
    from run import config, log
    from database import create_session
    from github import GitHub

    log.info('Run the cron for kicking off CI platform(s).')
    # Create session
    db = create_session(config['DATABASE_URI'])
    gh = GitHub(access_token=config['GITHUB_TOKEN'])
    repository = gh.repos(config['GITHUB_OWNER'])(config['GITHUB_REPOSITORY'])

    if testing is True:
        kvm_processor(current_app._get_current_object(), db, config.get('KVM_LINUX_NAME', ''), TestPlatform.linux,
                      repository, None)
    else:
        start_platforms(db, repository) 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:21,代碼來源:cron.py

示例3: inform_mailing_list

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def inform_mailing_list(mailer, id, title, author, body) -> None:
    """
    Send mail to subscribed users when a issue is opened via the Webhook.

    :param mailer: The mailer instance
    :type mailer: Mailer
    :param id: ID of the Issue Opened
    :type id: int
    :param title: Title of the Created Issue
    :type title: str
    :param author: The Authors Username of the Issue
    :type author: str
    :param body: The Content of the Issue
    :type body: str
    """
    from run import get_github_issue_link

    subject = f"GitHub Issue #{id}"
    url = get_github_issue_link(id)
    if not mailer.send_simple_message({
        "to": "ccextractor-dev@googlegroups.com",
        "subject": subject,
        "html": get_html_issue_body(title=title, author=author, body=body, issue_number=id, url=url)
    }):
        g.log.error('failed to send issue to mailing list') 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:27,代碼來源:controllers.py

示例4: authenticate

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def authenticate(self):
        """
            (class) -> boolean

            Passing throught authentication and verifying if the right credentials were given.
        """

        if self.personal_access_token is not None:
            self.gh = github.GitHub(access_token = self.personal_access_token)
        else:
            self.gh = github.GitHub(
                        self.consumer_key,
                        self.consumer_secret,
                        self.access_token,
                        self.access_secret)
        try:
            
            some_get = self.gh.users(self.user_name).get()
            print json.dumps(some_get, sort_keys=True, indent=4, separators=(',', ': '))
            return True
        except Exception, ex:
            print '[e] exception {}'.format(str(ex))
            return False 
開發者ID:vdmitriyev,項目名稱:services-to-wordcloud,代碼行數:25,代碼來源:github_commits.py

示例5: mergeCloneData

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def mergeCloneData(cloneStats, rid):
    # convert traffic data into SQL values
    data=""
    for cday in cloneStats['clones']:
        data+="("+str(rid)+",'"+cday['timestamp'][:10]+"',"+str(cday['count'])+","+str(cday['uniques'])+"),"
    mergeStatement=mergeClones1+data[:-1]+mergeClones2
    # execute MERGE statement
    res=ibm_db.exec_immediate(conn,mergeStatement)


# Overall flow:
# - loop over users
#   - log in to GitHub as that current user
#   - retrieve repos for that current user, loop the repos
#     - for each repo fetch stats
#     - merge traffic data into table
#  update last run info 
開發者ID:IBM-Cloud,項目名稱:github-traffic-stats,代碼行數:19,代碼來源:__main__.py

示例6: get_contributors

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def get_contributors(full_name):
    print("Getting GitHub repository `{}`".format(full_name))
    response = yield from gh_async.get_contributors(*full_name.split("/"))
    json = yield from response.json()
    print("response for {}: {}".format(full_name, json))
    return json 
開發者ID:prkumar,項目名稱:uplink,代碼行數:8,代碼來源:asyncio_example.py

示例7: get_contributors

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def get_contributors(full_name):
    print("Getting GitHub repository `{}`".format(full_name))
    response = yield gh_async.get_contributors(*full_name.split("/"))
    json = response.json()
    print("response for {}: {}".format(full_name, json)) 
開發者ID:prkumar,項目名稱:uplink,代碼行數:7,代碼來源:twisted_example.py

示例8: setUp

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def setUp(self):
        if os.environ.get('TRAVIS') is None:
            self.github = GitHub()
            self.db = DBConnector()
            self.config = Config() 
開發者ID:sendgrid,項目名稱:open-source-library-data-collector,代碼行數:7,代碼來源:test.py

示例9: get_commits

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def get_commits(self):
        """
            (class) -> None

            Getting commits of the particular repository of the GitHub.
        """

        counter = 0
        page = 1

        # one exta requrest to understand math pages commits per page
        commits = self.gh.repos(self.user_name)(self.repository_name).commits.get(author = self.user_name, page = page)
        max_commits_per_page = len(commits)

        while True:
            commits = self.gh.repos(self.user_name)(self.repository_name).commits.get(author = self.user_name, page = page)
            for index in range(len(commits)):
                 commit_message = self.__get_replaced(commits[index]['commit'])
                 commit_date = self.__get_date(commits[index]['commit'])
                 self.df.loc[counter,'githubCommitMessage'] = commit_message
                 self.df.loc[counter,'timestamp'] = commit_date
                 counter += 1

            if max_commits_per_page == len(commits):
                page+=1
            else:
                break 
開發者ID:vdmitriyev,項目名稱:services-to-wordcloud,代碼行數:29,代碼來源:github_commits.py

示例10: queue_test

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def queue_test(db, gh_commit, commit, test_type, branch="master", pr_nr=0) -> None:
    """
    Store test details into Test model for each platform, and post the status to GitHub.

    :param db: Database connection.
    :type db: sqlalchemy.orm.scoped_session
    :param gh_commit: The GitHub API call for the commit. Can be None
    :type gh_commit: Any
    :param commit: The commit hash.
    :type commit: str
    :param test_type: The type of test
    :type test_type: TestType
    :param branch: Branch name
    :type branch: str
    :param pr_nr: Pull Request number, if applicable.
    :type pr_nr: int
    :return: Nothing
    :rtype: None
    """
    from run import log

    fork_url = f"%/{g.github['repository_owner']}/{g.github['repository']}.git"
    fork = Fork.query.filter(Fork.github.like(fork_url)).first()

    if test_type == TestType.pull_request:
        log.debug('pull request test type detected')
        branch = "pull_request"

    linux_test = Test(TestPlatform.linux, test_type, fork.id, branch, commit, pr_nr)
    db.add(linux_test)
    windows_test = Test(TestPlatform.windows, test_type, fork.id, branch, commit, pr_nr)
    db.add(windows_test)
    db.commit()
    add_customized_regression_tests(linux_test.id)
    add_customized_regression_tests(windows_test.id)

    if gh_commit is not None:
        status_entries = {
            linux_test.platform.value: linux_test.id,
            windows_test.platform.value: windows_test.id
        }
        for platform_name, test_id in status_entries.items():
            try:
                gh_commit.post(
                    state=Status.PENDING,
                    description="Tests queued",
                    context=f"CI - {platform_name}",
                    target_url=url_for('test.by_id', test_id=test_id, _external=True)
                )
            except ApiError as a:
                log.critical(f'Could not post to GitHub! Response: {a.response}')

    log.debug("Created tests, waiting for cron...") 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:55,代碼來源:controllers.py

示例11: progress_reporter

# 需要導入模塊: import github [as 別名]
# 或者: from github import GitHub [as 別名]
def progress_reporter(test_id, token):
    """
    Handle the progress of a certain test after validating the token. If necessary, update the status on GitHub.

    :param test_id: The id of the test to update.
    :type test_id: int
    :param token: The token to check the validity of the request.
    :type token: str
    :return: Nothing.
    :rtype: None
    """
    from run import config, log

    test = Test.query.filter(Test.id == test_id).first()
    if test is not None and test.token == token:
        repo_folder = config.get('SAMPLE_REPOSITORY', '')

        if 'type' in request.form:
            if request.form['type'] == 'progress':
                log.info('[PROGRESS_REPORTER] Progress reported')
                if not progress_type_request(log, test, test_id, request):
                    return "FAIL"

            elif request.form['type'] == 'equality':
                log.info('[PROGRESS_REPORTER] Equality reported')
                equality_type_request(log, test_id, test, request)

            elif request.form['type'] == 'logupload':
                log.info('[PROGRESS_REPORTER] Log upload')
                if not upload_log_type_request(log, test_id, repo_folder, test, request):
                    return "EMPTY"

            elif request.form['type'] == 'upload':
                log.info('[PROGRESS_REPORTER] File upload')
                if not upload_type_request(log, test_id, repo_folder, test, request):
                    return "EMPTY"

            elif request.form['type'] == 'finish':
                log.info('[PROGRESS_REPORTER] Test finished')
                finish_type_request(log, test_id, test, request)
            else:
                return "FAIL"

            return "OK"

    return "FAIL" 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:48,代碼來源:controllers.py


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