Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

enh: use graphql to consolidate api calls #267

Merged
merged 8 commits into from
Mar 18, 2025
Merged

Conversation

lwasser
Copy link
Member

@lwasser lwasser commented Mar 5, 2025

Next steps

  • Run on all packages
  • Consider a small reorg; put all gh metrics in the github module
  • 🐛 contrib count isn't correct. (this is because this endpoint isn't available via graphQL. other options are mentionable and collaborators but those are different metrics.
  • Move get_gh_metrics to github module

@lwasser lwasser marked this pull request as draft March 6, 2025 00:00
Fix: full run

fix: bugs in run
Copy link

codecov bot commented Mar 6, 2025

Codecov Report

Attention: Patch coverage is 26.66667% with 33 lines in your changes missing coverage. Please review.

Project coverage is 80.25%. Comparing base (302d8b5) to head (195c6c0).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
src/pyosmeta/github_api.py 31.42% 24 Missing ⚠️
src/pyosmeta/parse_issues.py 10.00% 9 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #267      +/-   ##
==========================================
+ Coverage   76.27%   80.25%   +3.97%     
==========================================
  Files          10       10              
  Lines         725      714      -11     
  Branches       92       92              
==========================================
+ Hits          553      573      +20     
+ Misses        162      131      -31     
  Partials       10       10              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@lwasser
Copy link
Member Author

lwasser commented Mar 6, 2025

bummer. if we move to graphql we can't get a contributor count. We could consider a separate workflow just for that metric in the future.

repo_endpoints, accepted_reviews
)

# BUG : contrib count isn't correct - great tables has some and is returning 0
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This isn't a bug, the endpoint isn't available via graphql.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've updated the PR to use rest just for that metric. it reduces the api calls by one per package vs two now.

@lwasser lwasser marked this pull request as ready for review March 14, 2025 14:52

def get_repo_contribs(self, url: str) -> int | None:
def _get_metrics_graphql(
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As we refactor it might make sense to generalize this for all graphql calls. But for now this is a specific helper to get metrics data.

@lwasser
Copy link
Member Author

lwasser commented Mar 14, 2025

pre-commit.ci autofix

@lwasser lwasser requested a review from banesullivan March 15, 2025 01:04
@lwasser
Copy link
Member Author

lwasser commented Mar 15, 2025

Hey there, @banesullivan. I'm worried about merging this and breaking things in #270. Please have a look and let me know if we can merge and rebase or if that will cause problems. I'd also like to submit another pr that moves other parts of our workflow to graphql.

Copy link
Contributor

@banesullivan banesullivan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @lwasser, these changes look great and are much needed! I'm not concerned about conflicts with my work in #270 as I'll be able to quickly resolve those. Let's merge this whenever you're ready

@lwasser
Copy link
Member Author

lwasser commented Mar 18, 2025

thank you @banesullivan !!!

@lwasser lwasser merged commit 42a3cba into pyOpenSci:main Mar 18, 2025
2 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants