-
-
Notifications
You must be signed in to change notification settings - Fork 339
Expand file tree
/
Copy path2-is-proper-fraction.js
More file actions
52 lines (38 loc) · 1.57 KB
/
2-is-proper-fraction.js
File metadata and controls
52 lines (38 loc) · 1.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Implement a function isProperFraction,
// when given two numbers, a numerator and a denominator, it should return true if
// the given numbers form a proper fraction, and false otherwise.
// Assumption: The parameters are valid numbers (not NaN or Infinity).
// Note: If you are unfamiliar with proper fractions, please look up its mathematical definition.
// Acceptance criteria:
// After you have implemented the function, write tests to cover all the cases, and
// execute the code to ensure all tests pass.
function isProperFraction(numerator, denominator) {
return Math.abs(numerator) < Math.abs(denominator)
}
// The line below allows us to load the isProperFraction function into tests in other files.
// This will be useful in the "rewrite tests with jest" step.
module.exports = isProperFraction;
// Here's our helper again
function assertEquals(actualOutput, targetOutput) {
console.assert(
actualOutput === targetOutput,
`Expected ${actualOutput} to equal ${targetOutput}`
);
}
// TEST CASES
// Normal Scenarios
assertEquals(isProperFraction(1, 2), true);
assertEquals(isProperFraction(5, 10), true);
// Boundary Values
assertEquals(isProperFraction(0, 5), false);
assertEquals(isProperFraction(1, 1), false);
// Improper Fraction
assertEquals(isProperFraction(8, 3), false)
// Negative Values
assertEquals(isProperFraction(-3, 8), true);
assertEquals(isProperFraction(-8, -3), false);
assertEquals(isProperFraction(-3, -8), true);
//Very Small
assertEquals(isProperFraction(0.0001, 999999), true);
//Very Large
assertEquals(isProperFraction(999999, 0.0001), false);