From 5a1de3461152a288977d68c197712f46a703ae8e Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Wed, 30 Mar 2022 13:48:14 +0000 Subject: [PATCH] Fix JS Path#names bug --- io/js/src/main/scala/fs2/io/file/Path.scala | 2 +- io/shared/src/test/scala/fs2/io/file/PathSuite.scala | 9 +++++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/io/js/src/main/scala/fs2/io/file/Path.scala b/io/js/src/main/scala/fs2/io/file/Path.scala index be60b7aa96..babefc5f3b 100644 --- a/io/js/src/main/scala/fs2/io/file/Path.scala +++ b/io/js/src/main/scala/fs2/io/file/Path.scala @@ -55,7 +55,7 @@ final case class Path private (override val toString: String) extends PathApi { @tailrec def go(path: Path, acc: List[Path]): List[Path] = path.parent match { - case None => acc + case None => path :: acc case Some(parent) => go(parent, path.fileName :: acc) } diff --git a/io/shared/src/test/scala/fs2/io/file/PathSuite.scala b/io/shared/src/test/scala/fs2/io/file/PathSuite.scala index ac92eabc6d..d25a80305f 100644 --- a/io/shared/src/test/scala/fs2/io/file/PathSuite.scala +++ b/io/shared/src/test/scala/fs2/io/file/PathSuite.scala @@ -89,6 +89,11 @@ class PathSuite extends Fs2Suite { ) } + test("names") { + assertEquals(Path("foo").names, List(Path("foo"))) + assertEquals(Path("foo/bar").names, List(Path("foo"), Path("bar"))) + } + test("extName") { assertEquals(Path("index.html").extName, ".html") assertEquals(Path("index.coffee.md").extName, ".md") @@ -98,6 +103,10 @@ class PathSuite extends Fs2Suite { assertEquals(Path(".index.md").extName, ".md") } + test("endsWith") { + assert(!Path("foo").endsWith(".xml")) + } + test("startsWith/endsWith") { forAll { (start: Path, end: Path) => if (start.toString.nonEmpty && end.toString.nonEmpty) {