testing work for writing to fiule
This commit is contained in:
parent
0e3c0f36df
commit
426af12200
@ -1,5 +1,7 @@
|
|||||||
package org.baeldung.java.io;
|
package org.baeldung.java.io;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
import java.io.BufferedOutputStream;
|
import java.io.BufferedOutputStream;
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
@ -21,9 +23,9 @@ import java.nio.file.Files;
|
|||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class TestWriter extends TestCase {
|
public class TestWriter {
|
||||||
|
|
||||||
private String fileName = "test.txt";
|
private String fileName = "test.txt";
|
||||||
private String fileName1 = "test1.txt";
|
private String fileName1 = "test1.txt";
|
||||||
@ -32,20 +34,7 @@ public class TestWriter extends TestCase {
|
|||||||
private String fileName4 = "test4.txt";
|
private String fileName4 = "test4.txt";
|
||||||
private String fileName5 = "test5.txt";
|
private String fileName5 = "test5.txt";
|
||||||
|
|
||||||
public TestWriter(final String name) {
|
@Test
|
||||||
super(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void setUp() throws Exception {
|
|
||||||
super.setUp();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void tearDown() throws Exception {
|
|
||||||
super.tearDown();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void whenWriteStringUsingBufferedWritter_thenCorrect() throws IOException {
|
public void whenWriteStringUsingBufferedWritter_thenCorrect() throws IOException {
|
||||||
final String str = "Hello";
|
final String str = "Hello";
|
||||||
final BufferedWriter writer = new BufferedWriter(new FileWriter(fileName3));
|
final BufferedWriter writer = new BufferedWriter(new FileWriter(fileName3));
|
||||||
@ -53,6 +42,7 @@ public class TestWriter extends TestCase {
|
|||||||
writer.close();
|
writer.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenAppendStringUsingBufferedWritter_thenOldContentShouldExistToo() throws IOException {
|
public void whenAppendStringUsingBufferedWritter_thenOldContentShouldExistToo() throws IOException {
|
||||||
final String str = "World";
|
final String str = "World";
|
||||||
final BufferedWriter writer = new BufferedWriter(new FileWriter(fileName3, true));
|
final BufferedWriter writer = new BufferedWriter(new FileWriter(fileName3, true));
|
||||||
@ -61,6 +51,7 @@ public class TestWriter extends TestCase {
|
|||||||
writer.close();
|
writer.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteFormattedStringUsingPrintWriter_thenOutputShouldBeFormatted() throws IOException {
|
public void whenWriteFormattedStringUsingPrintWriter_thenOutputShouldBeFormatted() throws IOException {
|
||||||
final FileWriter fileWriter = new FileWriter(fileName);
|
final FileWriter fileWriter = new FileWriter(fileName);
|
||||||
final PrintWriter printWriter = new PrintWriter(fileWriter);
|
final PrintWriter printWriter = new PrintWriter(fileWriter);
|
||||||
@ -68,6 +59,7 @@ public class TestWriter extends TestCase {
|
|||||||
printWriter.close();
|
printWriter.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteStringUsingFileOutputStream_thenCorrect() throws IOException {
|
public void whenWriteStringUsingFileOutputStream_thenCorrect() throws IOException {
|
||||||
final String str = "Hello";
|
final String str = "Hello";
|
||||||
final FileOutputStream outputStream = new FileOutputStream(fileName3);
|
final FileOutputStream outputStream = new FileOutputStream(fileName3);
|
||||||
@ -76,6 +68,7 @@ public class TestWriter extends TestCase {
|
|||||||
outputStream.close();
|
outputStream.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteStringWithDataOutputStream_thenReadShouldBeTheSame() throws IOException {
|
public void whenWriteStringWithDataOutputStream_thenReadShouldBeTheSame() throws IOException {
|
||||||
final String value = "Hello";
|
final String value = "Hello";
|
||||||
final FileOutputStream fos = new FileOutputStream(fileName1);
|
final FileOutputStream fos = new FileOutputStream(fileName1);
|
||||||
@ -92,7 +85,8 @@ public class TestWriter extends TestCase {
|
|||||||
assertEquals(value, result);
|
assertEquals(value, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void whenWriteToPositionAndEditIt_thenItShouldChange() {
|
@Test
|
||||||
|
public void whenWriteToPositionAndEditIt_thenItShouldChange() throws IOException {
|
||||||
final int data1 = 2014;
|
final int data1 = 2014;
|
||||||
final int data2 = 1500;
|
final int data2 = 1500;
|
||||||
testWriteToPosition(data1, 4);
|
testWriteToPosition(data1, 4);
|
||||||
@ -101,6 +95,7 @@ public class TestWriter extends TestCase {
|
|||||||
assertEquals(data2, testReadFromPosition(4));
|
assertEquals(data2, testReadFromPosition(4));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenTryToLockFile_thenItShouldBeLocked() throws IOException {
|
public void whenTryToLockFile_thenItShouldBeLocked() throws IOException {
|
||||||
final RandomAccessFile stream = new RandomAccessFile(fileName4, "rw");
|
final RandomAccessFile stream = new RandomAccessFile(fileName4, "rw");
|
||||||
final FileChannel channel = stream.getChannel();
|
final FileChannel channel = stream.getChannel();
|
||||||
@ -119,6 +114,7 @@ public class TestWriter extends TestCase {
|
|||||||
channel.close();
|
channel.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteStringUsingFileChannel_thenReadShouldBeTheSame() throws IOException {
|
public void whenWriteStringUsingFileChannel_thenReadShouldBeTheSame() throws IOException {
|
||||||
final RandomAccessFile stream = new RandomAccessFile(fileName5, "rw");
|
final RandomAccessFile stream = new RandomAccessFile(fileName5, "rw");
|
||||||
final FileChannel channel = stream.getChannel();
|
final FileChannel channel = stream.getChannel();
|
||||||
@ -137,6 +133,7 @@ public class TestWriter extends TestCase {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteToTmpFile_thenCorrect() throws IOException {
|
public void whenWriteToTmpFile_thenCorrect() throws IOException {
|
||||||
final String toWrite = "Hello";
|
final String toWrite = "Hello";
|
||||||
final File tmpFile = File.createTempFile("test", ".tmp");
|
final File tmpFile = File.createTempFile("test", ".tmp");
|
||||||
@ -149,6 +146,7 @@ public class TestWriter extends TestCase {
|
|||||||
reader.close();
|
reader.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void whenWriteUsingJava7_thenCorrect() throws IOException {
|
public void whenWriteUsingJava7_thenCorrect() throws IOException {
|
||||||
final String str = "Hello";
|
final String str = "Hello";
|
||||||
|
|
||||||
@ -162,28 +160,20 @@ public class TestWriter extends TestCase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// use RandomAccessFile to write data at specific position in the file
|
// use RandomAccessFile to write data at specific position in the file
|
||||||
public void testWriteToPosition(final int data, final long position) {
|
private void testWriteToPosition(final int data, final long position) throws IOException {
|
||||||
try {
|
final RandomAccessFile writer = new RandomAccessFile(fileName2, "rw");
|
||||||
final RandomAccessFile writer = new RandomAccessFile(fileName2, "rw");
|
writer.seek(position);
|
||||||
writer.seek(position);
|
writer.writeInt(data);
|
||||||
writer.writeInt(data);
|
writer.close();
|
||||||
writer.close();
|
|
||||||
} catch (final Exception e) {
|
|
||||||
System.out.println(e.getLocalizedMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// use RandomAccessFile to read data from specific position in the file
|
// use RandomAccessFile to read data from specific position in the file
|
||||||
public int testReadFromPosition(final long position) {
|
private int testReadFromPosition(final long position) throws IOException {
|
||||||
int result = 0;
|
int result = 0;
|
||||||
try {
|
final RandomAccessFile reader = new RandomAccessFile(fileName2, "r");
|
||||||
final RandomAccessFile reader = new RandomAccessFile(fileName2, "r");
|
reader.seek(position);
|
||||||
reader.seek(position);
|
result = reader.readInt();
|
||||||
result = reader.readInt();
|
reader.close();
|
||||||
reader.close();
|
|
||||||
} catch (final Exception e) {
|
|
||||||
System.out.println(e.getLocalizedMessage());
|
|
||||||
}
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user