pytesthttps://docs.pytest.org/en/latest/ |
JBehavehttps://jbehave.org/ |
|
---|---|---|
Programming language |
Python |
Java |
Category |
Unit Testing |
Acceptance Testing |
General info |
Pytest is the TDD 'all in one' testing framework for PythonPytest is a powerful Python testing framework that can test all and levels of software. It is considered by many to be the best testing framework in Python with many projects on the internet having switched to it from other frameworks, including Mozilla and Dropbox. This is due to its many powerful features such as ‘assert‘ rewriting, a third-party plugin model and a powerful yet simple fixture model. |
JBehave is a Behaviour-Driven Development testing framework for javaJBehave is a Behaviour Driven Development framework. It intends to provide an intuitive and accessible way for automated acceptance testing |
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 |
Yespytest can test any part of the stack including front-end components |
YesYou can test front-end behaviour (scenarios) with JBehave |
Server-side
Allows testing the bahovior of a server-side code |
Yespytest is powerful enough to test database and server components and functionality |
JBehave tests scenarios and behaviours of components, it can test back-end behaviour |
Fixtures
Allows defining a fixed, specific states of data (fixtures) that are test-local. This ensures specific environment for a single test |
YesPytest has a powerful yet simple fixture model that is unmatched in any other testing framework. |
YesYou have a few options for using fixtures in JBehave: you can run your steps before/after each scenario by using LifeCycle: you can use @BeforeStory and @AfterStory annotations or you can define a dummy scenario with your setup/teardown steps |
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. |
YesPytest's powerful fixture model allows grouping of fixtures |
YesYou can define group fixtures with JBehave |
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. |
Yespytest has a hook function called pytest_generate_tests hook which is called when collecting a test function and one can use it to generate data |
No |
Licence
Licence type governing the use and redistribution of the software |
MIT License |
BSD-style 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) |
YesBy either using unittest.mock or using pytest-mock a thin wrapper that provides mock functionality for pytest |
The best way to mock is to use third party libraries like Mockito, Jmock or Jmockit |
Grouping
Allows organizing tests in groups |
YesTests can be grouped with pytest by use of markers which are applied to various tests and one can run tests with the marker applied |
N/A |
Other
Other useful information about the testing framework |
|
|