Cuando comienzas a programar una aplicación web, todo es bastante fácil de probar de forma manual. Pero las aplicaciones web crecen en tamaño y complejidad de forma gradual, lo cual convierte el testing manual en un proceso difícil y costoso.
La solucion proviene del testing. El testing nos ayuda a mantener la calidad de la aplicación a la vez que ahorramos el tiempo de las pruebas manuales.
-
Realiza un "Fork" del proyecto a tu repositorio GitHub.
-
Clona el proyecto en tu entorno de programació local.
La estructura del código del ejercicio consiste en:
proyecto/ ├── __tests__/ │ └── funcArray.test.js ├── src/ | └── funcArray.js ├── package.json
Ejecución de los tests
Para correr los tests de Jest ejecuta el comando pnpm test en el terminal.
Pasar los tests
Modifica el fichero funcArray.js del directorio src siguiendo las instrucciones que se ofrecen en este mismo documento. Poco a poco se deben pasar todos los tests.
No se trata de pasar todos los tests a la vez. Hay que leer detenidamente lo que se pide en cada iteración, resolviendo los errores de uno en uno.
Cuando se programa con tests es muy importante leer y entender los errores que devuelve cada test, es la manera de saber qué hay que codificar.
- Sube los cambios a tu repositorio GitHub.
- Cuando hayas pasado todos los tests realiza un pull-request del ejercicio.
Define una función maxOfTwoNumbers que tome dos números como argumentos y devuelva el mayor.
Escribe una función findLongestWord que tome un array de palabras y devuelva la más larga. Si hay 2 con la misma longitud, debería devolver la primera.
Itera sobre un array sumando cada elemento.
Semanticamente reduce es el mejor método para hacer esta operación, aunque se puede utilizar cualquier tipo de bucle de los que hemos visto.
Crea una función sumArray que tome un array de números como parámetro y calcule la suma de todos sus miembros.
Para ello sigue el siguiente algoritmo:
- Utiliza la suma del ejercicio anterior y divídela por el número de elementos.
Escribe una función averageNumbers que reciba un array de números y calcule la media de los números.
Escribe una función averageWordLength que reciba un array de palabras y calcule la media de la longitud de las palabras.
Coge el siguiente array, elimina los duplicados y devuelve un nuevo array. Si lo necesitas consulta la función indexOf.
Realiza este ejercicio como una fución uniquifyArray que reciba un array de palabras como parámetro.
Escribe una función doesWordExist que reciba un array de palabras como argumento y una palabra para buscar dentro del array. Devuelve true si existe, sino devuelve false. No utilices indexOf en este caso.
Escribe una función howManyTimes que tome un array de palabras como argumento y una palabra para buscar. La función devolverá el número de veces que una palabra aparece en el array.
Cual es el producto mayor de cuatro números adyacentes? Consideramos adyacentes cualquier grupo de cuatro números en horizontal, vertical o diagonal.
Por ejemplo, si tenemos una matriz de 5x5 como:
[ 1, 2, 3, 4, 5]
[ 1, 20, 3, 4, 5]
[ 1, 20, 3, 4, 5]
[ 1, 20, 3, 4, 5]
[ 1, 4, 3, 4, 5]
El mayor producto será 20x20x20x4 = 32,000;
Escribe una función greatestProduct para encontrar el producto mayor en la matriz de 20×20 siguiente!
let matrix = [
[08,02,22,97,38,15,00,40,00,75,04,05,07,78,52,12,50,77,91,08],
[49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48,04,56,62,00],
[81,49,31,73,55,79,14,29,93,71,40,67,53,88,30,03,49,13,36,65],
[52,70,95,23,04,60,11,42,69,24,68,56,01,32,56,71,37,02,36,91],
[22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80],
[24,47,32,60,99,03,45,02,44,75,33,53,78,36,84,20,35,17,12,50],
[32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70],
[67,26,20,68,02,62,12,20,95,63,94,39,63,08,40,91,66,49,94,21],
[24,55,58,05,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72],
[21,36,23,09,75,00,76,44,20,45,35,14,00,61,33,97,34,31,33,95],
[78,17,53,28,22,75,31,67,15,94,03,80,04,62,16,14,09,53,56,92],
[16,39,05,42,96,35,31,47,55,58,88,24,00,17,54,24,36,29,85,57],
[86,56,00,48,35,71,89,07,05,44,44,37,44,60,21,58,51,54,17,58],
[19,80,81,68,05,94,47,69,28,73,92,13,86,52,17,77,04,89,55,40],
[04,52,08,83,97,35,99,16,07,97,57,32,16,26,26,79,33,27,98,66],
[88,36,68,87,57,62,20,72,03,46,33,67,46,55,12,32,63,93,53,69],
[04,42,16,73,38,25,39,11,24,94,72,18,08,46,29,32,40,62,76,36],
[20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74,04,36,16],
[20,73,35,29,78,31,90,01,74,31,49,71,48,86,81,16,23,57,05,54],
[01,70,54,71,83,51,54,69,16,92,33,48,61,43,52,01,89,19,67,48],
];