blob: 0e3c5e86ced0eb9e9621594df6f685565829a69b [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.avro.tool;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.OutputStream;
import java.io.InputStream;
import java.io.FileOutputStream;
import java.io.FileInputStream;
import java.io.BufferedOutputStream;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.PrintStream;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Random;
import org.apache.avro.AvroTestUtil;
import org.apache.avro.Schema;
import org.apache.avro.Schema.Type;
import org.apache.avro.file.DataFileReader;
import org.apache.avro.file.DataFileWriter;
import org.apache.avro.generic.GenericDatumReader;
import org.junit.BeforeClass;
import org.junit.AfterClass;
import org.junit.Test;
@SuppressWarnings("deprecation")
public class TestTextFileTools {
private static final int COUNT =
Integer.parseInt(System.getProperty("test.count", "10"));
private static final byte[] LINE_SEP = System.getProperty("line.separator").getBytes();
static File linesFile;
static ByteBuffer[] lines;
static Schema schema;
static File schemaFile;
@BeforeClass
public static void writeRandomFile() throws IOException {
schema = Schema.create(Type.BYTES);
lines = new ByteBuffer[COUNT];
linesFile = AvroTestUtil.tempFile(TestTextFileTools.class, "random.lines");
OutputStream out =
new BufferedOutputStream(new FileOutputStream(linesFile));
Random rand = new Random();
for (int j = 0; j < COUNT; j++) {
byte[] line = new byte[rand.nextInt(512)];
System.out.println("Creating line = "+line.length);
for (int i = 0; i < line.length; i++) {
int b = rand.nextInt(256);
while (b == '\n' || b == '\r')
b = rand.nextInt(256);
line[i] = (byte)b;
}
out.write(line);
out.write(LINE_SEP);
lines[j] = ByteBuffer.wrap(line);
}
out.close();
}
private void fromText(String name, String... args) throws Exception {
File avroFile = AvroTestUtil.tempFile(getClass(), name + ".avro");
ArrayList<String> arglist = new ArrayList<String>();
arglist.addAll(Arrays.asList(args));
arglist.add(linesFile.toString());
arglist.add(avroFile.toString());
new FromTextTool().run(null, null, null, arglist);
// Read it back, and make sure it's valid.
DataFileReader<ByteBuffer> file = new DataFileReader<ByteBuffer>
(avroFile, new GenericDatumReader<ByteBuffer>());
int i = 0;
for (ByteBuffer line : file) {
System.out.println("Reading line = "+line.remaining());
assertEquals(line, lines[i]);
i++;
}
assertEquals(COUNT, i);
}
@Test
public void testFromText() throws Exception {
fromText("null", "--codec", "null");
fromText("deflate", "--codec", "deflate");
fromText("snappy", "--codec", "snappy");
}
@AfterClass
public static void testToText() throws Exception {
toText("null");
toText("deflate");
toText("snappy");
}
private static void toText(String name) throws Exception {
File avroFile = AvroTestUtil.tempFile(TestTextFileTools.class, name + ".avro");
File outFile = AvroTestUtil.tempFile(TestTextFileTools.class, name + ".lines");
ArrayList<String> arglist = new ArrayList<String>();
arglist.add(avroFile.toString());
arglist.add(outFile.toString());
new ToTextTool().run(null, null, null, arglist);
// Read it back, and make sure it's valid.
InputStream orig = new BufferedInputStream(new FileInputStream(linesFile));
InputStream after = new BufferedInputStream(new FileInputStream(outFile));
int b;
while ((b = orig.read()) != -1)
assertEquals(b, after.read());
assertEquals(-1, after.read());
orig.close();
after.close();
}
}