TwistedTrialhttps://twistedmatrix.com/trac/wiki/TwistedTrial |
DOHhttps://dojotoolkit.org/reference-guide/1.10/util/doh.html |
|
---|---|---|
Programming language |
Python |
JavaScript |
Category |
Unit Testing, unittest Extensions |
Unit Testing |
General info |
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' |
D.O.H means Dojo Objective Harness, it's a test framework for the DOJO web apps which tests and runs on the browser and on cloud test execution services like BrowserstackDojo is a Typescript framework build for modern web application, and D.O.H is a basically unit test library to test JavaScript functions and custom widgets |
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 components can be tested for example adding a web front-end using simple twisted.web.resource.Resource objects |
YesDOH is both flexible and extendable and runs in many environments including many browsers to test various front-end functionalities and components |
Server-side
Allows testing the bahovior of a server-side code |
YesServer-side behaviour can be tested with Trial, it has various functions for this in the twisted.web.Resource package |
YesPieces of back-end code can be tested with DOH as it performs Unit tests. It is flexible enough to test server-side behaviour and functionality |
Fixtures
Allows defining a fixed, specific states of data (fixtures) that are test-local. This ensures specific environment for a single test |
YesTrial supports various fixture methods such as 'setUp()' and 'tearDown' functions fixture for normal semantics of setup, and teardown |
It has various fixture methods like setUp(), tearDown() and Performance test fixtures which are just like a regular test fixtures, but with extra options. Specifically, it uses 'testType' to mark it as a "perf" test, which instructs the D.O.H. runner to treat the tests as performance and use the calibrate and execute test runner |
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. |
YesMethods like 'setUp()' allow for creation of group fixtures |
YesIt supports 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. |
Through use of third party libraries like test-generator. |
N/A |
Licence
Licence type governing the use and redistribution of the software |
MIT License |
FreeBSD 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) |
YesTrial can access the mock library inbuilt in python for mocking purposes |
N/A |
Grouping
Allows organizing tests in groups |
YesTrial allows tests to be grouped into test packages |
YesThere is a function that allows you to group tests, the 'doh.register(...)' function. It's most commonly used for registering Unit Tests |
Other
Other useful information about the testing framework |
|
|