-
-
Notifications
You must be signed in to change notification settings - Fork 76
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
northwest |Rahwa Zeslus |module-structure-and-Testing-Data | WEEK3 #224
base: main
Are you sure you want to change the base?
northwest |Rahwa Zeslus |module-structure-and-Testing-Data | WEEK3 #224
Conversation
@@ -1,8 +1,9 @@ | |||
// Predict and explain first... | |||
// the num is already declared by the constant keyword ,which is not going to change in every logging. |
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.
While your implementation is correct, your explanation does not clearly explain the reason for the bug. Please give your code a second look and update your explanation.
Sprint-2/implement/bmi.js
Outdated
@@ -13,3 +13,10 @@ | |||
// Given someone's weight in kg and height in metres | |||
// Then when we call this function with the weight and height | |||
// It should return their Body Mass Index to 1 decimal place | |||
function BMICalculation(height,adultWeight){ | |||
const heightSquare= Math.sqrt(height); |
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.
Your BMI implementation is wrong. You are doing something incorrectly with your height. Please look up the correct formula for BMI calculation.
Sprint-2/implement/cases.js
Outdated
@@ -13,3 +13,8 @@ | |||
|
|||
// You will need to come up with an appropriate name for the function | |||
// Use the string documentation to help you find a solution | |||
function changeToUpper(words){ |
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.
Can you come up with a more descriptive name for this function? changeToUpper does not clearly describe what the function is doing
} | ||
|
||
console.log(toPounds("90P")) | ||
|
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.
It would be best if you also handled edge cases like empty strings, missing "P", or invalid input.
Sprint-2/implement/vat.js
Outdated
@@ -8,3 +8,8 @@ | |||
// Given a number, | |||
// When I call this function with a number | |||
// it returns the new price with VAT added on | |||
function priceWithoutVAT(price){ | |||
priceWithVAT=price+ (price*0.2); |
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.
Can you make sure priceWithVAT is properly declared
thank you for your constructive reviews, I updated with the corrected one . |
Please take a look when you have the chance and let me know if there are any improvements or issues you see. Thanks in advance |
@RahwaZeslusHaile I think you can tag the reviewer (like what I did here with your ID) to let the reviewer know you would like a follow-up review from the reviewer. |
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.
The code is quite solid.
card-validator.md
has a bug that needs fixing.
Sprint-3/implement/get-angle-type.js
Outdated
// When the angle is greater than 180 degrees and less than 360 degrees, | ||
// Then the function should return "Reflex angle" | ||
function getAngleType(angleMeasure){ | ||
|
||
if (angleMeasure === 90){ | ||
return "Right_Angle"; | ||
} | ||
else if (angleMeasure < 90) { | ||
return "Acute angle"; | ||
} | ||
else if (angleMeasure > 90 && angleMeasure < 180) { | ||
return "Obtuse angle"; | ||
} | ||
else if (angleMeasure===180) { | ||
return "Straight angle"; | ||
} | ||
else if (angleMeasure > 180) { | ||
return "Reflex angle"; | ||
} | ||
} |
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 do you expect from the following function calls?
getAngleType(360)
getAngleType(1000)
getAngleType(0)
getAngleType(-1000)
If the spec is not clear about how to classify 0 or negative angles, you can lookup the definition of "Acute angle".
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.
Yes I understand ,I didn't see that way. So what I have done in this new code is try to change the degrees to to an equivalent angle within the standard range of
0 degree to 360 degree
Sprint-3/implement/get-angle-type.js
Outdated
console.log(getAngleType(90)) | ||
console.log(getAngleType(110)) | ||
console.log(getAngleType(10)) | ||
console.log(getAngleType(180)) | ||
console.log(getAngleType(200)) |
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.
Do you notice any inconsistency among the output produced by these statements?
if (!isNaN(rank) && Number(rank) >= 2 && Number(rank) <= 10) { | ||
return Number(rank); | ||
} |
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 do you expect from the following function calls?
Does your function return the value you expected?
getCardValue("010♠");
getCardValue("02♠");
getCardValue("0x02♠");
getCardValue("2.1♠")
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.
1,getCardValue("010♠"); expected : 10
!isNaN(rank) → true because "010" is a numeric string.
Number(rank) → 10 (leading zeros are ignored by Number()).
Number(rank) >= 2 && Number(rank) <= 10 → true.
2,getCardValue("02♠"); expected :2
!isNaN(rank) → true because "02" is a numeric string.
Number(rank) → 2 (leading zeros are ignored by Number()).
Number(rank) >= 2 && Number(rank) <= 10 → true.
3,getCardValue("0x02♠"); Expected output: 2
!isNaN(rank) → true because "0x02" is interpreted as a valid hexadecimal number in JavaScript.
Number(rank) → 2 (JavaScript converts "0x02" to its decimal equivalent).
Number(rank) >= 2 && Number(rank) <= 10 → true.
Expected output: 2.
4,getCardValue("2.1♠") ;Expected output: 2.1
!isNaN(rank) → true because "2.1" is a valid floating-point number.
Number(rank) → 2.1.
Number(rank) >= 2 && Number(rank) <= 10 → 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.
At the end, do you want the function to recognise these card values?
if(a <= 0 || b <= 0 || c <= 0){ | ||
return false; | ||
} |
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.
If any of a
, b
, and c
is less than or equal to zero, then the condition at line 43 will always be false.
Is there any need to further check if a
, b
, and c
is less than or equal to zero at line 51?
I will not go into details why in some programming languages (but not JavaScript) we need also to ensure a, b, c are positives.
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.
Thank you for your review! You're absolutely right in your observation. Since the check for whether any side is less than or equal to zero is already handled in the first condition (a <= 0 || b <= 0 || c <= 0) at line 43, the second check at line 51 is unnecessary.
This means the function can be simplified by removing that second check, making the logic more concise and clearer.
Sprint-3/implement/rotate-char.js
Outdated
if (char >= "a" && char <= "z") { | ||
// Calculate new character with wraparound | ||
const charCode = char.charCodeAt(0); | ||
const rotatedCode = ((charCode - 97 + shift) % 26) + 97; // 'a' starts at ASCII 97 |
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.
This approach is good.
If shift
were allowed to be negative so that charCode - 97 + shift
can become a negative number, how would you modify your code to deal with negative shift
?
function validateCreditCard(cardNumber) { | ||
if (cardNumber.length !== 16) { | ||
return false; | ||
} | ||
|
||
const digitSet = new Set(cardNumber); | ||
if (digitSet.size < 2) { | ||
return false; | ||
} | ||
|
||
|
||
const lastDigit = parseInt(cardNumber.charAt(cardNumber.length - 1), 10); | ||
if (lastDigit % 2 !== 0) { | ||
return false; | ||
} | ||
|
||
|
||
let sum = 0; | ||
for (let i = 0; i < cardNumber.length; i++) { | ||
sum += parseInt(cardNumber.charAt(i), 10); | ||
} | ||
|
||
if (sum <= 16) { | ||
return false; | ||
} | ||
|
||
return 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.
Have you fully tested this function? It missed checking something in the given cardNumber
.
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.
Yes! You are right—it misses checking the card in a lot of ways. I updated the code to have more comprehensive validations, including checks for:
1,Ensuring the card contains only numeric characters.
2,Verifying the card number length is exactly 16 digits.
3,Confirming the card has at least two unique digits.
4,Applying the Luhn algorithm for number validation.
5,Validating that the last digit (check digit) is even
|
||
function isPrimeNumber(number) { | ||
if (number <= 1) { | ||
throw new Error('There is no negative prime number or zero as a prime 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.
How are these non-prime numbers (e.g., -100, 1, 0) any different from other non-prime numbers (e.g., 10, 15, 100)?
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.
you’re absolutely right that treating numbers less than or equal to 1 differently by throwing an error while returning false for other non-prime numbers (e.g., 10, 15) introduces unnecessary complexity. Thank you
return false; | ||
} | ||
|
||
for (let index = 3; index <= Math.sqrt(number); index += 2) { |
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.
You can possibly improve the performance of the code in the following manner:
- Avoid calling
Math.sqrt(num)
repeatedly by assigning the value ofMath.sqrt(num)
to a variable once, and then refer to the variable in the condition of the loop.- Note: The condition is checked at the start of every iteration.
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.
Thank you for pointing out the potential improvement in performance by avoiding the repeated calculation of Math.sqrt(number) in the loop condition.
const previousPasswords = ['Password1!', 'Admin123#']; | ||
|
||
it('should return false for passwords with less than 5 characters', () => { | ||
expect(isValidPassword('P1!', previousPasswords)).toBe(false); |
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.
The function could have also returned false
because P1!
does not contain any lowercase letter. How can we be 100% sure the function can correctly check passwords shorter than 5 characters?
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.
Thank you for pointing out that ,I tried to include requirement to make the password valid(the lower case letter, uppercase letter, a number,and one-alphanumeric symbol) unless the length is less than 5. So the test only checks that the length is less than five and returns false.
Sprint-3/revise/implement/repeat.js
Outdated
if (count === 0) { | ||
return ''; | ||
} | ||
if (count === 1) { | ||
return str; | ||
} | ||
return str.repeat(count); |
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.
These statements could be greatly shorten if you know how String.repeat()
works.
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.
Yes! I would have used one string.repeat(count) to repeat the string and it can handle for all conditions(less than zero,one,and greater than one ). I really appreciate your review.
…the test only do the length checking
I’ve made corrections to improve the overall functionality, readability, and efficiency of the code. Can you please review the updates and provide feedback? |
northwest |Rahwa Zeslus |module-structure-and-Testing-Data | WEEK3