Agile@School 2022 – Final Boss!

di Pier-Paolo Mammi.

I ragazzi dell’Agile@School giungono finalmente allo scontro finale con l’ultimo boss del gioco: la temibile presentazione! Avranno acquisito sufficiente esperienza per uscire indenni o quasi dalla sfida? Scopriamolo insieme.

La sfida

L’obiettivo finale del corso si basava su due cose:

  • una presentazione del progetto che ne descrivesse la realizzazione e i punti di forza per un ipotetico investitore
  • il videogioco vero e proprio, eseguibile e testabile da noi

Il tutto seguendo il più possibile la filosofia DevOps illustrata negli incontri fatti a scuola e utilizzando gli strumenti aziendali di uso comune, quali Azure DevOps e Git.

Ready? Fight!

Anche quest’anno, sia per avere un’opinione “esterna” rispetto a noi che abbiamo seguito i ragazzi, sia per portare prova tangibile della bontà del formato, ci ha accompagnato Alex che ha partecipato qualche anno fa all’Agile@School e che da un paio di anni lavora brillantemente in azienda con noi! Riporteremo le sue osservazioni per avere un altro punto di vista più oggettivo.

Tutti Unity – Ein

I ragazzi del team Tutti Unity hanno realizzato un solo livello del gioco, in cui Ein, il protagonista (che, ricordiamo, è l’ultimo dei cloni di Hitler creati a seguito di un esperimento e scampato al loro sterminio) deve fuggire dal laboratorio in cui si risveglia privo della memoria. Plot twist inaspettato, Ein è in realtà una ragazza! 😀

Il gioco è stato sviluppato pregevolmente con grafica in pixel-art e tutti gli aspetti grafici sono stati realizzato da zero. Non c’è stato molto tempo di introdurre interattività con l’ambiente o con altri personaggi, ma nel complesso è risultato molto apprezzabile e interessante.

Anche la presentazione è stata fatta con cura e ha illustrato i possibili sviluppi futuri del gioco, ipotizzando un rilascio a episodi.

Alex: trama veramente interessante e particolare, grafica top (apprezzabile lo stile retrò), meccaniche un po’ trascurate con risultato di un gioco che finisce subito senza fare particolari azioni.

AppeninTech – The IRA Tale

Il gioco segue le vicende di un giornalista ai tempi dell’IRA: l’impostazione è quella più classica di un libro-game, ma arricchita di alcune funzionalità che lo rendono più dinamico, come un “allineamento” fra governo e terroristi che incide sulle probabilità di sopravvivenza del protagonista e un sistema di avvenimenti casuali.

Questo progetto è risultato il più “tecnico” in quanto il codice realizzato si presta particolarmente ad essere convertito in una sorta di framework riutilizzabile.

Da evidenziare la presentazione, in quanto aveva una forte impronta volta al marketing: abbiamo poi scoperto che il ragazzo che ha contribuito alla realizzazione ha aspirazioni di social media marketing!

Alex: presentazione professionale che punta ad eventuali investitori, mostrando una roadmap dettagliata sul progetto. Molto strutturato a livello di storyline, meccaniche semplici, ma efficaci per la storia che seguono. Questo è un classico esempio dove si ha una parte backend molto elaborata a scapito della parte frontend, che risulta quindi un po’ spoglia.

Anonymous – Skyrish Adventure

Il gruppo degli Anonymous, a dispetto di aver meno competenze tecniche rispetto agli altri, è riuscito a realizzare un gioco che forse è il più in linea con la richiesta iniziale di creare un libro-game. Nonostante l’impostazione più “grafica” (invece di pagine testuali, hanno utilizzato pagine web graficamente ricche), il risultato è stato un divertente viaggio fantasy tra omaggi più o meno velati ai vari videogame del genere.

È evidente quanto i ragazzi si siano divertiti nella creazione del gioco, questa è sicuramente una componente importante nella buona riuscita di un progetto!

Alex: trama interessante (cavaliere che deve sconfiggere un boss finale), carente un po’ di animazioni dovuto a qualche intoppo, ma in generale storia corposa e ben strutturata.

What-A-Kingdom

Questo è probabilmente il progetto che ha puntato più in alto di tutti in quanto i ragazzi hanno voluto realizzare il gioco (non più un libro-game, ma un vero e proprio gestionale di un regno) utilizzando il motore Unreal Engine 5, nonostante fossero molto più ferrati con Unity. I WAK sono forse il gruppo che ha maggiormente provato sulla pelle gli effetti di una scelta tecnologica coraggiosa, in quanto non solo hanno dovuto imparare un framework per loro nuovo, ma hanno anche utilizzato una versione cutting-edge, uscita dalla beta proprio mentre creavano il gioco, e quindi più soggetta a instabilità. Come conseguenza, il gioco è sicuramente risaltato fra gli altri dal punto di vista grafico, ma i ragazzi hanno dovuto tagliare gran parte dei personaggi inizialmente pianificati per poter rispettare le scadenze.

Alex: progetto ambizioso dal punto di vista delle tecnologie utilizzate (unreal engine 5). Presentazione efficace e risultato grafico degno di nota.

Conclusioni

La nostra prima considerazione emersa dopo aver visto i progetti presentati dai ragazzi è che ogni anno il livello tecnico si alza un po’ di più. Anche nelle edizioni passate ne abbiamo viste delle belle, ma quest’anno siamo rimasti particolarmente soddisfatti sia delle presentazioni che dei giochi.

Tutti i progetti erano testabili e funzionanti, nonché divertenti da giocare. Chiaramente ci sono degli spigoli da smussare, dovuti a mio avviso più che altro all’entusiasmo e alla troppa voglia di fare dei ragazzi, che in alcuni casi li ha portati a sottostimare l’entità di quello che avrebbero voluto introdurre, ma sono errori (mai come in questo caso) di gioventù!

Penso che l’obiettivo dell’Agile@School sia stato raggiunto pienamente. La realizzazione del progetto è un mezzo per dimostrare ai ragazzi cosa voglia dire lavorare in azienda, e ancora di più farlo utilizzando metodologie agili unite alla filosofia DevOps, ma soprattutto per far sperimentare loro le difficoltà tipiche che ci si trova ad affrontare, spesso in modo inaspettato, sul mondo del lavoro.

In definitiva, complimenti davvero a tutta la classe!

Agile@School 2022 – Episodio 2

Articolo di Pier-Paolo Mammi, il docente che da anni segue le lezioni con i ragazzi.

Finiva due settimane fa il secondo sprint del progetto che coinvolge la classe 4a dell’IISS Gadda. Mi ritrovo a scrivere il post con colpevole ritardo, anche se in realtà un (buon) motivo c’è e ne parlerò in seguito.

I progressi

Vediamo innanzitutto i progressi dei ragazzi. Premettiamo subito che per alcuni team all’inizio dello sprint è ancora risultato difficile entrare nell’ottica di integrare le fasi dello sviluppo con il tracciamento delle proprie attività su Azure DevOps. Insistendo però sui concetti e grazie al supporto del professore siamo riusciti a recuperare la situazione e alla fine tutte le board erano correttamente popolate.

Contemporaneamente, in queste tre settimane abbiamo affrontato svariati argomenti che, pur non influendo direttamente sul mero sviluppo, dovrebbero comunque essere apprese per poter essere efficaci in un contesto aziendale.

Dato che i ragazzi avevano già utilizzato le funzioni basilari di Git, ci siamo quindi concentrati sugli aspetti più avanzati, come il branching e i “flow“, evidenziando in particolar modo come (e perché) noi stessi lo utilizziamo in azienda.

Un altro argomento “scottante” è stato quello dello unit testing, che abbiamo dovuto approfondire in una giornata aggiuntiva, anche qui portando esempi concreti.

Le domande

Al di là di tutto questo, devo ammettere di essere rimasto molto colpito dalla curiosità dei ragazzi nei confronti della “vita da ufficio”. Alcuni di loro hanno infatti posto domande che non mi sarei aspettato, per esempio: “cosa succede se non riesco a rispettare le scadenze del progetto?” oppure: “se sono rimasto indietro con gli sviluppi, è permesso portarsi a casa il lavoro per continuarlo?”, o ancora: “come faccio a capire a chi devo scrivere, se ho bisogno di chiedere qualcosa su quello che sto facendo?”. Le prime domande scaturiscono evidentemente dall’ambiente scolastico, che prevede scadenze ben definite (beh, dovrebbe essere così anche sul lavoro 😅) e che “non ha orari” visto che i ragazzi devono studiare in continuazione! Ma l’ultima di queste domande ha attirato la mia attenzione, perché il problema è reale e si presenta in molti ambienti lavorativi. Questa è stata una buona occasione per parlare nuovamente di come affrontiamo concretamente certe questioni applicando la filosofia DevOps.

Il cerchio che si chiude

Nel terzo e ultimo sprint abbiamo deciso di saltare un paio di lezioni per lasciare un po’ di respiro ai ragazzi: in queste settimane saranno infatti messi a dura prova perché non solo avranno diversi esami e dovranno studiare parecchio, ma soprattutto li aspetta anche il periodo di alternanza scuola-lavoro in cui potranno mettere a frutto quanto imparato finora.

E qui arriva il motivo del ritardo nel post: due dei ragazzi della classe verranno infatti a svolgere l’alternanza proprio nella nostra azienda! Volevo quindi verificare come si sarebbero integrati da noi e devo dire che finora si sono comportati molto bene, anche se per ora ammettono di preferire andare a scuola invece che in ufficio 😄

Chiudiamo con un’altra bella notizia dell’ultimo minuto: la scorsa settimana abbiamo assunto ufficialmente una ragazza della classe che aveva partecipato all’Agile@School 2020, che nel frattempo si è diplomata. Una bella soddisfazione per tutti e un’ulteriore conferma della bontà del format!

Ci risentiamo presto per il post di chiusura del progetto, dopo la giornata finale in cui i ragazzi ci presenteranno i propri risultati.

Agile@School 2022 – Episodio 1

Testo di Pier-Paolo.

Benvenuti al settimo appuntamento col nostro amato progetto Agile@School, questa volta con una grossa “novità”: le lezioni in presenza! 😁 Ebbene sì, nonostante ricadute e limitazioni, quest’anno ci è stata data la facoltà di effettuare le nostre lezioni di persona. Nonostante la precedente esperienza in full remote sia stata positiva e avessimo possibilità di scegliere in che modo condurre l’attuale, abbiamo deciso di essere presenti in aula su consiglio del professor Memoli, che ci seguirà nel progetto. E in retrospettiva devo dire che abbiamo fatto proprio bene, ma di questo parleremo in seguito.

Il progetto

Visto il successo dell’anno scorso, abbiamo voluto riproporre il progetto di un videogioco che riproduca la logica di un libro-game, quindi una storia con un protagonista che, a seconda delle azioni eseguite dal giocatore, “vivrà” diverse esperienze fino ad arrivare (si spera) ad un lieto fine. Di nuovo, abbiamo proposto alcune linee guida, come avere una “barra di salute” del personaggio, per dare un po’ di confini alla fantasia sfrenata dei team. Tuttavia, non è servito a molto, poiché i giochi proposti presentano molte particolarità degne di titoli di grosso calibro!

I ragazzi non dovranno però soltanto creare un videogioco, ma, come fosse un “vero” progetto aziendale, dovranno utilizzare gli stessi strumenti che noi stessi adoperiamo sul lavoro, come Microsoft Azure DevOps e Git. Dovranno creare la documentazione tecnica e funzionale del progetto e anche una presentazione in stile marketing, come se dovessero proporre il progetto ad un vero e proprio cliente. Ah, naturalmente il gioco dovrà essere funzionante!

Ma bando alle ciance e presentiamo i team e i rispettivi progetti.

I team e i loro giochi

Una premessa é d’obbligo: abbiamo chiesto ai team di individuare al loro interno alcune figure ritrovabili anche in un tipico contesto aziendale:

  • un tech lead, che seguirà l’andamento dello sviluppo dal punto di vista tecnico
  • un coordinatore, che gestirà il team e le attività
  • un creativo, che si occuperà della presentazione e della parte artistica
  • ovviamente, gli sviluppatori!

Anonymous: la storia ideata dal team è ambientata in Irlanda, in un’epoca medioevale. Il giocatore dovrà impersonare un cavaliere la cui missione è salvare la principessa: lungo la strada il protagonista incontrerà molti personaggi che gli saranno di aiuto o di ostacolo, e potrà trovare ed equipaggiare una serie di oggetti più o meno magici per facilitare la sua missione. Il gioco verrà creato sotto forma di applicazione web e grafica in pixel art a partire da disegni a mano.

AppenninTech: torniamo in Irlanda, ma stavolta il gioco segue le vicissitudini di un giornalista irlandese ai tempi dell’IRA. Il protagonista dovrà infiltrarsi nel loro gruppo per scrivere l’articolo che gli frutterà il Nobel, ma dovrà stare attento a non farsi scoprire e a gestire le sue risorse per sopravvivere nella vita di tutti i giorni. La trama sarà inoltre costellata di eventi generati casualmente che potranno volgere a favore (oppure no!) del giocatore. Il videogioco utilizzerà Unity per la parte grafica e audio.

Tutti Unity: il gioco presenta un’ambientazione distopica e interessante. La Germania nazista crea dieci cloni di Hitler per vincere la guerra ma, dopo la loro disfatta, decide di eliminarli tutti: ne sopravvivrà uno solo (di nome Ein, “uno” in tedesco) che dovrà cercare di sfuggire ai suoi inseguitori e, contemporaneamente, decidere se seguire l’esempio del dittatore o se dare ascolto al suo lato buono. Interessante la funzionalità dell’allineamento morale vista in giochi tripla-A. Bellissimi anche i personaggi in pixel art!

What-A-Kingdom: l’idea del libro-game qui si è evoluta molto in fretta, diventando nella pratica un vero e proprio gestionale in cui il giocatore, impersonando il re di un regno medioevale, dovrà prendere decisioni in merito ad alleanze, risorse e conflitti, per assicurare ai suoi sudditi sicurezza e prosperità. Da evidenziare la cura nella caratterizzazione e nell’alberatura delle scelte dei molti personaggi che troveremo nel gioco. La grafica sarà realizzata interamente con l’ultima versione di Unreal Engine.

L’organizzazione

Come dicevamo in precedenza, abbiamo voluto dare un’impronta “aziendale” al progetto, il cui delivery plan è stato suddiviso in tre sprint. Abbiamo chiesto ai ragazzi di portare avanti il lavoro proprio come se stessero lavorando in un’azienda in cui si portano avanti i paradigmi di Agile Development e DevOps. Rispetto ad altre volte il nostro compito è stato facilitato, in quanto il professore aveva già improntato le attività dei ragazzi secondo la metodologia Scrum e aveva già insegnato loro l’utilizzo di Git per il versionamento del codice. Nel primo sprint abbiamo quindi potuto soprassedere sulle basi e andare dritto al sodo, mostrando alla classe quali sono le parti più “insidiose” del lavoro (che per noi è pane di tutti i giorni), come la suddivisione delle attività in features, il concetto di deliverable e l’organizzazione del lavoro di gruppo.

Fine dello Sprint 1

Il primo sprint si è concluso in maniera soddisfacente e tutti i gruppi hanno consegnato qualcosa di tangibile. Alcuni hanno lasciato più indietro la parte tecnica favorendo invece la presentazione del gioco e la parte grafica e di contenuti. Altri sono invece riusciti a mostrare parti funzionanti del software, come i menu di gioco e le funzioni di caricamento e salvataggio partita o i controlli del personaggio.

In generale, sono rimasto molto colpito dai team: non mi aspettavo una tale capacità di organizzarsi a livello di squadra e di attività, vista la relativa inesperienza nell’utilizzo degli strumenti aziendali, e una tale intraprendenza (e fantasia) nel presentare e portare avanti i loro progetti. Alla seconda lezione uno dei gruppi ha addirittura realizzato un piccolo slideshow con tanto di infografica in cui si presentava il progetto, le sue particolarità e la composizione del team, davvero di buon livello!

Chiaramente questa potrebbe essere un’arma a doppio taglio, perché ora ci aspettiamo davvero tanto dai ragazzi nei prossimi sprint!

Restate in linea per sapere come proseguirà il progetto.

Passo dopo passo, quanto si impara

Sono passati tre mesi dall’inizio della crescita aziendale “di massa”, se così vogliamo chiamarla. Quante cose sono cambiate, e quante ancora subiranno variazioni. Avevo una paura folle, mentre ora vedo che é sempre più possibile riuscire nell’intento di crescere in maniera sana, controllata e, soprattutto, mantenendo una certa qualità su quanto é fondamentale per noi: le persone, il rapporto vita/lavoro, la qualità del lavoro, il rispetto reciproco, il team.

Definitele una serie di frasi fatte o stereotipi utili a descrivere “quanto siamo bravi”, ma vi assicuro che non é così. E non lo è per vari motivi:
– siamo una grande azienda? No, per niente, ed eravamo piccini come la maggior parte delle aziende italiane
– siamo leader di mercato? Affatto! Anzi, stiamo lottando per cercare di posizionarci
– abbiamo solo i migliori talenti? Suvvia, e cosa vorrebbe dire? No, abbiamo persone proattive, curiose, che hanno continui conflitti per crescere, anche nei miei confronti (per fortuna).

vogliamo che le persone parlino tra loro, che crescano insieme e che coltivino l’interesse per topic anche non necessariamente in uso o orientati al business

Siamo un’azienda come le altre ma, forse, una differenza c’è. L’investimento enorme (e lo sottolineo) nella selezione del personale, nella crescita professionale di ogni persona, nell’ascolto delle proposte e nell’incitamento all’aiuto, se così vogliamo definirlo “bottom-up”. Vi faccio però una serie di esempi pragmatici per dirvi cosa intendo, perché altrimenti sembra tutto “campato in aria”.

Scalabilità

Dopo la crescita cospicua, serve scalare. Avremo a breve team verticali, purtroppo un po’ isolati tra loro. Ebbene, la nostra prima preoccupazione é stata quella di creare incontri trasversali (workshop, sessioni, ecc.) al fine di non far perdere i contatti tra le persone. Ma non solo, i contenuti erogati saranno proposti da chiunque, su qualunque argomento, da “come fare le presentazioni” a “cos’è React”. L’obbiettivo poi sarà quello di incentivare tutti a parlare e, perché no, a premiare le proposte con un programma di premi interni come corsi, libri, ecc.

Credo che il messaggio sia forte: vogliamo che le persone parlino tra loro, che crescano insieme e che coltivino l’interesse per topic anche non necessariamente in uso o orientati al business, purché possano essere di interesse e spunto di chiacchierate comuni. Ore perse? Non direi. Sono di qualità inestimabile.

Escalation engineers

Dal momento in cui ogni problema cliente, via ticket, arrivava fino a poco tempo fa agli sviluppatori, già impegnati in altri progetti, é nato un team dedicato alla risoluzione di tali problematiche. Il team ha la possibilità di fare proposte quando la problematica é ricorrente, sul backlog di progetto, per poter evitare spreco di tempo, andando anche a definire come essa potrebbe apparire, ad esempio, su un client. Per noi gli item di “proposal” stanno diventando sempre più importanti, perché chi é in prima linea sa bene come il cliente usa il prodotto e sa quello che serve. Ma non solo, gli escalation engineers sono la rampa di lancio per i nuovi arrivi, che grazie a ruoli di triage, primo intervento e testing (sì, fanno anche QA, la parte manuale) conoscono sempre di più quanto facciamo in azienda. E l’onboarding diventa sempre più completo. Anche questo dimostra quanto la persona sia centrale, perché non é semplicemente buttato nella mischia, ma é accompagnato in un processo di crescita, tra l’altro seguito da senior, con l’obbiettivo di capire come proseguire il suo cammino professionale in azienda.

A ognuno ciò che più piace

Di recente abbiamo assunto un ragazzo come backend developer. É alle prime armi tutt’ora, ma, chiacchierando in uno dei miei ricorrenti 1 to 1, é emersa la sua voglia di guardare il frontend. Inutile dire che a breve intraprenderà la strada della formazione e onboarding per la parte client web. Certo, lo possiamo fare perché abbiamo le persone, non posso nascondere questo grande vantaggio, però anche chi è appena arrivato è stato ascoltato. L’azienda aveva le possibilità di ragionarci, ed eccoci qui, a far fare ad una persona quello che davvero, sotto sotto, preferisce. É un win-win, non c’è dubbio.

Annosi problemi ed esercitazioni

Proprio qualche giorno fa abbiamo avuto un serio problema: un nostro collega, al primo turno di reperibilità nel fine settimana, si è trovato malissimo con strumenti e documentazione. Inoltre, durante la gestione dell’urgenza, non è stato allineato a dovere, il che lo ha fatto sentire impotente e completamente a bocca asciutta per il futuro. Questo, per noi, è un enorme ostacolo. Il lunedì successivo si è parlato immediatamente di come mitigare e poi risolvere questo tipo di problemi, grazie soprattutto alla proattività di Roberto che, dall’alto della sua esperienza e umiltà, ha dato una serie di feedback tra i più importanti degli ultimi anni. La nostra reazione è stata quella di creare una card ad alta priorità (massima, per la verità) sulla quale abbiamo già descritto le possibili soluzioni, una delle quali è quella di effettuare ripetute esercitazioni per ridurre la frizione che le problematiche potrebbero dare a chi dovrà affrontare il supporto tecnico nel weekend. Ancora una volta, orientati a migliorare il futuro di tutti, non solo in ottica di qualità e di risposta pronta al cliente.

Conclusioni

Ripeto, siamo grandi? Siamo i migliori? Siamo alla ricerca solo di talenti? Siamo speciali? No. Siamo però persone che si impegnano a migliorare il lavoro di tutti i giorni e le condizioni di ognuno di noi. Da lì poi, tutto é in discesa.

Abbiamo problemi? Eccome! E ancora sono enormi, non vi faccio gli esempi o “facciamo notte”,  ma se l’atteggiamento é quello descritto sopra, credo che la maggior parte possano essere risolti con buona probabilità. Vedremo cosa ci riserverà il futuro, per ora proseguiamo così.

Questi ultimi tre mesi sono stati molto costruttivi per l’azienda, per noi tutti e per me, grazie anche al lavoro sinergico che sto seguendo con Michele. Stiamo raddrizzando molte cose e il suo lavoro è preziosissimo.

La nostra battaglia più dura

Sono passati mesi dall’inizio della missione ristrutturazione aziendale e ormai si vede bene la fine dell’anno. Negli ultimi tempi abbiamo affrontato una crescita aziendale non indifferente, non solo dal punto di vista delle persone, ma anche dei ruoli, dei dipartimenti e della cultura necessaria alla crescita stessa.

Nonostante la considerazione non possa essere definitiva, visto che continueremo a crescere ancora anche per tutto il 2022, posso già affermare che questa quest (glossario da gamer) è stata, e probabilmente sarà, una delle più complesse affrontate nella mia vita professionale. C’è tutto dentro: organizzazione, approccio filosofico/culturale/etico/economico, analisi dei dati, misurazione delle metriche di team, tecnologia, e via discorrendo. Ma alla base, sempre e solo una cosa, le persone.

Mi ricordo con nostalgia quando il mio lavoro era pensare “chissà se i miei test sulle performance rispetteranno i risultati che mi aspetto in produzione” o “come posso scalare con il tal SQL server” o ancora “voglio sistemare quella stored procedure per ridurre il tempo di risposta”. Era comunque molto impegnativo, vero, e senza studio e ricerca costante gli obbiettivi non si raggiungevano. Però era piuttosto deterministico. Diciamo che con un relazionale in certi casi hai quel dipende che i fan delle regole scolpite non digeriscono, ma era ancora macchina, software e tecnologia in generale. Oggi il mio lavoro è cambiato, un po’ per necessità, ma anche, in parte, per piacere e per sfruttare meglio la mia forma mentis, tutto sommato orientata all’organizzazione e all’ottimizzazione.

Scrivo questo post per condividere alcune riflessioni su quanto sia importante muoversi bene in contesti di migrazione come quello che stiamo vivendo, contesti in cui anche l’influsso di cambiamenti radicali a livello sociale (vedi pandemia) ci pone di fronte a scenari del tutto nuovi, con sfide non previste e difficoltà mai avute.

In passato molti di noi bramavano la possibilità di lavorare in remoto, di avere trattamento e approccio smart, di essere più indipendenti da tempo per ragionare ad obbiettivi. Oggi, alcune di queste condizioni sono fisiologicamente diventate uno standard, per la maggior parte accettate come nuovo modello. Altre hanno toccato l’esagerazione, come il non vedersi più di persona nemmeno quando possibile/importante, il numero delle call conference, il fatto di avere tutto e subito, sempre online. E ora, il metaverso (concetto che io ricordo dagli anni 90 da un romanzo intitolato Snow Crash) e tutte le innovazioni che, come la storia ci insegna, vengono idolatrate e demonizzate da chi, rispettivamente, vede solo vantaggi o tragedie apocalittiche. Oggi, comunque, abbiamo la gara a quello che va di moda e i social sono la monoposto con cui parteciparvi.

Ma crescere e cambiare vanno ben oltre questo. Quando abbiamo dovuto agire per predisporre un nostro percorso, non dormivo la notte, per paura (che ho tutt’ora) di una implosione aziendale e/o di non essere all’altezza. Il primo problema è stato avere una deadline stretta, che ci ha dato un ritmo atipico per fare selezione del personale. Per fortuna, la possibilità di lavorare da remoto con pochi requisiti di presenza ci ha dato il quid per venirne fuori egregiamente, visto che il resto è già people-first fin da quando abbiamo avviato l’attività. Le persone aggiunte seguono tutte i nostri principi, e non potremmo scegliere diversamente, pena “non remare tutti nella stessa direzione”.

Ma il vero problema, che é quello per cui ho fatto più fatica e che tuttora mi tiene sotto battuta, è stata la scalabilità dei nostri processi in essere. Ah, come funzionavano bene quindici persone fa! Da qualche tempo, invece, ogni cosa aveva iniziato a rallentare, si avevano stalli continui, la consapevolezza trasversale calava sempre di più e le prime reazioni precipitose rischiavano di portare a figure gatekeeper. Forse è naturale arrivare a ciò nella mente di tutti noi, a prima vista. Ma per chi crede nei principi della cultura DevOps e osserva più a lungo la situazione, questa non può essere la soluzione.

Ed è qui che abbiamo deciso di cambiare seriamente. Nessuna reorg, nessuna variazione all’organigramma. La gerarchia è rimasta piuttosto piatta, e non ci siamo fatti sopraffare dalla voglia di adattare il software sulla base della struttura aziendale (Team Topologies e la legge di Conway). Al contrario, abbiamo aggredito i problemi uno ad uno, cambiando a volte il processo, altre volte le abitudini. Abbiamo incluso persone nuove, con tanta esperienza sia con lo strumento (Azure DevOps) sia con le migrazioni culturali in realtà ben più grandi della nostra, abbiamo destabilizzato, di certo, ma stiamo già percependo i risultati. Per non dimenticare che l’appoggio del mio socio Michael Denny è stato indispensabile. I principi condivisi dall’azienda partono, in fondo, da noi due.

È importante avere una cultura aziendale condivisa in termini DevOps, ancor prima di pensare a qualunque strumento o prodotto. E non basta il coraggio, non serve il controllo gerarchico, ma un vero team di persone affiatate e pronte all’adattamento

La prossima retrospettiva verrò certamente rimproverato per l’impeto e la spinta rivoluzionaria, insieme a chi ha fatto sì che questo accadesse (il collega e amico Michele Ferracin, che mi ha consigliato anche il libro di cui sopra). Non potrò dare torto a chi lo farà; i cambiamenti fatti, forse, potevano essere affrontati con meno foga. Il fatto è che il processo antecedente alle modifiche non sarebbe più stato sostenibile e il rischio sarebbe stato quello di incappare in scelte da punto di non ritorno. Ho trattenuto il fiato e, credetemi, rispetto al quantitativo di variazioni, sono stato praticamente trasparente.

E ora? Beh, abbiamo una kanban board ben fatta, che rispecchia perfettamente un processo semplice, meno stati, meno informazioni inutili, meno dispersione e più consapevolezza trasversale. Certo, dobbiamo pulire gli arretrati, ma il peggio é passato. Siamo anche pronti a ridurre il numero di strumenti, perché essi sono stati semplicemente un supporto per la nostra cultura, sempre molto forte.

Con questo post, in conclusione, volevo sottolineare quanto sia importante avere una cultura aziendale condivisa in termini DevOps, ancor prima di pensare a qualunque strumento o prodotto. Senza questa radicata visione, la nostra azienda non sarebbe mai riuscita a reggere la crescita fino ad ora, né tantomeno a cambiare radicalmente pur mantenendo senza implodere. E non si tratta di hard skill, ma di un duro e prolungato lavoro di persone che remano dalla stessa parte, da oggi ancora più in maniera coerente e sincronizzata. Non basta il coraggio, non serve il controllo gerarchico, ma un vero team di persone affiatate e pronte all’adattamento.

Il piacere dell’attesa (degli eventi)

Sono già passati due anni dall’ultima edizione di DevOpsHeroes e fra poco più di un mese questo sarà vero anche per SQL Saturday. Entrambi gli eventi, così tanto seguiti da tutti voi, da tutti quanti siano affamati di conoscenza e condivisione. Entrambi a Parma, in un periodo in cui la nebbia è un valore aggiunto per il nostro territorio (ogni riferimento alla Food Valley è puramente casuale). Entrambi in presenza, seppure io sia un sostenitore della digitalizzazione e dell’approccio in remoto. Entrambi da record di presenze, ma uno solo nato totalmente da noi di Engage

Edizione del 2016 di entrambi gli eventi

Ci sono tanti fattori per cui questi due appuntamenti sono mancati a molti di noi, autori compresi, ma ci sono pochi motivi per cui abbiamo deciso di saltare le ultime due edizioni. Primo su tutti la necessità, secondo la nostra visione, di parlarsi faccia a faccia e di vivere le emozioni direttamente sul campo, sia lato speaker sia lato pubblico. Nelle sei edizioni di sqlsat e nelle cinque di DOH abbiamo visto prime esperienze da palco, persone venute fino a qui da molto lontano, speaker internazionali e audience insolitamente mista per un evento “offline”. Questo è qualcosa di insostituibile, a fronte di un piccolo sforzo in termini di viaggio al sabato. Il networking che si fa in eventi come questo assume caratteri unici in ogni sua versione in presenza, cosa che, almeno personalmente, non crediamo semplice in una erogazione solo digitale. Calore mancante, insomma.

Gianluca durante la sua sessione con il pienone

In secondo luogo, visto il numero minore di eventi a cui partecipare a causa di una logistica più impegnativa, il peso che assume il momento e la preparazione della sessione. Credo che più la frequenza di un evento è minore, più la qualità dei contenuti è alta. Ma è una nostra opinione.

Infine, ma non per importanza, il premio per il duro lavoro di mesi alla fine dell’evento, cena speaker (fortunelli!) annessa. Mi ricordo la stanchezza della sera e la tensione della mattina prima di entrare al Campus. Momenti stressanti, ma che bello vedere persone trovarsi lì, per qualcosa di organizzato “in casa”.

Speaker a cena

Non é mia intenzione sminuire tutti gli ottimi lavori fatti dalla community per erogare ininterrottamente giornate facilmente raggiungibili da tutti, di qualità e quantità, sia chiaro. Anzi, credo che siano stati più coraggiosi del sottoscritto. Però ho scelto una strada, coerente con ciò che pensiamo qui in azienda, che é quella dell’attesa con ansia di un grande ritorno. E se ancora avremo i risultati di un tempo, vorrà dire che siamo stati bravi. In caso contrario, ci avremo comunque provato.

Fra un anno avremo due nuovi eventi, Data Saturday Parma 22 e DevOpsHeroes 22, speriamo di trovarvi pronti per una grande accoglienza come solo voi sapete dare.

Del resto, il piacere dell’attesa non é l’attesa stessa?
Stay tuned!

Essere smart

Viste le recenti uscite sui social in materia di remote working, sento la necessità di condividere con voi una serie di pensieri e di considerazioni che mi frullano nella testa. Il momento storico è particolarmente delicato, la stretta morsa della pandemia si sta allentando e all’orizzonte vediamo la luce. Ma non solo, l’imminente (e chi lo sa in realtà) e totale apertura delle attività spingerà a fare i conti con una scelta tra un “ritorno al passato” o un vero e proprio “rinnovo”.

Nemmeno una pandemia riesce a farci cambiare per il verso giusto

Si leggono esternazioni su quanto i lavoratori dipendenti non siano produttivi o concentrati da casa e, allo stesso tempo, post in cui per alcuni le aziende siano considerate retrograde perché non capiscono il valore aggiunto della pratica del lavoro remoto. Vediamo anche forti critiche a realtà che hanno visto nella pandemia solo una costrizione a vivere una condizione a cui non erano abituate, accuse sulla loro necessità di avere totale controllo delle persone che operano in loco a discapito della salute delle stesse, considerazioni sugli sprechi che potrebbero essere evitati e via discorrendo. Ovviamente da una parte e dall’altra.

Il tono polemico e accusatorio assunto da ambo le parti non porta a nulla e la prima constatazione che mi balza in mente è che nemmeno una pandemia riesce a farci cambiare per il verso giusto. Vale probabilmente in tutti i contesti, ma soprattutto ora viene da chiedersi “perché non stiamo facendo analisi retrospettive sull’accaduto?”. È come se avessimo trattenuto il fiato fino a risalire in superficie e ritornare a respirare. La pseudo conversione culturale che abbiamo affrontato tutti quanti, volenti o nolenti, non è paragonabile a un soffocamento, anzi! È vero che in molti hanno sofferto, tanti non ce l’hanno fatta a superare il momento e tantissimi probabilmente rischieranno di perdere il lavoro. Purtroppo però non possiamo farci nulla direttamente, quindi, per chi ha avuto la fortuna e la forza di passare indenne questo paio di anni, perché non cogliere l’occasione per migliorarsi, per provare a cambiare, per capire le condizioni di tutti gli attori e per fare critiche sì, ma costruttive?

Ancora una volta si finisce sul concetto di cambiamento, non se ne può fare a meno. E nuovamente conflitti sui punti di vista, non per forza complementari ma di certo in contrasto per quanto riguarda il succo centrale della situazione: lavorare fuori dall’ambiente ufficio.

Un datore dovrebbe ragionare ad obbiettivi, ma siamo sicuri che sia sempre corretto affermarlo e che, tra l’altro, sia possibile in ogni caso applicare questo pattern? Un lavoratore dipendente dovrebbe garantire presenza ad orari fissi, indipendentemente da quello che fa, ma siamo sicuri che non ci sia una soluzione migliore? Chi é in team dovrebbe partecipare con gli altri membri nelle stesse fasce di orario, ma se i fusi orari sono differenti? Ho letto su alcuni post che “una grande azienda può definirsi tale se lascia decidere il miglior posto di lavoro al dipendente”, ma siamo certi che tutti i dipendenti vogliano questo e che, più in generale, sia una sentenza corretta in ogni caso? Non so, non ho di certo la conoscenza in mano, ma a mio modo di vedere frasi così dirette e sicure come si leggono qui e là lasciano il tempo che trovano, e si tramutano in critiche non costruttive simil-motivazionali, per fare un po’ di rumore sulle varie piattaforme. Ognuno é e deve essere libero di esprimere il proprio pensiero, ma allo stesso tempo deve essere pronto a ricevere commenti e, sperabilmente, ad affrontare una discussione.

Detto questo, datori e lavoratori dipendenti ne hanno vissute di cotte e di crude. Chi, come il sottoscritto, ha vissuto da entrambi i lati per anni, può capire quanto sia fondamentale eliminare quel muro che si viene a creare tra le parti. Un po’ come vale per DevOps, abbattere i confini, comunicare e condividere, fluidificare, scegliere insieme per il bene e il benessere di tutto e tutti, imparare di continuo dalle esperienze fatte, sono i mantra su cui ogni vita lavorativa dovrebbe basarsi ogni giorno.

Insomma, é vero che lo stress sta uccidendo chi si deve (talvolta) inutilmente recare sul posto di lavoro, spesso lontano. É altresì importante il fatto che il nostro pianeta risenta anche dell’emissione di polveri sottili derivanti dal trasporto autonomo. E infine, é ovvio che il tempo e le energie sprecati per viaggiare rendono chi lavora terribilmente meno performante. Ma vediamo anche l’altra faccia della medaglia: siamo sicuri che lavorare solamente da casa (o da dove ci sentiamo meglio) anche per stare con la nostra famiglia il più possibile, sia veramente la soluzione? Sicuri che la qualità di quel “vedere la nostra famiglia” sia così alta? Dobbiamo pur sempre lavorare e, almeno mio figlio, non é che abbia potuto godersi il suo papà così tanto. Allo stesso tempo, io ho visto in maniera sfocata la sua crescita, non presente mentalmente. Questo non genera stress? Siamo certi che il consumo elettrico, il riscaldamento invernale e il raffreddamento estivo aumentati nelle nostre abitazioni sia così poco dannoso in termini di emissione? Abbiamo tutti controllato che chi ci eroga energia non lo fa, ad esempio, con combustibile fossile? E in inverno, accendiamo magari stufe a pellet, la cui combustione non é per nulla ecosostenibile! Quelle stufe magari potevano starsene spente. Per chiudere, le performance sono migliori evitando gli sprechi della nostra energia in viaggio nel traffico, potendo magari risposare meglio, vero, ma il side effect del lavorare molte ore in più (perché se non si é disciplinati temo si finisca con il lavorare molto più tempo) é proprio quello di ridurre drasticamente le nostre capacità cognitive e di focalizzazione, fatto estremamente deleterio per chiunque lavori con ragionamento, pensiero e creatività.

L’idea è semplicemente basata sul pattern inspect and adapt, ovvero osservare con cura, capire e, sulla base dell’ispezione, adattarsi alla situazione.

Non dico che vi sia una soluzione definitiva e oggettiva. Non ho il sapere in mano, però mi sono fatto qualche idea negli ultimi tempi sulle persone che fanno parte della nostra realtà e i clienti che ho conosciuto. Come spesso accade, seguire la via ibrida, risulta essere la scelta più efficace ad un costo più che accettabile. Ibridazione ed elasticità sono due caratteristiche a mio avviso fondamentali quando si tratta di rapporto di lavoro e di base per poter parlare di smart (termine più che abusato e utilizzato in maniera errata) ma il tutto dovrebbe essere supportato da un modo di vivere l’azienda consapevole da parte di tutti i membri, dal vertice alla base. E una serie di strumenti collaborativi aiuta ancora di più nella comunicazione dello stile di vita in e con l’azienda. L’idea è semplicemente basata sul pattern inspect and adapt, ovvero osservare con cura, capire e, sulla base dell’ispezione, adattarsi alla situazione. Così facendo si ottiene una personalizzazione elevata sul lavoro delle persone, con un equilibrio tra presenza in ufficio e lavoro remoto, partecipazione in team e fusi orari differenti, il tutto a supporto delle esigenze aziendali e personali e supportato da strumenti collaborativi, come chat (slack, Teams, ecc.), strumenti per videoconferenze (zoom, Teams, meet, ecc.), strumenti di gestione attività e sviluppo (Azure DevOps, Trello, Jira, ecc.) e via discorrendo. In fin dei conti, è importante ascoltare le persone per metterle nelle condizioni di lavorare al meglio, a pro dell’azienda e delle persone stesse. Cosa meglio di una soluzione ibrida può supportare questo?

Concludendo, abbiamo gli strumenti, possiamo affrontare tutto quanto descritto con un cambiamento culturale graduale e non da farsi tutto e subito, dovremmo ridurre sprechi, aumentare il benessere delle persone e quindi anche quello aziendale. Con i dovuti spunti e le osservazioni di ciò che accade nelle nostre realtà, potremmo cogliere finalmente un’occasione per una trasformazione più naturale e meno polemica di come la stiamo vivendo. Avrà dei costi, ma il ritorno dell’investimento credo che sia impagabile.

Agile@School 2021 – La serie completa

Per chi volesse dare una letta alla stagione 2021 di Agile@School qui sotto le puntate. Ogni episodio è dedicato a un personaggio o a un gioco, proprio per la natura del progetto:

Agile@School – Giornata conclusiva

Ultimo appuntamento di Agile@School 2021. Per questa occasione ci racconta l’incontro Alex, una new entry che qualche anno fa prese parte a questa iniziativa proprio come i ragazzi. Siamo finalmente arrivati all’appuntamento che pone sotto i riflettori l’impegno e la dedizione dei ragazzi ovvero i progetti ultimati.

L’idea di fondo proposta era quella di avere una presentazione composta da una panoramica del progetto a 360 gradi partendo quindi dalla descrizione di quest’ultimo per poi procedere con pregi, difetti, punti di forza, difficoltà incontrate e motivi accattivanti per spronare un possibile giocatore ad acquistare il prodotto per poi concludere con la presa visione del progetto e la conseguente prova dello stesso da parte di noi supervisori momentaneamente nei panni di “gamer”.

Presentazione dei progetti

Una volta superata la tensione generale il Team Cromosomi# ha preso l’iniziativa e, anche se non al completo causa assenze, è riuscito a presentare un progetto interessante caratterizzato da un gameplay che assume dinamicità grazie anche al cambio di musica in base alle scelte fatte dal giocatore.
Il gioco è stato presentato su console application e salvo qualche inserimento di dato non previsto non presentava problemi che ostacolassero la giocabilità. Un paio di consigli proposti per migliorare il tutto sono stati l’inserimento di un valore per indicare la vita del giocatore e l’inserimento di immagini che seguono il cambiamento musicale per incrementare il coinvolgimento in game.

A seguire ha preso parola il Team Fisher, team in questo caso al completo.
Presentazione ben organizzata che ha principalmente fatto focus sulle molte tecnologie utilizzate caratterizzata anche da un video realizzato su misura per l’occasione. Ben strutturata anche la storia narrativa che sta dietro al progetto. In questo caso il gioco è stato lanciato direttamente con il proprio eseguibile ed è stato provato dal sottoscritto, che non ha perso tempo per una citazione di alto calibro (infatti ho inserito subito come nome del protagonista della mia partita Rohan Kishibe… ed ho detto tutto). Gameplay con una profonda trama che fa quasi pensare ad un libro-game e che da luogo a una moltitudine di finali raggiungibili variando le scelte del nostro personaggio giocando più volte. Un problema relativo al cambio di musica durante il gioco non ha comunque influito sulla giocabilità in generale.

È stato poi il momento del Team MonkeTeck anche loro al completo.
Idea molto promettente per il progetto di questo team che grazie alla loro presentazione molto ben organizzata hanno centrato l’obbiettivo di dare informazioni che spieghino il processo creativo ma allo stesso tempo attirino il giocatore spiegando il Perché e il Come ponendo anche l’attenzione sul fattore curiosità. Gameplay che si distingue come tema dagli altri avendo come protagonista una nave a scelta che può compiere diverse azioni che possono portare anche alla distruzione della stessa se si azzerano i punti salute. Nota di merito va proprio a quest’ultimo punto, ovvero la vita o salute che finalmente vediamo implementata in uno dei progetti, l’unico fino ad ora. Molto accattivante anche la differenziazione delle statistiche in base alla nave scelta. In questo caso i consigli dati per possibili feature sono stati l’inserimento di immagini o suoni che rendano più coinvolgente la battaglia tra due navi.

Ultimo ma non per importanza è il Team GentsAndLady.py purtroppo in carenza di componenti ma carico abbastanza da sopperire alla mancanza. Presentazione abbastanza esaustiva, anche nel loro caso sarebbe stato ottimo avere una parte dedicata al Perché del gioco ma hanno compensato questa mancanza parlandone direttamente a voce, almeno per far capire a noi l’intenzione che c’era dietro. Anche in questo caso troviamo un gioco in console application preso di mira stavolta da Pier-Paolo, ormai diventato game-tester della giornata che non si è fatto sfuggire l’occasione di mettere qualche dato per far “scoppiare” tutto. Tralasciando piccoli problemi non gestiti nel complesso il gioco segue quanto promesso, quindi la storia di Napoleone in parte romanzata ma che segue un filo logico che permette lo studio giocando più volte.

Fine della corsa

Arrivati a questo punto devo ammettere che siamo stati molto sorpresi e soddisfatti dei ragazzi in quanto nonostante difficoltà, membri mancanti e tester improvvisati rompi scatole sono tutti riusciti a portare a termine un prodotto che, anche se imperfetto, risulta comunque completo.
Anche personalmente sono rimasto particolarmente stupito nel vedere i lavori realizzati dai ragazzi in quanto anche io, giusto qualche anno fa, ero al loro posto e, come loro, avevo realizzato il mio personale progetto con Engage. La differenza che ho notato maggiormente è stata la dedizione riposta in questi lavori. Quando frequentavo la scuola, non c’era questo livello nei progetti ed erano quasi tutti realizzati giusto perché “andavano fatti”. Nel mio caso il gruppo di lavoro era costituito da me :-). La voglia di fare che avevo non era particolarmente condivisa, di conseguenza, seppure non sia stato un progetto rivoluzionario, la mia “chat bella che funzionante tra smartphone e pc” l’avevo portata a termine (soddisfazione alle stelle).
Sono convinto che avvicinandosi sempre di più alle loro passioni si avrà un consenso sempre maggiore a questa iniziativa e una conseguente qualità dei progetti in continuo aumento.

Spero vivamente di poter partecipare nuovamente in futuro proprio per assistere di persona a questa evoluzione e per inserire qua e là qualche citazione di alta classe… Yare yare daze.

Agile@School – Anno sesto, terzo incontro

Arriviamo oggi al terzo appuntamento di Agile@School 2021. Pier-Paolo ci racconta l’attività dal punto di vista della programmazione.

Negli incontri precedenti abbiamo cominciato a tracciare la strada delle attività (come vedremo, non tutte strettamente legate alla programmazione vera e propria) che i ragazzi dovranno svolgere per arrivare al loro obiettivo, cioè rilasciare un videogioco in stile libro-game.

Lungo questo percorso vogliamo insegnare loro non solo gli aspetti “tecnici” di realizzazione di un software, ma anche quello che sta “al contorno” di un progetto di questo genere: parliamo ovviamente dell’approccio Agile – DevOps, quindi tutta una serie di pratiche e cerimonie volte a facilitare la collaborazione, la condivisione delle conoscenze e la gestione dei progetti. È risultato evidente come sia già consolidato l’utilizzo degli stand-up meeting all’inizio di ogni lezione, tant’è che oggi sono stati i ragazzi stessi a proporsi per un veloce aggiornamento sullo stato dei progetti, dal quale sono emersi spunti molto interessanti legati agli aspetti di software selection di cui si era parlato nel post precedente.

Infatti, due dei gruppi che avevano scelto di utilizzare Unreal Engine per la realizzazione del loro progetto si sono resi conto che non avrebbero fatto in tempo a produrre qualcosa di funzionante entro la fine degli sprint: questo non li ha però scoraggiati e, messe da parte le loro preferenze personali, hanno avuto un buon senso di responsabilità nel decidere di intraprendere una strada di sviluppo differente, pur mantenendo intatta la trama principale scelta inizialmente.

Il Team Fisher ha quindi deciso di realizzare il videogioco tramite una web application, fruibile quindi da browser, con l’intenzione di integrare nel gioco dei file multimediali precostruiti. Il Team GentsAndLady-py ha invece deciso di implementare una console application in Java; anche loro hanno dichiarato di voler utilizzare grafica e audio per aumentare il coinvolgimento all’interno del gioco.

In entrambi i casi, tale decisione è stata presa non tanto in base alla difficoltà della creazione del software tramite lo stack tecnologico scelto, quanto alla valutazione delle tempistiche di rilascio del software stesso. Questa a mio avviso è stata una scelta molto oculata, soprattutto se considerata in un contesto aziendale in cui i tempi sono fondamentali forse più che la tecnologia scelta.

Dopo una rapida revisione delle board di ogni team è seguita una parte di suggerimenti e correzioni delle user story inserite dai ragazzi: la scrittura di questi item talvolta non è facile neanche per chi segue le pratiche Agile da molto tempo, per cui era facile aspettarsi qualche sbavatura. Ci aspettiamo che per la prossima lezione le user story vengano migliorate, e soprattutto che vengano utilizzati in maniera più intensiva i task per la suddivisione delle attività.

A questo proposito, una nota positiva viene dal Team Fisher che ha chiesto se fosse corretta la suddivisione delle attività da loro individuate fra più persone in parallelo e l’affiancamento di due persone su una stessa attività di programmazione: non solo questo è corretto, ma è proprio quello che si auspica con l’adozione delle pratiche Agile! E pur non sapendolo (non ne avevamo ancora parlato), ne hanno messo in evidenza uno degli aspetti chiave, cioè il pair programming. Molto bene!

Il resto della lezione è proseguito con l’introduzione del software per il controllo del codice sorgente Git, che però temo non abbia avuto l’impatto sperato. Purtroppo, non siamo stati in grado di effettuare degli esercizi live, un po’ perché non è stato possibile installare il software sulle postazioni usate dai ragazzi, un po’ per problemi logistici (noi e i ragazzi siamo lontani “fisicamente”, chi in classe, chi da casa, e la connessione instabile non permetteva una condivisione dello schermo). Abbiamo comunque chiesto a ciascuna squadra di creare un repository su GitHub, sia per poterlo connettere successivamente ad Azure DevOps e dimostrare come si possano collegare i task alle modifiche del codice, sia per iniziare a caricare i file del proprio progetto.

See the source image

Con questo appuntamento si concludeva in teoria il primo sprint, ma fra cambi di tecnologia e necessità di adattamento all’Agile i ragazzi non sono ancora riusciti produrre nulla di significativo, ma non disperiamo, c’è tutto il secondo sprint!