Test::Unithttps://test-unit.github.io/ |
unittest2https://pypi.org/project/unittest2/ |
|
---|---|---|
Programming language |
Ruby |
Python |
Category |
Unit Testing, Intergration Testing |
Unit Testing |
General info |
Test::Unit is a unit testing framework for RubyTest::Unit is an implementation of the xUnit testing framework for ruby which is used for Unit Testing. However Test::Unit has been left in the standard library to support legacy test suites therefore if you are writing new test code use Minitest instead of Test::Unit |
Unittest2 is a newer version on the inbuilt unit testing framework unittestTo use o use unittest2 instead of unittest, simply replace 'import unittest' with 'import unittest2'. It has many new features such as: - addCleanups for better resource management; -many new assert methods; - assertRaises as context manager, with access to the exception afterwards; - test discovery and new command line options (including failfast and better handling of ctrl-C during test runs); - class and module level fixtures: setUpClass, tearDownClass, setUpModule, tearDownModule; -test skipping and expected failures and many more improvements on the API and bug fixes |
xUnit
Set of frameworks originating from SUnit (Smalltalk's testing framework). They share similar structure and functionality. |
Yestest-unit is a xUnit family unit testing framework for Ruby |
Yesunittest2 is a newer version of unittest which is an xUnit style framework for Python. |
Client-side
Allows testing code execution on the client, such as a web browser |
It could have tested some front-end components but its now legacy hence wouldn't work with the many new front-end components |
YesFront-end functionality and behaviour can be tested by unittest2. function by function |
Server-side
Allows testing the bahovior of a server-side code |
Yes |
YesWe can write tests with unittest2 to test each function for server-side behaviour |
Fixtures
Allows defining a fixed, specific states of data (fixtures) that are test-local. This ensures specific environment for a single test |
YesFixture methods are available through its ClassMethods Module |
YesBy use of the 'setUp()' function which is called to prepare the test fixture |
Group fixtures
Allows defining a fixed, specific states of data for a group of tests (group-fixtures). This ensures specific environment for a given group of tests. |
YesGroup fixture methods are supported |
Yesunittest2 allows you to group your initialization code buy use of the 'setUp()' function and clean up code with a 'tearDown()' function |
Generators
Supports data generators for tests. Data generators generate input data for test. The test is then run for each input data produced in this way. |
No |
Yesunittest2 contains generator methods in the module 'unittest.TestCase' |
Licence
Licence type governing the use and redistribution of the software |
LGPLv2.1, Ruby Licence |
MIT License |
Mocks
Mocks are objects that simulate the behavior of real objects. Using mocks allows testing some part of the code in isolation (with other parts mocked when needed) |
No |
YesMocks are available from the library unittest.mock which allows you to replace parts of your system under test with mock objects |
Grouping
Allows organizing tests in groups |
No |
YesOne can build suites either manually or use test discovery to build the suite automatically by scanning a directory |
Other
Other useful information about the testing framework |
|
|