2018-08-07 10:23:28 +00:00
const repeatString = require ( './repeatString' )
2017-08-21 15:28:29 +00:00
2021-03-03 02:13:24 +00:00
describe ( 'repeatString' , ( ) => {
test ( 'repeats the string' , ( ) => {
2017-08-21 15:28:29 +00:00
expect ( repeatString ( 'hey' , 3 ) ) . toEqual ( 'heyheyhey' ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'repeats the string many times' , ( ) => {
2017-08-21 15:28:29 +00:00
expect ( repeatString ( 'hey' , 10 ) ) . toEqual ( 'heyheyheyheyheyheyheyheyheyhey' ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'repeats the string 1 times' , ( ) => {
2017-08-21 15:28:29 +00:00
expect ( repeatString ( 'hey' , 1 ) ) . toEqual ( 'hey' ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'repeats the string 0 times' , ( ) => {
2017-08-21 15:28:29 +00:00
expect ( repeatString ( 'hey' , 0 ) ) . toEqual ( '' ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'returns ERROR with negative numbers' , ( ) => {
2017-08-21 15:28:29 +00:00
expect ( repeatString ( 'hey' , - 1 ) ) . toEqual ( 'ERROR' ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'repeats the string a random amount of times' , function ( ) {
2020-05-02 14:04:40 +00:00
/ * T h e n u m b e r i s g e n e r a t e d b y u s i n g M a t h . r a n d o m t o g e t a v a l u e f r o m b e t w e e n
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 ) . * /
2020-10-14 21:14:33 +00: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.
2021-04-04 14:49:14 +00:00
// 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
2020-05-02 14:04:40 +00:00
const number = Math . floor ( Math . random ( ) * 1000 )
/*The .match(/ ( ( hey ) ) / g ) . length is a regex that will count the number of heys
in the result , which if your function works correctly will equal the number that
2022-01-02 00:50:35 +00:00
was randomly generated . * /
2020-05-01 17:44:55 +00:00
expect ( repeatString ( 'hey' , number ) . match ( /((hey))/g ) . length ) . toEqual ( number ) ;
} ) ;
2023-11-04 11:05:11 +00:00
test ( 'works with blank strings' , ( ) => {
2020-05-08 06:59:37 +00:00
expect ( repeatString ( '' , 10 ) ) . toEqual ( '' ) ;
} ) ;
2017-08-21 15:28:29 +00:00
} ) ;