Projekty testowe NUnit czy Visual Studio 2008 do testowania jednostkowego? [Zamknięte]


254

Zamierzam rozpocząć nowy projekt w pracy i chcę przejść do testów jednostkowych. Będziemy używać VS 2008, C # i ASP.NET MVC. Rozważam użycie NUnit lub wbudowanych projektów testowych VS2008, ale jestem otwarty na badanie innych sugestii. Czy jeden system jest lepszy od drugiego, a może łatwiejszy w użyciu / zrozumieniu niż drugi? Chcę, aby ten projekt został ustanowiony jako „najlepsza praktyka” dla naszych dalszych wysiłków rozwojowych.

Dzięki za wszelką pomoc i sugestie !!

Odpowiedzi:


99

Daok wymienił wszystkich pro projektów testowych VS2008, oto pro NUnit.

  • NUnit ma frameworki.
  • NUnit można uruchomić poza środowiskiem IDE, może to być przydatne, jeśli chcesz uruchomić testy na serwerze kompilacji innym niż MS, takim jak CC.Net
  • NUnit ma więcej wersji niż studio graficzne. Nie musisz czekać lat na nową wersję I nie musisz instalować nowej wersji IDE, aby uzyskać nowe funkcje.
  • Opracowywane są rozszerzenia dla NUnit, takie jak testy wierszy itp.
  • Z jakiegoś powodu testy Visual Studio trwają długo. Tak jest lepiej w 2008 r., Ale wciąż jest zbyt powolny jak na mój gust. Szybkie uruchomienie testu, aby sprawdzić, czy coś nie popsuło, może zająć zbyt długo. NUnit z czymś takim jak Testdriven.Net do uruchamiania testów z IDE jest w rzeczywistości znacznie szybszy. szczególnie podczas wykonywania pojedynczych testów.
    Według Kjetil Klaussen jest to spowodowane przez testrunner Visual Studio, uruchomienie testów MSTest w TestDriven.Net sprawia, że ​​wydajność MSTest jest porównywalna z NUnit.

19
Czy nie możesz po prostu użyć mstest.exe do uruchomienia testów MSTest poza IDE?
Phillip Wells,

13
Nunit posiadający kpiące ramy nie jest dużą zaletą. Korzystam z projektów testów jednostkowych VS 2008 ze strukturą Moq, która wykorzystuje nowatorskie podejście, wykorzystując drzewa wyrażeń LINQ: code.google.com/p/moq
DSO

5
Jeszcze jeden plus dla Nunit, dla mnie, jest to, że Resharper ma bardzo ładny interfejs użytkownika, który jest znacznie szybszy niż komponenty testujące VS. Hiperłącza nawet ślad stosu nieudanych testów do kodu.
Jeff Putz

7
Testy jednostkowe są zawarte w profesjonalnej wersji VS 2008.
użytkownik179700

3
@Jeff Putz: Resharper może również uruchamiać testy jednostkowe Visual Studio, nawet poza projektem testowym.
Paul Ruane

64

Struktura testowania jednostkowego nie ma większego znaczenia, ponieważ można konwertować klasy testowe za pomocą osobnych plików projektu i kompilacji warunkowej (np. VS-> NUnit):

 #if! NUNIT
  using Microsoft.VisualStudio.TestTools.UnitTesting;
 #jeszcze
  using NUnit.Framework;
  using TestClass = NUnit.Framework.TestFixtureAttribute;
  using TestMethod = NUnit.Framework.TestAttribute;
  using TestInitialize = NUnit.Framework.SetUpAttribute;
  using TestCleanup = NUnit.Framework.TearDownAttribute;
  using TestContext = System.String;
  using DeploymentItem = NUnit.Framework.DescriptionAttribute;
 #endif

Wtyczka TestDriven.Net jest ładna i niezbyt droga ... Z samym zwykłym VS2008 musisz znaleźć test z klasy testów lub listy testów. Dzięki TestDriven.Net możesz uruchomić test bezpośrednio z testowanej klasy. W końcu test jednostkowy powinien być łatwy w utrzymaniu i znajdować się w pobliżu dewelopera.


12
Głosowałem za tym, ponieważ NUnit ma bogatszą składnię niż MSTest, co oznacza, że ​​możesz przejść z MSTest -> NUnit, ale nie odwrotnie, chyba że BARDZO jesteś ostrożny. Historia pokazuje, że przynajmniej jeden z nas nie jest.
Thomas Eyde,

2
Zgadzam się z Thomasem. Działa to przy założeniu, że używasz najbardziej podstawowych instrukcji aser, ale model ograniczenia NUnit jest bardzo wydajny i wystarczający powód, aby wybrać NUnit zamiast MSTest.
Mark

Wierzę, że to podejście jest wzięte przez wzorzec ms i grupę ćwiczeń w testach EntLib.
robi-y

1
@ Dan Neely, jeśli testujesz szeregowców, robisz to źle :(
JDPeckham

2
@JDPeckham Nie twierdzę, że konwencje tego, co należy / nie należy robić za pomocą narzędzia, nie są ważne, ale pod koniec dnia najważniejsze jest wykonanie pracy. Jeśli to oznacza wbicie gwoździa w tylną stronę siekiery, ponieważ sprzedawcy narzędzi nie sprzedają młotków, producenci siekiery będą musieli żyć z oburzenia.
Dan Is Fiddling By Firelight

34

Korzyści / zmiany we wbudowanym systemie testowania jednostek VS2008

  1. Wersja 2008 jest teraz dostępna w profesjonalnych wersjach (zanim wymagała drogich wersji VS, jest to tylko do testowania jednostek programistycznych). Pozostawiono wielu programistom jedyny wybór otwartych / zewnętrznych ram testowych.
  2. Wbudowany interfejs API obsługiwany przez jedną firmę.
  3. Użyj tych samych narzędzi, aby uruchomić i utworzyć testy (możesz je uruchomić przy użyciu wiersza polecenia, również MSTest)
  4. Prosta konstrukcja (nie ma frameworku Mock, ale jest to świetny punkt wyjścia dla wielu programistów)
  5. Udzielono długoterminowego wsparcia (wciąż pamiętam, co stało się z nDoc, nie chcę angażować się w ramy testowe, które mogą nie być obsługiwane za 5 lat, ale nadal uważam nUnit za świetny framework).
  6. Jeśli używasz serwera Foundation Foundation jako zaplecza, możesz w prosty sposób tworzyć elementy pracy lub błędy z nieudanymi danymi testowymi.

4
Myślę, że wciąż mówi o poglądach Microsoftu na testowanie, że NIE jest on w wersji Standard, tylko Professional i nowszej.
J Wynia

Zgadzam się, chciałbym zobaczyć to w standardzie i wyżej. W wersjach ekspresowych dla początkujących będzie to przesada.
Simara,

1
@J Wynia: Czytanie ich decyzji o umieszczeniu go tylko w wersji Professional i wyższej, ponieważ mówienie czegoś o ich opinii na temat testowania jest zbyt duże. Bardziej prawdopodobne jest, że jest to decyzja biznesowa niż filozoficzna.
jason

@Simara Testowanie powinno być nieodłącznym elementem cyklu rozwojowego. Należy go podawać w wydaniach ekspresowych.
eastender

33

Używam NUnit od 2 lat. Wszystko w porządku, ale muszę powiedzieć, że system jednostek w VS jest całkiem fajny, ponieważ znajduje się w GUI i może łatwiej wykonać test funkcji prywatnej bez konieczności bałaganu. Testowanie jednostkowe VS pozwala także na wykonywanie czynności obejmujących i innych rzeczy, których sam NUnit nie jest w stanie zrobić.


44
Nie powinieneś dotykać swoich szeregowych. Pomijając żart, jedna szkoła myśli jest taka, że ​​wszystko czego potrzebujesz do testu to metody publiczne. Wywoływanie wszystkich metod publicznych powinno wywoływać wszystkie metody prywatne. Jeśli metoda prywatna nie jest wywoływana za pomocą metody publicznej, metoda prywatna jest zbędna.
Lieven Keersmaekers

7
@Lieven: jeśli testujesz osoby prywatne, naprawdę robisz test integracyjny, a nie test jednostkowy. (Oczywiście nie jestem fanatykiem TDD i prawdopodobnie po prostu przetestowałbym publiczność ... ale mam ochotę pomóc w rozpoczęciu walki)
Matthew Whited

11
@Matthew, testy integracyjne testują dwie lub więcej jednostek razem. Testowanie metod prywatnych jest po prostu (ogromnym) naruszeniem enkapsulacji i może prowadzić do kruchych testów jednostkowych, które należy modyfikować za każdym razem, gdy wprowadzane są zmiany w implementacji.
Omer Rauchwerger,

3
Możesz także użyć [assembly: InternalsVisibleTo (...)] z dyrektywą kompilatora, aby usunąć go podczas tworzenia kompilacji RTM.
Iain Galloway

1
Cały czas dotykam moich szeregów :) Myślę, że szczególnie warto testować członków prywatnych, aby uniknąć narzutu związanego z testowaniem rozmówców, które wymagają wielu skomplikowanych ustawień.
Crackerjack,

14

Niewielką irytacją frameworka testowego Visual Studio jest to, że utworzy on wiele plików uruchomień testowych, które mają tendencję do zaśmiecania katalogu projektu - choć nie jest to aż tak duże.

Ponadto, jeśli brakuje wtyczki, takiej jak TestDriven.NET, nie można debugować testów jednostkowych NUnit (lub MbUnit, xUnit itp.) W środowisku Visual Studio, jak to możliwe dzięki wbudowanemu środowisku testowemu Microsoft VS.


3
Możesz debugować testy NUnit w Visual Studio 2005.
Jason Short

Możesz także debugować Xunit, ale nie jest oczywiste, jak to skonfigurować (strona właściwości)
annakata

1
Możesz łatwo debugować NUnit, dołączając debugera do działającego procesu NUnit, jak powiedział grimus. Nie ma tutaj prawdziwej wady.
Anne Schuessler,

1: Liczba testów konfigurowalnych w ustawieniach VS - ustawiłem na jeden. 2: Zgadzam się z powyższymi komentarzami - możliwe, ale niezręczne, 3: Ogólnie rzecz biorąc, wolę wbudowane środowisko testowe VS.
RaoulRubin

14

Nie na temat, ale jeśli korzystasz z NUnit, mogę polecić użycie ReSharper - dodaje kilka przycisków do interfejsu użytkownika VS, które znacznie ułatwiają uruchamianie i debugowanie testów z poziomu IDE.

Ta recenzja jest nieco nieaktualna, ale wyjaśnia to bardziej szczegółowo:

http://codebetter.com/blogs/paul.laudeman/archive/2006/08/15/Using-ReSharper-as-an-essential-part-of-your-TDD-toolkit.aspx


Dzięki wtyczce Gallio do R # możesz również uruchomić MSTest.
Kjetil Klaussen

CodeRush umieszcza ikony w testach bezpośrednio w kodzie, abyś mógł uruchomić jeden test lub wszystkie testy w klasie lub w przestrzeni nazw. Zobacz tutaj: community.devexpress.com/blogs/markmiller/archive/2009/11/16/…
Ryan Lundy

Resharper przeprowadzi również testy MSTest.
JDPeckham


11

Moja główna wołowina z testami jednostkowymi VS nad NUnit polega na tym, że tworzenie testów VS zwykle wstrzykuje wiązkę wygenerowanego kodu dla dostępu prywatnego członka.

Niektórzy mogą chcieć przetestować swoje prywatne metody, inni nie, to inny temat.

Obawiam się, że kiedy piszę testy jednostkowe, powinny one być bardzo kontrolowane, więc wiem dokładnie, co testuję i jak to testuję. Jeśli jest kod generowany automatycznie, tracę część tego prawa własności.


11

Zrobiłem trochę TDD przy użyciu obu i (może jestem trochę głupi) nUnit wydaje się być o wiele szybszy i prostszy w użyciu dla mnie. A kiedy dużo mówię, dużo mam na myśli.

W MS Test wszędzie jest zbyt wiele atrybutów - kodem wykonującym prawdziwe testy są małe linie, które możesz przeczytać tu i tam. Wielki bałagan. W nUnit kod wykonujący test dominuje atrybuty, tak jak powinien.

Ponadto w nUnit wystarczy kliknąć testy, które chcesz uruchomić (tylko jeden? Wszystkie testy obejmujące klasę? Zestaw? Rozwiązanie?). Jedno kliknięcie. A okno jest czyste i duże. Dostajesz jasne zielone i czerwone światła. Naprawdę wiesz, co dzieje się w jednym widoku.

W VSTS lista testów jest zablokowana w dolnej części ekranu, jest mała i brzydka. Musisz spojrzeć dwa razy, aby wiedzieć, co się stało. I nie możesz uruchomić tylko jednego testu (cóż, jeszcze się nie dowiedziałem!).

Ale oczywiście mogę się mylić - właśnie przeczytałem około 21 postów na blogu na temat „Jak zrobić proste TDD za pomocą VSTS”. Powinienem był przeczytać więcej, masz rację.

Dla nUnit czytam jeden. A ja byłem TDD tego samego dnia. Z zabawą.

Nawiasem mówiąc, zazwyczaj uwielbiam produkty Microsoft. Visual Studio jest naprawdę najlepszym narzędziem, jakie może kupić programista - ale TDD i zarządzanie elementami roboczymi w Visual Studio Team System jest do kitu.

Wszystkiego najlepszego. Sylvain.


9

Dostaję wiadomości, że „struktura plików NUnit jest bogatsza niż VSTest” ... Oczywiście jeśli wolisz strukturę plików NUnit, możesz użyć tego rozwiązania w inny sposób, na przykład (NUnit-> VS):

 #if !MSTEST
  using NUnit.Framework;
 #else
  using Microsoft.VisualStudio.TestTools.UnitTesting;
  using TestFixture = Microsoft.VisualStudio.TestTools.UnitTesting.TestClassAttribute;
  using Test = Microsoft.VisualStudio.TestTools.UnitTesting.TestMethodAttribute;
  using SetUp = Microsoft.VisualStudio.TestTools.UnitTesting.TestInitializeAttribute;
  using TearDown = Microsoft.VisualStudio.TestTools.UnitTesting.TestCleanupAttribute;
 #endif

Lub dowolna inna konwersja ... :-) To użycie tutaj jest tylko aliasem dla kompilatora.


1
Nie rozumiem co tu mówisz.
PositiveGuy

brak konfiguracji poziomu wyposażenia / porzucenia :( czy zakładają, że używamy ctor i dtor?
JDPeckham

9

Najpierw chcę poprawić niepoprawne zdanie: możesz uruchomić msTest poza Visual Studio za pomocą wiersza poleceń. Chociaż kilka narzędzi CI, takich jak TeamCity, ma lepszą obsługę NUnit (prawdopodobnie zmieniłoby się, gdy msTest stałby się bardziej popularny). W moim obecnym projekcie używamy obu, a jedyną dużą różnicą, jaką znaleźliśmy, jest to, że mstest zawsze działa jako 32-bitowy, podczas gdy NUnit działa jako test 32-bitowy lub 64-bitowy, co ma znaczenie tylko wtedy, gdy Twój kod używa kodu natywnego, który jest zależny od 32/64.


8

Zacząłem od MSTest, ale zmieniłem z jednego prostego powodu. MSTest nie obsługuje dziedziczenia metod testowych z innych zespołów.

Nienawidziłem pomysłu napisania tego samego testu wiele razy. Zwłaszcza w dużym projekcie, w którym metody testowe mogą z łatwością przejść do setek testów.

NUnit robi dokładnie to, czego potrzebuję. Jedyne, czego brakuje w NUnit, to dodatek Visual Studio, który może wyświetlać status Czerwonego / Zielonego (jak VSTS) każdego testu.



7

Jeśli zastanawiasz się nad MSTest lub nUnit, polecam przyjrzeć się mbUnit. Moje powody są

  1. Kompatybilność z TestDriven.Net. TestyDriven.Net.ReRunWithDebugger nie są powiązane z kombinacją klawiszy.
  2. Ramy Gallio. Gallio jest biegaczem testowym, jak nUnits. Jedyna różnica polega na tym, że nie ma znaczenia, czy testy zostały napisane w nUnit, msTest, xUnit lub mbUnit. Wszyscy uciekają.
  3. Kompatybilność z nUnit. Wszystkie funkcje w nUnit są obsługiwane przez mbUnit. Myślę, że nawet nie musisz zmieniać swoich atrybutów (musisz to sprawdzić), tylko swoje referencje i zastosowania.
  4. Kolekcja twierdzi. mbUnit ma więcej przypadków Assert, w tym klasę CollectionAssert. Zasadniczo nie musisz już pisać własnych testów, aby sprawdzić, czy 2 kolekcje są takie same.
  5. Testy kombinatoryczne. Czy nie byłoby fajnie, gdybyś mógł dostarczyć dwa zestawy danych i przetestować wszystkie kombinacje danych. Jest w mbUnit.

Pierwotnie wybrałem mbUnit ze względu na jego funkcjonalność [RowTest ....] i nie znalazłem żadnego powodu, aby wrócić. Przeniosłem wszystkie moje aktywne zestawy testów z nUnit i nigdy nie oglądałem się za siebie. Od tego czasu przekonałem dwa różne zespoły programistów do korzyści.


6

O ile mi wiadomo, obecnie dostępne są cztery frameworki do testowania jednostkowego w .NET

  • NUnit
  • MbUnit
  • MSTest
  • xUnit

NUnit zawsze był na czele, ale luka zniknęła w ciągu ostatniego roku. Nadal wolę NUnit, zwłaszcza że dodali jakiś płynny interfejs, dzięki czemu testy są bardzo czytelne.

Jeśli dopiero zaczynasz testować jednostki, prawdopodobnie nie ma to większego znaczenia. Gdy osiągniesz maksymalną prędkość, będziesz w stanie lepiej ocenić, który system najlepiej odpowiada Twoim potrzebom.


6

Nie podoba mi się wbudowana platforma testowa VS, ponieważ zmusza cię to do utworzenia osobnego projektu, a nie do testowania go jako części projektu, który testujesz.


3
Możesz oszukać program Visual Studio, ręcznie edytując pliki projektu i dodając wartości ProjectTypeGuids, które wykorzystuje do identyfikacji projektów testowych: <ProjectTypeGuids & gt; {3AC096D0-A1C2-E12C-1390-A8335801FDAB}; {FAE04EC0-301F-11D3- BF4B-00C04F79EFBC} </ ProjectTypeGuids & gt;
Paul Ruane

5

MSTest jest zasadniczo nieco przerobiony przez NUnit, z kilkoma nowymi funkcjami (takimi jak konfiguracja zestawu i porzucenie, nie tylko poziom urządzenia i poziom testowy), i brakuje niektórych najlepszych bitów (takich jak nowa składnia ograniczenia 2.4). NUnit jest bardziej dojrzały i jest obsługiwany przez innych dostawców; i oczywiście, ponieważ zawsze był darmowy (podczas gdy MSTest dostał się tylko do wersji Professional 2008, wcześniej było to o wiele droższe SKU), większość projektów ALT.NET go używa.

To powiedziawszy, jest kilka firm, które są bardzo niechętne do używania czegoś, co nie ma etykiety Microsoft, a zwłaszcza kodu OSS. Posiadanie oficjalnych ram testów MS może być motywacją, że firmy te muszą przejść testy; i bądźmy szczerzy, liczy się testowanie, a nie to, jakiego narzędzia używasz (i korzystając z powyższego kodu Tuomasa Hietanena , możesz niemalże zamienić swój szkielet testowy na wymienny).


Uwielbiam składnię przeciwwskazań NUnit, ale myślę, że powinieneś przeczytać to w odniesieniu do SetUpi TearDownatrybutów: jamesnewkirk.typepad.com/posts/2007/09/why-you-should-.html
Nikt

4

Wraz z wydaniem w .NET 4.0 systemu Code Contracts i dostępnością sprawdzania statycznego będziesz musiał teoretycznie napisać mniej przypadków testowych, a narzędzie takie jak Pex pomoże zidentyfikować te przypadki. Odnosząc to do omawianej dyskusji, jeśli chcesz zrobić mniej z testami jednostkowymi, ponieważ twoje kontrakty obejmują twój ogon, to dlaczego nie po prostu skorzystać z wbudowanych elementów, ponieważ jest to o jedną mniejszą zależność do zarządzania. W dzisiejszych czasach chodzi mi o prostotę. :-)

Zobacz też:


3

Wolałbym używać małego szkieletu testowego MS, ale na razie trzymam się NUnit. Problemy ze stwardnieniem rozsianym są ogólnie (dla mnie)

  • Udostępniony plik „testowy” (bezcelowy), który należy zachować
  • Listy testów powodują konflikty z wieloma programistami / VCS
  • Zły zintegrowany interfejs użytkownika - myląca konfiguracja, uciążliwy wybór testów
  • Brak dobrego biegacza zewnętrznego

Ostrzeżenia - Gdybym testował witrynę aspx, zdecydowanie użyłbym MS - Gdybym rozwijał solo, również MS byłoby w porządku - Gdybym miał ograniczone umiejętności i nie mógłbym skonfigurować NUnit :)

O wiele łatwiej jest mi napisać testy i odpalić NUnitGUI lub jeden z innych interfejsów (testDriven jest zdecydowanie o wiele za drogi). Konfigurowanie debugowania za pomocą wersji wiersza poleceń jest również dość łatwe.


Obecnie używam Resharpera do przeprowadzania testów MS, więc nie mam nic przeciwko. Wolę CodeRush + RefactorPro, chociaż nie używamy go tutaj. Może mają teraz przyzwoity biegacz do testu MS Test.
Andrew Backer,
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.