org.scalatestexamples.easymock.EasyMockExampleFixtureFlatSpec.scala Maven / Gradle / Ivy
/*
* Copyright 2001-2009 OFFIS, Tammo Freese
*
* 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.scalatestexamples.easymock
import org.scalatestexamples._
import org.easymock.EasyMock._
import org.junit.Assert._
import java.util.ArrayList
import java.util.List
import org.easymock.IAnswer
import org.junit.Before
import org.junit.Test
import org.scalatest.verb.ShouldVerb
import org.scalatest.mock.EasyMockSugar
import org.scalatest.{BeforeAndAfterEach, FlatSpec}
import org.scalatest.fixture
class EasyMockExampleFixtureFlatSpec extends fixture.FlatSpec with EasyMockSugar {
case class FixtureHolder(classUnderTest: ClassTested, mockCollaborator: Collaborator)
type FixtureParam = FixtureHolder
def withFixture(test: OneArgTest) {
val mockCollaborator = mock[Collaborator]
val classUnderTest = new ClassTested()
classUnderTest.addListener(mockCollaborator)
test(FixtureHolder(classUnderTest, mockCollaborator))
}
"ClassTested" should "not call the collaborator when removing a non-existing document" in { fixture => import fixture._
replay(mockCollaborator)
classUnderTest.removeDocument("Does not exist")
}
it should "call documentAdded on the Collaborator when a new document is added" in { fixture => import fixture._
expecting {
mockCollaborator.documentAdded("New Document")
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("New Document", new Array[Byte](0))
}
}
it should "call documentChanged on the Collaborator when a document is changed" in { fixture => import fixture._
expecting {
mockCollaborator.documentAdded("Document")
mockCollaborator.documentChanged("Document")
lastCall.times(3)
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("Document", new Array[Byte](0))
classUnderTest.addDocument("Document", new Array[Byte](0))
classUnderTest.addDocument("Document", new Array[Byte](0))
classUnderTest.addDocument("Document", new Array[Byte](0))
}
}
it should "call voteForRemoval on Collaborator when removeDocument is called on ClassTested, and " +
"if a POSITIVE number is returned (i.e., a vote FOR removal), documentRemoved " +
"should be called on Collaborator" in { fixture => import fixture._
expecting {
// expect document addition
mockCollaborator.documentAdded("Document");
// expect to be asked to vote, and vote for it
mockCollaborator.voteForRemoval("Document").andReturn((42).asInstanceOf[Byte]);
// expect document removal
mockCollaborator.documentRemoved("Document");
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("Document", new Array[Byte](0));
assert(classUnderTest.removeDocument("Document"))
}
}
it should "call voteForRemoval on Collaborator when removeDocument is called on ClassTested, and " +
"if a NEGATIVE number is returned (i.e., a vote AGAINST removal), documentRemoved " +
"should NOT be called on Collaborator" in { fixture => import fixture._
expecting {
// expect document addition
mockCollaborator.documentAdded("Document");
// expect to be asked to vote, and vote against it
mockCollaborator.voteForRemoval("Document").andReturn((-42).asInstanceOf[Byte]); //
// document removal is *not* expected
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("Document", new Array[Byte](0));
assert(!classUnderTest.removeDocument("Document"))
}
}
it should "call voteForRemoval on Collaborator when removeDocument is called on ClassTested " +
"to remove multiple documents, and if a POSITIVE number is returned (i.e., a vote " +
"FOR removal), documentRemoved should be called on Collaborator" in { fixture => import fixture._
expecting {
mockCollaborator.documentAdded("Document 1");
mockCollaborator.documentAdded("Document 2");
val documents = Array("Document 1", "Document 2")
mockCollaborator.voteForRemovals(aryEq(documents)).andReturn((42).asInstanceOf[Byte]);
mockCollaborator.documentRemoved("Document 1");
mockCollaborator.documentRemoved("Document 2");
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("Document 1", new Array[Byte](0));
classUnderTest.addDocument("Document 2", new Array[Byte](0));
assert(classUnderTest.removeDocuments(Array("Document 1",
"Document 2")))
}
}
it should "call voteForRemoval on Collaborator when removeDocument is called on ClassTested " +
"to remove multiple documents, and if a NEGATIVE number is returned (i.e., a vote " +
"AGAINST removal), documentRemoved should NOT be called on Collaborator" in { fixture => import fixture._
expecting {
mockCollaborator.documentAdded("Document 1");
mockCollaborator.documentAdded("Document 2");
val documents = Array("Document 1", "Document 2")
mockCollaborator.voteForRemovals(aryEq(documents)).andReturn((-42).asInstanceOf[Byte]);
}
whenExecuting(mockCollaborator) {
classUnderTest.addDocument("Document 1", new Array[Byte](0));
classUnderTest.addDocument("Document 2", new Array[Byte](0));
assert(!classUnderTest.removeDocuments(Array("Document 1",
"Document 2")))
}
}
"EasyMock" should "work with both andAnswer and andDelegateTo styles" in { () =>
val list = mock[List[String]]
expecting {
// andAnswer style
list.remove(10).andAnswer(new IAnswer[String]() {
def answer(): String = {
return getCurrentArguments()(0).toString();
}
});
// andDelegateTo style
list.remove(10).andDelegateTo(new ArrayList[String]() {
// private static final long serialVersionUID = 1L;
override def remove(index: Int): String = {
return Integer.toString(index);
}
});
}
whenExecuting(list) {
assert("10" === list.remove(10))
assert("10" === list.remove(10))
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy