Description
System Rules is a collection of JUnit rules for testing code which uses java.lang.System.
System Rules alternatives and similar libraries
Based on the "Testing" category.
Alternatively, view system-rules alternatives based on common mentions on social networks and blogs.
-
Karate
Karate is the only open-source tool to combine API test-automation, mocks, performance-testing and even UI automation into a single, unified framework. -
TestContainers
Provides throwaway instances of common databases, Selenium web browsers, or anything else that can run in a Docker container. -
PowerMock
Enables mocking of static methods, constructors, final classes and methods, private methods and removal of static initializers. -
PIT
Fast mutation-testing framework for evaluating fault-detection abilities of existing JUnit or TestNG test-suites. -
GreenMail
In-memory email server for integration testing. Supports SMTP, POP3 and IMAP including SSL. -
Mutability Detector
Reports on whether instances of a given class are immutable. -
junit-dataprovider
A TestNG like dataprovider runner for JUnit. -
Arquillian
Integration and functional testing platform for Java EE containers. -
Randomized Testing
JUnit test runner and plugins for running JUnit tests with pseudo-randomness. -
Scott Test Reporter
Detailed failure reports and hassle free assertions for Java tests - Power Asserts for Java -
J8Spec
J8Spec is a library that allows tests written in Java to follow the BDD style introduced by RSpec and Jasmine.
Get performance insights in less than 4 minutes.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest. Visit our partner's website for more details.
Do you think we are missing an alternative of System Rules or a related project?
README
System Rules
System Rules is a collection of JUnit rules for testing code which uses
java.lang.System
.
System Lambda is an alternative to System Rules that leverages the possibilities of Java 8. It is independent of the test framework. You can use it for example as a replacement for System Rules in JUnit Jupiter and TestNG.
Installation
System Rules is available from Maven Central.
<dependency>
<groupId>com.github.stefanbirkner</groupId>
<artifactId>system-rules</artifactId>
<version>1.19.0</version>
</dependency>
Please don't forget to add the scope test
if you're using System
Rules for tests only.
Usage
System Rules' documentation is stored in the gh-pages
branch and is
available online at
http://stefanbirkner.github.io/system-rules/index.html
Contributing
You have three options if you have a feature request, found a bug or simply have a question about System Rules.
- Write an issue.
- Create a pull request. (See Understanding the GitHub Flow)
- Write a mail to [email protected]
Development Guide
System Rules is build with Maven. If you want to contribute code than
- Please write a test for your change.
- Ensure that you didn't break the build by running
mvnw test
. - Fork the repo and create a pull request. (See Understanding the GitHub Flow)
The basic coding style is described in the
EditorConfig file .editorconfig
.
System Rules supports Travis CI (Linux) and AppVeyor (Windows) for continuous integration. Your pull request will be automatically build by both CI servers. On Travis CI we build your pull request with OpenJDK 6 and run test with different JDKs (Java 6 to 10).
Release Guide
- Select a new version according to the Semantic Versioning 2.0.0 Standard.
- Set the new version in
pom.xml
and in theInstallation
section of this readme. - Commit the modified
pom.xml
andREADME.md
. - Run
mvnw clean deploy
with JDK 6 or 7. - Add a tag for the release:
git tag system-rules-X.X.X