Thursday, September 27, 2007

Kunskapsföretag utan tid?

Vi IT-konsulter befinner oss ofta i uppdrag hos kund eller i projekt som innebär heltid, alltså ungefär fyrtio timmar per vecka. För många av oss finns det sällan utrymme till mer än ett tillfälle i månaden för att vara med på möten eller kompetensträffar som inte är direkt relaterat till det pågående uppdraget. En vanlig konstruktion i vår bransch är att ge konsulter ungefär fem dagar per år att till exempel gå en kurs eller delta i en konferens. Vanligt är att dessa fem dagar används vid ett tillfälle. Räcker en vecka per år och person för att ett kunskapsföretag ska utvecklas och vara konkurrenskraftigt?

För mig räcker det inte. Jag spenderar mångdubbelt mer tid än dessa fem dagar, till inhämtning av kunskap och testande av diverse tekniker och det hinner jag bara göra på kvällar och helger. Men i projekten då, där lär man ju sig av misstag och gör nya upptäckter under resans gång. Visst gör man det, men ska verkligen kunden betala för din utbildning? Ofta är det också försent när man väl har kunskapen som behövs, då produkten redan är i drift (med diverse ”tillfälliga nödlösningar” i den utvecklade koden).

De kvällar och helger jag ägnar åt att prova nya utvecklingstekniker, läsa böcker med Agile i titeln och google:a efter lösningar till kända och okända problem, betalas av mig i form av tid och med arbetsrelaterade frågeställningar i huvudet lagom till sovdags. Att företaget uppgraderats med ny kunskap syns inte i tidredovisningen för interna kostnader, men en sömnig IT-konsult gör misstag som materialiseras i form av buggar i koden.

Det tycks vara så att kunskap och utbildning till personal har ganska låg prioritet bland IT-företag och alltid lägre prioritet än de fakturerbara projekten. För mig är detta konstigt, eftersom kunskap oftast är det enda ett konsultbolag har att erbjuda sina kunder. Kunskap i vår bransch blir snabbt omodern och ny teknik innebär ofta enklare vägar till resultat och affärsvärde. Om man har ägnat tid åt att testa och undersöka den nya tekniken, det vill säga.

Jag tror att utbildning behöver finnas inbyggt i verksamheten. Det behövs spelrum på arbetstid och det behöver vara en naturlig del av det dagliga arbetet. Det behöver finnas timmar varje vecka öronmärkta för vidareutbildning med krav på individen att redovisa resultat - allt från en kort sammanfattning av en bok, till en prototyp av en möjlig framtida produkt. Modellen innebär att det blir färre timmar att fakturera, men den kunskap man tar in kan användas i projekten på en gång. Och hur många prototyper och nyskapande idéer ser dagens ljus om tid inte finns till detta? Google - som ju levererar nya produkter och lösningar på löpande band – har sådana modeller inbyggt i sin verksamhet. Idag är de ett av världens mest framgångsrika företag med sitt välkända varumärke. Ett riktigt kunskapsföretag i 2000-talet. Vill inte vi också vara det?





Fotnot: kunskap och inspiration har inhämtats (på fritiden) från boken ”Spelrum på jobbet” av Tom DeMarco. Läs den!

Monday, September 17, 2007

Felfri = kvalitet?

Jag tror att begreppet felfri för de flesta i vår bransch betyder att en produkt har minimalt med så kallade buggar. Med bugg menar man till exempel ett datorprogram som kraschar eller att en viss funktion i programmet inte fungerar. De företag som säger sig fokusera på kvalitet har testavdelningar som ägnar sig åt felsökning och kontroll av programmerarnas leveranser, för att fånga upp och rätta fel. Bra!

När produkten anses vara klar för leverans så är det oftast en liten grej man glömt, eller helt enkelt inte brytt sig om. Nämligen att låta de som faktiskt ska använda produkten testa den innan man levererar. I de flesta fall har man ju redan identifierat sina målgrupper och ägnat tid åt att ta fram funktionalitet som i framtiden ska ge tillbaka affärsvärde - Return On Investment.

Men varför struntar man i att testa om folk kan använda produkten eller inte? Ju mer jag tänker på det här blir det för mig bara mer och mer konstigt att användbarhetstester oftast inte finns med i framtagandet av IT-produkter.

Ett exempel:
tänk om tre av tio besökare på en e-handelssajt inte skulle klara av att ta sig igenom en kassa för att handla webbplatsens produkter. Majoriteten – sju av tio – klarar det galant, men hur mycket pengar förlorar e-handelsföretaget när tre av tio besökare, trettio av hundra, tre hundra av tusen besökare inte förmår göra ett avslut?

Trettio misslyckanden av hundra låter, i alla fall för mig, som allvarliga buggar. Som eventuellt upptäcks när man redan förlorat stora summor pengar. Föreställ dig vad en otestad applikation i till exempel medicin- eller kärnkraftsindustrin kan ställa till med. Skuld läggs ofta på människor - den mänskliga faktorn - när det troligtvis är så att fel finns i själva kommunikationen mellan människa och dator. Man gör det på tok för enkelt för sig när man pekar på att handhavande finns beskrivet i pärmar i något dammigt kontorsarkiv.

Varför är inte användbarhet en självklar del av kvalitetsbegreppet?

Jag tror att det finns en allmän uppfattning, både hos beställare och bland producenter, att de som programmerar bör veta vad som är användarvänligt, användbart och tillgängligt. Därför är det inte något som man ska behöva betala för, eller spendera dyrbar tid på. Konstigt nog gäller det inte för de direkt funktionella testerna - man litar alltså inte på att programmerare kan programmera.

Jag vill mycket gärna se denna skepsis för min och mina kollegors kunskaper även för användbarhet i applikationer. Kan man i förväg veta hur den där användaren kommer att bete sig i interaktionen med vårt fina gränssnitt och vår snyggt skrivna kod? Troligtvis inte. Jag tror att man med erfarenhet lär sig mer och mer om hur vi människor agerar framför datorn, men fakta får vi enbart genom att låta olika människor kontinuerligt testa det vi producerar.

Vi som gillar att arbeta med lättrörliga metoder i projekt (agile) har en jättechans att göra något riktigt bra. Vi behöver först vidga begreppet utvecklare, till att i våra Team omfatta alla som deltar i att utveckla en produkt: programmerare, testare, skribenter och så vidare.

I varje delmoment (iteration, Sprint) i projektet genomför vi regelbundet användbarhetstester på det som vi hittills byggt. Det är en missuppfattning att det måste finnas en helhet som användaren ska testa. Det går alldeles utmärkt att låta folk testa till exempel en sökfunktion på en ännu inte helt färdig webbplats. Frågan är, har vi tänkt rätt och vad kan vi göra bättre? Inte om personen framför datorn är tillräckligt smart för att klara av att genomföra ett köp på en webbplats. Don't make me think! - är en bra utgångspunkt att ha när man bygger gränssnitt, tycker jag.

Användbarhetstester är besvärliga för oss producenter. Det finns en hel del personligt engagemang, förutfattade meningar och prestige som står på spel. Det är dags att slänga bort det där nu. Användarvänlighet och användarnytta ger oss affärsvärde tillbaka och goda relationer med våra kunder.