com.datatorrent.lib.util.FSWindowDataManagerTest.java Source code

Java tutorial

Introduction

Here is the source code for com.datatorrent.lib.util.FSWindowDataManagerTest.java

Source

/**
 * 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 com.datatorrent.lib.util;

import java.io.File;
import java.io.IOException;
import java.util.Arrays;
import java.util.Map;
import java.util.TreeSet;

import org.junit.Assert;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TestWatcher;
import org.junit.runner.Description;

import org.apache.commons.io.FileUtils;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;

import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.google.common.collect.Sets;

import com.datatorrent.api.Attribute;
import com.datatorrent.api.Context;
import com.datatorrent.api.DAG;
import com.datatorrent.api.annotation.Stateless;
import com.datatorrent.lib.helper.OperatorContextTestHelper;

/**
 * Tests for {@link WindowDataManager}
 */
public class FSWindowDataManagerTest {
    private static class TestMeta extends TestWatcher {

        String applicationPath;
        WindowDataManager.FSWindowDataManager storageManager;
        Context.OperatorContext context;

        @Override
        protected void starting(Description description) {
            TestUtils.deleteTargetTestClassFolder(description);
            super.starting(description);
            storageManager = new WindowDataManager.FSWindowDataManager();
            applicationPath = "target/" + description.getClassName() + "/" + description.getMethodName();

            Attribute.AttributeMap.DefaultAttributeMap attributes = new Attribute.AttributeMap.DefaultAttributeMap();
            attributes.put(DAG.APPLICATION_PATH, applicationPath);
            context = new OperatorContextTestHelper.TestIdOperatorContext(1, attributes);
        }

        @Override
        protected void finished(Description description) {
            TestUtils.deleteTargetTestClassFolder(description);
        }
    }

    @Rule
    public TestMeta testMeta = new TestMeta();

    @Test
    public void testLargestRecoveryWindow() {
        testMeta.storageManager.setup(testMeta.context);
        Assert.assertEquals("largest recovery", Stateless.WINDOW_ID,
                testMeta.storageManager.getLargestRecoveryWindow());
        testMeta.storageManager.teardown();
    }

    @Test
    public void testSave() throws IOException {
        testMeta.storageManager.setup(testMeta.context);
        Map<Integer, String> data = Maps.newHashMap();
        data.put(1, "one");
        data.put(2, "two");
        data.put(3, "three");
        testMeta.storageManager.save(data, 1, 1);
        testMeta.storageManager.setup(testMeta.context);
        @SuppressWarnings("unchecked")
        Map<Integer, String> decoded = (Map<Integer, String>) testMeta.storageManager.load(1, 1);
        Assert.assertEquals("dataOf1", data, decoded);
        testMeta.storageManager.teardown();
    }

    @Test
    public void testLoad() throws IOException {
        testMeta.storageManager.setup(testMeta.context);
        Map<Integer, String> dataOf1 = Maps.newHashMap();
        dataOf1.put(1, "one");
        dataOf1.put(2, "two");
        dataOf1.put(3, "three");

        Map<Integer, String> dataOf2 = Maps.newHashMap();
        dataOf2.put(4, "four");
        dataOf2.put(5, "five");
        dataOf2.put(6, "six");

        testMeta.storageManager.save(dataOf1, 1, 1);
        testMeta.storageManager.save(dataOf2, 2, 1);
        testMeta.storageManager.setup(testMeta.context);
        Map<Integer, Object> decodedStates = testMeta.storageManager.load(1);
        Assert.assertEquals("no of states", 2, decodedStates.size());
        for (Integer operatorId : decodedStates.keySet()) {
            if (operatorId == 1) {
                Assert.assertEquals("data of 1", dataOf1, decodedStates.get(1));
            } else {
                Assert.assertEquals("data of 2", dataOf2, decodedStates.get(2));
            }
        }
        testMeta.storageManager.teardown();
    }

    @Test
    public void testRecovery() throws IOException {
        testMeta.storageManager.setup(testMeta.context);
        Map<Integer, String> dataOf1 = Maps.newHashMap();
        dataOf1.put(1, "one");
        dataOf1.put(2, "two");
        dataOf1.put(3, "three");

        Map<Integer, String> dataOf2 = Maps.newHashMap();
        dataOf2.put(4, "four");
        dataOf2.put(5, "five");
        dataOf2.put(6, "six");

        testMeta.storageManager.save(dataOf1, 1, 1);
        testMeta.storageManager.save(dataOf2, 2, 2);

        testMeta.storageManager.setup(testMeta.context);
        Assert.assertEquals("largest recovery window", 2, testMeta.storageManager.getLargestRecoveryWindow());
        testMeta.storageManager.teardown();
    }

    @Test
    public void testDelete() throws IOException {
        testMeta.storageManager.setup(testMeta.context);
        Map<Integer, String> dataOf1 = Maps.newHashMap();
        dataOf1.put(1, "one");
        dataOf1.put(2, "two");
        dataOf1.put(3, "three");

        Map<Integer, String> dataOf2 = Maps.newHashMap();
        dataOf2.put(4, "four");
        dataOf2.put(5, "five");
        dataOf2.put(6, "six");

        Map<Integer, String> dataOf3 = Maps.newHashMap();
        dataOf2.put(7, "seven");
        dataOf2.put(8, "eight");
        dataOf2.put(9, "nine");

        for (int i = 1; i <= 9; ++i) {
            testMeta.storageManager.save(dataOf1, 1, i);
        }

        testMeta.storageManager.save(dataOf2, 2, 1);
        testMeta.storageManager.save(dataOf3, 3, 1);

        testMeta.storageManager.partitioned(Lists.<WindowDataManager>newArrayList(testMeta.storageManager),
                Sets.newHashSet(2, 3));
        testMeta.storageManager.setup(testMeta.context);
        testMeta.storageManager.deleteUpTo(1, 6);

        Path appPath = new Path(testMeta.applicationPath + '/' + testMeta.storageManager.getRecoveryPath());
        FileSystem fs = FileSystem.newInstance(appPath.toUri(), new Configuration());
        FileStatus[] fileStatuses = fs.listStatus(new Path(appPath, Integer.toString(1)));
        Assert.assertEquals("number of windows for 1", 3, fileStatuses.length);
        TreeSet<String> windows = Sets.newTreeSet();
        for (FileStatus fileStatus : fileStatuses) {
            windows.add(fileStatus.getPath().getName());
        }
        Assert.assertEquals("window list for 1", Sets.newTreeSet(Arrays.asList("7", "8", "9")), windows);
        Assert.assertEquals("no data for 2", false, fs.exists(new Path(appPath, Integer.toString(2))));
        Assert.assertEquals("no data for 3", false, fs.exists(new Path(appPath, Integer.toString(3))));
        testMeta.storageManager.teardown();
    }

    @Test
    public void testAbsoluteRecoveryPath() throws IOException {
        testMeta.storageManager.setRecoveryPathRelativeToAppPath(false);
        long time = System.currentTimeMillis();
        testMeta.storageManager.setRecoveryPath("target/" + time);
        testSave();
        File recoveryDir = new File("target/" + time);
        Assert.assertTrue("recover path exist", recoveryDir.isDirectory());
        FileUtils.deleteDirectory(recoveryDir);
    }

}