Il feature creep, o creeping featurism o ancora featuritis, è l'eccessiva ed incontrollata aggiunta di funzionalità in un prodotto[1], soprattutto nell'ambito dei software e dell'elettronica di consumo. Le funzionalità aggiunte non sono quelle basilari del prodotto e non sono necessarie. Ciò può portare anche al software bloat e all'eccessiva complicazione del prodotto, cioè l'opposto dell'approccio Keep It Simple, Stupid, che mira a mantenere semplice i progetti.
La causa più comune di un feature creep è il desiderio di fornire ai clienti un prodotto più utile o desiderabile, aumentando le vendite. Quando il prodotto è pronto per svolgere la funzione per cui è stato progettato, si può scegliere di aggiungere funzionalità non necessarie, causando riduzione dell'efficienza oppure mancanza di aggiornamenti alle versioni successive, costringendo gli utenti a rimanere fermi ad una vecchia versione.
Un'altra importante causa del feature creep è la presenza di un gruppo di progettisti che non riesce a trovare un accordo su quali debbano essere i casi di utilizzo e le funzionalità base del prodotto, volendo così aggiungerli tutti. Più funzionalità sono aggiunte, più sarà necessario far sì che si interfaccino tra loro, complicando l'assetto generale del software.
Ci sono differenti modi di limitare il feature creep, tra cui limitare le funzionalità del prodotto che si deve creare ed eliminare le funzioni in eccesso.
La tentazione di aggiungere sempre più funzionalità può essere evitata, fino ad un certo punto, con una solida progettazione. Può essere anche controllata attivamente con un rigoroso change management e rimandando i cambiamenti più importanti ad una successiva fase di sviluppo del progetto.[2]
Il feature creep causa costi aggiuntivi e ritardi nella roadmap.[3] Mette in pericolo e fa cancellare prodotti e progetti.
Ogni tanto, il feature creep incontrollato può portare i prodotti lontano dai casi d'uso per i quali erano stati progettati. Questo fenomeno si può chiamare anche scope creep.
Spesso, un progetto ragionevolmente completo di funzionalità oppure uno con un feature creep moderato può sopravvivere, ma la distribuzione delle versioni successive subirà sempre gravi ritardi quando si prenderà la decisione di riscrivere l'intero codice per utilizzare nuove tecnologie.
Per esempio, Windows Vista doveva essere una release minore tra Windows XP e Windows 7, nome in codice Blackcomb, ma dopo che Microsoft aggiunse sempre più funzionalità previste per Blackcomb (molte furono anche cancellate), Vista divenne una release maggiore e richiese cinque anni di sviluppo.
Un simile destino ha avuto Netscape 6, inizialmente pianificato come Netscape 5. La decisione del 1998 di Netscape Communications di rendere open-source Netscape Navigator fece notare che il codice di base fosse troppo difficile e ne richiese una completa riscrittura. Ciò portò a ritardi significativi, Netscape 5 venne saltato e l'intera società venne comprata da AOL. La release che ne venne fuori nel 2000 fu molto criticata per il suo essere simile ad un'alpha ed infatti raggiunse la stabilità solo nel 2001 con Netscape 6.1, ben tre anni dopo la decisione di riscrivere il browser e l'internet suite ad esso collegata. In quel lasso di tempo Internet Explorer aveva avuto la possibilità di superare enormemente Netscape come percentuale di utilizzo.
Anche dopo aver raggiunto la piena stabilità ed aver acquisito nuove funzionalità, il nuovo Mozilla Application Suite, sul quale AOL costruì Netscape, fu visto come software bloat.
Appena un anno dopo, un gruppo di sviluppatori Mozilla decise di scindere la componente browser in Firefox.
Il videogioco Broken Age è un altro esempio di progetto rallentato dal feature creep. Originariamente previsto per ottobre 2012, la prima metà del gioco è stata distribuita nel gennaio 2014 e la seconda parte l'ha seguita nell'aprile 2015. Il gioco ha quindi richiesto complessivamente due diversi round di finanziamento per essere completato.[4]
Il feature creep unito a delle scadenze ristrette porta spesso ad una soluzione alla buona.
I cambiamenti che devono essere fatti potrebbero essere così grandi da necessitare una riprogettazione dalle fondamenta del progetto, ma la scadenza che si avvicina porta gli sviluppatori a dover far funzionare il tutto in breve tempo. Il gioco di parole inglese "feeping creaturism" è stato creato per enfatizzare l'avversione di uno sviluppatore contro la situazione[5], il prodotto eccessivamente complicato diventa una "creatura malforme di soluzioni improvvisate... che si aggira nell'oscurità"[6][7] ("Feeping" è un sinonimo gergale della parola inglese "beeping".)[8]