Skip to content

Commit 3604eed

Browse files
committed
Add test for conflate
1 parent 1c66d40 commit 3604eed

File tree

1 file changed

+48
-0
lines changed

1 file changed

+48
-0
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
/*
2+
* Copyright (c) 2013 Functional Streams for Scala
3+
*
4+
* Permission is hereby granted, free of charge, to any person obtaining a copy of
5+
* this software and associated documentation files (the "Software"), to deal in
6+
* the Software without restriction, including without limitation the rights to
7+
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
8+
* the Software, and to permit persons to whom the Software is furnished to do so,
9+
* subject to the following conditions:
10+
*
11+
* The above copyright notice and this permission notice shall be included in all
12+
* copies or substantial portions of the Software.
13+
*
14+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
16+
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
17+
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
18+
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
19+
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
20+
*/
21+
22+
package fs2
23+
24+
import cats.effect.IO
25+
import cats.effect.testkit.TestControl
26+
27+
import scala.concurrent.duration._
28+
29+
class StreamConflateSuite extends Fs2Suite {
30+
31+
test("conflate") {
32+
TestControl.executeEmbed(
33+
Stream
34+
.iterate(0)(_ + 1)
35+
.covary[IO]
36+
.metered(10.millis)
37+
.map(List(_))
38+
.conflate
39+
.metered(101.millis)
40+
.take(5)
41+
.compile
42+
.toList
43+
.assertEquals(
44+
List(0) :: (1 until 10).toList :: 10.until(40).toList.grouped(10).toList
45+
)
46+
)
47+
}
48+
}

0 commit comments

Comments
 (0)