odin-javascript-exercises/02_repeatString/solution/repeatString-solution.spec.js

40 lines
1.7 KiB
JavaScript
Raw Normal View History

2023-02-01 15:53:54 -08:00
const repeatString = require('./repeatString-solution');
2022-02-20 11:07:44 -08:00
2023-02-01 15:53:54 -08:00
describe('repeatString', () => {
test('repeats the string', () => {
expect(repeatString('hey', 3)).toEqual('heyheyhey');
2023-01-21 09:53:41 -08:00
});
2023-02-01 15:58:58 -08:00
test('repeats the string many times', () => {
2023-02-01 15:53:54 -08:00
expect(repeatString('hey', 10)).toEqual('heyheyheyheyheyheyheyheyheyhey');
2023-01-21 09:53:41 -08:00
});
2023-02-01 15:58:58 -08:00
test('repeats the string 1 times', () => {
2023-02-01 15:53:54 -08:00
expect(repeatString('hey', 1)).toEqual('hey');
2023-01-21 09:53:41 -08:00
});
2023-02-01 15:58:58 -08:00
test('repeats the string 0 times', () => {
2023-02-01 15:53:54 -08:00
expect(repeatString('hey', 0)).toEqual('');
2023-01-21 09:53:41 -08:00
});
2023-02-01 15:58:58 -08:00
test('returns ERROR with negative numbers', () => {
2023-02-01 15:53:54 -08:00
expect(repeatString('hey', -1)).toEqual('ERROR');
2023-01-21 09:53:41 -08:00
});
2023-02-01 15:58:58 -08:00
test('repeats the string a random amount of times', function () {
2023-01-21 09:53:41 -08:00
/*The number is generated by using Math.random to get a value from between
2022-02-20 11:07:44 -08:00
0 to 1, when this is multiplied by 1000 and rounded down with Math.floor it
equals a number between 0 to 999 (this number will change everytime you run
the test).*/
2023-01-21 09:53:41 -08:00
// DO NOT use Math.floor(Math.random() * 1000) in your code,
// this test generates a random number, then passes it into your code with a function parameter.
// If this doesn't make sense, you should go read about functions here: https://www.theodinproject.com/paths/foundations/courses/foundations/lessons/fundamentals-part-3
const number = Math.floor(Math.random() * 1000);
/*The .match(/((hey))/g).length is a regex that will count the number of heys
2022-02-20 11:07:44 -08:00
in the result, which if your function works correctly will equal the number that
was randomaly generated. */
2023-02-01 15:53:54 -08:00
expect(repeatString('hey', number).match(/((hey))/g).length).toEqual(
2023-01-21 09:53:41 -08:00
number
);
});
2023-02-01 15:58:58 -08:00
test('works with blank strings', () => {
2023-02-01 15:53:54 -08:00
expect(repeatString('', 10)).toEqual('');
2023-01-21 09:53:41 -08:00
});
2022-02-20 11:07:44 -08:00
});