-
-
Notifications
You must be signed in to change notification settings - Fork 624
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
Updating tests for armstrong-numbers #2577
base: main
Are you sure you want to change the base?
Updating tests for armstrong-numbers #2577
Conversation
Hello. Thanks for opening a PR on Exercism 🙂 We ask that all changes to Exercism are discussed on our Community Forum before being opened on GitHub. To enforce this, we automatically close all PRs that are submitted. That doesn't mean your PR is rejected but that we want the initial discussion about it to happen on our forum where a wide range of key contributors across the Exercism ecosystem can weigh in. You can use this link to copy this into a new topic on the forum. If we decide the PR is appropriate, we'll reopen it and continue with it, so please don't delete your local branch. If you're interested in learning more about this auto-responder, please read this blog post. Note: If this PR has been pre-approved, please link back to this PR on the forum thread and a maintainer or staff member will reopen it. |
@@ -37,4 +37,12 @@ describe('Armstrong Numbers', () => { | |||
xtest('Seven digit number that is not an Armstrong number', () => { | |||
expect(isArmstrongNumber(9926314)).toEqual(false); | |||
}); | |||
|
|||
xtest('Armstrong number containing seven zeroes', () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What's the runtime for these two for the proof.ci solution on your machine?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
FYI the tests are failing because that's not a valid integer. You probably need to switch to BigInt for these tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yep, I’m aware of that, and that’s why comments are included in the test cases’ canonical-data.json
file in the problem-specifications
repository, indicating that these tests can be skipped if appropriate.
{
"uuid": "5ee2fdf8-334e-4a46-bb8d-e5c19c02c148",
"description": "Armstrong number containing seven zeroes",
"comments": [
"The numeric size of this input number is 108 bits. Consider skipping this test if appropriate."
],
"scenarios": ["big-integer"],
"property": "isArmstrongNumber",
"input": {
"number": 186709961001538790100634132976990
},
"expected": true
},
{
"uuid": "12ffbf10-307a-434e-b4ad-c925680e1dd4",
"description": "The largest and last Armstrong number",
"comments": [
"The numeric size of this input number is 127 bits. Consider skipping this test if appropriate."
],
"scenarios": ["big-integer"],
"property": "isArmstrongNumber",
"input": {
"number": 115132219018763992565095597973971522401
},
"expected": true
}
I was wondering if we should include these tests or not because doing so might cause all community solutions to become outdated and would require new students to use BigInt
. This is the concern I was referring to in my first message—apologies for not being clearer earlier! Let me know your thoughts.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, updating the tests causes all solutions to be rerun again so they will become outdated anyway. You are correct that the current solutions that don't use BigInt will be invalid (if we include the two new tests).
I feel that if there's an easy way to implement a solution that would pass all the tests, including the new ones, then they should be included, so if you can figure it out, feel free to commit.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've got it working using the BigInt approach, but we can't directly pass those large numbers as they are in the test file. Instead, we need to pass them either as strings or as BigInt values. I've demonstrated both approaches in the second-to-last and last tests, respectively. Please review them and let me know which approach we should proceed with.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We barely have any BigInt
exercises, so let's just upgrade everything.
I prefer it if you pass the numbers into the tests with the n
suffix:
const largeNumber = 186709961001538790100634132976990n
expect(isArmstrongNumber(largeNumber)).toEqual(true);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would also recommend to add an appends
file to note that some of the tests will pass a BigInt
. Your proof will keep working because:
const bigInput = BigInt(42);
// 42n
const bigInput = BigInt(42n);
// 42n
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, and it passes the tests!
@Cool-Katt, the last two tests are not consistent yet, as they're currently taking different approaches. Let me know which approach you'd prefer me to implement for both. |
I'm thinking that the one that explicitly passes a |
Sure @Cool-Katt, I'll make the changes ASAP! |
description = "Single-digit numbers are Armstrong numbers" | ||
|
||
[2d6db9dc-5bf8-4976-a90b-b2c2b9feba60] | ||
description = "There are no 2 digit Armstrong numbers" | ||
description = "There are no two-digit Armstrong numbers" | ||
|
||
[509c087f-e327-4113-a7d2-26a4e9d18283] | ||
description = "Three digit number that is an Armstrong number" | ||
description = "Three-digit number that is an Armstrong number" | ||
|
||
[7154547d-c2ce-468d-b214-4cb953b870cf] | ||
description = "Three digit number that is not an Armstrong number" | ||
description = "Three-digit number that is not an Armstrong number" | ||
|
||
[6bac5b7b-42e9-4ecb-a8b0-4832229aa103] | ||
description = "Four digit number that is an Armstrong number" | ||
description = "Four-digit number that is an Armstrong number" | ||
|
||
[eed4b331-af80-45b5-a80b-19c9ea444b2e] | ||
description = "Four digit number that is not an Armstrong number" | ||
description = "Four-digit number that is not an Armstrong number" | ||
|
||
[f971ced7-8d68-4758-aea1-d4194900b864] | ||
description = "Seven digit number that is an Armstrong number" | ||
description = "Seven-digit number that is an Armstrong number" | ||
|
||
[7ee45d52-5d35-4fbd-b6f1-5c8cd8a67f18] | ||
description = "Seven digit number that is not an Armstrong number" | ||
description = "Seven-digit number that is not an Armstrong number" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Other test descriptions needs to be updated to match this.
@@ -37,4 +37,12 @@ describe('Armstrong Numbers', () => { | |||
xtest('Seven digit number that is not an Armstrong number', () => { | |||
expect(isArmstrongNumber(9926314)).toEqual(false); | |||
}); | |||
|
|||
xtest('Armstrong number containing seven zeroes', () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We barely have any BigInt
exercises, so let's just upgrade everything.
I prefer it if you pass the numbers into the tests with the n
suffix:
const largeNumber = 186709961001538790100634132976990n
expect(isArmstrongNumber(largeNumber)).toEqual(true);
|
||
xtest('The largest and last Armstrong number', () => { | ||
expect( | ||
isArmstrongNumber(`115132219018763992565095597973971522401`), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
isArmstrongNumber(`115132219018763992565095597973971522401`), | |
isArmstrongNumber(115132219018763992565095597973971522401n), |
@@ -37,4 +37,12 @@ describe('Armstrong Numbers', () => { | |||
xtest('Seven digit number that is not an Armstrong number', () => { | |||
expect(isArmstrongNumber(9926314)).toEqual(false); | |||
}); | |||
|
|||
xtest('Armstrong number containing seven zeroes', () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would also recommend to add an appends
file to note that some of the tests will pass a BigInt
. Your proof will keep working because:
const bigInput = BigInt(42);
// 42n
const bigInput = BigInt(42n);
// 42n
@SleeplessByte, I've made all the changes you requested. However, could you please clarify what you meant by adding an |
Certainly This exercise is synced with the problem-specifications, so when a change is introduced there, we receive it via pull request. This will replace the We now want to add a note to that file that the solution needs to be able to handle However:
Edit or create this file for this exercise and it will remain in place when the main instructions are updated. |
Sure, I'll make the changes as soon as possible! Additionally, I had a question unrelated to the PR, so I’ve sent an email to the address listed on your GitHub profile since GitHub doesn’t support direct messaging. I’d really appreciate it if you could take a look. Thank you! |
I found it! |
Pull Request
This PR adds two new test cases to the Armstrong-Numbers exercise to align it with the
problem-specifications
repository. However, both numbers in these new tests are extremely large and will cause thetest-runner
to fail. Please let me know how you'd like me to proceed with this!