Browse Source

Test Observable.take; Update Observable.skip test;

bjorn 10 years ago
parent
commit
96b05ed7ee
3 changed files with 46 additions and 0 deletions
  1. 1 0
      tests/observable.lua
  2. 10 0
      tests/skip.lua
  3. 35 0
      tests/take.lua

+ 1 - 0
tests/observable.lua

@@ -169,4 +169,5 @@ describe('Observable', function()
   dofile('tests/reduce.lua')
   dofile('tests/reduce.lua')
   dofile('tests/reject.lua')
   dofile('tests/reject.lua')
   dofile('tests/skip.lua')
   dofile('tests/skip.lua')
+  dofile('tests/take.lua')
 end)
 end)

+ 10 - 0
tests/skip.lua

@@ -5,6 +5,16 @@ describe('skip', function()
     expect(observable:skip(1).subscribe).to.fail()
     expect(observable:skip(1).subscribe).to.fail()
   end)
   end)
 
 
+  it('produces all values if the count is zero', function()
+    local observable = Rx.Observable.fromTable({2, 3, 4}):skip(0)
+    expect(observable).to.produce(2, 3, 4)
+  end)
+
+  it('produces all values if the count is less than zero', function()
+    local observable = Rx.Observable.fromTable({2, 3, 4}):skip(-3)
+    expect(observable).to.produce(2, 3, 4)
+  end)
+
   it('skips one element if no count is specified', function()
   it('skips one element if no count is specified', function()
     local observable = Rx.Observable.fromTable({2, 3, 4}, ipairs):skip()
     local observable = Rx.Observable.fromTable({2, 3, 4}, ipairs):skip()
     expect(observable).to.produce(3, 4)
     expect(observable).to.produce(3, 4)

+ 35 - 0
tests/take.lua

@@ -0,0 +1,35 @@
+describe('take', function()
+  it('produces an error if its parent errors', function()
+    local observable = Rx.Observable.fromValue(''):map(function(x) return x() end)
+    expect(observable.subscribe).to.fail()
+    expect(observable:take(1).subscribe).to.fail()
+  end)
+
+  it('produces nothing if the count is zero', function()
+    local observable = Rx.Observable.fromValue(3):take(0)
+    expect(observable).to.produce({})
+  end)
+
+  it('produces nothing if the count is less than zero', function()
+    local observable = Rx.Observable.fromValue(3):take(-3)
+    expect(observable).to.produce({})
+  end)
+
+  it('takes one element if no count is specified', function()
+    local observable = Rx.Observable.fromTable({2, 3, 4}, ipairs):take()
+    expect(observable).to.produce(2)
+  end)
+
+  it('produces all values if it takes all of the values of the original', function()
+    local observable = Rx.Observable.fromTable({1, 2}):take(2)
+    expect(observable).to.produce(1, 2)
+  end)
+
+  it('completes and does not fail if it takes more values than were produced', function()
+    local observable = Rx.Observable.fromValue(3):take(5)
+    local onNext, onError, onComplete = observableSpy(observable)
+    expect(onNext).to.equal({{3}})
+    expect(#onError).to.equal(0)
+    expect(#onComplete).to.equal(1)
+  end)
+end)