All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.dasasian.chok.testutil.GenerateMapFiles Maven / Gradle / Ivy

/**
 * Copyright (C) 2014 Dasasian ([email protected])
 *
 * 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 com.dasasian.chok.testutil;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.RawLocalFileSystem;
import org.apache.hadoop.io.MapFile;
import org.apache.hadoop.io.Text;

import java.io.File;

public class GenerateMapFiles {

    /**
     * This generates the very simple MapFiles in chok/src/test/testMapFile[AB]/.
     * These files are supposed to simulate taking 2 large MapFiles and splitting the first one
     * into 4 shards, the second into 2 shards. We do not provide such a tool yet.
     * The results are checked in, so you should not need to run this. Is is provided
     * as a reference.
     * @param args the arguments
     * @throws java.lang.Exception when and error occurs
     */
    public static void main(String[] args) throws Exception {
        Configuration conf = new Configuration();
        conf.set("io.file.buffer.size", "4096");
        FileSystem fs = new RawLocalFileSystem();
        fs.setConf(conf);
        //
        File f = new File("src/test/testMapFileA/a1");
        MapFile.Writer w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "a.txt", "This is a test");
        write(w, "b.xml", "test");
        write(w, "c.log", "1/1/2009: test");
        w.close();
        //
        f = new File("src/test/testMapFileA/a2");
        w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "d.html", "test");
        write(w, "e.txt", "An e test");
        write(w, "f.log", "1/2/2009: test2");
        w.close();
        //
        f = new File("src/test/testMapFileA/a3");
        w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "g.log", "1/3/2009: more test");
        write(w, "h.txt", "Test in part 3");
        w.close();
        //
        f = new File("src/test/testMapFileA/a4");
        w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "i.xml", "test");
        write(w, "j.log", "1/4/2009: 4 test");
        write(w, "k.out", "test data");
        write(w, "l.txt", "line 4");
        w.close();
        //
        //
        f = new File("src/test/testMapFileB/b1");
        w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "u.txt", "Test U text");
        write(w, "v.xml", "foo");
        write(w, "w.txt", "where is test");
        w.close();
        //
        f = new File("src/test/testMapFileB/b2");
        w = new MapFile.Writer(conf, fs, f.getAbsolutePath(), Text.class, Text.class);
        write(w, "x.txt", "xrays ionize");
        write(w, "y.xml", "foo");
        write(w, "z.xml", "foo");
        w.close();
    }

    private static void write(MapFile.Writer w, String fn, String data) throws Exception {
        w.append(new Text(fn), new Text(data));
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy