Una volta chiusa la prima beta-version, l’aspetto deploy diventa un tema interessante. In uno scenario enterprise il deploy di un’applicazione è un aspetto decisamente importante. In molti progetti in cui ho lavorato il Configuration Management aveva una parte significativa nella gestione del ciclo di vita del software e, in ultima istanza, nei costi del progetto.
Ci sono davvero scuole di pensiero e metodologie dietro il configuration management, ma, da sviluppatore software e project manager, gli aspetti che alla fine più mi premono sono:
- velocizzare le attività di impacchettamento e rilascio del software (time-to-market!!)
- automatizzarlo (ho visto troppi ftp manuali sbagliati in vita mia…)
Al quarto deploy su github-pages per l’ambiente di test, ero già stanco…quindi mi son detto che era ora di sfruttare le potenzialità appena intraviste di Grunt. Non è stato difficile, fondamentalmente Grunt è pensato per essere modulare e per poter inserire nuove funzionalità all’occorrenza. Al momento il mio processo di deploy prevede questi step:
- clean: pulizia delle cartelle definite per l’ambiente di deploy
- concat:css: concatenazione in unico file dei css
- concat:libraries: concatenazione in un unico file dei js di terze parti
- concat:app: concatenazione in un unico file dei js dell’applicazione
- cssmin: minificazione del file css
- uglify: minificazione e compattazione dei file js
- copy: copia dei file da deployare nelle cartelle finali dell’ambiente di deploy
- htmlbuild: manipolazione di index.html per linkare i css ed i js concatenati/minificati/compattati a seconda dell’ambiente
- hashres: modifica dei riferimenti ai file js e css per forzare l’aggiornamento sui client (per evitare il caching delle precedenti versioni dei file)
Una versione funzionante si trova sul repository: https://github.com/williamverdolini/discitur-web/blob/master/Gruntfile.js
Fatto. Duplicare il set di task per il deploy in produzione è altrettanto semplice ed ora con un clik è possibile eseguire in maniera automatizzata il deploy dell’applicazioni in test o in produzione senza troppo sforzo.
Ovviamente questi task si possono aggiungere e complicare a piacere; ad es. mi piacerebbe (in un prossimo futuro) gestire in automatico il clone da una release specifica di github (passata magari da riga di comando al grunt) e l’ftp finale verso l’ambiente. Come dicevo prima Grunt nasce per essere modulare e quindi nulla vieta di agganciare moduli per il lancio di comandi da shell o di creare proprio moduli custom per le più disparate esigenze.
Comments