Can anybody explain what the differents between these 3 variants?
http://jsfiddle.net/8vx2g3fr/2/
This all is in fact expected behavior.
The confusing thing is what happens when you reuse Subjectand an operator such as take() multiple times.
Operator take(1) takes just a single value and send complete notification. This notification is received by the Subject because of .subscribe(bs2). Now comes the most important part.
When a Subject receives a complete or error notification it marks itself as stopped. This means it will never remit any items or notifications which is correct and expected behavior in Rx. Notifications complete or error have to be the last emissions.
So the Subject is completed by the first take(1) which is triggered by value 0 (the bs2.next(0) call).
Then when value 2 triggers the second run of the Observable.interval(0).take(1) it's received by the Subject but it's automatically ignored because the Subject is already marked as stopped.
The process in you third demo is exactly the same.
You can see it in the source code in Subject.ts:
https://github.com/ReactiveX/rxjs/blob/master/src/Subject.ts#L86
https://github.com/ReactiveX/rxjs/blob/master/src/Subject.ts#L56