/* | |
* Copyright 2007 the original author or authors. | |
* | |
* 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.mockftpserver.core.command; | |
import org.slf4j.Logger; | |
import org.slf4j.LoggerFactory; | |
import org.mockftpserver.core.util.AssertFailedException; | |
import org.mockftpserver.test.AbstractTestCase; | |
import java.util.Date; | |
import java.util.HashSet; | |
import java.util.Set; | |
/** | |
* Tests for InvocationRecord | |
* | |
* @version $Revision$ - $Date$ | |
* | |
* @author Chris Mair | |
*/ | |
public final class InvocationRecordTest extends AbstractTestCase { | |
private static final Logger LOG = LoggerFactory.getLogger(InvocationRecordTest.class); | |
private static final Command COMMAND = new Command("command", EMPTY); | |
private static final String KEY1 = "key1"; | |
private static final String KEY2 = "key2"; | |
private static final String STRING = "abc123"; | |
private static final Integer INT = new Integer(77); | |
private InvocationRecord invocationRecord; | |
/** | |
* Test the Constructor | |
*/ | |
public void testConstructor() { | |
final Command COMMAND = new Command("ABC", EMPTY); | |
long beforeTime = System.currentTimeMillis(); | |
InvocationRecord commandInvocation = new InvocationRecord(COMMAND, DEFAULT_HOST); | |
long afterTime = System.currentTimeMillis(); | |
LOG.info(commandInvocation.toString()); | |
assertEquals("Command", COMMAND, commandInvocation.getCommand()); | |
assertTrue("time", commandInvocation.getTime().getTime() >= beforeTime | |
&& commandInvocation.getTime().getTime() <= afterTime); | |
assertEquals("host", DEFAULT_HOST, commandInvocation.getClientHost()); | |
} | |
/** | |
* Test the set() method, passing in a null key | |
*/ | |
public void testSet_NullKey() { | |
try { | |
invocationRecord.set(null, STRING); | |
fail("Expected AssertFailedException"); | |
} | |
catch (AssertFailedException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the set() method, passing in a null value | |
*/ | |
public void testSet_NullValue() { | |
invocationRecord.set(KEY1, null); | |
assertNull(KEY1, invocationRecord.getObject(KEY1)); | |
} | |
/** | |
* Test the containsKey() method | |
*/ | |
public void testContainsKey() { | |
invocationRecord.set(KEY1, STRING); | |
assertTrue(KEY1, invocationRecord.containsKey(KEY1)); | |
assertFalse(KEY2, invocationRecord.containsKey(KEY2)); | |
} | |
/** | |
* Test the containsKey() method, passing in a null key | |
*/ | |
public void testContainsKey_Null() { | |
try { | |
invocationRecord.containsKey(null); | |
fail("Expected AssertFailedException"); | |
} | |
catch (AssertFailedException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the getString() method | |
*/ | |
public void testGetString() { | |
assertNull("undefined", invocationRecord.getString("UNDEFINED")); | |
invocationRecord.set(KEY1, STRING); | |
assertEquals(KEY1, STRING, invocationRecord.getString(KEY1)); | |
} | |
/** | |
* Test the getString() method, passing in a null key | |
*/ | |
public void testGetString_Null() { | |
try { | |
invocationRecord.getString(null); | |
fail("Expected AssertFailedException"); | |
} | |
catch (AssertFailedException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the getString() method, when the value for the key is not a String | |
*/ | |
public void testGetString_NotAString() { | |
invocationRecord.set(KEY1, INT); | |
try { | |
invocationRecord.getString(KEY1); | |
fail("Expected ClassCastException"); | |
} | |
catch (ClassCastException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the getObject() method | |
*/ | |
public void testGetObject() { | |
assertNull("undefined", invocationRecord.getObject("UNDEFINED")); | |
invocationRecord.set(KEY1, STRING); | |
assertEquals(KEY1, STRING, invocationRecord.getObject(KEY1)); | |
} | |
/** | |
* Test the keySet() method | |
*/ | |
public void testKeySet() { | |
Set set = new HashSet(); | |
assertEquals("empty", set, invocationRecord.keySet()); | |
invocationRecord.set(KEY1, STRING); | |
invocationRecord.set(KEY2, STRING); | |
set.add(KEY1); | |
set.add(KEY2); | |
assertEquals("2", set, invocationRecord.keySet()); | |
} | |
/** | |
* Test that the keySet() return value does not allow breaking immutability | |
*/ | |
public void testKeySet_Immutability() { | |
Set keySet = invocationRecord.keySet(); | |
try { | |
keySet.add("abc"); | |
fail("Expected UnsupportedOperationException"); | |
} | |
catch (UnsupportedOperationException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the getObject() method, passing in a null key | |
*/ | |
public void testGetObject_Null() { | |
try { | |
invocationRecord.getObject(null); | |
fail("Expected AssertFailedException"); | |
} | |
catch (AssertFailedException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test the lock() method | |
*/ | |
public void testLock() { | |
assertFalse("locked - before", invocationRecord.isLocked()); | |
invocationRecord.set(KEY1, STRING); | |
invocationRecord.lock(); | |
assertTrue("locked - after", invocationRecord.isLocked()); | |
try { | |
invocationRecord.set(KEY2, "abc"); | |
fail("Expected AssertFailedException"); | |
} | |
catch (AssertFailedException expected) { | |
LOG.info("Expected: " + expected); | |
} | |
} | |
/** | |
* Test that the getTime() return value does not break immutability | |
*/ | |
public void testGetTime_Immutability() { | |
Date timestamp = invocationRecord.getTime(); | |
long timeInMillis = timestamp.getTime(); | |
timestamp.setTime(12345L); | |
assertEquals("time", timeInMillis, invocationRecord.getTime().getTime()); | |
} | |
/** | |
* Perform initialization before each test | |
* | |
* @see org.mockftpserver.test.AbstractTestCase#setUp() | |
*/ | |
protected void setUp() throws Exception { | |
super.setUp(); | |
invocationRecord = new InvocationRecord(COMMAND, DEFAULT_HOST); | |
} | |
} |