Co robi tester oprogramowania na co dzień?

Jeśli jeszcze jesteś osobą spoza branży to pewnie czasem zastanawiasz się na czym polega praca testera oprogramowania i jak wygląda typowy dzień pracy w tym zawodzie. Dlatego poniżej przedstawiam listę najczęstszych zajęć specjalistek i specjalistów kontroli oraz zapewnienia jakości oprogramowania. Picie kawy pomijam 🙂
 

Wykonywanie testów

Ten obowiązek można znaleźć niemal w każdej ofercie pracy dla testera oprogramowania i, co za tym idzie, często dominuje on nad innymi aktywnościami. Może mieć jednak różne formy.
 

  • Manualne wykonywanie przypadków testowych
  • Ma to miejsce, gdy realizuje się krok po kroku scenariusz, opisany we wcześniej stworzonym na podstawie m.in. wymagań dokumencie – przypadku testowym (test case). Zadanie polega na wykonywaniu opisanych akcji w systemie i porównywaniu spodziewanych rezultatów z rzeczywistymi. Różnice pomiędzy nimi powinny zostać zaraportowane i najczęściej są one defektami systemu.
     

  • Testowanie eksploracyjne (często oparte na kontekście)
  • Generalnie jest to wykonywanie testów bez uprzednio zdefiniowanych kroków. Największą wartość ma wtedy, gdy tworzony ad-hoc scenariusz bazuje na wiedzy i kontekście, w jakim system jest używany przez użytkowników końcowych. Również i takie testowanie wymaga dokumentowania (przykładowo test charter).
     

  • Testowanie wspomagane automatami
  • Tam, gdzie to uzasadnione, zamiast testów manualnych mogą być automatyczne. Niektóre z nich są wywoływane o zaplanowanej porze bez udziału człowieka (np. jako element Continuous Integration), ale interpretacja ich wyników to już zwykle zadanie testera. Istotne jest tu odfiltrowanie problemów powodowanych przez nieodpowiednią konfigurację czy nieaktualny skrypt testujący i identyfikacja rzeczywistych defektów systemu, którego jakość mierzymy.

 

Raportowanie

To dokumentacja i następstwo wykonanych testów. Obejmuje wpisane bug-i w systemie do śledzenia defektów oraz informacje co, kiedy, gdzie, jak i przez kogo zostało przetestowane. Większość z tych danych jest często zbierana przez narzędzia do zarządzania testami. W zależności od organizacji, mogą powstawać też dodatkowe raporty dla interesariuszy lub klientów.
 

Retesty

Wpisane defekty, zwłaszcza te istotne, są prędzej czy później poprawiane przez programistów. Po zbudowaniu kolejnej wersji systemu przychodzi czas na weryfikację poprawki. Obejmuje ona ponowne wykonanie kroków które spowodowały awarię systemu. Czasami, w ramach testów regresji, wykonywany jest cały zestaw powiązanych przypadków testowych.
 

Analiza, projektowanie i implementacja testów

Zwykle są to zadania bardziej doświadczonych testerów i obejmują między innymi analizę podstawy testów (w tym wymagań), określenie danych i środowiska testowego, a następnie specyfikację procedur i skryptów. I tutaj również możemy mieć do czynienia z testami manualnymi lub automatycznymi. W przypadku tych drugich należy pamiętać, że liczy się nie tyko poprawnie napisany kod. Nic nie zwalnia z obowiązku z odpowiedniego zaprojektowania scenariusza testu. Dlatego solidne doświadczenie testerskie przydaje się również w czasie programowania testów.
 

Obowiązki z zakresu zapewnienia jakości oprogramowania (Quality Assurance)

Takiego rodzaju zadania z reguły dotyczą osób, które maja QA w nazwie czy opisie stanowiska – co powinno łączyć się z wiedzą i doświadczeniem pozwalającymi na kształtowanie i korektę procesu rozwoju oprogramowania. Jak można przeczytać w słowniczku Quality Assurance to część zarządzania jakością. W niektórych organizacjach osoby za to odpowiedzialne nie zajmują się w ogóle stricte testowaniem, jednak częściej łączy się zadania testera i QA.
 

Podsumowanie

To tylko niektóre z obowiązków testerów. Mam wrażenie, że zaledwie nakreśliłem temat. Ale taka też była rola tego wpisu. Zachęcam Cię do zgłębienia tematu i pytań w komentarzach, jeśli coś wymaga rozwinięcia lub szerszych wyjaśnień.

4 komentarze(-y) do “Co robi tester oprogramowania na co dzień?

  1. Iwona

    WItaj, mam pytanie, co polecisz dla osoby początkującej ?
    Chcę się przebranżowić, nie jestem po studiach technicznych.
    Mam wytyczne od znajomego czego się nauczyć ale to wszystko teoria…
    nie wiem jak naprawdę wygląda to testowanie od środka…

    polecisz jakieś filmiki, strony ?
    góry dzięki
    Iwo.

    • Cześć,
      Jak widzę, znalazłaś sporo porad i linków na grupie Testowanie Oprogramowania na FB 🙂 Jeśli chodzi o moje rekomendacje – sukcesywnie zamieszczam je na blogu i zamierzam to kontynuować. Życzę Ci powodzenia w drodze do zawodu testerki!

  2. Monika

    witam, stawiam pierwsze kroki w kierunku nowej branży. Mam nadzieje się w zawodzie testera z satysfakcja odnaleźć. Czy powinnam znać jakiś język programowania? Zauważyłam ze w ofertach pracy często pytają o sql. Miałam to jeszcze na studiach, czy warto wiedzę odświeżyć i uzupełnić? Pewnie sporo się zmieniło.

    Dzięki,

    • Witaj Monika. SQL to język zapytań stosowany przy pracy z relacyjnymi bazami danych. Rzeczywiście, często jest wymieniany w ofertach, a jego znajomość jest sprawdzana na większości rozmów kwalifikacyjnych na stanowisko testera oprogramowania. Na szczęście opanowanie podstaw SQL nie powinno zająć dużo czasu i naprawdę warto to zrobić. Co do innych umiejętności – w październiku ukaże się dodatek do bloga, gdzie podsumuję najważniejsze rzeczy, które należy poznać przed rozmową o pracę. O możliwości jego pobrania będę informował także poprzez newsletter i na Facebook’u.

Dodaj komentarz

Twój adres email nie zostanie opublikowany. Pola, których wypełnienie jest wymagane, są oznaczone symbolem *