core
core copied to clipboard
fix(pipe): isObservable usage
isObservable(res) instead of isObservable(res.subscribe)
I changed the usage of isObservable function to the correct one. Previously, it checks the subscribe function itself while it should check the observable itself. I also add a test that describes in which case it could lead to problem.
Without my fix the test is red and the actual result is
"{"operator": [Function anonymous], "source": {"_subscribe": [Function anonymous]}}"
data:image/s3,"s3://crabby-images/4a048/4a04820d42905a9e9066da9bf44abe25ee64dc2e" alt="image"
With my fix the test is green.
data:image/s3,"s3://crabby-images/e279f/e279fc2b88723702c2a09e2eb89baae08094581e" alt="image"
In my test I described the scenario of a race condition when there is a bit delay of loading new language translation (after switching) and the usage MissingHandler with observable takes place.
P.S.
In many cases the next tick will solve the problem and user will see the correct translation, but there is a chance to see the stringified observable "{"operator": [Function anonymous], "source": {"_subscribe": [Function anonymous]}}"
In my PR I also removed some redundat imports.