String tmpFilePath = tmpOutPath.toURI().toString();
// check fail if file exists
DummyFileOutputFormat dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.PARONLY);
dfof.configure(new Configuration());
boolean exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(exception);
// check fail if directory exists
tmpOutPath.delete();
Assert.assertTrue("Directory could not be created.", tmpOutPath.mkdir());
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.PARONLY);
dfof.configure(new Configuration());
exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(exception);
// check success
tmpOutPath.delete();
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.PARONLY);
dfof.configure(new Configuration());
exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(!exception);
Assert.assertTrue(tmpOutPath.exists() && tmpOutPath.isFile());
// ----------- test again with always directory mode
// check fail if file exists
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.ALWAYS);
dfof.configure(new Configuration());
exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(exception);
// check success if directory exists
tmpOutPath.delete();
Assert.assertTrue("Directory could not be created.", tmpOutPath.mkdir());
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.ALWAYS);
dfof.configure(new Configuration());
exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(!exception);
Assert.assertTrue(tmpOutPath.exists() && tmpOutPath.isDirectory());
Assert.assertTrue(tmpOutFile.exists() && tmpOutFile.isFile());
// check fail if file in directory exists
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.ALWAYS);
dfof.configure(new Configuration());
exception = false;
try {
dfof.open(0, 1);
dfof.close();
} catch (Exception e) {
exception = true;
}
Assert.assertTrue(exception);
// check success if no file exists
// delete existing files
(new File(tmpOutPath.getAbsoluteFile()+"/1")).delete();
tmpOutPath.delete();
dfof = new DummyFileOutputFormat();
dfof.setOutputFilePath(new Path(tmpFilePath));
dfof.setWriteMode(WriteMode.NO_OVERWRITE);
dfof.setOutputDirectoryMode(OutputDirectoryMode.ALWAYS);
dfof.configure(new Configuration());