Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ribot/assertj-rx

[DEPRECATED] AssertJ assertions for RxJava Observables
https://github.com/ribot/assertj-rx

Last synced: 2 months ago
JSON representation

[DEPRECATED] AssertJ assertions for RxJava Observables

Awesome Lists containing this project

README

        

Deprecated
===========

Assertj-rx is now deprecated. In-order to test observabales, please use the [TestSubscriber](http://reactivex.io/RxJava/javadoc/rx/observers/TestSubscriber.html#TestSubscriber%28rx.Subscriber%29) - more information on this can be found [here](https://labs.ribot.co.uk/unit-testing-rxjava-6e9540d4a329#.tjmv351u0). Whilst the current version still remains usable, there will no longer be any new development taking place.

# AssertJ RxJava
[AssertJ](http://joel-costigliola.github.io/assertj/) assertions for [RxJava](https://github.com/ReactiveX/RxJava) Observables.

This library extends AssertJ core with the aim of providing elegant assertions to test RxJava Observables. The current version of this library only provides assertions aimed at testing "cold" Observables. You will need to transform your Observable into a [`BlockingObservable`](http://reactivex.io/RxJava/javadoc/rx/observables/BlockingObservable.html) before performing any assertion.

Feedback and contributions are very welcome.

##Examples

* Assert that completes successfully without emitting any error:
```java
assertThat(observable.toBlocking()).completes();
```
* Assert that completes after emitting a single value "hello":
```java
assertThat(observable.toBlocking())
.completes()
.emitsSingleValue("hello");
```
* Assert that completes without emitting any value:
```java
assertThat(observable.toBlocking())
.completes()
.emitsNoValues();
```
* Assert that emits an error:
```java
assertThat(observable.toBlocking()).fails();
```
* Assert that emits an error of type `IllegalArgumentException`
```java
assertThat(observable.toBlocking())
.failsWithError(IllegalArgumentException.class);
```
* Assert that completes after emitting three values that are exactly "a", "b" and "c":
```java
assertThat(observable.toBlocking())
.completes()
.listOfValuesEmitted()
.containsExactly("a", "b", "c");
```
* Assert that fails after emitting "a" and "b":
```java
assertThat(observable.toBlocking())
.fails()
.listOfValuesEmitted()
.containsExactly("a", "b");
```
* Assert that completes after emitting 10 values
```java
assertThat(observable.toBlocking())
.completes()
.valuesCountIs(10);
```
## Installation

Artifacts are on Maven central.

Gradle:
```groovy
testCompile 'uk.co.ribot.assertj-rx:assertj-rx:0.1.0'
```
Maven:
```xml

uk.co.ribot.assertj-rx
assertj-rx
0.1.0
test

```
Alternatively, you can download the jar from the [releases section](https://github.com/ribot/assertj-rx/releases).
## License
```
Copyright (C) 2015 Ribot Ltd.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```