- 1. Preámbulo
- 2. Resumen del proyecto
- 3. Justificación
- 4. Consideraciones generales
- 5. Criterios de aceptación mínimos del proyecto
- 6. Funcionamiento
Markdown es un lenguaje de marcado ligero usado en plataformas que manejan texto plano (GitHub, foros, blogs, ...) .
Estos archivos Markdown
normalmente contienen links (vínculos/ligas) que
muchas veces están rotos o ya no son válidos y eso perjudica mucho el valor de
la información que se quiere compartir.
Se creo una herramienta usando Node.js, que lea y analice archivos
en formato Markdown
, para verificar los links que contengan y reportar algunas estadísticas como total de links, links únicos y links rotos. Por ejemplo para detectar los links rotos en los readmes de los proyectos
o en un área de facturación verificar los links rotos de una factura digital.
La implementación de este proyecto tiene varias partes: leer del sistema de archivos, recibir argumentos a través de la línea de comando, analizar texto, hacer consultas HTTP, ... y todas estas cosas pueden enfocarse de muchas formas, tanto usando librerías como implementando en VanillaJS.
-
La librería y el script ejecutable (herramienta de línea de comando - CLI) está implementado en JavaScript para ser ejecutados con Node.js.
-
El módulo debe ser instalable via
npm install <github-user>/md-links
. Este módulo debe incluir tanto un ejecutable que podamos invocar en la línea de comando como una interfaz que podamos importar conrequire
para usarlo programáticamente. -
Para personalizar el estilo de la aplicación en la terminal se uso la libreria chalk.
-
Se uso Jest y nodejs native Test runner para los tests unitarios de statements, functions, lines y branches.
-
Para este proyecto no se utilizó
async/await
. -
Para este proyecto no se usó la versión síncrona de la función para leer archivos,
readFileSync
. -
Uso de ES Modules
(import/export)
, en lugar de commonJS(require/module.exports)
. -
Para el parseado (análisis) del markdown para extraer los links se utilizo expresiones regulares(
RegExp
). -
StandardJS para evitar que tu código JavaScript contenta errores con npm install standard -D adicional eslintConfig en package.json
README.md
con descripción del módulo, instrucciones de instalación/uso, documentación del API y ejemplos.mdlinks.js
: Desde este archivo se exportan funciones a index.jsindex.js
: Desde este archivo se exporta una función (mdLinks
).package.json
con nombre, versión, descripción, autores, licencia, dependencias, scripts (pretest, test, ...), main, bin.editorconfig
con configuración para editores de texto. Este archivo no se debe cambiar..gitignore
para ignorarnode_modules
u otras carpetas que no deban incluirse en control de versiones (git
).test/md-links.spec.js
y `test/index.spec.js que contienen los tests unitarios.
npm i mdlinks-b
Se ejecuta de la siguiente manera a través de la terminal:
md-links <path-to-file> [options]
$ md-links ./some/example.md
Href: URL encontrada.
Text: Texto que aparecía dentro del link (`<a>`).
File: Ruta del archivo donde se encontró el link.
$ md-links ./some/example.md --validate
Href: URL encontrada.
Text: Texto que aparecía dentro del link (`<a>`).
File: Ruta del archivo donde se encontró el link.
Status: Código de respuesta HTTP.
Msg: Mensaje `fail` en caso de fallo u `ok` en caso de éxito.
Si pasamos la opción --stats
el output (salida) será un texto con estadísticas
básicas sobre los links.
$ md-links ./some/example.md --stats
Total: 3
Unique: 3
También podemos combinar --stats
y --validate
para obtener estadísticas que
necesiten de los resultados de la validación.
$ md-links ./some/example.md --stats --validate
Total: 3
Unique: 3
Broken: 1
Información de los comandos a utilizar.
$ md-links --help
<path> All links .md
<path> --validate Links with status and msg
<path> --stats Stats: Total and Unique links
<path> --stats --validate Stats: Total, Unique and Broken links