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
/ * 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
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
} ) ;