stestrhttps://pypi.org/project/stestr/ |
TestNGhttps://testng.org/doc/documentation-main.html |
|
---|---|---|
Programming language |
Python |
Java |
Category |
Unit Testing |
Unit Testing, Intergration Testing, End-to-End Testing |
General info |
stestr is a Python test runner designed to execute unittest test suitesstestr executes unittest test suites by using multiple processes to split up execution of a test suite then stores a history of all test runs to help in debugging failures and optimizing the scheduler to improve speed. |
TestNG is a testing framework for the Java programming language inspired by JUnit and NUnitTestNG is similar to JUnit and NUnit but with newer functionalities such as: annotations, test that your code is multithread safe, flexible test configuration, support for data-driven testing (with @DataProvider), support for parameters, powerful execution model (no more TestSuite) and more... It's also designed to cover all categories of tests unit, functional, end-to-end, intergration... etc |
xUnit
Set of frameworks originating from SUnit (Smalltalk's testing framework). They share similar structure and functionality. |
No |
No |
Client-side
Allows testing code execution on the client, such as a web browser |
YesStestr being a test runner that runs unittest tests, it can test fron-tend functionality and behaviour. |
YesThe scope of testing with testNg is wide and you can test various front-end functionalities and behaviours with it |
Server-side
Allows testing the bahovior of a server-side code |
YesStestr being a test runner that runs unittest tests, it can run back-end tests for functionality and behaviour. |
YesYou can test server-side functionalities and behaviours with TestNg |
Fixtures
Allows defining a fixed, specific states of data (fixtures) that are test-local. This ensures specific environment for a single test |
YesBy use of a third party library like Fixture |
YesFixtures are inbuilt into testNG, these are the annotations which are: @BeforeSuite, @AfterSuite, @BeforeTest, @AfterTest, @BeforeGroups, @AfterGroups, @BeforeClass, @AfterClass, @BeforeMethod, @AfterMethod |
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. |
By use of a third party library like Fixture |
YesYou can use various fixtures to setup environments for group tests |
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. |
YesBy using a library like test-generator |
N/A |
Licence
Licence type governing the use and redistribution of the software |
Apache License 2.0 |
Apache License 2.0 |
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) |
N/A |
YesBy Use of an external library like mockit which intergrates well with testNG |
Grouping
Allows organizing tests in groups |
N/A |
YesMultiple test cases can be grouped more easily by converting them into testng.xml file, in which you can make priorities which test case should be executed first |
Other
Other useful information about the testing framework |
|
|