summaryrefslogtreecommitdiff
path: root/core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala
diff options
context:
space:
mode:
authorRocky Madden <git@rockymadden.com>2014-03-26 16:09:24 -0600
committerRocky Madden <git@rockymadden.com>2014-03-26 16:09:24 -0600
commit3c806b88e9169ed742ae5740d81fbbb24f0ca768 (patch)
tree4b6a75a1042000841200b6af031abe62b542ab71 /core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala
parenta25d9e70528a0b2bab96cc55ede9232076fd4299 (diff)
downloadstringmetric-3c806b88e9169ed742ae5740d81fbbb24f0ca768.tar.gz
stringmetric-3c806b88e9169ed742ae5740d81fbbb24f0ca768.tar.bz2
stringmetric-3c806b88e9169ed742ae5740d81fbbb24f0ca768.zip
Removed module structure.
Diffstat (limited to 'core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala')
-rw-r--r--core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala62
1 files changed, 62 insertions, 0 deletions
diff --git a/core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala b/core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala
new file mode 100644
index 0000000..fbdc536
--- /dev/null
+++ b/core/src/test/scala/com/rockymadden/stringmetric/StringMetricSpec.scala
@@ -0,0 +1,62 @@
+package com.rockymadden.stringmetric
+
+import com.rockymadden.stringmetric.phonetic._
+import com.rockymadden.stringmetric.similarity._
+import com.rockymadden.stringmetric.transform._
+
+object StringMetricSpec extends org.specs2.mutable.SpecificationWithJUnit {
+ "StringMetric convenience methods" should {
+ "pass through" in {
+ StringMetric.compareWithDiceSorensen(1)("testone", "testtwo").get must
+ beEqualTo(DiceSorensenMetric(1).compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithHamming("testone", "testtwo").get must
+ beEqualTo(HammingMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithJaccard(1)("testone", "testtwo").get must
+ beEqualTo(JaccardMetric(1).compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithJaro("testone", "testtwo").get must
+ beEqualTo(JaroMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithJaroWinkler("testone", "testtwo").get must
+ beEqualTo(JaroWinklerMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithLevenshtein("testone", "testtwo").get must
+ beEqualTo(LevenshteinMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithMetaphone("testone", "testtwo").get must
+ beEqualTo(MetaphoneMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithNGram(1)("testone", "testtwo").get must
+ beEqualTo(NGramMetric(1).compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithNysiis("testone", "testtwo").get must
+ beEqualTo(NysiisMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithOverlap(1)("testone", "testtwo").get must
+ beEqualTo(OverlapMetric(1).compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithRefinedNysiis("testone", "testtwo").get must
+ beEqualTo(RefinedNysiisMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithRefinedSoundex("testone", "testtwo").get must
+ beEqualTo(RefinedSoundexMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithSoundex("testone", "testtwo").get must
+ beEqualTo(SoundexMetric.compare("testone".toCharArray, "testtwo".toCharArray).get)
+ StringMetric.compareWithWeightedLevenshtein(1, 2, 3)("testone", "testtwo").get must
+ beEqualTo(WeightedLevenshteinMetric(1, 2, 3).compare("testone".toCharArray, "testtwo".toCharArray).get)
+ }
+ }
+
+ "StringMetricDecorator withMemoization()" should {
+ "memoize" in {
+ val memo = MetaphoneMetric withMemoization
+
+ (0 until 1000000) foreach { i =>
+ memo.compare("abc123", "abc456")
+ memo.compare("abc456", "abc123")
+ }
+
+ true must beTrue
+ }
+ }
+
+ "StringMetricDecorator withTransform()" should {
+ "transform" in {
+ (MetaphoneMetric withTransform filterAlpha).compare("abc123", "abc456").get must
+ beEqualTo(true)
+ (DiceSorensenMetric(1) withTransform filterAlpha).compare("abc123", "abc456").get must
+ beEqualTo(1.0)
+ }
+ }
+}