2024-01-04 11:21:43 +00:00
const repeatString = require ( "./repeatString-solution" ) ;
2022-02-20 19:07:44 +00:00
2024-01-04 11:21:43 +00:00
describe ( "repeatString" , ( ) => {
test ( "repeats the string" , ( ) => {
expect ( repeatString ( "hey" , 3 ) ) . toEqual ( "heyheyhey" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "repeats the string many times" , ( ) => {
expect ( repeatString ( "hello" , 10 ) ) . toEqual ( "hellohellohellohellohellohellohellohellohellohello" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "repeats the string 1 times" , ( ) => {
expect ( repeatString ( "hi" , 1 ) ) . toEqual ( "hi" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "repeats the string 0 times" , ( ) => {
expect ( repeatString ( "bye" , 0 ) ) . toEqual ( "" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "returns ERROR with negative numbers" , ( ) => {
expect ( repeatString ( "goodbye" , - 1 ) ) . toEqual ( "ERROR" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "repeats the string a random amount of times" , function ( ) {
2023-01-21 17:53:41 +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
2022-02-20 19:07:44 +00: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 17:53:41 +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.
// 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 19:07:44 +00:00
in the result , which if your function works correctly will equal the number that
was randomaly generated . * /
2024-01-04 11:21:43 +00:00
expect ( repeatString ( "odin" , number ) . match ( /((odin))/g ) . length ) . toEqual ( number ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2024-01-04 11:21:43 +00:00
test ( "works with blank strings" , ( ) => {
expect ( repeatString ( "" , 10 ) ) . toEqual ( "" ) ;
2023-01-21 17:53:41 +00:00
} ) ;
2022-02-20 19:07:44 +00:00
} ) ;