How to calculate total nodes in a call having total commits filtered by author?


#1

I am working on a github contributions analyzer, for a user there is a repo having 300,000 + commits in total, on a default branch I am querying total commits and total commits by the user and it is giving me response “Oh Snap!” in html with few imgs.

The part of the query is :

contributions: defaultBranchRef {
          target {
            ... on Commit {
              userCommits: history(author: {id: $id}) {
                totalCount
              }
              totalCommits: history {
                totalCount
              }
            }
          }
        }

This is working for all the repos except the one having so many commits. I was querying 100 repos data in one query earlier but then i tried calling data for the specific repo, still didn’t work.


#2

Hi @hereisnaman. Thanks for opening this topic!

Can you tell me a bit more about the response that you’re receiving? I believe I’ve been able to reproduce this but want to make sure.


#3

Try the following query repo(https://github.com/championswimmer/android_kernel_sony_msm8960T):

query($username: String!, $id: ID!, $afterCursor: String)
      {
        rateLimit {
          limit
          cost
          remaining
          resetAt
        }
        user(login: $username) {
          id
          repositories(first: 1, after: $afterCursor, orderBy: {field: NAME,direction: ASC}) {
            ...repoData
          }
        }
      }

      fragment repoStats on Repository {
        nameWithOwner
        url
        owner {
          login
        }
        stargazers {
          totalCount
        }
        watchers {
          totalCount
        }
        forks {
          totalCount
        }
        branch: defaultBranchRef {
          name
        }
        primaryLanguage {
          name
          color
        }
        languages(first: 10, orderBy: {field: SIZE, direction: DESC}){
          nodes{
            name
            color
          }
          totalSize
        }
        contributions: defaultBranchRef {
          target {
            ... on Commit {
              userCommits: history(author: {id: $id}) {
                totalCount
              }
              totalCommits: history {
                totalCount
              }
            }
          }
        }
      }

      fragment repoData on RepositoryConnection {
        totalCount
        pageInfo {
          hasNextPage
          endCursor
        }
        nodes {
          ... on Repository {
            isFork
            parent {
              ...repoStats
            }
            ...repoStats
          }
        }
      }

with the following variables:

{
	"username": "championswimmer",
	"id": "MDQ6VXNlcjEzMjcwNTA=",
  "afterCursor": "Y3Vyc29yOnYyOpK7YW5kcm9pZF9rZXJuZWxfc29ueV9tc204OTMwzgCdzYE="
}

the response is:

"<!DOCTYPE html>\n<html>\n  <head>\n    <meta http-equiv=\"Content-type\" content=\"text/html; charset=utf-8\">\n    <meta http-equiv=\"Content-Security-Policy\" content=\"default-src 'none'; base-uri 'self'; connect-src 'self'; form-action 'self'; img-src data:; script-src 'self'; style-src 'unsafe-inline'\">\n    <meta content=\"origin\" name=\"referrer\">\n    <title>Oh snap! &middot; GitHub</title>\n    <style type=\"text/css\" media=\"screen\">\n      body {\n        background-color: #f1f1f1;\n        margin: 0;\n        font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n      }\n\n      .outer-container {\n        position: relative;\n      }\n\n      .container {\n        width: 600px;\n        text-align: center;\n\n        position: absolute;\n        top: 50%;\n        left: 50%;\n        transform: translate(-50%, -50%);\n      }\n\n      a { color: #4183c4; text-decoration: none; }\n      a:hover { text-decoration: underline; }\n\n      h1 { letter-spacing: -1px; line-height: 60px; font-size: 60px; font-weight: 100; margin: 0px; text-shadow: 0 1px 0 #fff; }\n      p { color: rgba(0, 0, 0, 0.5); margin: 20px 0 40px; }\n\n      ul { list-style: none; margin: 25px 0; padding: 0; }\n      li { display: table-cell; font-weight: bold; width: 1%; }\n\n      .logo { display: inline-block; margin-top: 35px; }\n      .logo-img-2x { display: none; }\n      @media\n      only screen and (-webkit-min-device-pixel-ratio: 2),\n      only screen and (   min--moz-device-pixel-ratio: 2),\n      only screen and (     -o-min-device-pixel-ratio: 2/1),\n      only screen and (        min-device-pixel-ratio: 2),\n      only screen and (                min-resolution: 192dpi),\n      only screen and (                min-resolution: 2dppx) {\n        .logo-img-1x { display: none; }\n        .logo-img-2x { display: inline-block; }\n      }\n\n      #suggestions {\n        margin-top: 35px;\n        color: #ccc;\n      }\n      #suggestions a {\n        color: #666666;\n        font-weight: 200;\n        font-size: 14px;\n        margin: 0 10px;\n      }\n\n      .emoji {\n        color: #000;\n        line-height: 1;\n      }\n\n    </style>\n  </head>\n  <body>\n\n    <div class=\"container\">\n\n      <h1>Oh snap!</h1>\n      <p>\n        Something, somewhere, has gone horribly, horribly wrong.<br>\n        If the problem persists, try refreshing your browser.<br>\n      </p>\n      <div id=\"suggestions\">\n        <a href=\"https://github.com/contact\">Contact Support</a> &mdash;\n        <a href=\"https://status.github.com\">GitHub Status</a> &mdash;\n        <a href=\"https://twitter.com/githubstatus\">@githubstatus</a>\n      </div>\n\n      <a href=\"/\" class=\"logo logo-img-1x\">\n        <img width=\"32\" height=\"32\" title=\"\" alt=\"\" src=\"\">\n      </a>\n\n      <a href=\"/\" class=\"logo logo-img-2x\">\n        <img width=\"32\" height=\"32\" title=\"\" alt=\"\" src=\"\">\n      </a>\n    </div>\n  </body>\n</html>\n"

#4

Thanks @hereisnaman – that’s super helpful! I’m able to reproduce this and it’s likely caused by a timeout. I’ve opened an issue to investigate the problem. We’ll update here as soon as we know more.


#5

What is the status ?


#6

@LizzHale Its been 13 days, are there any updates?


#7

I apologize @hereisnaman, I missed your reply. Let me check in on the status of the issue.


#8

so, any updates?


#9

Hey @hereisnaman!

I’m sorry for the lack of fix and responses here! Right now, this is a known issue - for certain large repositories, it can take a significant amount of time to calculate certain information - long enough that our platform cuts off the query to avoid causing problems for other users.

In this case, the root of the problem is the use of totalCommits twice over - once to get the number of commits for the user, and once to get the total number of commits. Due to our implementation of this connection, the count must be calculated twice, which is an expensive operation.

I’m currently doing some digging to see what our opportunities are for speeding this up. In the meantime, I’ve been able to get that query to work by removing either the total count for all commits or the total user commits.

I realize this isn’t the best solution - I really want to make sure that we’re providing a stable API without these limitations, and i’m committed to doing what we can to finding a fix here that will get you what you need.


#10

It ain’t working even with a single totalCommits query. Its been quite a long now. 50 days.


#11

Are there any updates on the issue? My application is not being able to serve well to the users because of this issue.