Ejercicio de programación con TypeScript: Proyecto validación de tipado

Proyecto
Práctica
3h 0m

Desarrolla un sistema modular de validación de tipos en TypeScript con validadores primitivos, compuestos y personalizados para datos complejos.

  1. Crea un nuevo proyecto TypeScript con la estructura básica de archivos: tsconfig.json, src/index.ts, src/validators/index.ts, y src/types/index.ts.

  2. Define en el archivo src/types/index.ts las interfaces básicas para el sistema de validación. Debes crear una interfaz ValidationResult que indique si la validación ha sido exitosa y, en caso contrario, el mensaje de error. También define una interfaz Validator<T> que represente una función que recibe un valor y devuelve un ValidationResult.

  3. Implementa en src/validators/primitives.ts los validadores básicos para tipos primitivos: isString, isNumber, isBoolean e isDate. Cada uno debe devolver un objeto que cumpla con la interfaz ValidationResult.

  4. Crea en src/validators/composite.ts funciones para validar estructuras de datos complejas como arrays (isArray) y objetos (isObject), que puedan utilizar otros validadores para verificar los elementos internos.

  5. Desarrolla en src/validators/custom.ts validadores personalizados para formatos específicos como email (isEmail), código postal español (isSpanishPostalCode) y número de teléfono (isPhoneNumber).

  6. Implementa en src/validators/utils.ts funciones de utilidad como optional (para campos opcionales), oneOf (para validar que un valor cumpla con al menos uno de varios validadores) y allOf (para validar que un valor cumpla con todos los validadores proporcionados).

  7. Crea en src/validators/schema.ts una función validateSchema que reciba un objeto y un esquema de validación (definido como un objeto donde cada clave tiene asociado un validador) y verifique si el objeto cumple con el esquema.

  8. Implementa en src/index.ts ejemplos de uso de tu sistema de validación con diferentes estructuras de datos, mostrando tanto casos exitosos como fallidos.

  9. Añade pruebas unitarias en un directorio tests que verifiquen el correcto funcionamiento de todos los validadores implementados.

  10. Documenta tu código con comentarios JSDoc que expliquen el propósito de cada función, sus parámetros y valores de retorno.

Empezar ejercicio de programación

Más ejercicios de programación con TypeScript

Evalúa tus conocimientos en TypeScript con más ejercicios de programación de tipo Test, Puzzle, Código y Proyecto con VSCode.

Tecnologías de este ejercicio de programación

Entornos de desarrollo para este ejercicio

Image

Visual Studio Code

Image

GitHub