Testowanie bazy danych - krótki przewodnik

Testowanie bazy danych obejmuje sprawdzanie poprawności danych, testowanie integralności danych, kontrolę wydajności związaną z bazą danych oraz testowanie procedur, wyzwalaczy i funkcji w bazie danych.

Przykład

Rozważ aplikację, która przechwytuje szczegóły codziennych transakcji dla użytkowników i przechowuje je w bazie danych. Z punktu widzenia testowania bazy danych, należy przeprowadzić następujące sprawdzenia -

  • Informacje transakcyjne z aplikacji powinny być przechowywane w bazie danych i powinny dostarczać użytkownikowi poprawnych informacji.

  • Informacje nie powinny zostać utracone podczas ładowania do bazy danych.

  • Należy przechowywać tylko zakończone transakcje, a wszystkie niekompletne operacje powinny zostać przerwane przez aplikację.

  • Należy zachować uprawnienia dostępu do bazy danych. Nie należy zapewniać niezatwierdzonego lub nieautoryzowanego dostępu do informacji o użytkowniku.

Dlaczego musisz przeprowadzać testy bazy danych?

Istnieje wiele powodów, dla których przeprowadza się testy bazy danych. Istnieje potrzeba przeprowadzania integralności danych, walidacji i sprawdzania spójności danych w bazie danych, ponieważ system zaplecza jest odpowiedzialny za przechowywanie danych i jest dostępny w wielu celach.

Poniżej podano kilka typowych powodów testowania bazy danych -

  • Aby uprościć złożoność wywołań zaplecza bazy danych, programiści zwiększają użycie View i Stored Procedury.

  • Te Stored procedury i Viewszawierają krytyczne zadania, takie jak wprowadzanie danych klienta (imię i nazwisko, dane kontaktowe itp.) oraz danych sprzedaży. Zadania te należy przetestować na kilku poziomach.

  • Black-box testingwykonywane na front-endzie jest ważne, ale utrudnia wyodrębnienie problemu. Testowanie w systemie zaplecza zwiększa niezawodność danych. Dlatego testowanie bazy danych jest wykonywane w systemie zaplecza.

  • W bazie danych dane pochodzą z wielu aplikacji i istnieje możliwość, że w bazie danych są przechowywane szkodliwe lub nieprawidłowe dane. Dlatego konieczne jest regularne sprawdzanie składników bazy danych. Ponadto należy regularnie sprawdzać integralność i spójność danych.

Testowanie bazy danych a testowanie front-end

Testowanie bazy danych różni się od testowania interfejsu użytkownika. Poniższa tabela przedstawia kluczowe różnice -

Testowanie baz danych Testowanie interfejsu użytkownika

Testowanie bazy danych jest znane jako sprawdzanie poprawności danych i testowanie integralności lub testowanie zaplecza.

Testowanie interfejsu użytkownika lub testowanie frontendowe jest również nazywane testowaniem aplikacji lub testowaniem interfejsu użytkownika.

Testowanie baz danych polega na testowaniu komponentów zaplecza, które nie są widoczne dla użytkowników.

Obejmuje to komponenty baz danych i systemy DBMS, takie jak My SQL, Oracle.

Testowanie UI polega na sprawdzeniu funkcjonalności aplikacji i jej komponentów, takich jak formularze, wykresy, menu, raporty itp.

Te komponenty są tworzone przy użyciu narzędzi programistycznych typu front-end, takich jak VB.net, C #, Delphi itp.

Testowanie bazy danych obejmuje sprawdzanie procedur składowanych, widoków, schematów w bazie danych, tabel, indeksów, kluczy, wyzwalaczy, sprawdzanie poprawności danych i sprawdzanie spójności danych.

Testowanie interfejsu użytkownika polega na sprawdzeniu funkcjonalności aplikacji, przycisków, formularzy i pól, kalendarza i obrazów, nawigacji z jednej strony na drugą oraz ogólnej funkcjonalności aplikacji.

Aby przeprowadzić testowanie bazy danych, tester potrzebuje dogłębnej znajomości koncepcji bazy danych - takich jak procedury i funkcje, widoki, indeksy, klucze i dobra praktyczna znajomość języka SQL.

Aby przeprowadzić testy interfejsu użytkownika, tester musi dobrze rozumieć wymagania biznesowe, znajomość funkcji aplikacji, kodowanie itp.

Dane pochodzą z wielu heterogenicznych źródeł danych w aplikacjach internetowych, intranetowych i różnych innych aplikacjach.

Dane są wprowadzane ręcznie do aplikacji. Polega na funkcjonalnym testowaniu aplikacji frontendowych.

W oparciu o funkcję i strukturę bazy danych, testy DB można podzielić na trzy kategorie -

  • Structural Database Testing - Zajmuje się testowaniem tabel i kolumn, testowaniem schematów, testowaniem procedur składowanych i widoków, sprawdzaniem wyzwalaczy itp.

  • Functional Testing- Polega na sprawdzeniu funkcjonalności bazy danych z punktu widzenia użytkownika. Najbardziej powszechnym typem testów funkcjonalnych są testy białoskrzynkowe i testy czarnoskrzynkowe.

  • Nonfunctional Testing - Obejmuje testy obciążenia, testy ryzyka w bazie danych, testy warunków skrajnych, minimalne wymagania systemowe i zajmuje się wydajnością bazy danych.

Testowanie strukturalnych baz danych

Testowanie strukturalne bazy danych polega na weryfikacji tych elementów bazy danych, które nie są widoczne dla użytkowników końcowych. Obejmuje wszystkie komponenty repozytorium, które służą do przechowywania danych i nie są zmieniane przez użytkowników końcowych. Administratorzy baz danych z dobrą znajomością procedur składowanych SQL i innych koncepcji zwykle przeprowadzają te testy.

Omówiono typowe komponenty testowane pod kątem testów strukturalnych -

Testowanie schematu / mapowania

Obejmuje walidację obiektów aplikacji frontonu za pomocą mapowania obiektów bazy danych.

W testowaniu schematu -

  • Czasami zdarza się, że obiekty aplikacji użytkownika końcowego nie są poprawnie odwzorowane lub nie są zgodne z obiektami bazy danych. Dlatego wymagane jest sprawdzenie walidacji różnych formatów schematów powiązanych z bazami danych.

  • Wymagane jest znalezienie niezamapowanych obiektów w bazie danych, takich jak tabele, widoki, kolumny itp.

Na rynku dostępne są różne narzędzia, których można używać do wykonywania mapowania obiektów w schematach.

Example - W Microsoft SQL Server tester może pisać proste zapytania w celu sprawdzania i walidacji schematów w bazie danych.

Jeśli tester chce wprowadzić zmiany w strukturze tabeli, powinien upewnić się, że wszystkie pliki stored procedury posiadające tę tabelę są zgodne z tą zmianą.

Testowanie procedur składowanych i widoków

W tym testowaniu tester zapewnia, że ​​ręczne wykonanie procedur składowanych i widoków generuje wymagany wynik.

Tester zapewnia -

  • Jeśli umożliwia wykonanie wymaganych wyzwalaczy zgodnie z oczekiwaniami.

  • Jeśli zespół programistów uwzględnił wszystkie pętle i warunki, przekazując dane wejściowe do aplikacji w procedurach.

  • Jeśli w bazie danych znajdują się nieużywane procedury składowane.

  • Operacje TRIM są stosowane prawidłowo, gdy dane są pobierane z wymaganych tabel w bazie danych.

  • Walidacja ogólnej integracji modułów procedur składowanych zgodnie z wymaganiami testowanej aplikacji.

  • Przestrzegane są mechanizmy obsługi wyjątków i błędów.

Najpopularniejszymi narzędziami używanymi do przeprowadzania testów procedur składowanych są LINQ, SP Test toolitp.

Testowanie wyzwalacza

Podczas testowania wyzwalaczy tester musi zapewnić:

  • Czy konwencje kodowania są przestrzegane podczas fazy kodowania wyzwalaczy.

  • Zobacz, czy wykonane wyzwalacze spełniają wymagane warunki.

  • Czy wyzwalacz poprawnie aktualizuje dane po ich wykonaniu.

  • Weryfikacja aktualizacji / wstawienia / usunięcia uruchamia funkcjonalność testowanej aplikacji.

Tabele i testy kolumnowe

Kluczowe obszary objęte tym testem to:

  • Sprawdzanie poprawności typów danych w bazie danych do wartości pól w aplikacji frontonu.

  • Walidacja długości pola danych w bazie danych do długości typów danych w aplikacji.

  • Sprawdzanie, czy w bazie danych znajdują się niezamapowane tabele lub kolumny z obiektów pól aplikacji.

  • Konwencje nazewnictwa tabel i kolumn bazy danych są weryfikowane, czy są zgodne z wymaganiami biznesowymi, czy nie.

  • Sprawdzanie poprawności kluczy i indeksów w bazie danych, tj. Klucze podstawowe i obce w tabelach są definiowane zgodnie z wymaganiami.

  • Sprawdź, czy klucze podstawowe i odpowiadające im klucze obce są takie same w dwóch tabelach.

  • Sprawdź, czy są zachowane unikalne i NIE NULL właściwości kluczy.

  • Długość i typ danych kluczy i indeksów są utrzymywane zgodnie z wymaganiami.

Sprawdzanie serwera bazy danych

Sprawdzanie serwera bazy danych obejmuje weryfikację -

  • Czy serwer bazy danych może obsłużyć oczekiwaną liczbę transakcji zgodnie z wymaganiami biznesowymi.

  • Jeśli szczegóły konfiguracji serwerów baz danych spełniają wymagania biznesowe.

  • Jeśli autoryzacja użytkownika jest utrzymywana zgodnie z wymaganiami.

Testy funkcjonalności

Testowanie funkcjonalne przeprowadza się z uwzględnieniem punktu widzenia użytkownika końcowego; czy wymagane transakcje i operacje wykonywane przez użytkowników końcowych są zgodne ze specyfikacjami biznesowymi.

Testowanie czarnoskrzynkowe

Testowanie czarnoskrzynkowe polega na weryfikacji integracji bazy danych w celu sprawdzenia funkcjonalności. Przypadki testowe są proste i służą do weryfikacji danych przychodzących i wychodzących z funkcji.

Do testowania funkcjonalności bazy danych wykorzystuje się różne techniki, takie jak technika graficzna przyczynowo-skutkowa, podział równoważności i analiza wartości brzegowych.

Jego advantages są następujące -

  • Jest to dość proste i wykonywane na wczesnych etapach rozwoju.
  • Koszt opracowania przypadków testowych jest niższy w porównaniu z testami białoskrzynkowymi.

Jego wady są następujące -

  • Nie można wykryć kilku błędów
  • Nie wiadomo, ile programów należy przetestować.

Testowanie w białej skrzynce

White Box Testing zajmuje się wewnętrzną strukturą bazy danych, a szczegóły specyfikacji są ukryte przed użytkownikami. Obejmuje testowanie wyzwalaczy bazy danych i widoków logicznych, które będą wspierać refaktoryzację bazy danych.

Wykonuje modułowe testowanie funkcji bazy danych, wyzwalaczy, widoków, zapytań SQL itp. Ten rodzaj testów sprawdza poprawność tabel bazy danych, modeli danych, schematów bazy danych itp. Sprawdza reguły integralności referencyjnej. Wybiera domyślne wartości tabeli w celu sprawdzenia spójności bazy danych.

Najpopularniejszymi technikami używanymi do przeprowadzania testów białoskrzynkowych są pokrycie warunków, pokrycie decyzji, pokrycie instrukcji itp.

Błędy kodowania można wykryć podczas testów białoskrzynkowych, dzięki czemu można wyeliminować wewnętrzne błędy w bazie danych. Ograniczeniem testowania białoskrzynkowego jest to, że instrukcje SQL nie są uwzględniane.

Testowanie niefunkcjonalne

Testowanie niefunkcjonalne obejmuje wykonywanie testów obciążeniowych, testów warunków skrajnych, sprawdzanie minimalnych wymagań systemowych w celu spełnienia specyfikacji biznesowej, znajdowanie ryzyka i optymalizację wydajności bazy danych.

Testowanie obciążenia

Głównym celem testowania obciążenia jest sprawdzenie, czy większość uruchomionych transakcji ma wpływ na wydajność bazy danych.

W testach obciążenia tester sprawdza -

  • Czas odpowiedzi na wykonanie transakcji dla wielu użytkowników zdalnych.
  • Czas potrzebny bazie danych na pobranie określonych rekordów.

Examples of load testing in different testing types -

  • Wielokrotne uruchamianie najczęściej używanych transakcji, aby zobaczyć wydajność systemu bazy danych.
  • Pobieranie serii dużych plików z Internetu.
  • Jednoczesne uruchamianie wielu aplikacji na komputerze lub serwerze.

Test naprężeń

Testy warunków skrajnych są wykonywane w celu zidentyfikowania punktu przerwania systemu. W tym teście aplikacja jest ładowana w taki sposób, że w pewnym momencie system zawiedzie. Ten punkt nazywa siębreakpoint systemu baz danych.

Określenie stanu transakcji w bazie danych wymaga dużego nakładu pracy. Aby uniknąć problemów związanych z czasem i kosztami, wymagane jest właściwe planowanie.

Najczęściej używanymi narzędziami do testów warunków skrajnych są LoadRunner i WinRunner.

Weźmy exampletestów warunków skrajnych. Aplikacja CRM może przyjąć maksymalnie 50000 jednoczesnych użytkowników. Załóżmy, że zwiększasz obciążenie do 51000 i dokonujesz transakcji, takich jak aktualizowanie rekordów lub dodawanie wpisu. Jak tylko wykonasz transakcję, aplikacja może zsynchronizować się z systemem bazy danych. Zatem następny test jest wykonywany przy obciążeniu użytkownika wynoszącym 52000. Czasami nazywane jest również testowanie warunków skrajnychFatigue Testing.

Proces testowania bazy danych jest podobny do testowania innych aplikacji. Testowanie bazy danych można opisać kluczowymi procesami podanymi poniżej.

  • Skonfiguruj środowisko
  • Uruchom test
  • Sprawdź wynik testu
  • Sprawdź zgodnie z oczekiwanymi wynikami
  • Zgłoś ustalenia odpowiednim zainteresowanym stronom

Do tworzenia przypadków testowych używane są różne instrukcje SQL. Najpopularniejszą instrukcją SQL używaną do testowania bazy danych jestSelectkomunikat. Oprócz tego można również używać różnych instrukcji DDL, DML, DCL.

Example - Tworzenie, wstawianie, wybieranie, aktualizowanie itp.

Etapy testowania bazy danych

Testowanie bazy danych nie jest żmudnym procesem i obejmuje różne etapy cyklu życia testowania bazy danych zgodnie z procesami testowymi.

Kluczowe etapy testowania bazy danych to:

  • Sprawdzanie stanu początkowego
  • Testowe uruchomienie
  • Walidacja wyniku zgodnie z oczekiwanym wynikiem
  • Generowanie wyników

First stagew DB Testing polega na sprawdzeniu początkowego stanu bazy danych przed rozpoczęciem procesu testowania. Następnie testowane jest zachowanie bazy danych dla zdefiniowanych przypadków testowych. Zgodnie z uzyskanymi wynikami przypadki testowe są dostosowywane.

Aby pomyślnie przetestować bazę danych, poniższy przepływ pracy jest wykonywany przy każdym pojedynczym teście.

  • Cleaning up the database - Jeśli w bazie danych znajdują się dane do przetestowania, należy ją opróżnić.

  • Set up Fixture - Polega to na wprowadzeniu danych do bazy danych i sprawdzeniu aktualnego stanu bazy danych.

  • Perform test, verify results and generate results- Test jest uruchamiany, a wyjście jest weryfikowane. Jeśli wynik jest zgodny z oczekiwanymi wynikami, następnym krokiem jest wygenerowanie wyników zgodnie z wymaganiami. W przeciwnym razie testy są powtarzane w celu znalezienia błędów w bazie danych.

W tym rozdziale opisano najpopularniejsze techniki używane do testowania bazy danych.

Testowanie schematu bazy danych

Jak wspomniano wcześniej, obejmuje testowanie każdego obiektu w schemacie.

Weryfikacja baz danych i urządzeń

  • Weryfikacja nazwy bazy danych
  • Weryfikacja urządzenia danych, urządzenia rejestrującego i urządzenia zrzutowego
  • Sprawdzanie, czy dla każdej bazy danych przydzielono wystarczającą ilość miejsca
  • Weryfikacja ustawienia opcji bazy danych

Sprawdzanie reguł tabel, kolumn, typów kolumn

Sprawdź poniższe pozycje, aby poznać różnice między aktualnym a zastosowanym ustawieniem.

  • Nazwy wszystkich tabel w bazie danych

  • Nazwy kolumn dla każdej tabeli

  • Typy kolumn dla każdej tabeli

  • NULL wartość sprawdzona czy nie

  • Określa, czy wartość domyślna jest powiązana z poprawnymi kolumnami tabeli

  • Definicje reguł poprawiające nazwy tabel i uprawnienia dostępu

Klucz i indeksy

Sprawdź klucz i indeksy w każdej tabeli -

  • Klucz podstawowy dla każdej tabeli

  • Klucze obce dla każdej tabeli

  • Typy danych między kolumną klucza obcego a kolumną w innej tabeli Indeksy, klastrowe lub nieklastrowe unikalne lub nieunikalne

Testy procedur składowanych

Obejmuje sprawdzenie, czy procedura składowana jest zdefiniowana i porównywanie wyników wyjściowych. W teście procedury składowanej sprawdzane są następujące punkty -

  • Nazwa procedury składowanej

  • Nazwy parametrów, typy parametrów itp.

  • Output- czy wynik zawiera wiele rekordów. Zero wierszy jest wprowadzanych lub wyodrębnianych jest tylko kilka rekordów.

  • Jaka jest funkcja procedury składowanej, a czego procedura składowana nie powinna robić?

  • Przekazywanie przykładowych zapytań wejściowych w celu sprawdzenia, czy procedura składowana wyodrębnia poprawne dane.

  • Stored Procedure Parameters- Wywołaj procedurę składowaną z danymi granicznymi i prawidłowymi danymi. Unieważ każdy parametr raz i uruchom procedurę.

  • Return values- Sprawdź wartości zwracane przez procedurę składowaną. W przypadku niepowodzenia należy zwrócić wartość niezerową.

  • Error messages check- Wprowadź zmiany w taki sposób, aby procedura składowana nie powiodła się i przynajmniej raz wygeneruj każdy komunikat o błędzie. Sprawdź scenariusze wyjątków, jeśli nie ma wstępnie zdefiniowanego komunikatu o błędzie.

Testy wyzwalania

W teście wyzwalacza tester musi wykonać następujące zadania -

  • Upewnij się, że nazwa wyzwalacza jest poprawna.
  • Sprawdź poprawność wyzwalacza, jeśli został wygenerowany dla określonej kolumny tabeli.
  • Weryfikacja aktualizacji wyzwalacza.
  • Zaktualizuj rekord, podając prawidłowe dane.
  • Zaktualizuj rekord z nieprawidłowymi danymi i zakryj każdy błąd wyzwalacza.
  • Zaktualizuj rekord, gdy nadal odwołuje się do niego wiersz w innej tabeli.
  • Zapewnij wycofywanie transakcji w przypadku awarii.
  • Dowiedz się o przypadkach, w których wyzwalacz nie powinien cofać transakcji.

Skrypty konfiguracji serwera

Należy przeprowadzić dwa rodzaje testów -

  • Konfigurowanie bazy danych od podstaw i
  • Aby skonfigurować istniejącą bazę danych.

Testy integracji SQL Server

Testy integracyjne należy przeprowadzić po zakończeniu testów modułowych.

  • Należy intensywnie wywoływać procedury składowane, aby wybierać, wstawiać, aktualizować i usuwać rekordy w różnych tabelach w celu znalezienia wszelkich konfliktów i niezgodności.

  • Wszelkie konflikty między schematem a wyzwalaczami.

  • Wszelkie konflikty między procedurami składowanymi a schematem.

  • Wszelkie konflikty między procedurami składowanymi i wyzwalaczami.

Metoda testowania funkcjonalnego

Testowanie funkcjonalne można przeprowadzić, dzieląc bazę danych na moduły zgodnie z funkcjonalnością. Funkcje są dwojakiego rodzaju -

  • Type 1- W testach typu 1 poznaj cechy projektu. Dla każdej głównej funkcji znajdź schemat, wyzwalacze i procedury składowane odpowiedzialne za implementację tej funkcji i umieść je w grupie funkcjonalnej. Następnie przetestujcie razem każdą grupę.

  • Type 2- W testach typu 2 granica grup funkcjonalnych w zapleczu nie jest oczywista. Możesz sprawdzić przepływ danych i zobaczyć, gdzie możesz je sprawdzić. Zacznij od front-endu.

Następujący proces ma miejsce -

  • Gdy usługa ma żądanie lub zapisuje dane, wywoływane są niektóre procedury składowane.

  • Procedury zaktualizują niektóre tabele.

  • Te procedury składowane będą miejscem do rozpoczęcia testowania, a te tabele będą miejscem do sprawdzenia wyników testów.

Test naprężeń

Testowanie warunków skrajnych polega na uzyskaniu listy głównych funkcji bazy danych i odpowiednich procedur składowanych. Postępuj zgodnie z instrukcjami podanymi poniżej, aby wykonać testy warunków skrajnych -

  • Napisz skrypty testowe, aby wypróbować te funkcje, a każda funkcja musi zostać sprawdzona przynajmniej raz w pełnym cyklu.

  • Wykonuj skrypty testowe wielokrotnie przez określony czas.

  • Weryfikacja plików dziennika w celu sprawdzenia wszelkich zakleszczeń, braku pamięci, uszkodzenia danych itp.

Testy porównawcze

Jeśli w Twojej bazie danych nie ma żadnych problemów z danymi ani błędów, można sprawdzić wydajność systemu. Słabe działanie systemu można znaleźć w testach porównawczych, sprawdzając parametry podane poniżej -

  • Wydajność na poziomie systemu
  • Zidentyfikuj najczęściej używane funkcje / cechy
  • Czas - maksymalny czas, minimalny czas i średni czas wykonywania funkcji
  • Dostęp do głośności

Testowanie bazy danych za pośrednictwem interfejsu użytkownika

Błędy zaplecza można również czasami znaleźć, wykonując testy front-end. Możesz wykonać proste kroki podane poniżej, aby wykryć błędy za pomocą testów front-end.

  • Pisz zapytania z front-endu i przeprowadzaj wyszukiwania.

  • Wybierz istniejący rekord, zmień wartości w niektórych polach i zapisz rekord. (Obejmuje instrukcję UPDATE lub aktualizację procedur składowanych i wyzwalaczy aktualizacji).

  • Wstaw nową pozycję menu w oknie frontonu. Wypełnij informacje i zapisz rekord. (Obejmuje instrukcje INSERT lub procedury składowane wstawiania i wyzwalacze usuwania).

  • Wybierz istniejący rekord, kliknij przycisk USUŃ lub USUŃ i potwierdź usunięcie. (Obejmuje instrukcję DELETE lub usuwanie procedur składowanych i wyzwalaczy usuwania).

  • Powtórz te przypadki testowe z nieprawidłowymi danymi i zobacz, jak odpowiada baza danych.

W tym rozdziale zobaczymy kilka typowych scenariuszy testowania baz danych w odniesieniu do różnych metod testowania.

Testowanie strukturalnych baz danych

Typowe scenariusze baz danych w odniesieniu do testowania ustrukturyzowanych baz danych podano poniżej -

  • Weryfikacja nazwy bazy danych, weryfikacja urządzenia danych, urządzenia rejestrującego i urządzenia zrzutowego, weryfikacja, czy wystarczająca ilość miejsca jest przydzielona dla każdej bazy danych oraz weryfikacja ustawienia opcji bazy danych.

  • Nazwy wszystkich tabel w bazie danych, nazwy kolumn dla każdej tabeli, typy kolumn dla każdej tabeli, sprawdzanie wartości null lub nie. Sprawdź klucz i indeksy w każdej tabeli: klucz podstawowy dla każdej tabeli, klucze obce dla każdej tabeli.

  • Typy danych między kolumną klucza obcego a kolumną w innych indeksach tabeli, klastrowe lub nieklastrowe unikatowe lub nieunikalne.

Testowanie funkcjonalnych baz danych

Scenariusze wspólnych testów bazy danych w odniesieniu do Functional Database Testing są -

  • Znalezienie schematu, wyzwalaczy i procedur składowanych odpowiedzialnych za implementację tej funkcji i uczynienie z nich grupy funkcjonalnej, a następnie każdą grupę można przetestować razem.

  • Sprawdź przepływ danych i zobacz, gdzie możesz je sprawdzić. Zacznij od front-endu.

Testowanie niefunkcjonalnych baz danych

Scenariusze wspólnych testów bazy danych w odniesieniu do Non-Functional Database Testing są -

  • Napisz skrypty testowe, aby wypróbować główne funkcje, a każda funkcja musi zostać sprawdzona przynajmniej raz w pełnym cyklu.

  • Wykonuj skrypty testowe wielokrotnie przez określony czas.

  • Weryfikacja plików dziennika w celu sprawdzenia zakleszczenia, braku pamięci, uszkodzenia danych itp.

  • Pisz zapytania z interfejsu użytkownika i przeprowadzaj wyszukiwania. Wybierz istniejący rekord, zmień wartości w niektórych polach i zapisz rekord. (Obejmuje instrukcję UPDATE lub aktualizację procedur składowanych, wyzwalacze aktualizacji).

  • Wstaw nową pozycję menu w oknie frontonu. Wypełnij informacje i zapisz rekord. (Obejmuje instrukcje INSERT lub procedury składowane wstawiania, wyzwalacze usuwania).

  • Wybierz istniejący rekord, kliknij przycisk USUŃ lub USUŃ i potwierdź usunięcie. (Obejmuje instrukcję DELETE lub procedury składowane usuwania, wyzwalacze usuwania).

  • Powtórz te przypadki testowe z nieprawidłowymi danymi i zobacz, jak odpowiada baza danych.

Schemas, tables, stored procedures, i Triggerssą kluczowymi obiektami bazy danych. Udostępniliśmy już typy testów bazy danych i scenariusze testów dla tych obiektów bazy danych.

Schematy

Schemat bazy danych definiuje strukturę systemu baz danych w formacie obsługiwanym przez system zarządzania bazą danych. Schemat odnosi się do struktury bazy danych (składa się z tabel bazy danych w przypadku relacyjnych baz danych).

Schemat bazy danych to zestaw formuł nazywanych ograniczeniami integralności nałożonymi na bazę danych. Te ograniczenia integralności zapewniają zgodność między częściami schematu.

W relacyjnej bazie danych schemat składa się z tabel, pól, widoków, indeksów, pakietów, procedur, funkcji, wyzwalaczy, typów, zmaterializowanych widoków, synonimów, łączy do baz danych i innych elementów.

Schematy są zwykle przechowywane w słowniku danych. Chociaż schemat jest zdefiniowany w tekstowym języku bazy danych, termin ten jest często używany w odniesieniu do graficznego przedstawienia struktury bazy danych. Innymi słowy, schemat to struktura bazy danych, która definiuje obiekty w bazie danych.

Typowe schematy używane w hurtowni danych to -

  • Schemat gwiazdy
  • Schemat płatków śniegu
  • Schemat galaktyki

Tabele w bazie danych

W relacyjnej bazie danych tabela służy do organizowania informacji w wierszach i kolumnach.

Example - Tabela klientów zawiera informacje, takie jak identyfikator klienta, adresy, numery telefonów itp. W postaci serii kolumn.

Każdy pojedynczy fragment danych jest polem w tabeli. Kolumna zawiera wszystkie wpisy w jednym polu, takie jak numery telefonów wszystkich klientów. Pola są zorganizowane w postaci rekordów, czyli pełnych zestawów informacji (takich jak zestaw informacji o konkretnym kliencie), z których każdy zawiera wiersz.

Procedury składowane

Procedura składowana to seria instrukcji SQL przechowywanych w bazie danych w postaci skompilowanej, którą może współużytkować wiele programów. Stosowanie procedur składowanych może być pomocne w utrzymaniu integralności danych, kontroli dostępu do danych i poprawie produktywności.

Wyzwalacze

Wyzwalacz bazy danych to kod wykonywany w odpowiedzi na określone zdarzenia w określonej tabeli lub widoku w bazie danych. Wyzwalacz jest używany głównie do zachowania integralności informacji w bazie danych.

Integralność danych jest ważna w bazie danych. Obejmuje walidację danych przed wstawieniem, aktualizacją i usunięciem. Wyzwalacze muszą być na miejscu, aby sprawdzić poprawność rekordów tabeli odniesień.

Aby sprawdzić integralność danych, musisz wykonać następujące operacje -

  • Musisz sprawdzić główne kolumny w każdej tabeli i sprawdzić, czy istnieją nieprawidłowe dane. (Znaki w polu nazwy, ujemna wartość procentowa itp.)

  • Znajdź niespójne dane i wstaw je do odpowiednich tabel i zobacz, czy wystąpi jakakolwiek awaria.

  • Wstaw dane podrzędne przed wstawieniem danych jego rodzica. Spróbuj usunąć rekord, do którego nadal odwołują się dane z innej tabeli.

  • Jeśli dane w tabeli są aktualizowane, sprawdź, czy zaktualizowane są również inne istotne dane. Musisz upewnić się, że replikowane serwery lub bazy danych są zsynchronizowane i zawierają spójne informacje.

Mapowanie danych w bazie danych jest jedną z kluczowych koncepcji, która musi zostać zweryfikowana przez każdego testera. Zwykle testerzy muszą zweryfikować mapowanie pól interfejsu użytkownika interfejsu użytkownika z odpowiednim polem bazy danych zaplecza.

Te informacje są podane w specyfikacji wymagań oprogramowania lub dokumencie specyfikacji wymagań biznesowych SRS / BRS. Jeśli mapowanie nie jest zapewnione, musisz sprawdzić część kodującą.

Kiedy wykonujesz jakąkolwiek akcję w aplikacji frontonu, wywoływana jest odpowiednia akcja CRUD, a tester musi sprawdzić, czy każda wywołana akcja zakończyła się powodzeniem, czy nie.

Kluczowe aspekty mapowania danych

Poniżej przedstawiono kluczowe aspekty mapowania danych -

  • Aby sprawdzić pola w formularzach interfejsu użytkownika / interfejsu użytkownika i spójnie zmapowane z odpowiednią tabelą bazy danych. Te informacje dotyczące mapowania są zdefiniowane w dokumentach wymagań, jak wspomniano powyżej.

  • W przypadku każdej akcji wykonywanej w interfejsie aplikacji, na zapleczu inicjowana jest odpowiednia akcja CRUD „Utwórz, pobierz, zaktualizuj i usuń”.

  • Tester będzie musiał sprawdzić, czy wywoływana jest właściwa akcja, a wywoływana akcja sama w sobie jest skuteczna, czy nie.

Kroki w testowaniu mapowania danych

Poniżej przedstawiono kroki, które należy wykonać, aby przeprowadzić testowanie mapowania danych -

  • Step 1 - Najpierw sprawdź, czy w każdym skrypcie nie ma błędów składniowych.

  • Step 2 - Następnie należy sprawdzić mapowanie tabeli, mapowania kolumn i mapowania typu danych.

  • Step 3 - Sprawdź mapowanie danych wyszukiwania.

  • Step 4 - Uruchom każdy skrypt, gdy rekordy nie istnieją w tabelach docelowych.

  • Step 5 - Uruchom każdy skrypt, gdy rekordy już istnieją w tabelach docelowych.

Aplikacja z dłuższym czasem odpowiedzi i słabą wydajnością może prowadzić do ogromnych problemów. Testowanie obciążenia bazy danych służy do znajdowania wszelkich problemów z wydajnością przed wdrożeniem aplikacji bazy danych dla użytkowników końcowych.

Testowanie obciążenia bazy danych pomaga zaprojektować aplikację bazy danych pod kątem wydajności, niezawodności i skalowalności. Testowanie obciążenia aplikacji bazy danych obejmuje testowanie wydajności i skalowalności aplikacji bazy danych przy różnym obciążeniu użytkowników.

Testowanie obciążenia bazy danych obejmuje symulację rzeczywistego obciążenia użytkownika dla docelowej aplikacji bazy danych. Pomaga określić, jak zachowuje się aplikacja bazy danych, gdy wielu użytkowników jednocześnie ją odwiedza.

Testowanie obciążenia

Głównym celem testowania obciążenia jest sprawdzenie, czy większość uruchomionych transakcji ma wpływ na wydajność bazy danych. Podczas testowania obciążenia należy sprawdzić następujące aspekty -

  • Należy sprawdzić czas odpowiedzi na wykonanie transakcji dla wielu zdalnych użytkowników.

  • W przypadku normalnych transakcji należy dołączyć jedną transakcję, którą można edytować, aby sprawdzić wydajność bazy danych dla transakcji tego typu pf.

  • W przypadku normalnych transakcji należy dołączyć jedną transakcję bez edycji, aby sprawdzić wydajność bazy danych dla tego typu transakcji.

  • Należy sprawdzić czas potrzebny do pobrania przez bazę danych określonych rekordów.

Test naprężeń

Testy warunków skrajnych są przeprowadzane w celu identyfikacji systemu breakpoint. Tutaj aplikacja jest ładowana w taki sposób, że w pewnym momencie system zawiedzie. Ten punkt nazywany jest punktem przerwania systemu bazy danych. Testowanie warunków skrajnych jest również znane jakoFatigue Testing.

Określenie stanu transakcji w bazie danych wymaga dużego nakładu pracy. Aby uniknąć problemów związanych z czasem i kosztami, wymagane jest właściwe planowanie.

Najpopularniejsze narzędzia do testów warunków skrajnych to LoadRunner i WinRunner.

Istnieją różne narzędzia dostarczane przez dostawców, których można używać do generowania danych testowych, zarządzania danymi testowymi i przeprowadzania testów baz danych, takich jak testy obciążeniowe i testy regresyjne.

Poniżej podano kilka najczęściej używanych narzędzi.

Sr.No Opis kategorii Przykłady
1

Load Testing Tools

Narzędzia te są używane do dużego obciążenia Twojej bazy danych, co pozwala określić, czy krajobraz Twojego systemu sprosta Twoim potrzebom biznesowym.

Wydajność sieci

Rad View

Mercury

2

Data Security Tools

These tools are used to implement compliance and standards as per the information security regulations.

IBM Optim Data Privacy

3

Test Data generator tools

A tester uses these tools to generate the test data for a database system. These are mostly required when you have huge amount of data and you need sample to perform DB Testing. It is commonly used for Load and Stress testing.

Data Factory

DTM Data Generator

Turbo Data

4

Test Data Management Tool

These tools are used to maintain version control for test data. You have to define the expected results and then you compare it with the actual outcomes of the tests.

IBM Optim Test Data Management

5

Tools to perform Unit Testing

These tools are used to perform regression testing on your database.

SQLUnit

TSQLUnit

DBFit

DBUnit

The most important part of an organizational growth is its data. In case of a system failure, there is a need to restore the data. Back up is an exact copy of the database, which helps you to restore your data in case of any data loss.

Consider a finance company which has data related to its customers such as A/C number, customer names, credit and debits, duration, etc. How would such an organization deal with the pressure of losing such important information in case of a data failure?

This is the reason you back up the data so that in case of any failure of a disk, disk controller, etc. you can rely on the backup to restore it into the database.

Types of Data Backups

There are two types of backup that can be used −

  • Physical Backups − Physical backup includes taking back up using third-party backup tools like Veritas Net Back, IBM Tivoli Manager or user manager backups using OS utilities.

  • Logical Backups − Logical backup of database includes taking backups of logical objects like tables, indexes, procedures, etc.

Example − One of common tool to take data backup is Oracle Recovery Manager (RMAN) that is an Oracle utility to take database backup.

RMAN consists of two components −

  • Target database for which backup is required.

  • RMAN client is used to run commands to take data backup.

BACKUP VALIDATE is used to test if you are able to make a valid backup of database files. It ensures −

  • If backup is in place for physical or logical objects of database.
  • If regular backups are set up for invaluable data.
  • If the backup tool meets the backup requirements of an organization.

Database recovery testing is used to ensure that the database is recovered. Recovery testing allows you to find out whether the application is running properly and to check retrieving invaluable data that would have been lost if your recovery method is not properly setup.

You also check if several critical processes are running smooth to ensure that the data recovery will pass smoothly through the testing phase.

You can perform the following checks for database recovery −

  • Any errors or mistakes in the backup software and you need to resolve these issues at an earlier stage.

  • You need to conduct the recovery testing so that you will know what to do in case of an emergency situation.

  • You need to check recovery testing needs so that you can plan for an effective recovery strategy.

  • You should also know how you can recover the documents.

You need to run the recovery tests in early phase of the project. This allows you to remove and throw away every type of errors from the system. Here is a list of some of important points, which should be considered at the time of testing −

  • Time span when changes or modifications occurs in database system.

  • The period by which you want your recovery plan conducted.

  • The sensitivity of data in database system. More critical the data is, the more regularly you will need to test the software.

Common Steps in Database Backup and Recovery Testing

In database recovery testing, you need to run the test in the actual environment to check if the system or the data can actually be recovered in case of any disasters and any other unforeseen events in the business environment.

Given below are the common actions performed in Database Recovery Testing −

  • Testing of database system
  • Testing of the SQL files
  • Testing of partial files
  • Testing of data backup
  • Testing of Backup tool
  • Testing log backups

Database security testing is done to find the loopholes in security mechanisms and also about finding the vulnerabilities or weaknesses of database system.

The main target of database security testing is to find out vulnerabilities in a system and to determine whether its data and resources are protected from potential intruders. Security testing defines a way to identify potential vulnerabilities effectively, when performed regularly.

Given below are the primary objectives of performing database security testing −

  • Authentication
  • Authorization
  • Confidentiality
  • Availability
  • Integrity
  • Resilience

Types of Threats on a Database System

SQL Injection

This is most common type of attack in a database system where malicious SQL statements are inserted in the database system and are executed to get critical information from the database system. This attack takes advantage of loopholes in implementation of user applications. To prevent this, user inputs fields should be carefully handled.

Privilege Elevation in Database

In this attack, a user already has some access in the database system and he only tries to elevate this access higher level so that he/she can perform some unauthorized activities in database system.

Denial of Service

In this type of attack, an attacker makes a database system or application resource unavailable to its legitimate users. Applications can also be attacked in ways that render the application, and sometimes the entire machine, unusable.

Unauthorized Access to data

Another type of attack is gaining unauthorized access to data within an application or database system. Unauthorized access includes −

  • Unauthorized access to data via user based applications
  • Unauthorized access to by monitoring the access of others
  • Unauthorized access to reusable client authentication information

Identity Spoofing

In Identity Spoofing, a hacker uses the credentials of a user or device to launch attacks against network hosts, steal data or bypass access controls to database system. Preventing this attack requires IT-infrastructure and network-level mitigations.

Data Manipulation

In a data manipulation attack, a hacker changes data to gain some advantage or to damage the image of database owners.

Database Security Testing Techniques

Penetration Testing

A penetration test is an attack on a computer system with the intention of finding security loopholes, potentially gaining access to it, its functionality and data.

Risk Finding

Risk Finding is a process of assessing and deciding on the risk involved with the type of loss and the possibility of vulnerability occurrence. This is determined within the organization by various interviews, discussions and analysis.

SQL Injection Test

It involves checking the user inputs in application fields. For example, entering a special character like ‘,’ or ‘;’ in any text box in a user application should not be allowed. When a database error occurs, it means that the user input is inserted in some query, which is then executed by the application. In such a case, the application is vulnerable to SQL injection.

These attacks are a big threat to data as the attackers can get access to important information from the server database. To check SQL injection entry points into your web application, find out code from your code base where direct MySQL queries are executed on the database by accepting some user inputs.

SQL Injection Testing can be performed for Brackets, Commas, and Quotation marks.

Password Cracking

This is the most important check while performing database system testing. To access critical information, hackers can use a password-cracking tool or can guess a common username/password. These common passwords are easily available on internet and also password cracking tools exist freely.

Therefore, it is necessary to check at the time of testing if the password policy is maintained in the system. In case of any banking and finance applications, there is a need to set a strict password policy on all the critical information database systems.

Security Audit of Database System

A security audit is a process of evaluating company’s security policies at a regular time interval to determine whether necessary standards are followed or not. Various security standards can be followed as per business requirement to define the security policy and then assessment of set policies against those standards can be done.

Example of most common security standards are ISO 27001, BS15999, etc.

Database Security Testing Tools

There are various system testing tools available in market, which can be used to test OS and application check. Some of the most common tools are discussed below.

Zed Attack Proxy

It is a penetration-testing tool for finding vulnerabilities in web applications. It is designed to be used by people with a wide range of security experience and as such is ideal for developers and functional testers who are new to penetration testing. It is commonly used for Windows, Linux, Mac OS.

Paros

All HTTP and HTTPS data between server and client, including cookies and form fields, can be intercepted and modified using these scanners. It is used for Cross-platform, Java JRE/JDK 1.4.2 or above.

Social Engineer Toolkit

It is an open source tool and human elements are attacked rather than the system element. It enables you to send emails, java applets etc. containing the attack code. It is preferred for Linux, Apple Mac OS X and Microsoft Windows.

Skipfish

This tool is used to scan their sites for vulnerabilities. Reports generated by the tool are meant to serve as a foundation for professional web application security assessments. It is preferred for Linux, FreeBSD, MacOS X, and Windows.

Vega

It is an open source, multiplatform web security tool that is used to find instances of SQL injection, cross-site scripting (XSS), and other vulnerabilities in web applications. It is preferred for Java, Linux, and Windows.

Wapiti

Wapiti is an open source and web-based tool that scans the web pages of the web application and check for scripts and forms where it can inject data. It is built with Python and can detect File handling errors, Database, XSS, LDAP and CRLF injections, Command execution detection.

Web Scarab

It is written in Java and is used for analyzing the applications that communicate through HTTP/HTTPS protocols. This tool is primarily designed for developers who can write code themselves. This tool is not OS dependent.

To perform database testing successfully, a tester should collect the requirements from all the sources, like technical and functional requirements. There is a possibility that a few requirements are at a high level, so there is a need to breakdown those requirements into the small parts. Testing database is a complex task and the testers face many challenges while performing this testing. Most common database testing challenges are −

Testing scope is too large

A tester needs to identify the test items in database testing otherwise he may not have a clear understanding of what he would test and what he would not test. Therefore, if you are clear on the requirement, you may waste a lot of time testing uncritical objects in the database.

When you have a list of objects to test, next is to estimate the effort required to design the tests and execute the tests for each test item. Depending on their design and data size, some database tests may take a long time to execute.

As the database size is too large, it becomes a big challenge to find out the objects that have to be tested and those which are to be left out.

Scaled-down test database

Normally testers are provided with a copy of the development database to test. That database only have little data, which is sufficient to run the application. So there is a need to test the development, staging and as well as production database system.

Changes in database structure

This is one of the common challenges in DB testing. Sometimes, it happens that you design or execute a test, and the database structure has been changed at that time. This is necessary that you should be aware of the changes made to the database during testing.

Po zmianie struktury bazy danych należy przeanalizować wpływ zmian i zmodyfikować testy. Ponadto, jeśli wielu użytkowników korzysta z testowej bazy danych, nie masz pewności co do wyników testów, więc powinieneś upewnić się, że testowa baza danych jest używana wyłącznie do celów testowych.

Kolejnym wyzwaniem podczas testowania bazy danych jest wykonywanie wielu testów w tym samym czasie. Powinieneś uruchamiać jeden test naraz, przynajmniej w przypadku testów wydajności. Nie chcesz, aby Twoja baza danych wykonywała wiele zadań i miała niską wydajność raportowania.

Złożone plany testów

Struktura bazy danych jest zwykle złożona i zawiera ogromne ilości danych, więc istnieje możliwość, że wielokrotnie wykonujesz niekompletne lub te same testy. Dlatego istnieje potrzeba stworzenia planu testów i postępowania zgodnie z nim oraz regularnego sprawdzania postępów.

Dobra znajomość języka SQL

Aby przetestować bazę danych, należy dobrze znać zapytania SQL i wymagane narzędzia do zarządzania bazą danych.

Testowanie bazy danych obejmuje sprawdzanie poprawności danych, testowanie integralności danych, kontrolę wydajności związaną z bazą danych oraz testowanie procedur, wyzwalaczy i funkcji w bazie danych.

Istnieje wiele powodów, dla których przeprowadza się testy bazy danych. Istnieje potrzeba przeprowadzania integralności danych, walidacji i sprawdzania spójności danych w bazie danych, ponieważ system zaplecza jest odpowiedzialny za przechowywanie danych i jest dostępny w wielu celach.

Niektóre z typowych powodów, dla których należy przeprowadzić testy bazy danych, są następujące:

  • Aby uprościć złożoność wywołań zaplecza bazy danych, programiści zwiększają użycie View i Stored Procedury.

  • Te Stored procedury i Viewszawierają krytyczne zadania, takie jak wprowadzanie danych klienta (imię i nazwisko, dane kontaktowe itp.) oraz danych sprzedaży. Zadania te należy przetestować na kilku poziomach.

  • Testowanie czarnoskrzynkowe wykonywane na front-endzie jest ważne, ale utrudnia wyodrębnienie problemu. Testowanie w systemie zaplecza zwiększa niezawodność danych. Dlatego testowanie bazy danych jest wykonywane w systemie zaplecza.

  • W bazie danych dane pochodzą z wielu aplikacji i istnieje możliwość, że w bazie danych są przechowywane szkodliwe lub nieprawidłowe dane. Dlatego konieczne jest regularne sprawdzanie składników bazy danych. Ponadto należy regularnie sprawdzać integralność i spójność danych.

Kroki, które należy wykonać podczas testowania bazy danych, są następujące -

  • Dane znajdujące się w bazie danych muszą zostać zweryfikowane.
  • Sprawdź, czy ograniczenia są zachowane.
  • Należy sprawdzić działanie procedur i wykonanie wyzwalaczy.
  • Należy sprawdzić wycofanie i zatwierdzenie transakcji.

Na podstawie funkcji i struktury bazy danych testy DB można podzielić na następujące kategorie -

  • Structural Database testing - Zajmuje się testowaniem tabel i kolumn, testowaniem schematów, testowaniem procedur składowanych i widoków, sprawdzaniem wyzwalaczy itp.

  • Functional Testing- Polega na sprawdzeniu funkcjonalności bazy danych z punktu widzenia użytkownika. Najbardziej powszechnym typem testów funkcjonalnych są testy białoskrzynkowe i testy czarnoskrzynkowe.

  • Nonfunctional Testing - Obejmuje testy obciążenia, testy ryzyka w bazie danych, testy warunków skrajnych, minimalne wymagania systemowe i zapewnia wydajność bazy danych.

Najpopularniejszymi narzędziami używanymi do przeprowadzania testów procedur składowanych są LINQ, narzędzie SP Test itp.

Łączenia służą do łączenia dwóch lub więcej tabel w logiczny sposób. Typowe typy sprzężeń to: Łączenie wewnętrzne, Łączenie nierównomierne, Łączenie zewnętrzne, Łączenie samoczynne i Łączenie krzyżowe.

Możesz dołączyć do jednego stołu. W takim przypadku używasz dwukrotnie tej samej tabeli.

Step 1 - Połącz się z bazą danych

db_connect(query1 DRIVER {drivername};SERVER server_name;UID uidname;
   PWD password;DBQ database_name );

Step 2 - Wykonaj zapytanie do bazy danych -

db_excecute_query (write the required query that is to execute); Specify the appropriate condition

Step 3 - Rozłącz połączenie z bazą danych za pomocą

db_disconnect(query);

Korzystając z punktów kontrolnych wyjściowej bazy danych, należy wybrać opcje ręcznych zapytań SQL. Tutaj można zapisać zapytanie wybierające.

Najpierw sprawdź wymagania procedury składowanej. Następnym krokiem jest sprawdzenie, czy indeksy, złączenia, usunięcia, aktualizacja są poprawne w porównaniu z tabelami wymienionymi w procedurze składowanej.

Następnie wykonaj następujące czynności -

  • Sprawdź poprawność nazwy procedury wywołującej, parametrów wywołania i oczekiwanych odpowiedzi dla różnych zestawów parametrów wejściowych.

  • Wykonaj procedurę za pomocą TOAD, MySQL lub Query Analyzer.

  • Wykonaj ponownie dostępne procedury, wysyłając różne parametry i porównaj wyniki z oczekiwanymi wartościami.

  • Podsumowując, zautomatyzuj testy za pomocą programu WinRunner.

Tester powinien wywołać procedurę składowaną w bazie danych za pomocą polecenia EXEC. Jeśli jakieś parametry są wymagane, należy je przekazać. Aby potwierdzić, czy procedura składowana jest wykonywana, czy nie, należy przekazać różne wartości parametrów. Wywołując to polecenie, musi sprawdzić i zweryfikować charakter i zachowanie bazy danych.

Example - Jeśli zapisano procedurę składowaną w celu zapełnienia jakiejś tabeli, należy sprawdzić wartości tabeli.

Mamy trzy typy instrukcji SQL -

  • Język manipulacji danymi (DML)
  • Język definicji danych (DDL)
  • Język kontroli danych (DCL)

Instrukcje DDL służą do definiowania struktury lub schematu bazy danych. Kilka przykładów -

  • CREATE - do tworzenia obiektów w bazie danych

  • ALTER - zmienia strukturę bazy danych

  • DROP - usuń obiekty z bazy danych

Operatory służą do określania warunków w instrukcji SQL i służą jako spójniki dla wielu warunków w instrukcji.

  • Operatory arytmetyczne
  • Operatory porównania / relacyjne
  • Operatory logiczne
  • Operatory zbioru
  • Operatory używane do negowania warunków

Union służy do łączenia wyników dwóch lub więcej instrukcji Select. Jednak wyeliminuje zduplikowane wiersze. Unia jest operatorem zbioru.

Unionsłuży do łączenia wyników dwóch lub więcej instrukcji Select. Jednak wyeliminuje zduplikowane wiersze

Union All operacja jest podobna do Union, ale pokazuje również zduplikowane wiersze.

Wyzwalacze służą do zachowania integralności bazy danych. Aby sprawdzić, czy wyzwalacz jest uruchomiony, czy nie, możesz sprawdzić dzienniki inspekcji.

Wyzwalaczy nie można wywoływać na żądanie. Są wywoływane, gdy skojarzona akcja (wstawianie, usuwanie i aktualizowanie) ma miejsce w tabeli, na której są zdefiniowane. Wyzwalacze służą do stosowania reguł biznesowych, przeprowadzania audytów, a także do sprawdzania integralności referencyjnej.

Najpierw uzyskaj wymagania funkcjonalne. Następnie zapoznaj się ze strukturą tabeli, połączeniami, kursorami i wyzwalaczami, zastosowaną procedurą składowaną i innymi parametrami. Następnie możesz napisać przypadek testowy z różnymi wartościami jako danymi wejściowymi dla tych obiektów.

Testowanie bazy danych polega na testowaniu komponentów zaplecza, które nie są widoczne dla użytkowników. Obejmuje komponenty baz danych i systemy DBMS, takie jak MySQL i Oracle.

Testowanie front-end polega na sprawdzeniu funkcjonalności aplikacji i jej komponentów, takich jak formularze, wykresy, menu, raporty itp. Komponenty te są tworzone przy użyciu narzędzi programistycznych typu front-end, takich jak VB.net, C #, Delphi itp.

Proces testowania bazy danych jest podobny do testowania innych aplikacji. Testowanie bazy danych można opisać za pomocą następujących kluczowych procesów -

  • Przygotowanie środowiska
  • Uruchom test
  • Sprawdź wynik testu
  • Weryfikacja zgodnie z oczekiwanymi wynikami
  • Zgłoś ustalenia odpowiednim zainteresowanym stronom

Do tworzenia przypadków testowych używane są różne instrukcje SQL. Najpopularniejszą instrukcją SQL używaną do testowania bazy danych jest instrukcja select. Oprócz tego można również używać różnych instrukcji DDL, DML, DCL.

Example - Tworzenie, wstawianie, wybieranie, aktualizowanie itp.

Widok to tabela, która w rzeczywistości nie istnieje sama w sobie, ale zamiast tego pochodzi z co najmniej jednej tabeli bazowej. Innymi słowy, nie ma przechowywanego pliku, który bezpośrednio reprezentuje widok, zamiast tego definicja widoku jest przechowywana w słowniku danych.

Wzrost i restrukturyzacja tabel podstawowych nie jest odzwierciedlany w widokach. W ten sposób widok może odizolować użytkowników od zmian w bazie danych. Stąd bierze się pod uwagę logiczną niezależność danych.

Określa widoki użytkownika i ich odwzorowania na schemat koncepcyjny.

Jest to proces dekompozycji tabeli na wiele tabel bez utraty jakichkolwiek informacji. Normalizacja ma na celu osiągnięcie następujących celów -

  • Aby zminimalizować nadmiarowość.
  • Aby zminimalizować wstawianie, usuwanie i aktualizowanie anomalii.

Indeksowanie to technika określania, jak szybko można znaleźć określone dane. Służy do optymalizacji wydajności zapytań. Indeksowanie może mieć następujące typy -

  • Indeksowanie w stylu wyszukiwania binarnego
  • Indeksowanie B-Tree
  • Odwrócone indeksowanie list
  • Tabela rezydentna pamięci
  • Indeksowanie tabel

SQL to język zapytań strukturalnych, który został zaprojektowany specjalnie do wykonywania operacji dostępu do danych w znormalizowanych strukturach relacyjnych baz danych.

Podstawowa różnica między SQL a innymi konwencjonalnymi językami programowania polega na tym, że instrukcje SQL określają, jakie operacje na danych powinny być wykonywane, a nie jak je wykonywać.

Procedury składowane służą do wykonywania operacji zdefiniowanych przez użytkownika. Procedura składowana może mieć zestaw złożonych instrukcji SQL. Procedura składowana wykonuje polecenia SQL i zwraca wynik do klienta.

PL / SQL używa kursorów do wszystkich instrukcji dostępu do informacji w bazie danych. Język obsługuje dwa typy kursorów - niejawne i jawne.

Cold Backup- Zimny ​​powrót jest znany jako tworzenie kopii zapasowych plików bazy danych, ponowne wykonywanie dzienników i plik kontrolny, gdy instancja jest zamykana. Jest to kopia pliku, zwykle z dysku bezpośrednio na taśmę. Musisz zamknąć instancję, aby zagwarantować spójną kopię.

Jeśli wykonywana jest zimna kopia zapasowa, jedyną opcją dostępną w przypadku utraty pliku danych jest przywrócenie wszystkich plików z najnowszej kopii zapasowej. Wszystkie zmiany wprowadzone po ostatniej kopii zapasowej zostaną utracone.

Hot Backup- Niektórych baz danych nie można zamknąć podczas tworzenia kopii zapasowej plików, dlatego zimna kopia zapasowa nie jest dostępna. W przypadku tego typu baz danych używamy kopii zapasowej na gorąco.

Podzapytanie SQL służy do wysyłania zapytań do dwóch lub więcej tabel w tym samym czasie. Samo podzapytanie jest instrukcją SQL SELECT zawartą w klauzuli WHERE innej instrukcji SQL SELECT i oddzieloną za pomocą nawiasów. Niektóre podzapytania mają równoważne struktury łączenia SQL, ale skorelowanych podzapytań nie można powielić przez łączenie

W takim przypadku musisz przetestować następujące aspekty -

  • Zależności wielowartościowe
  • Zależności funkcjonalne
  • Klucze kandydatów
  • Klucze podstawowe
  • Klucz obcy

Możesz przejść do bazy danych i uruchomić odpowiednie zapytanie SQL. W WinRunner możesz skorzystać z funkcji punktu kontrolnego bazy danych. Jeśli aplikacja zapewnia funkcję widoku, możesz to sprawdzić z poziomu interfejsu użytkownika.

Testowanie oparte na danych jest definiowane jako proces testowania automatyzacji, w którym aplikacja będzie testowana przy użyciu wielu danych testowych. Jest to proste i łatwe niż ponowne testowanie, w którym tester po prostu siedzi przed systemem i ręcznie wprowadza różne nowe wartości wejściowe z interfejsu front-end.

Po wykonaniu przypadków testowych i znalezieniu defektów, które zostały już wykryte i naprawione. Ponowne wykonanie tego samego testu z różnymi wartościami wejściowymi w celu potwierdzenia, że ​​pierwotna usterka została pomyślnie usunięta, nazywa się ponownym testowaniem.

Ponowne testowanie jest również nazywane testowaniem opartym na danych z niewielką różnicą -

  • Retesting - Jest to proces ręcznego testowania, podczas gdy testowanie aplikacji odbywa się z wykorzystaniem całego nowego zestawu danych.

  • Data-driven Testing- Jest to proces testowania automatyzacji, w którym aplikacja będzie testowana na wielu danych testowych. Jest to proste i łatwe niż ponowne testowanie, w którym tester po prostu siedzi przed systemem i ręcznie wprowadza różne nowe wartości wejściowe z interfejsu front-end.

Istnieją cztery typy testów opartych na danych -

  • Dynamiczne przesyłanie danych testowych za pomocą klawiatury
  • Testy oparte na danych za pośrednictwem plików płaskich .txt, .doc
  • Testy oparte na danych za pośrednictwem obiektów front-end
  • Testy oparte na danych za pośrednictwem arkusza Excel

Testowanie wydajności to technika testowania oprogramowania służąca do określenia, jak system działa pod względem szybkości, czułości i stabilności przy dużym obciążeniu.

Podczas testowania odzyskiwania bazy danych należy wziąć pod uwagę następujące kluczowe punkty:

  • Przedział czasu, w którym zmiany lub modyfikacje zachodzą w systemie bazy danych.

  • Okres, w którym plan odzyskiwania ma być realizowany.

  • Wrażliwość danych w systemie bazodanowym. Im bardziej istotne są dane, tym częściej będziesz musiał testować oprogramowanie.

Do generowania danych testowych służą następujące narzędzia -

  • Data Factory
  • Generator danych DTM
  • Dane Turbo

Istnieją dwa typy kopii zapasowych, których można użyć -

  • Physical Backups- backup fizyczny obejmuje podejmowanie wykonać kopię zapasową przy użyciu 3 rd narzędzia zapasowych partia jak Veritas tyłu netto, IBM Tivoli Manager lub użytkowników kopii zapasowych Manager za pomocą narzędzi systemu operacyjnego.

  • Logical Backups - Logiczna kopia zapasowa bazy danych obejmuje tworzenie kopii zapasowych obiektów logicznych, takich jak tabele, indeksy, procedury itp.

Powszechnym narzędziem do tworzenia kopii zapasowych danych jest Oracle Recovery Manager (RMAN), czyli narzędzie Oracle do tworzenia kopii zapasowych bazy danych.

Podczas testowania odzyskiwania bazy danych wykonywane są następujące czynności -

  • Testowanie systemu baz danych
  • Testowanie plików SQL
  • Testowanie plików częściowych
  • Testowanie kopii zapasowych danych
  • Testowanie narzędzia Backup
  • Testowanie kopii zapasowych dziennika

Testy bezpieczeństwa bazy danych są przeprowadzane w celu znalezienia luk w mechanizmach bezpieczeństwa, a także znalezienia luk lub słabości systemu bazy danych.

Testy bezpieczeństwa bazy danych są przeprowadzane w celu sprawdzenia następujących aspektów -

  • Authentication
  • Authorization
  • Confidentiality
  • Availability
  • Integrity
  • Resilience

Zagrożenie SQL Injection to najczęstszy rodzaj ataku w systemie baz danych, w którym złośliwe instrukcje SQL są wstawiane do systemu bazy danych i wykonywane w celu uzyskania krytycznych informacji z systemu bazy danych. Atak ten wykorzystuje luki w implementacji aplikacji użytkownika. Aby temu zapobiec, należy ostrożnie obchodzić się z polami wprowadzanymi przez użytkownika.

Do testowania bezpieczeństwa bazy danych można użyć następujących narzędzi: Zed Attack Proxy, Paros, Social Engineer Toolkit, Skipfish, Vega, Wapiti i Web Scarab.

Typowe wyzwania, przed którymi stoi się podczas testowania bazy danych, są następujące:

  • Zakres testowy jest za duży
  • Skalowana testowa baza danych
  • Zmiany w strukturze bazy danych
  • Złożone plany testów
  • Dobra znajomość języka SQL