Enten du er designer, en utvikler eller begge deler, er det stor risiko for at du har en rekke versjoner eller eksempler på det samme prosjektet på datamaskinen din på en gang. Problemet er at det kan være vanskelig å holde tritt med disse elementene hvis du ikke har noen form for system på plass.
Ethvert system du bruker, enten det er ditt eget eller en slags proprietær system, kalles versjonskontroll. Det er en viktig del av prosessen, og hvis du ikke har en, spør du om problemer.
Hvor mange ganger har du opprettet en designfil for en klient i Photoshop eller Illustrator, og endte opp med rundt 10 forskjellige versjoner eller variasjoner av samme design? Jeg har sikkert, men det vi ender med er noe slikt:
Det er ikke en god måte å gå når det gjelder versjonskontroll. For en ting vet kunden ikke hva han skal henvise til, annet enn en fysisk beskrivelse av hva de husker filen ser ut som. Du sannsynligvis må sile gjennom hver enkelt mappe for å finne ut hvilken som de refererer til. Også, hvis du kommer tilbake til et prosjekt måneder nedover veien, hvordan skal du huske hvilken filversjon du leter etter?
Det siste du vil gjøre er å lagre over arbeidskopien av filene dine. Hva om noe går galt? Du trenger en kopi av koden din som er lagret på et godt punkt der alt fortsatt fungerer. Å ha en beskyttelse mot tvingende tidligere versjoner er et must, med mindre du vil starte om igjen.
Å ha et versjonskontrollsystem på plass vil tillate lag å jobbe med de nyeste filene i et prosjekt. Dette forhindrer medlemmene i å jobbe på eldre versjoner som kan ha feil i dem som andre lagmedlemmer kan ha adressert og eliminert. Versjonskontroll holder alt organisert og reduserer team-wide feil.
Versjonskontroll gjør det mulig å holde oversikt over hvem som jobbet på en fil og når. Når en bruker gjør endringer og laster opp endringene, lager de notater, noe som gjør at laget kan holde rede på endringer og når de fant sted i utviklingsprosessen. Dette er viktig, fordi hvis du oppdager et problem senere, kan du jobbe bakover til det punktet der tingene gikk galt.
Deretter kan du se på endringene som ble gjort, som kan bidra til å diagnostisere problemet.
Når en lagkamerat gjør notater, kan det også bidra til å holde oversikt over fremdriften av et prosjekt. La oss si at et medarbeider er ansvarlig for fire oppgaver, men de nevner bare tre i notatene sine, det vil be andre medlemmer å sjekke inn for å sikre at alt er ferdig. Dette kan holde deg fra å ha hull i prosjektene dine.
Forgrening gjør det mulig for en bruker å lage en egen kopi av et utvalg av filer eller mapper som de kan arbeide utelukkende. Dette tillater utviklere å teste ting separat, uten å måtte bekymre seg for å bryte originalen.
Når alle feilene er utarbeidet, kan du fusjonere disse endringene tilbake til kjernesystemet. Å ha muligheten til å skille prosjekter i forskjellige stykker, gjør at gruppemedlemmene kan jobbe på områder de er ansvarlige for, uten å påvirke andres arbeid. Dette er spesielt nyttig for spesialutvikling, hvor et team kan arbeide med standard kjernevner, mens spesialfunksjoner kan jobbe separat og fusjoneres senere. Det påskynder utviklingen, og hjelper prosjekter å gå raskere.
Å ha flere personer som arbeider på forskjellige deler og deler betyr at du har å gjøre med et mangfoldig prosjekt. Det er bundet til å være konflikter: teammedlem 1 og teammedlem 3 kan skape noe som står i konflikt med hverandre, slik at prosjektet blir ødelagt. Versjonskontroll motvirker dette ved å la deg velge en sti eller den andre.
Som et lag kan du bestemme hva som er best, og gå videre fra det punktet. Så, som før, mottar alle de nyeste arbeidsfilene, og alle er på samme side med prosjektet.
Med så mange som jobber med et prosjekt, og så mange forskjellige versjoner, kan det være vanskelig å finne forskjellene i filer uten versjonskontroll. Å finne disse forskjellene er viktig for å diagnostisere hvor noe gikk galt. Du kan sammenligne og finne hvor det er konflikt, eller en endring som noen gjorde som forårsaket problemer.
Ellers er det tøft, fra et menneskelig perspektiv, for å begrense det. Hele prosessen er mindre skremmende når du kan begrense fokuset til bestemte områder av et prosjekt.
I likhet med hvordan et innholdsadministrasjonssystem fungerer for et nettsted, gjør versjonskontrollen enklere å administrere flersidige prosjekter. Den lar deg fokusere mer på selve prosjektet i stedet for å styre prosessen. Å ha et system på plass vil gjøre prosjekter gå jevnere.