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

add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease], [GitHubTag]) #4395

Merged
merged 6 commits into from
Feb 14, 2020

Conversation

agilgur5
Copy link
Contributor

@agilgur5 agilgur5 commented Dec 4, 2019

Description

Uses the new query params logic from the GitHubRelease Service to provide the same functionality for the GitHubCommitsSince Service when using the latest release (so one can use e.g. latest.json?sort=semver).

Motivation

I have some libraries where I have a commits since badge meant to track number of commits since the "latest" release. Since "latest" by GitHub API is by date, this means if I release a backport, the badge will start tracking from that backport since it's latest by date. Tracking commits since latest by semver is what I would like to do.

The workaround I've been having to do without this is to put the latest SemVer version into the badge and updating it whenever I make a new release (tedious, and has to already be pinned before any backport is released, otherwise above bug will occur until the badge is pinned, and if, say it's released on NPM before the badge is pinned, it will be tracking the backport until another release is added)

Related

Related to #1955 ; upon second read, I realized that asks for the addition of tags on top of just releases, what I was looking for in #1955 (comment) is actually different -- the addition of SemVer. Guess I read that wrong when I made that comment and never filed a separate issue for SemVer support.

Review Notes

Some things to look at in particular:

  • I renamed github-release.spec.js to gh.l7l.us.kgmon-fetch.spec.js because I moved the logic there so it could be shared. getLatestRelease isn't normally exposed, so I exported it as _getLatestRelease so that the tests could import it. Not sure what the optimal/preferred way would be to do this (other than rewriting the tests to run against the new fetchLatestRelease).
    • EDIT: I also don't know how to run gh.l7l.us.kgmon-fetch.spec.js as it itself is not a service. It's currently causing CI to error because it's not found 😕
  • The examples and tests for commits since. I could add more permutations of how one could combine the query params with each other and with branches, but not sure if that is necessary.

Potential Future Opportunities

In addition to latest, could extending tracking for specific SemVer line -- e.g. ^1.0.0 would track latest 1.x.x releases. This seems far from trivial (and unsure of efficiency on GitHub API), but it would allow say, a backport branch to show how many commits since the latest backport, instead of latest by SemVer or latest by date. Could also be used to track a certain SemVer line of dependencies or something

@shields-ci
Copy link

shields-ci commented Dec 4, 2019

Messages
📖 ✨ Thanks for your contribution to Shields, @agilgur5!

Generated by 🚫 dangerJS against 4e882d3

@calebcartwright calebcartwright changed the title add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease] to move logic to [GitHubCommonFetch]) add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease] to move logic to gh.l7l.us.kgmon-fetch.js) Dec 4, 2019
@calebcartwright calebcartwright added the service-badge New or updated service badge label Dec 4, 2019
@agilgur5 agilgur5 changed the title add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease] to move logic to gh.l7l.us.kgmon-fetch.js) add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease] to move logic to gh.l7l.us.kgmon-fetch.js, and [GitHubTag] to re-use that schema) Dec 4, 2019
@calebcartwright
Copy link
Member

Thanks for the PR @agilgur5!

EDIT: I also don't know how to run gh.l7l.us.kgmon-fetch.spec.js as it itself is not a service. It's currently causing CI to error because it's not found 😕

That's correct, the [ServiceClassName..] notation in the PR title's are used to specify which subset of the service tests to run in the service test stage (more details here). That's utilized because the of the nature of the service tests (integration testing with the upstream platforms/APIs) and how long it takes to run the full suite.

There's other jobs that will run all of the unit tests, including those defined in gh.l7l.us.kgmon-fetch.spec.js, so those don't have to be called out explicitly in the PR title.

I've updated the PR title accordingly and everything looks green now 👍

@shields-cd shields-cd temporarily deployed to shields-staging-pr-4395 December 4, 2019 06:11 Inactive
@agilgur5
Copy link
Contributor Author

agilgur5 commented Dec 4, 2019

Thanks for the super-fast response @calebcartwright !! 😮

There's other jobs that will run all of the unit tests, including those defined in gh.l7l.us.kgmon-fetch.spec.js, so those don't have to be called out explicitly in the PR title.

Ah I see, gotcha. I read the service-tests docs and didn't have trouble understanding those, but I didn't know what the Jasmine tests ran under. Somehow I didn't realize they were unit tests when I was reading through (despite looking up what the sazerac package does) -- that makes a lot more sense now 😅

@calebcartwright
Copy link
Member

Thanks for the super-fast response

Fortunate timing 😄

CI looks good and the review app is up at https://shields-staging-pr-4395.herokuapp.com/ if you'd like to poke around.

I'm signing out for the night but this'll get a more thorough review from a maintainer soon. Thanks again!

@agilgur5 agilgur5 changed the title add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease] to move logic to gh.l7l.us.kgmon-fetch.js, and [GitHubTag] to re-use that schema) add sort and prerelease query params to [GitHubCommitsSince] (also refactors [GitHubRelease], [GitHubTag]) Dec 4, 2019
@PyvesB
Copy link
Member

PyvesB commented Dec 5, 2019

Thanks for the contribution @agilgur5! Will aim at reviewing it over the week-end if no one picks it up before. 😉

- so that the sorting and prerelease logic can be used for other
  services too, like commits-since
@agilgur5 agilgur5 force-pushed the commits-since-query-params branch from 049f0ec to 02324d3 Compare December 15, 2019 22:19
- they only work when using the 'latest' version of course

- uses same logic as release service
- as they were the exact same schema
- and the same variable everywhere
@agilgur5 agilgur5 force-pushed the commits-since-query-params branch from 02324d3 to 6f32ae4 Compare December 15, 2019 22:27
…cts [GitHubCommitsSince], [GitHubRelease], [GitHubTag])

- this logic is only used for code related to releases & tags, so made
  sense as a split point
@calebcartwright
Copy link
Member

Thanks @agilgur5! Will try to take a final look at this one within the next couple days

@shields-cd shields-cd temporarily deployed to shields-staging-pr-4395 February 5, 2020 23:44 Inactive
@shields-cd shields-cd temporarily deployed to shields-staging-pr-4395 February 14, 2020 01:32 Inactive
Copy link
Member

@calebcartwright calebcartwright left a comment

Choose a reason for hiding this comment

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

LGTM! Thanks again for this, apologies for the late review

@calebcartwright calebcartwright merged commit 7f7ecfd into badges:master Feb 14, 2020
@shields-deployment
Copy link

This pull request was merged to master branch. This change is now waiting for deployment, which will usually happen within a few days. Stay tuned by joining our #ops channel on Discord!

After deployment, changes are copied to gh-pages branch:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
service-badge New or updated service badge
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants