Mateusz Stanek

Znak ostrzegawczy Testy

Testy – błędne wyniki

Testy

O tym jak ważne są testy chyba nie muszę nikomu mówić, nie mniej jednak są sytuacje, kiedy testy dają nam fałszywe poczucie bezpieczeństwa. W jednym z projektów jakie miałem okazje realizować, klient podchodził do testów bardzo rygorystycznie. Podeście to, w pewnym momencie przekroczyło moim zdaniem granicę absurdu, kiedy to została zatrudniona osoba, specjalnie po to, ażeby pisała test. Testy post-factum do kodu, którego nie znała, rozwiązującego problemy, których nie rozumiała. Wartość tych testów była jak by to powiedzieć niezbyt wysoka. Klient był zadowolony, pokrycie kodu testami rosło. Zespól tworzył testy jakie uważał za konieczne, a dedykowany developer uzupełniał testy do magicznego wymaganego przez klienta poziomu pokrycia.

Błędne wyniki

O jakości testów przekonaliśmy się w momencie, w którym konieczne były zmiany. Jak wiadomo testy przy zmianach są ważne, gdyż pozwalają sprawdzić czy główne funkcje klas pozostają niezmienione. Tutaj zetknęliśmy się z jednym z błędnych wyników.

Testy – False Positive

Fałszywie pozytywne testy, są szczególnie niebezpieczne według mnie, gdyż dają złudne poczucie bezpieczeństwa. Bezpieczeństwa, które przy zmianach jest jakże ważne. Zmieniamy coś, uruchamiamy testy, sprawdzamy podstawową ścieżkę wykonania – działa, działa. Niestety zmiany nie były takie niewinne. Z powodów braku wiedzy o warunkach brzegowych testy pokrywały całą klasę, ale specyficzne przypadki nie były testowane, o czym ów piszący testy developer nie wiedział (tak, tak daliśmy ciała nie pisząc tych testów wcześniej).  Problem na szczęście wyszedł w czasie testów manualnych. Cała ta sytuacja zapaliła u nas światełko ostrzegawcze i zmusiła cały zespól do refleksji, na temat jakości testów oraz baczniejszego zwracania na nie uwagi.

Testy – False Negative

Ten przypadek testów jest mniej niebezpieczny od opisanego wcześniej “False Positive”, jest on jednak dużo bardziej denerwujący. Odnosi się do przypadku, w którym, mimo iż implementacja jest prawidłowa testy failują. Odruchowo sprawdzamy co może być nie tak i szukamy w pierwszej kolejności problemów w zmienionym kodzie, a dopiero później w implementacji testów. Warto dodać, iż tego typu problemy występują szczególnie często po znalezieniu błędów w implementacji, gdzie pierwszą rzeczą powinno być poprawienie (bądź dodanie nowych) testów, na takie, ażeby błąd został odkryty w testach, a następnie poprawiona implementacja. Może to dać nam fałszywie negatywne wyniki testów w przypadkach, o których nie pomyśleliśmy w czasie poprawek. Nie ważne jak znaleźliśmy takie testy, poprawka w takich przypadkach powinna zostać starannie przemyślana i wykonana z rozwagą tak, ażebyśmy nie stali się ofiarami testów fałszywie pozytywnych.

Podsumowanie

Nie jestem specjalistą od testów. Jednakże w czasie pracy spotkałem się z różnymi przypadkami, gdzie testy ratowały nam skórę, jak i takie, gdzie zepsuły nam naprawdę wiele krwi. Zwracajmy uwagę na nasze testy i w miarę możliwości starajmy się być świadomymi wszelkich zagrożeń. A co najważniejsze, jeśli mamy wiedzę o warunkach specjalnych, które mogą być ciężkie do wyłapania piszmy testy, w których będą one specjalnie, może nawet nadmiarowo testowane. Pozwoli nam to uniknąć późniejszych problemów.

No related posts.

8 kwietnia 2017 DSP2017
2 komentarze

Enumeracja - wartość domyślna

Atrybuty w C#

  1. jakzyc 8 września 2017 o 23:03 Odpowiedz

    No i blog umarł :<

    • Mateusz Stanek 23 października 2017 o 19:13 Odpowiedz

      Chwilowo znajduje się w stanie śpiączki mam nadzieje na szybką poprawę sytuacji.

Dodaj komentarz Anuluj pisanie odpowiedzi

Zobacz

  • Mateusz Stanek o mnie
Mateusz Stanek

Zaprzyjaźnione blogi

SGDev.pl

Ostatnie wpisy

  • Rola Prelegent
  • Elektronika – powrót do starego hobby
  • Badger2040
  • 2023 Tydzień 11
  • 2023 Tydzień 10

Najnowsze komentarze

  • Lukas L - Podsumowanie roku 2022
  • Oktawian Kurzynski - Enumeracja – wartość domyślna
  • Mateusz Stanek - Typy generyczne
  • Ola - Enumeracja – wartość domyślna
  • Typy generyczne w języku C# nie są 'rozwiązywane' w czasie kompilacji - Typy generyczne

Archiwa

  • marzec 2025
  • marzec 2023
  • luty 2023
  • styczeń 2023
  • grudzień 2022
  • marzec 2018
  • luty 2018
  • kwiecień 2017
  • marzec 2017
  • luty 2017

Kategorie

  • Bez kategorii
  • DSP2017
  • Elektronika
  • MiroBurn Challange
  • Narzędzia
  • Podsumowanie
  • Produktywność
  • Programowanie
  • Projekt
  • Prywatne
  • Rok 2023
  • Tips

Ostatnie wpisy

  • Rola Prelegent
  • Elektronika – powrót do starego hobby
  • Badger2040
  • 2023 Tydzień 11
  • 2023 Tydzień 10
Dumnie wspierane przez WordPressa | Motyw: Neblue by NEThemes.
Ta strona korzysta z ciasteczek aby świadczyć usługi na najwyższym poziomie. Dalsze korzystanie ze strony oznacza, że zgadzasz się na ich użycie.Zgoda
Privacy & Cookies Policy

Privacy Overview

This website uses cookies to improve your experience while you navigate through the website. Out of these cookies, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may have an effect on your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. This category only includes cookies that ensures basic functionalities and security features of the website. These cookies do not store any personal information.
Non-necessary
Any cookies that may not be particularly necessary for the website to function and is used specifically to collect user personal data via analytics, ads, other embedded contents are termed as non-necessary cookies. It is mandatory to procure user consent prior to running these cookies on your website.
SAVE & ACCEPT