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

ci(check-ci-skip): fix commitMessagesMetadata.forEach is not a function #3618

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

zondervancalvez
Copy link
Contributor

@zondervancalvez zondervancalvez commented Nov 5, 2024

Commit to be reviewed

ci(check-ci-skip): fix commitMessagesMetadata.forEach is not a function

Primary Changes
----------------
1. Changed the method in getting the commit
message from GitHub API to shell command to avoid
the rate limits in calling the API.
2. Same goes for the author of commit message,
we use shell command to fetch the username.

Fixes #3614

Pull Request Requirements

  • Rebased onto upstream/main branch and squashed into single commit to help maintainers review it more efficient and to avoid spaghetti git commit graphs that obfuscate which commit did exactly what change, when and, why.
  • Have git sign off at the end of commit message to avoid being marked red. You can add -s flag when using git commit command. You may refer to this link for more information.
  • Follow the Commit Linting specification. You may refer to this link for more information.

Character Limit

  • Pull Request Title and Commit Subject must not exceed 72 characters (including spaces and special characters).
  • Commit Message per line must not exceed 80 characters (including spaces and special characters).

A Must Read for Beginners
For rebasing and squashing, here's a must read guide for beginners.

Copy link
Contributor

@jagpreetsinghsasan jagpreetsinghsasan left a comment

Choose a reason for hiding this comment

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

@zondervancalvez I don't think you have checked the code difference when creating this PR. Its totally wrong as you have already commented all the input arguments and hard-coded them with constant fields.
Also the check you have added should output a result which would be self explanatory. Saying Commit message data is empty or null doesn't help the creator of a PR. The right message should be Fetching data from github API failed. This is most likely due to an intermittent issue from Github end or the api being rate limited (one hour cooldown). Please retry running the failed check after an hour.
Also, it would be much better if we fine tune the error handling so that we can clearly say if it is an intermittent issue or rate limit issue.
Although rate limit errors are less likely to occur as the limit for the hosted runners is 1000 per hour

Also, even after mentioning it multiple times, yet we are at the same point where I have to specifically mention that ## Commit and ## **Commit** are rendered same.

@zondervancalvez zondervancalvez force-pushed the zondervancalvez/issue3614 branch 3 times, most recently from 1398b2c to 1178be7 Compare November 5, 2024 09:06
Copy link
Contributor

@petermetz petermetz left a comment

Choose a reason for hiding this comment

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

@zondervancalvez Is this diff going to also fix the issue that if the check script crashes, the CI jobs get skipped by default?

commitMessageList.push(commitMessageMetadata["commit"]["message"]);
});
} else {
console.error(
Copy link
Contributor

Choose a reason for hiding this comment

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

@zondervancalvez Instead of just logging on stderr we should crash. Otherwise there will be more unintended side-effects to the error.
The bottom line is that if we canot fetch the commit message metadata, then we cannot complete the check at all.

@zondervancalvez Is it possible to refactor this code to use the local git installation and list the commits that way so that we are not hitting the GitHub API at all for this?

@zondervancalvez zondervancalvez force-pushed the zondervancalvez/issue3614 branch 2 times, most recently from 8ca65ca to 38a7d3f Compare November 8, 2024 09:32
Copy link
Contributor

@petermetz petermetz left a comment

Choose a reason for hiding this comment

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

@zondervancalvez Do these changes solve the problem that if the ci-ckip-for-maintainers.js code crashes, it implicitly skips all the test checks?

console.log("Latest commit message:\n", commitMessage);
} catch (error) {
console.error("Error fetching commit message:\n", error.message);
}

// Check if skip-ci is found in commit message
const checkSkipCI = () => {
Copy link
Contributor

Choose a reason for hiding this comment

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

@zondervancalvez Please have all the functions be non-nested functions.

tools/ci-skip-for-maintainers.js Outdated Show resolved Hide resolved
@zondervancalvez zondervancalvez force-pushed the zondervancalvez/issue3614 branch 3 times, most recently from 3227fee to 1e0129b Compare November 14, 2024 08:15
Copy link
Contributor

@petermetz petermetz left a comment

Choose a reason for hiding this comment

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

@zondervancalvez Could you please address the questions above?

@zondervancalvez
Copy link
Contributor Author

@zondervancalvez Could you please address the questions above?
Hi @petermetz please see the latest commit. Thanks

@zondervancalvez zondervancalvez force-pushed the zondervancalvez/issue3614 branch from 1e0129b to 7289fe9 Compare November 20, 2024 06:14
@petermetz
Copy link
Contributor

@zondervancalvez Could you please address the questions above?
Hi @petermetz please see the latest commit. Thanks

@zondervancalvez I'm sorry, I can't find the answer to my question from earlier regarding the crashes. Could you please be more specific about which part of the commit message is answering that question?

//const committerLogin = "<username>";
// Function to get the latest commit message
const getLatestCommitMessage = () => {
const commitMsgBuffer = execSync("git log -1 --pretty=%B");
Copy link
Contributor Author

Choose a reason for hiding this comment

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

@petermetz to answer your question, this git log shell command is the alternative we used for fetching commit messages instead of calling github API to avoid limits and crashing

Copy link
Contributor

Choose a reason for hiding this comment

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

@zondervancalvez I'll post a screenshot here with the question(s). Maybe you posted the answers somewhere else and I just couldn't find it? Pull request comments/reviews get confusing quick.

image

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@petermetz I added if: always() on the jobs that requires check-ci-skip job. This will bypass check-ci-skip job if the job failed/crashes.

Copy link
Contributor

Choose a reason for hiding this comment

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

@zondervancalvez OK, but would that then mean that the skip CI marker does not work anymore?

What I mean is that the .js script currently exists with a job failure when it is trying to indicate that the CI should be skipped. But with if: always() the jobs will ignore that. If I'm understanding it correctly.

So I'm thinking you need to refactor the .js script to use a different signaling mechanism where it succeeds as long as there was no crash in it, and it places the information about the CI being skipped or not into some other context variable (which must not be writeable by pull request code because then people could just hack it by writing to this place where we store the information about the CI being skipped or not)

if (isMaintainer) {
  console.log(
    "CI skipped as per request. Exit with an error to PAUSE dependent workflows.",
  );
  process.exit(1);
} else {
  process.exit(0);
}

Copy link
Contributor

@petermetz petermetz left a comment

Choose a reason for hiding this comment

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

@zondervancalvez zondervancalvez force-pushed the zondervancalvez/issue3614 branch 5 times, most recently from 9fada48 to 7b95db2 Compare January 9, 2025 15:51
Primary Changes
----------------
1. Changed the method in getting the commit
message from GitHub API to shell command to avoid
the rate limits in calling the API.
2. Same goes for the author of commit message,
we use shell command to fetch the username.

Fixes hyperledger-cacti#3614

Signed-off-by: bado <[email protected]>
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.

ci(check-ci-skip): fix commitMessagesMetadata.forEach is not a function
3 participants