From 72f1556eb14c9b70cb2aa1a5e2a03b1b56e20b51 Mon Sep 17 00:00:00 2001 From: "Aaron S. Hawley" Date: Thu, 8 Apr 2021 20:51:52 -0400 Subject: [PATCH] Hide ambiguous implicit buildableSeq --- project/MimaSettings.scala | 1 + .../scala/org/scalacheck/util/Buildable.scala | 2 +- .../scala/scala/StringSpecification.scala | 27 +++++++++++++++++++ 3 files changed, 29 insertions(+), 1 deletion(-) create mode 100644 src/test/scala/scala/StringSpecification.scala diff --git a/project/MimaSettings.scala b/project/MimaSettings.scala index d094ec82c..5592b366e 100644 --- a/project/MimaSettings.scala +++ b/project/MimaSettings.scala @@ -19,6 +19,7 @@ object MimaSettings { ) private def removedPrivateMethods = Seq( + "org.scalacheck.util.Buildable.buildableSeq" ) private def removedPrivateClasses = Seq( diff --git a/src/main/scala/org/scalacheck/util/Buildable.scala b/src/main/scala/org/scalacheck/util/Buildable.scala index 6d352cb8c..486c63168 100644 --- a/src/main/scala/org/scalacheck/util/Buildable.scala +++ b/src/main/scala/org/scalacheck/util/Buildable.scala @@ -27,7 +27,7 @@ object Buildable extends BuildableVersionSpecific { def builder = new ArrayListBuilder[T] } - implicit def buildableSeq[T]: Buildable[T, Seq[T]] = + private[scalacheck] implicit def buildableSeq[T]: Buildable[T, Seq[T]] = new Buildable[T, Seq[T]] { def builder: mutable.Builder[T, Seq[T]] = Seq.newBuilder[T] diff --git a/src/test/scala/scala/StringSpecification.scala b/src/test/scala/scala/StringSpecification.scala new file mode 100644 index 000000000..0a8ff3048 --- /dev/null +++ b/src/test/scala/scala/StringSpecification.scala @@ -0,0 +1,27 @@ +/*-------------------------------------------------------------------------*\ +** ScalaCheck ** +** Copyright (c) 2007-2021 Rickard Nilsson. All rights reserved. ** +** http://www.scalacheck.org ** +** ** +** This software is released under the terms of the Revised BSD License. ** +** There is NO WARRANTY. See the file LICENSE for the full text. ** +\*------------------------------------------------------------------------ */ + +package scala + +import org.scalacheck.Gen +import org.scalacheck.Prop +import org.scalacheck.Properties + +object StringSpecification extends Properties("scala.String") { + + property("mkString") = { // Issue #721 + import scala.collection.JavaConverters._ + val listOfGens: List[Gen[Char]] = "".toList.map(Gen.const(_)) + val g1: Gen[String] = Gen.sequence(listOfGens).map(_.asScala.mkString) + val g2: Gen[String] = Gen.sequence(List(Gen.listOf(' ').map(_.mkString))).map(_.asScala.mkString) + Prop.forAll(g1, g2) { (s1, s2) => + true + } + } +}