All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.scalatest.words.NotWord.scala Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2001-2013 Artima, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.scalatest.words

import org.scalatest.matchers._
import org.scalatest.enablers._
import scala.collection.GenTraversable
import org.scalautils._
import org.scalautils.TripleEqualsSupport.Spread
import TripleEqualsSupport.TripleEqualsInvocation
import org.scalatest.Suite
import org.scalatest.Resources
import org.scalatest.FailureMessages
import org.scalatest.UnquotedString
import org.scalautils.Equality
import org.scalatest.Assertions.areEqualComparingArraysStructurally
import org.scalatest.MatchersHelper.matchSymbolToPredicateMethod
import scala.annotation.tailrec
import org.scalatest.MatchersHelper.fullyMatchRegexWithGroups
import org.scalatest.MatchersHelper.startWithRegexWithGroups
import org.scalatest.MatchersHelper.endWithRegexWithGroups
import org.scalatest.MatchersHelper.includeRegexWithGroups
import org.scalatest.Suite.getObjectsForFailureMessage

/**
 * This class is part of the ScalaTest matchers DSL. Please see the documentation for Matchers for an overview of
 * the matchers DSL.
 *
 * @author Bill Venners
 */
final class NotWord {

  /**
   * This method enables the following syntax, where tempFile, for example, refers to a java.io.File
   * and exist is a Matcher[java.io.File]: 
   *
   * 
   * tempFile should not (exist)
   *                     ^
   * 
*/ def apply[S <: Any](matcher: Matcher[S]): Matcher[S] = new Matcher[S] { def apply(left: S): MatchResult = matcher(left).negated override def toString: String = "not (" + Prettifier.default(matcher) + ")" } /** * This method enables the following syntax: * *
   * hasNoSize should not { have size (2) and equal (hasNoSize) }
   *                      ^
   * 
*/ def apply[S <: Any, TYPECLASS[_]](matcherGen1: MatcherFactory1[S, TYPECLASS]): MatcherFactory1[S, TYPECLASS] = { new MatcherFactory1[S, TYPECLASS] { def matcher[V <: S : TYPECLASS]: Matcher[V] = { val innerMatcher: Matcher[V] = matcherGen1.matcher new Matcher[V] { def apply(left: V): MatchResult = innerMatcher(left).negated override def toString: String = "not (" + Prettifier.default(matcherGen1) + ")" } } override def toString: String = "not (" + Prettifier.default(matcherGen1) + ")" } } def apply[S <: Any, TYPECLASS1[_], TYPECLASS2[_]](matcherGen2: MatcherFactory2[S, TYPECLASS1, TYPECLASS2]): MatcherFactory2[S, TYPECLASS1, TYPECLASS2] = { new MatcherFactory2[S, TYPECLASS1, TYPECLASS2] { def matcher[V <: S : TYPECLASS1 : TYPECLASS2]: Matcher[V] = { val innerMatcher: Matcher[V] = matcherGen2.matcher new Matcher[V] { def apply(left: V): MatchResult = innerMatcher(left).negated override def toString: String = "not (" + Prettifier.default(matcherGen2) + ")" } } override def toString: String = "not (" + Prettifier.default(matcherGen2) + ")" } } /** * This method enables any BeMatcher to be negated by passing it to not. * For example, if you have a BeMatcher[Int] called odd, which matches * Ints that are odd, you can negate it to get a BeMatcher[Int] that matches * even Ints, like this: * *
   * val even = not (odd)
   *                ^
   * 
* *

* In addition, this method enables you to negate a BeMatcher at its point of use, like this: *

* *
   * num should be (not (odd))
   * 
* *

* Nevertheless, in such as case it would be more idiomatic to write: *

* *
   * num should not be (odd)
   * 
*/ def apply[S <: Any](beMatcher: BeMatcher[S]): BeMatcher[S] = new BeMatcher[S] { def apply(left: S): MatchResult = beMatcher(left).negated override def toString: String = "not (" + Prettifier.default(beMatcher) + ")" } /** * This method enables syntax such as the following: * *
   * file should not (exist)
   *             ^
   * 
*/ def apply(existWord: ExistWord): ResultOfNotExist = new ResultOfNotExist(this) /* * This is used in logical expression like: * outerInstance.and(MatcherWords.not.exist) * ^ */ private[scalatest] val exist: MatcherFactory1[Any, Existence] = new MatcherFactory1[Any, Existence] { def matcher[T <: Any : Existence]: Matcher[T] = new Matcher[T] { def apply(left: T): MatchResult = { val existence = implicitly[Existence[T]] MatchResult( !existence.exists(left), Resources("exists"), Resources("doesNotExist"), Vector(left) ) } override def toString: String = "not exist" } } /** * This method enables the following syntax: * *
   * num should (not equal (7) and be < (9))
   *                 ^
   * 
*/ def equal(right: Any): MatcherFactory1[Any, Equality] = apply(MatcherWords.equal(right)) /** * This method enables the following syntax for the "primitive" numeric types: * *
   * sevenDotOh should ((not equal (17.1 plusOrMinus 0.2)) and (not equal (27.1 plusOrMinus 0.2)))
   *                         ^
   * 
*/ def equal[U](spread: Spread[U]): Matcher[U] = { new Matcher[U] { def apply(left: U): MatchResult = { MatchResult( !(spread.isWithin(left)), Resources("equaledPlusOrMinus"), Resources("didNotEqualPlusOrMinus"), Vector(left, spread.pivot, spread.tolerance) ) } override def toString: String = "not equal " + Prettifier.default(spread) } } /** * This method enables the following syntax: * *
   * map should (not equal (null))
   *                 ^
   * 
*/ def equal(o: Null): Matcher[AnyRef] = new Matcher[AnyRef] { def apply(left: AnyRef): MatchResult = { MatchResult( left != null, Resources("equaledNull"), Resources("didNotEqualNull"), Resources("midSentenceEqualedNull"), Resources("didNotEqualNull"), Vector.empty, Vector(left), Vector.empty, Vector(left) ) } override def toString: String = "not equal null" } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not have length (5) and not have length (3))
   *                         ^
   * 
*/ def have(resultOfLengthWordApplication: ResultOfLengthWordApplication): MatcherFactory1[Any, Length] = apply(MatcherWords.have.length(resultOfLengthWordApplication.expectedLength)) // This looks similar to the AndNotWord one, but not quite the same because no and /** * This method enables the following syntax: * *
   * Array(1, 2) should (not have size (5) and not have size (3))
   *                         ^
   * 
*/ def have(resultOfSizeWordApplication: ResultOfSizeWordApplication): MatcherFactory1[Any, Size] = apply(MatcherWords.have.size(resultOfSizeWordApplication.expectedSize)) /** * This method enables the following syntax: * *
   * result should (not have message ("Message from Mars!") and not have message ("Message from Mars!"))
   *                    ^
   * 
*/ def have(resultOfMessageWordApplication: ResultOfMessageWordApplication): MatcherFactory1[Any, Messaging] = apply(MatcherWords.have.message(resultOfMessageWordApplication.expectedMessage)) /** * This method enables the following syntax, where, for example, book is of type Book and title and author * are both of type HavePropertyMatcher[Book, String]: * *
   * book should (not have (title ("Moby Dick")) and (not have (author ("Melville"))))
   *                  ^
   * 
*/ def have[T](firstPropertyMatcher: HavePropertyMatcher[T, _], propertyMatchers: HavePropertyMatcher[T, _]*): Matcher[T] = apply(MatcherWords.have(firstPropertyMatcher, propertyMatchers: _*)) /** * This method enables the following syntax, where, for example, num is an Int and odd * of type BeMatcher[Int]: * *
   * num should (not be (odd) and be <= (8))
   *                 ^
   * 
*/ def be[T](beMatcher: BeMatcher[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = beMatcher(left).negated override def toString: String = "not be " + Prettifier.default(beMatcher) } } /** * This method enables the following syntax: * *
   * map should (not be (null))
   *                 ^
   * 
*/ def be(o: Null): Matcher[AnyRef] = new Matcher[AnyRef] { def apply(left: AnyRef): MatchResult = { MatchResult( left != null, Resources("wasNull"), Resources("wasNotNull"), Resources("midSentenceWasNull"), Resources("wasNotNull"), Vector.empty, Vector(left), Vector.empty, Vector(left) ) } override def toString: String = "not be null" } // These next four are for things like not be /<=/>=: /** * This method enables the following syntax: * *
   * num should (not be < (7) and not be > (10))
   *                 ^
   * 
*/ def be[T](resultOfLessThanComparison: ResultOfLessThanComparison[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = MatchResult( !resultOfLessThanComparison(left), Resources("wasLessThan"), Resources("wasNotLessThan"), Vector(left, resultOfLessThanComparison.right) ) override def toString: String = "not be " + Prettifier.default(resultOfLessThanComparison) } } /** * This method enables the following syntax: * *
   * num should (not be > (10) and not be < (7))
   *                 ^
   * 
*/ def be[T](resultOfGreaterThanComparison: ResultOfGreaterThanComparison[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = MatchResult( !resultOfGreaterThanComparison(left), Resources("wasGreaterThan"), Resources("wasNotGreaterThan"), Vector(left, resultOfGreaterThanComparison.right) ) override def toString: String = "not be " + Prettifier.default(resultOfGreaterThanComparison) } } /** * This method enables the following syntax: * *
   * num should (not be <= (7) and not be > (10))
   *                 ^
   * 
*/ def be[T](resultOfLessThanOrEqualToComparison: ResultOfLessThanOrEqualToComparison[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = MatchResult( !resultOfLessThanOrEqualToComparison(left), Resources("wasLessThanOrEqualTo"), Resources("wasNotLessThanOrEqualTo"), Vector(left, resultOfLessThanOrEqualToComparison.right) ) override def toString: String = "not be " + Prettifier.default(resultOfLessThanOrEqualToComparison) } } /** * This method enables the following syntax: * *
   * num should (not be >= (10) and not be < (7))
   *                 ^
   * 
*/ def be[T](resultOfGreaterThanOrEqualToComparison: ResultOfGreaterThanOrEqualToComparison[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = MatchResult( !resultOfGreaterThanOrEqualToComparison(left), FailureMessages("wasGreaterThanOrEqualTo"), FailureMessages("wasNotGreaterThanOrEqualTo"), Vector(left, resultOfGreaterThanOrEqualToComparison.right) ) override def toString: String = "not be " + Prettifier.default(resultOfGreaterThanOrEqualToComparison) } } /** * * The should be === syntax has been deprecated and will be removed in a future version of ScalaTest. Please use should equal, should ===, shouldEqual, * should be, or shouldBe instead. Note, the reason this was deprecated was so that === would mean only one thing in ScalaTest: a customizable, type- * checkable equality comparison. * * * This method enables the following syntax: * *
   * num should (not be === (7) and not be === (10))
   *                 ^
   * 
*/ @deprecated("The should be === syntax has been deprecated. Please use should equal, should ===, shouldEqual, should be, or shouldBe instead.") def be(tripleEqualsInvocation: TripleEqualsInvocation[_]): Matcher[Any] = { new Matcher[Any] { def apply(left: Any): MatchResult = { val (leftee, rightee) = Suite.getObjectsForFailureMessage(left, tripleEqualsInvocation.right) // TODO: Should move this part to reporter MatchResult( !(left == tripleEqualsInvocation.right), FailureMessages("wasEqualTo"), FailureMessages("wasNotEqualTo"), Vector(left, tripleEqualsInvocation.right), Vector(leftee, rightee) ) } override def toString: String = "not be " + Prettifier.default(tripleEqualsInvocation) } } /** * This method enables the following syntax: * *
   * myFile should (not be ('hidden) and have (name ("temp.txt")))
   *                    ^
   * 
*/ def be[T <: AnyRef](symbol: Symbol): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val positiveMatchResult = matchSymbolToPredicateMethod(left, symbol, false, false) MatchResult( !positiveMatchResult.matches, positiveMatchResult.rawNegatedFailureMessage, positiveMatchResult.rawFailureMessage, positiveMatchResult.negatedFailureMessageArgs, positiveMatchResult.failureMessageArgs ) } override def toString: String = "not be " + Prettifier.default(symbol) } } /** * This method enables the following syntax, where tempFile, for example, refers to a java.io.File * and hidden is a BePropertyMatcher[java.io.File]: * *
   * tempFile should (not be (hidden) and have ('name ("temp.txt")))
   *                    ^
   * 
*/ def be[T <: AnyRef](bePropertyMatcher: BePropertyMatcher[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val result = bePropertyMatcher(left) MatchResult( !result.matches, Resources("was"), Resources("wasNot"), Vector(left, UnquotedString(result.propertyName)) ) } override def toString: String = "not be " + Prettifier.default(bePropertyMatcher) } } /** * This method enables the following syntax: * *
   * isNotFileMock should (not be a ('file) and have ('name ("temp.txt"))))
   *                           ^
   * 
*/ def be[T <: AnyRef](resultOfAWordApplication: ResultOfAWordToSymbolApplication): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val positiveMatchResult = matchSymbolToPredicateMethod(left, resultOfAWordApplication.symbol, true, true) MatchResult( !positiveMatchResult.matches, positiveMatchResult.rawNegatedFailureMessage, positiveMatchResult.rawFailureMessage, positiveMatchResult.negatedFailureMessageArgs, positiveMatchResult.failureMessageArgs ) } override def toString: String = "not be " + Prettifier.default(resultOfAWordApplication) } } /** * This method enables the following syntax, where notSoSecretFile, for example, refers to a java.io.File * and directory is a BePropertyMatcher[java.io.File]: * *
   * notSoSecretFile should (not be a (directory) and have ('name ("passwords.txt")))
   *                             ^
   * 
*/ def be[T <: AnyRef](resultOfAWordApplication: ResultOfAWordToBePropertyMatcherApplication[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val result = resultOfAWordApplication.bePropertyMatcher(left) MatchResult( !result.matches, Resources("wasA"), Resources("wasNotA"), Vector(left, UnquotedString(result.propertyName)) ) } override def toString: String = "not be " + Prettifier.default(resultOfAWordApplication) } } /** * This method enables the following syntax: * *
   * result should (not be a (passedMarks) and be a (validMarks)))
   *                    ^
   * 
*/ def be[T](resultOfAWordApplication: ResultOfAWordToAMatcherApplication[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val result = resultOfAWordApplication.aMatcher(left) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not be " + Prettifier.default(resultOfAWordApplication) } } /** * This method enables the following syntax: * *
   * isNotAppleMock should (not be an ('apple) and not be ('rotten))
   *                            ^
   * 
*/ def be[T <: AnyRef](resultOfAnWordApplication: ResultOfAnWordToSymbolApplication): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val positiveMatchResult = matchSymbolToPredicateMethod(left, resultOfAnWordApplication.symbol, true, false) MatchResult( !positiveMatchResult.matches, positiveMatchResult.rawNegatedFailureMessage, positiveMatchResult.rawFailureMessage, positiveMatchResult.negatedFailureMessageArgs, positiveMatchResult.failureMessageArgs ) } override def toString: String = "not be " + Prettifier.default(resultOfAnWordApplication) } } /** * This method enables the following syntax: * *
   * myFile should (not be an (directory) and not be an (directory))
   *                    ^
   * 
*/ def be[T <: AnyRef](resultOfAnWordApplication: ResultOfAnWordToBePropertyMatcherApplication[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val result = resultOfAnWordApplication.bePropertyMatcher(left) MatchResult( !result.matches, Resources("wasAn"), Resources("wasNotAn"), Vector(left, UnquotedString(result.propertyName)) ) } override def toString: String = "not be " + Prettifier.default(resultOfAnWordApplication) } } /** * This method enables the following syntax: * *
   * result should (not be a (passedMarks) and be a (validMarks)))
   *                    ^
   * 
*/ def be[T](resultOfAnWordApplication: ResultOfAnWordToAnMatcherApplication[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val result = resultOfAnWordApplication.anMatcher(left) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not be " + Prettifier.default(resultOfAnWordApplication) } } /** * This method enables the following syntax: * *
   * myFish should (not be theSameInstanceAs (redFish) and not be theSameInstanceAs (blueFish))
   *                    ^
   * 
*/ def be[T <: AnyRef](resultOfTheSameInstanceAsApplication: ResultOfTheSameInstanceAsApplication): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { MatchResult( resultOfTheSameInstanceAsApplication.right ne left, Resources("wasSameInstanceAs"), Resources("wasNotSameInstanceAs"), Vector(left, resultOfTheSameInstanceAsApplication.right) ) } override def toString: String = "not be " + Prettifier.default(resultOfTheSameInstanceAsApplication) } } /** * This method enables the following syntax for the "primitive" numeric types: * *
   * sevenDotOh should ((not be (17.1 plusOrMinus 0.2)) and (not be (27.1 plusOrMinus 0.2)))
   *                         ^
   * 
*/ def be[U](spread: Spread[U]): Matcher[U] = { new Matcher[U] { def apply(left: U): MatchResult = { MatchResult( !(spread.isWithin(left)), Resources("wasPlusOrMinus"), Resources("wasNotPlusOrMinus"), Vector(left, spread.pivot, spread.tolerance) ) } override def toString: String = "not be " + Prettifier.default(spread) } } /** * This method enables the following syntax, where fraction is a PartialFunction: * *
   * fraction should (not be definedAt (8) and not be definedAt (0))
   *                      ^
   * 
*/ def be[A, U <: PartialFunction[A, _]](resultOfDefinedAt: ResultOfDefinedAt[A]): Matcher[U] = { new Matcher[U] { def apply(left: U): MatchResult = MatchResult( !(left.isDefinedAt(resultOfDefinedAt.right)), Resources("wasDefinedAt"), Resources("wasNotDefinedAt"), Vector(left, resultOfDefinedAt.right) ) override def toString: String = "not be " + Prettifier.default(resultOfDefinedAt) } } /** * This method enables be to be used for inequality comparison. Here are some examples: * *
   * result should not be (None)
   *                      ^
   * result should not be (Some(1))
   *                      ^
   * result should not be (true)
   *                      ^
   * result should not be (false)
   *                      ^
   * sum should not be (19)
   *                   ^
   * 
*/ def be(right: Any): Matcher[Any] = { new Matcher[Any] { def apply(left: Any): MatchResult = { left match { case null => MatchResult( right != null, Resources("wasNull"), Resources("wasNotNull"), Resources("midSentenceWasNull"), Resources("wasNotNull"), Vector.empty, Vector(right) ) case _ => val (leftee, rightee) = getObjectsForFailureMessage(left, right) // TODO: To move this to reporter MatchResult( !areEqualComparingArraysStructurally(left, right), Resources("wasEqualTo"), Resources("wasNotEqualTo"), Vector(left, right), Vector(leftee, rightee) ) } } override def toString: String = "not be " + Prettifier.default(right) } } /** * This method enables the following syntax: * *
     * fraction should (not be sorted and not be sorted)
     *                      ^
     * 
*/ def be[T <: Any](sortedWord: SortedWord): MatcherFactory1[Any, Sortable] = apply(MatcherWords.be(sortedWord)) /** * This method enables the following syntax: * *
     * fraction should (not be readable and not equal readableFile)
     *                      ^
     * 
*/ def be(readableWord: ReadableWord): MatcherFactory1[Any, Readability] = apply(MatcherWords.be(readableWord)) /** * This method enables the following syntax: * *
     * fraction should (not be writable and not be writableFile)
     *                      ^
     * 
*/ def be(writableWord: WritableWord): MatcherFactory1[Any, Writability] = apply(MatcherWords.be(writableWord)) /** * This method enables the following syntax: * *
     * nonEmptyList should (not be empty and not equal emptyList)
     *                          ^
     * 
*/ def be(emptyWord: EmptyWord): MatcherFactory1[Any, Emptiness] = apply(MatcherWords.be(emptyWord)) /** * This method enables the following syntax: * *
     * result should (not be defined and not equal something)
     *                    ^
     * 
*/ def be(definedWord: DefinedWord): MatcherFactory1[Any, Definition] = apply(MatcherWords.be(definedWord)) /** * This method enables the following syntax: * *
   * result should (not be a [Book] and not be sorted)
   *                    ^
   * 
*/ def be(aType: ResultOfATypeInvocation[_]) = new Matcher[Any] { def apply(left: Any): MatchResult = { val clazz = aType.clazz MatchResult( !clazz.isAssignableFrom(left.getClass), Resources("wasAnInstanceOf"), Resources("wasNotAnInstanceOf"), Vector(left, UnquotedString(clazz.getName)) ) } override def toString: String = "not be " + Prettifier.default(aType) } /** * This method enables the following syntax: * *
   * result should (not be an [Book] and not be sorted)
   *                    ^
   * 
*/ def be(anType: ResultOfAnTypeInvocation[_]) = new Matcher[Any] { def apply(left: Any): MatchResult = { val clazz = anType.clazz MatchResult( !clazz.isAssignableFrom(left.getClass), Resources("wasAnInstanceOf"), Resources("wasNotAnInstanceOf"), Vector(left, UnquotedString(clazz.getName)) ) } override def toString: String = "not be " + Prettifier.default(anType) } /** * This method enables the following syntax: * *
   * string should (not fullyMatch regex ("Hel*o") and not include ("orld"))
   *                    ^
   * 
*/ def fullyMatch(resultOfRegexWordApplication: ResultOfRegexWordApplication): Matcher[String] = { new Matcher[String] { def apply(left: String): MatchResult = { val result = fullyMatchRegexWithGroups(left, resultOfRegexWordApplication.regex, resultOfRegexWordApplication.groups) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not fullyMatch " + Prettifier.default(resultOfRegexWordApplication) } } /** * This method enables the following syntax: * *
   * string should (not include regex ("Hel.o") and not include regex ("""(-)?(\d+)(\.\d*)?"""))
   *                    ^
   * 
*/ def include(resultOfRegexWordApplication: ResultOfRegexWordApplication): Matcher[String] = { val rightRegex = resultOfRegexWordApplication.regex new Matcher[String] { def apply(left: String): MatchResult = { val result = includeRegexWithGroups(left, resultOfRegexWordApplication.regex, resultOfRegexWordApplication.groups) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not include " + Prettifier.default(resultOfRegexWordApplication) } } /** * This method enables the following syntax: * *
   * string should (not include ("cat") and not include ("1.7"))
   *                    ^
   * 
*/ def include(expectedSubstring: String): Matcher[String] = { new Matcher[String] { def apply(left: String): MatchResult = MatchResult( !(left.indexOf(expectedSubstring) >= 0), Resources("includedSubstring"), Resources("didNotIncludeSubstring"), Vector(left, expectedSubstring) ) override def toString: String = "not include " + Prettifier.default(expectedSubstring) } } /** * This method enables the following syntax: * *
   * string should (not startWith regex ("hel*o") and not endWith regex ("wor.d"))
   *                    ^
   * 
*/ def startWith(resultOfRegexWordApplication: ResultOfRegexWordApplication): Matcher[String] = { val rightRegex = resultOfRegexWordApplication.regex new Matcher[String] { def apply(left: String): MatchResult = { val result = startWithRegexWithGroups(left, resultOfRegexWordApplication.regex, resultOfRegexWordApplication.groups) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not startWith " + Prettifier.default(resultOfRegexWordApplication) } } /** * This method enables the following syntax: * *
   * string should ((not startWith ("red")) and (not startWith ("1.7")))
   *                     ^
   * 
*/ def startWith(expectedSubstring: String): Matcher[String] = { new Matcher[String] { def apply(left: String): MatchResult = MatchResult( left.indexOf(expectedSubstring) != 0, Resources("startedWith"), Resources("didNotStartWith"), Vector(left, expectedSubstring) ) override def toString: String = "not startWith " + Prettifier.default(expectedSubstring) } } /** * This method enables the following syntax: * *
   * string should (not endWith regex ("wor.d") and not startWith regex ("Hel*o"))
   *                    ^
   * 
*/ def endWith(resultOfRegexWordApplication: ResultOfRegexWordApplication): Matcher[String] = { val rightRegex = resultOfRegexWordApplication.regex new Matcher[String] { def apply(left: String): MatchResult = { val result = endWithRegexWithGroups(left, resultOfRegexWordApplication.regex, resultOfRegexWordApplication.groups) MatchResult( !result.matches, result.rawNegatedFailureMessage, result.rawFailureMessage, result.negatedFailureMessageArgs, result.failureMessageArgs ) } override def toString: String = "not endWith " + Prettifier.default(resultOfRegexWordApplication) } } /** * This method enables the following syntax: * *
   * string should (not endWith ("blue") and not endWith ("1.7"))
   *                    ^
   * 
*/ def endWith(expectedSubstring: String): Matcher[String] = { new Matcher[String] { def apply(left: String): MatchResult = { MatchResult( !(left endsWith expectedSubstring), Resources("endedWith"), Resources("didNotEndWith"), Vector(left, expectedSubstring) ) } override def toString: String = "not endWith " + Prettifier.default(expectedSubstring) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain (5) and not contain (3))
   *                         ^
   * 
*/ def contain[T](expectedElement: T): MatcherFactory1[Any, Containing] = { new MatcherFactory1[Any, Containing] { def matcher[U <: Any : Containing]: Matcher[U] = new Matcher[U] { def apply(left: U): MatchResult = { val containing = implicitly[Containing[U]] MatchResult( !containing.contains(left, expectedElement), Resources("containedExpectedElement"), Resources("didNotContainExpectedElement"), Vector(left, expectedElement) ) } override def toString: String = "not contain " + Prettifier.default(expectedElement) } override def toString: String = "not contain " + Prettifier.default(expectedElement) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain oneOf (5, 6, 7))
   *                         ^
   * 
*/ def contain[T](oneOf: ResultOfOneOfApplication): MatcherFactory1[Any, Containing] = { new MatcherFactory1[Any, Containing] { def matcher[T](implicit containing: Containing[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = oneOf.right MatchResult( !containing.containsOneOf(left, right), Resources("containedOneOfElements"), Resources("didNotContainOneOfElements"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(oneOf) } } override def toString: String = "not contain " + Prettifier.default(oneOf) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain (5) and not contain (3))
   *                         ^
   * 
*/ def contain[T](atLeastOneOf: ResultOfAtLeastOneOfApplication): MatcherFactory1[Any, Aggregating] = { new MatcherFactory1[Any, Aggregating] { def matcher[T](implicit aggregating: Aggregating[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = atLeastOneOf.right MatchResult( !aggregating.containsAtLeastOneOf(left, right), Resources("containedAtLeastOneOf"), Resources("didNotContainAtLeastOneOf"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(atLeastOneOf) } } override def toString: String = "not contain " + Prettifier.default(atLeastOneOf) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain noneOf (5, 6, 7))
   *                         ^
   * 
*/ def contain[T](noneOf: ResultOfNoneOfApplication): MatcherFactory1[Any, Containing] = { new MatcherFactory1[Any, Containing] { def matcher[T](implicit containing: Containing[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = noneOf.right MatchResult( !containing.containsNoneOf(left, right), Resources("didNotContainOneOfElements"), Resources("containedOneOfElements"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(noneOf) } } override def toString: String = "not contain " + Prettifier.default(noneOf) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain theSameElementsAs (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](theSameElementAs: ResultOfTheSameElementsAsApplication): MatcherFactory1[Any, Aggregating] = { new MatcherFactory1[Any, Aggregating] { def matcher[T](implicit aggregating: Aggregating[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = theSameElementAs.right MatchResult( !aggregating.containsTheSameElementsAs(left, right), Resources("containedSameElements"), Resources("didNotContainSameElements"), Vector(left, right) ) } override def toString: String = "not contain " + Prettifier.default(theSameElementAs) } } override def toString: String = "not contain " + Prettifier.default(theSameElementAs) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain theSameElementsInOrderAs (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](theSameElementInOrderAs: ResultOfTheSameElementsInOrderAsApplication): MatcherFactory1[Any, Sequencing] = { new MatcherFactory1[Any, Sequencing] { def matcher[T](implicit sequencing: Sequencing[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = theSameElementInOrderAs.right MatchResult( !sequencing.containsTheSameElementsInOrderAs(left, right), Resources("containedSameElementsInOrder"), Resources("didNotContainSameElementsInOrder"), Vector(left, right) ) } override def toString: String = "not contain " + Prettifier.default(theSameElementInOrderAs) } } override def toString: String = "not contain " + Prettifier.default(theSameElementInOrderAs) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain only (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](only: ResultOfOnlyApplication): MatcherFactory1[Any, Aggregating] = { new MatcherFactory1[Any, Aggregating] { def matcher[T](implicit aggregating: Aggregating[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = only.right MatchResult( !aggregating.containsOnly(left, right), Resources("containedOnlyElements"), Resources("didNotContainOnlyElements"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(only) } } override def toString: String = "not contain " + Prettifier.default(only) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain only (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](inOrderOnly: ResultOfInOrderOnlyApplication): MatcherFactory1[Any, Sequencing] = { new MatcherFactory1[Any, Sequencing] { def matcher[T](implicit sequencing: Sequencing[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = inOrderOnly.right MatchResult( !sequencing.containsInOrderOnly(left, right), Resources("containedInOrderOnlyElements"), Resources("didNotContainInOrderOnlyElements"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(inOrderOnly) } } override def toString: String = "not contain " + Prettifier.default(inOrderOnly) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain allOf (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](allOf: ResultOfAllOfApplication): MatcherFactory1[Any, Aggregating] = { new MatcherFactory1[Any, Aggregating] { def matcher[T](implicit aggregating: Aggregating[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = allOf.right MatchResult( !aggregating.containsAllOf(left, right), Resources("containedAllOfElements"), Resources("didNotContainAllOfElements"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(allOf) } } override def toString: String = "not contain " + Prettifier.default(allOf) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain inOrder (1, 2, 3) and not contain (3))
   *                                 ^
   * 
*/ def contain[T](inOrder: ResultOfInOrderApplication): MatcherFactory1[Any, Sequencing] = { new MatcherFactory1[Any, Sequencing] { def matcher[T](implicit sequencing: Sequencing[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = inOrder.right MatchResult( !sequencing.containsInOrder(left, right), Resources("containedAllOfElementsInOrder"), Resources("didNotContainAllOfElementsInOrder"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(inOrder) } } override def toString: String = "not contain " + Prettifier.default(inOrder) } } /** * This method enables the following syntax: * *
   * Array(1, 2) should (not contain atMostOneOf (5) and not contain (3))
   *                         ^
   * 
*/ def contain[T](atMostOneOf: ResultOfAtMostOneOfApplication): MatcherFactory1[Any, Aggregating] = { new MatcherFactory1[Any, Aggregating] { def matcher[T](implicit aggregating: Aggregating[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val right = atMostOneOf.right MatchResult( !aggregating.containsAtMostOneOf(left, right), Resources("containedAtMostOneOf"), Resources("didNotContainAtMostOneOf"), Vector(left, UnquotedString(right.map(FailureMessages.decorateToStringValue).mkString(", "))) ) } override def toString: String = "not contain " + Prettifier.default(atMostOneOf) } } override def toString: String = "not contain " + Prettifier.default(atMostOneOf) } } /** * This method enables the following syntax: * *
   * Map("one" -> 1, "two" -> 2) should (not contain key ("three"))
   *                                         ^
   * 
*/ def contain(resultOfKeyWordApplication: ResultOfKeyWordApplication): MatcherFactory1[Any, KeyMapping] = { new MatcherFactory1[Any, KeyMapping] { def matcher[T](implicit keyMapping: KeyMapping[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val expectedKey = resultOfKeyWordApplication.expectedKey MatchResult( !keyMapping.containsKey(left, expectedKey), Resources("containedKey"), Resources("didNotContainKey"), Vector(left, expectedKey) ) } override def toString: String = "not contain " + Prettifier.default(resultOfKeyWordApplication) } } override def toString: String = "not contain " + Prettifier.default(resultOfKeyWordApplication) } } /** * This method enables the following syntax: * *
   * Map("one" -> 1, "two" -> 2) should (not contain value (3))
   *                                         ^
   * 
*/ def contain(resultOfValueWordApplication: ResultOfValueWordApplication): MatcherFactory1[Any, ValueMapping] = { new MatcherFactory1[Any, ValueMapping] { def matcher[T](implicit valueMapping: ValueMapping[T]): Matcher[T] = { new Matcher[T] { def apply(left: T): MatchResult = { val expectedValue = resultOfValueWordApplication.expectedValue MatchResult( !valueMapping.containsValue(left, expectedValue), Resources("containedValue"), Resources("didNotContainValue"), Vector(left, expectedValue) ) } override def toString: String = "not contain " + Prettifier.default(resultOfValueWordApplication) } } override def toString: String = "not contain " + Prettifier.default(resultOfValueWordApplication) } } /** * This method enables the following syntax: * *
   * result should (not contain a (passedMarks) and contain a (validMarks)))
   *                    ^
   * 
*/ private[scalatest] def contain[T](resultOfAWordApplication: ResultOfAWordToAMatcherApplication[T]): Matcher[GenTraversable[T]] = { new Matcher[GenTraversable[T]] { def apply(left: GenTraversable[T]): MatchResult = { val aMatcher = resultOfAWordApplication.aMatcher val matched = left.find(aMatcher(_).matches) MatchResult( !matched.isDefined, Resources("containedA"), Resources("didNotContainA"), Vector(left, UnquotedString(aMatcher.nounName), UnquotedString(if (matched.isDefined) aMatcher(matched.get).negatedFailureMessage else "-")), Vector(left, UnquotedString(aMatcher.nounName)) ) } override def toString: String = "not contain " + Prettifier.default(resultOfAWordApplication) } } /** * This method enables the following syntax: * *
   * result should (not contain an (passedMarks) and contain an (validMarks)))
   *                    ^
   * 
*/ private[scalatest] def contain[T](resultOfAnWordApplication: ResultOfAnWordToAnMatcherApplication[T]): Matcher[GenTraversable[T]] = { new Matcher[GenTraversable[T]] { def apply(left: GenTraversable[T]): MatchResult = { val anMatcher = resultOfAnWordApplication.anMatcher val matched = left.find(anMatcher(_).matches) MatchResult( !matched.isDefined, Resources("containedAn"), Resources("didNotContainAn"), Vector(left, UnquotedString(anMatcher.nounName), UnquotedString(if (matched.isDefined) anMatcher(matched.get).negatedFailureMessage else "-")), Vector(left, UnquotedString(anMatcher.nounName)) ) } override def toString: String = "not contain " + Prettifier.default(resultOfAnWordApplication) } } /** * Overrides toString to return "not" */ override def toString: String = "not" }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy