package com.ibm.tck.javax.microedition.io.file.FileConnection;
import java.io.IOException;
import javax.microedition.io.Connector;
import javax.microedition.io.file.ConnectionClosedException;
import javax.microedition.io.file.FileConnection;
import javax.microedition.io.file.IllegalModeException;
import com.ibm.tck.javax.microedition.io.file.support.TestCaseWithLog;
/*
* Licensed Materials - Property of IBM,
* (c) Copyright IBM Corp. 2003 All Rights Reserved
*/
public class LastModified extends TestCaseWithLog {
/**
* @see com.ibm.tck.client.TestCase#runTests()
*/
public void runTests() {
if (isTestValid("test0001")) test0001();
if (isTestValid("test0002")) test0002();
if (isTestValid("test0003")) test0003();
if (isTestValid("test0004")) test0004();
if (isTestValid("test0005")) test0005();
if (isTestValid("test0006")) test0006();
if (isTestValid("test0007")) test0007();
if (isTestValid("test0008")) test0008();
if (isTestValid("test0009")) test0009();
if (isTestValid("test0010")) test0010();
}
/*
* Tests lastModified() on a file
*/
public void test0001() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.READ_WRITE);
try {
addOperationDesc("Creating file: " + conn.getURL());
long startTime = System.currentTimeMillis();
ensureFileExists(conn);
long endTime = System.currentTimeMillis();
// round startTime down to nearest minute
startTime -= startTime % 60000;
// round endTime up to nearest minute
endTime += 60000 - (endTime % 60000);
long modifyTime = conn.lastModified();
addOperationDesc("lastModified() returned " + modifyTime);
passed = modifyTime >= startTime && modifyTime <= endTime;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a file", passed);
}
/*
* Tests lastModified() on a file (modification date is NOT supported by filesystem)
*/
public void test0002() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.READ_WRITE);
try {
addOperationDesc("Creating file: " + conn.getURL());
ensureFileExists(conn);
long modifyTime = conn.lastModified();
addOperationDesc("lastModified() returned " + modifyTime);
passed = modifyTime == 0;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a file (modification date is NOT supported by filesystem)", passed);
}
/*
* Tests lastModified() on a directory
*/
public void test0003() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"testdir/", Connector.READ_WRITE);
try {
addOperationDesc("Creating directory: " + conn.getURL());
long startTime = System.currentTimeMillis();
ensureDirExists(conn);
long endTime = System.currentTimeMillis();
// round startTime down to nearest minute
startTime -= startTime % 60000;
// round endTime up to nearest minute
endTime += 60000 - (endTime % 60000);
long modifyTime = conn.lastModified();
addOperationDesc("lastModified() returned " + modifyTime);
passed = modifyTime >= startTime && modifyTime <= endTime;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a directory", passed);
}
/*
* Tests lastModified() on a directory (modification date is NOT supported by filesystem)
*/
public void test0004() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"testdir/", Connector.READ_WRITE);
try {
addOperationDesc("Creating directory: " + conn.getURL());
ensureDirExists(conn);
long modifyTime = conn.lastModified();
addOperationDesc("lastModified() returned " + modifyTime);
passed = modifyTime == 0;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a directory (modification date is NOT supported by filesystem)", passed);
}
/**
* ConnectionClosedException thrown if invoked on a closed connection
*/
public void test0005() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.READ_WRITE);
try {
conn.close();
try {
conn.lastModified();
addOperationDesc("No ConnectionClosedException thrown");
passed = false;
} catch (ConnectionClosedException e) {
addOperationDesc("Expected ConnectionClosedException thrown");
passed = true;
}
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("ConnectionClosedException thrown if invoked on a closed connection", passed);
}
/**
* IllegalModeException thrown for connections opened in Connector.WRITE mode
*/
public void test0006() {
boolean passed = false;
try {
addOperationDesc("Opening connection in WRITE mode");
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.WRITE);
try {
try {
conn.lastModified();
addOperationDesc("No IllegalModeException thrown");
passed = false;
} catch (IllegalModeException e) {
passed = true;
addOperationDesc("Expected IllegalModeException thrown");
}
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("IllegalModeException thrown for connections opened in Connector.WRITE mode", passed);
}
/**
* Tests lastModified() in Connector.READ mode
*/
public void test0007() {
boolean passed = false;
try {
addOperationDesc("Opening connection in READ mode");
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.READ);
try {
long lastModified = conn.lastModified();
addOperationDesc("lastModified() call returned " + lastModified);
passed = true;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() in Connector.READ mode", passed);
}
/*
* Tests lastModified() on a non-existent file
*/
public void test0008() {
boolean passed = false;
try {
FileConnection conn = (FileConnection)Connector.open("file://"+getTestPath()+"test", Connector.READ_WRITE);
try {
addOperationDesc("Deleting file: " + conn.getURL());
ensureNotExists(conn);
long modifyTime = conn.lastModified();
addOperationDesc("lastModified() returned " + modifyTime);
passed = modifyTime == 0;
} finally {
conn.close();
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a non-existent file", passed);
}
/**
* Tests lastModified() on a non-existent file system
*/
public void test0009() {
boolean passed = false;
try {
FileConnection conn = null;
try {
String possibleNonExistentFilesystem ="/TCKFileSystem/";
conn = (FileConnection)Connector.open("file://"+possibleNonExistentFilesystem+"testdir/", Connector.READ_WRITE);
} catch (IOException ioe) {
addOperationDesc("Expected IOException thrown");
passed = true;
} catch (SecurityException e) {
passed = true;
addOperationDesc("Expected SecurityException thrown");
}
if (conn != null) {
addOperationDesc("Opened connection on a non existent file system: " + conn.getURL());
try {
long lastModified = conn.lastModified();
addOperationDesc("lastModified() call returned " + lastModified);
passed = lastModified==0;
} finally {
conn.close();
}
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a non-existent file system", passed);
}
/**
* Tests lastModified() on a non-existent host
*/
public void test0010() {
boolean passed = false;
try {
FileConnection conn = null;
try {
String possibleNonExistentFilesystem ="TCKBogusHost/TCKFileSystem/";
conn = (FileConnection)Connector.open("file://"+possibleNonExistentFilesystem+"testdir/", Connector.READ_WRITE);
} catch (IOException ioe) {
addOperationDesc("Expected IOException thrown");
passed = true;
} catch (SecurityException e) {
passed = true;
addOperationDesc("Expected SecurityException thrown");
}
if (conn != null) {
addOperationDesc("Opened connection on a non existent file system: " + conn.getURL());
try {
long lastModified = conn.lastModified();
addOperationDesc("lastModified() call returned " + lastModified);
passed = lastModified==0;
} finally {
conn.close();
}
}
} catch (Exception e) {
logUnexpectedExceptionDesc(e);
passed = false;
}
assertTrueWithLog("Tests lastModified() on a non-existent host", passed);
}
}