Python Testifyhttps://github.com/Yelp/Testify |
TwistedTrialhttps://twistedmatrix.com/trac/wiki/TwistedTrial |
|
---|---|---|
Programming language |
Python |
Python |
Category |
Unit Testing |
Unit Testing, unittest Extensions |
General info |
A Python unit testing framework modelled after unittestTestify is modelled after unittest but has more features while still supporting unittest classes. It has more pythonic naming conventions, an better test runner output visually, a decorator-based approach to fixture methods among many other features |
Trial is a unit testing framework for Python built by Twisted Matrix labsTrial is composed of two parts: First is a command-line test runner, which can be run on plain Python unit tests and can do automated unit-test discovery across files, modules, or even arbitrarily nested packages. Second is a test library, derived from Python's 'unittest.TestCase' |
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 |
YesFront-end functionality and behaviour can be tested by Testify. |
YesFront-end components can be tested for example adding a web front-end using simple twisted.web.resource.Resource objects |
Server-side
Allows testing the bahovior of a server-side code |
YesTestify can test various server and database behaviours and functionality |
YesServer-side behaviour can be tested with Trial, it has various functions for this in the twisted.web.Resource package |
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 supported and it follows a decorator based approach, that is they are written similar to decorators |
YesTrial supports various fixture methods such as 'setUp()' and 'tearDown' functions fixture for normal semantics of setup, and teardown |
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 fixtures are supported |
YesMethods like 'setUp()' allow for creation of group fixtures |
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. |
YesOne can create generator methods to yield runnable test methods which will pick out the test methods from your TestCases, and then exclude any in any of your exclude_suites method.If there are any require_suites, it will then further limit itself to test methods in those suites. |
Through use of third party libraries like test-generator. |
Licence
Licence type governing the use and redistribution of the software |
Apache License 2.0 |
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) |
YesIt includes the turtle mock object library |
YesTrial can access the mock library inbuilt in python for mocking purposes |
Grouping
Allows organizing tests in groups |
YesTestify includes support for detecting and running test suites, grouped by modules, classes, or individual test methods. |
YesTrial allows tests to be grouped into test packages |
Other
Other useful information about the testing framework |
|
|