Il low-code offre velocità e flessibilità nello sviluppo di applicazioni, ma per sfruttarlo appieno è necessario adottare un approccio strutturato basato sulle ISO/IEC 15288 e 12207. Nell’approfondimento, spieghiamo le ragioni della nostra scelta del low-code come strumento per lo sviluppo software e i criteri per massimizzarne il valore.
Non si scappa: la domanda digitale è in aumento.
Un comunicato stampa dell’Osservatorio Digital Transformation Academy del Politecnico di Milano prevede un aumento dell’1,5% dei budget in ICT delle aziende italiane, confermando un trend positivo negli ultimi nove anni e superando le previsioni di crescita del PIL nazionale.
Questi dati evidenziano una crescente domanda di prodotti e servizi digitali da parte delle aziende italiane, spinte dalla necessità di migliorare l’efficienza operativa, l’adattabilità al mercato e l’esperienza del cliente.
Un esempio concreto dell’aumento dell’efficienza operativa potrebbe essere legato all’eliminazione di tutti quei processi aziendali ancora basati su fogli Excel, spesso usati come collante o elemento di connessione tra due sistemi aziendali strutturati. I limiti di Excel sono evidenti soprattutto nella gestione individuale di grandi volumi di dati in quanto un foglio Excel manca di uniformità: ognuno organizza i dati a suo modo ed è difficile mettere i diversi file a fattor comune. La stessa mancanza di automazione è un limite, con errori manuali, perdita di dati e rallentamenti operativi. Inoltre, il replacement di sistemi legacy rappresenta un altro aspetto chiave: questi sistemi risultano costosi da aggiornare, difficili da integrare e limitanti per l’innovazione.
Quando si tratta di rispondere alla domanda di soluzioni digitali, le aziende hanno due alternative principali: MAKE o BUY. Se sul mercato esiste già una soluzione che soddisfa pienamente le esigenze aziendali, la scelta più logica è BUY, ovvero acquistarla, poiché consente di risparmiare tempo e risorse. Questo approccio include l’utilizzo di soluzioni già pronte sul mercato, conosciute come COTS (Commercial Off-The-Shelf Software), che sono prodotti standard progettati per soddisfare bisogni comuni e disponibili per un’implementazione immediata.
La scelta del BUY è la migliore a prescindere perché offre un ottimo TCO: va a ridurre nel massimo il costo di manutenzione e supporto della soluzione nel tempo, una voce di spesa che molto spesso viene erroneamente ignorata durante la fase decisionale.
Tuttavia, quando la soluzione desiderata non è disponibile (e lo scenario non è così raro avendo le aziende processi e integrazioni interne molto complesse), l’opzione è MAKE, ovvero sviluppare in proprio.
Se le aziende optano per la strada del MAKE, possono esplorare diverse opzioni che vanno dalla scrittura tradizionale del codice fino all’utilizzo di soluzioni più o meno avanzate che semplificano e automatizzano la generazione stessa di questo.
Per garantire la personalizzazione totale, i team IT di solito si appoggiano a team interni o esterni di sviluppatori e ingegneri del software, con tutti i limiti legati al fatto che non si lavora a risorse infinite e i tempi spesso non sposano le richieste del business.
Per accelerare i tempi di sviluppo ci sono delle strategie: gli sviluppatori possono sfruttare risorse online e librerie di snippet di codice come Stack Overflow o altri database dove è possibile trovare risposte dettagliate e testate a problemi comuni. Oppure possono ricorrere all’Intelligenza Artificiale per automatizzare parte dello sviluppo. I modelli di AI, infatti, possono essere addestrati con dati di repository come GitHub, che è uno dei repository più grandi e completi per progetti software open source ed essere sfruttati come assistenti nello sviluppo con suggerimenti di ottimizzazioni, identificazione di bug e completamenti automatici del codice. Ovviamente si tenga presente che questi modelli sono validi prevalentemente per applicazioni standard, quando si parla di soluzioni complesse o altamente personalizzate i loro limiti sono evidenti.
Esistono poi sul mercato anche piattaforme specializzate per lo sviluppo e l’integrazione di app verticali come SAP, Salesforce o ServiceNow, ma anche qui le personalizzazioni sono limitate alle specifiche dell’ecosistema in cui si trovano. Nel caso di piccole modifiche possono andare bene, ma diviene sempre più difficile gestire sviluppi che si allontanino molto dallo standard di prodotto.
Per poter avere una tecnologia che garantisca allo stesso tempo flessibilità di personalizzazione e velocità, la scelta più indicata è appoggiarsi alle tecnologie low-code e no-code perché grazie a strumenti visuali e intuitivi queste permettono di generare rapidamente codice mantenendo allo stesso tempo elevati livelli di adattabilità alle esigenze aziendali.
In WEGG riteniamo che queste tecnologie siano la migliore opzione per soddisfare la richiesta di soluzioni digitali in azienda perché permettono di:
Nella scelta della tecnologia low-code abbiamo optato per Mendix, perché è riconosciuta come leader nel Quadrante Magico di Gartner per lo sviluppo di applicazioni enterprise. Mendix, oltre a supportare i requisiti di velocità e personalizzazione richiesti a queste tecnologie, ha il vantaggio di integrarsi profondamente con le infrastrutture IT aziendali esistenti, supportando il principio delle architetture componibili.
Segnaliamo a tal riguardo il fatto che offre un’integrazione nativa con SAP, con connettori che rendono semplice l’accesso ai dati e ai processi di business già presenti nell’ecosistema aziendale.
La tecnologia low-code, con tutti i suoi vantaggi in termini di velocità e flessibilità, rappresenta comunque un foglio bianco: la sua efficacia dipende interamente da come viene utilizzata. Per sviluppare applicazioni che raggiungano effettivamente gli obiettivi desiderati, è essenziale adottare un approccio ben strutturato.
Questo richiede non solo competenze tecniche, ma anche una visione strategica che sappia applicare le best-practices nella gestione del ciclo di vita dei sistemi e del software. Una prospettiva limitata al solo software potrebbe non cogliere l’intera gamma di impatti che un cambiamento o una decisione potrebbe avere sull’intero ecosistema, inteso come insieme di hardware, software, persone e organizzazioni.
A tal proposito ci vengono in aiuto gli standard ISO/IEC 15288 e ISO/IEC 12207 che offrono un framework integrato per rispondere a queste esigenze: la ISO/IEC 15288 si concentra sul ciclo di vita dei sistemi, suddividendo i processi in cinque categorie principali (Agreement Processes, Enterprise Processes, Project Processes, Technical Processes e Special Processes), mentre la ISO/IEC 12207 approfondisce il ciclo di vita del software come elemento fondamentale di questi sistemi.
Entrambi gli standard evidenziano l’importanza di analizzare e gestire i requisiti non solo in relazione all’applicazione specifica, ma anche al contesto più ampio in cui il sistema o il software saranno integrati.
Nella ISO/IEC 15288, questa prospettiva emerge chiaramente nei Technical Processes, dove due processi fondamentali guidano la raccolta e l’analisi dei requisiti:
La ISO/IEC 12207 approfondisce ulteriormente questo approccio, derivando i requisiti software dai requisiti di sistema e dagli stakeholder. Questi requisiti vengono classificati in due categorie principali:
La raccolta iniziale dei requisiti dell’applicativo costituisce una baseline che funge da guida per l’intero sviluppo. Quanto più accurata è l’analisi e quanto più integrata è nel contesto del sistema, tanto più sarà possibile evitare incomprensioni, flussi non ottimali, ritardi e variazioni che potrebbero compromettere il progetto.
Un ulteriore elemento centrale negli standard ISO è la tracciabilità bidirezionale dei requisiti. Ogni requisito deve essere collegato al componente software che lo implementa e verificabile tramite test specifici, assicurando che le funzionalità sviluppate siano coerenti con le esigenze definite e che eventuali modifiche siano gestite in modo controllato.
Noi di WEGG, quando affianchiamo i nostri clienti nella realizzazione di soluzioni digitali, adottiamo un approccio rigoroso basato sugli standard ISO citati prima, assicurandoci di redigere una baseline di requisiti chiara e completa. Questa baseline è il faro dell’intero progetto perché definisce in modo preciso obiettivi e deliverable e assicura che siano conseguiti correttamente.
Grazie a questo approccio, la tecnologia low-code, da semplice foglio bianco, si trasforma in una soluzione che riflette fedelmente il disegno strategico immaginato dall’organizzazione.
Approfondimenti
I NOSTRI UFFICI
I NOSTRI UFFICI
PADOVA
Via Arnaldo Fusinato 42, 35137
MILANO
Viale Enrico Forlanini 23, 20134
ROMA
Viale Giorgio Ribotta 11, 00144
Copyright © 2022 WEGG S.r.l. • P.I 03447430285 • C.F. 02371140233 • REA 311023
Azienda certificata ISO 9001:2015