gobblin.data.management.retention.FsCleanableHelperTest.java Source code

Java tutorial

Introduction

Here is the source code for gobblin.data.management.retention.FsCleanableHelperTest.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 gobblin.data.management.retention;

import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.instanceOf;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;

import java.util.List;
import java.util.Properties;
import java.util.Set;

import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.extern.slf4j.Slf4j;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
import org.testng.Assert;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;

import com.google.common.collect.ImmutableList;
import com.google.common.collect.Sets;
import com.google.common.io.Files;
import com.typesafe.config.ConfigFactory;

import gobblin.data.management.retention.dataset.FsCleanableHelper;
import gobblin.data.management.trash.MockTrash;
import gobblin.data.management.version.FileSystemDatasetVersion;
import gobblin.dataset.FileSystemDataset;

@Slf4j
@Test(groups = { "gobblin.data.management.retention" })
public class FsCleanableHelperTest {
    private FileSystem fs;
    private Path testTempPath;

    @BeforeClass
    public void setup() throws Exception {
        this.fs = FileSystem.getLocal(new Configuration());
        this.testTempPath = new Path(Files.createTempDir().getAbsolutePath(), "FsCleanableHelperTest");
        this.fs.mkdirs(this.testTempPath);
    }

    @AfterClass
    public void cleanUp() {
        try {
            fs.delete(this.testTempPath, true);
        } catch (Exception e) {
            // ignore
        }
    }

    @Test
    public void testSimulateTrash() throws Exception {

        Properties props = new Properties();
        props.setProperty(FsCleanableHelper.SIMULATE_KEY, Boolean.toString(true));
        FsCleanableHelper fsCleanableHelper = new FsCleanableHelper(this.fs, props, ConfigFactory.empty(), log);

        assertThat(fsCleanableHelper.getTrash(), instanceOf(MockTrash.class));
    }

    @Test
    public void testDeleteEmptyDirs() throws Exception {
        Properties props = new Properties();
        props.setProperty(FsCleanableHelper.SKIP_TRASH_KEY, Boolean.toString(true));
        FsCleanableHelper fsCleanableHelper = new FsCleanableHelper(this.fs, props, ConfigFactory.empty(), log);
        FileSystemDataset fsDataset = mock(FileSystemDataset.class);
        Path datasetRoot = new Path(testTempPath, "dataset1");
        when(fsDataset.datasetRoot()).thenReturn(datasetRoot);

        // To delete
        Path deleted1 = new Path(datasetRoot, "2016/01/01/13");
        Path deleted2 = new Path(datasetRoot, "2016/01/01/14");
        Path deleted3 = new Path(datasetRoot, "2016/01/02/15");

        // Do not delete
        Path notDeleted1 = new Path(datasetRoot, "2016/01/02/16");

        this.fs.mkdirs(deleted1);
        this.fs.mkdirs(deleted2);
        this.fs.mkdirs(deleted3);
        this.fs.mkdirs(notDeleted1);

        // Make sure all paths are created
        Assert.assertTrue(this.fs.exists(deleted1));
        Assert.assertTrue(this.fs.exists(deleted2));
        Assert.assertTrue(this.fs.exists(deleted3));
        Assert.assertTrue(this.fs.exists(notDeleted1));

        List<FileSystemDatasetVersion> deletableVersions = ImmutableList.<FileSystemDatasetVersion>of(
                new MockFileSystemDatasetVersion(deleted1), new MockFileSystemDatasetVersion(deleted2),
                new MockFileSystemDatasetVersion(deleted3));

        fsCleanableHelper.clean(deletableVersions, fsDataset);

        // Verify versions are deleted
        Assert.assertFalse(this.fs.exists(deleted1));
        Assert.assertFalse(this.fs.exists(deleted2));
        Assert.assertFalse(this.fs.exists(deleted3));

        // Verify versions are not deleted
        Assert.assertTrue(this.fs.exists(notDeleted1));

        // Verify empty parent dir "2016/01/01" is deleted
        Assert.assertFalse(this.fs.exists(deleted1.getParent()));

        // Verify non empty parent dir "2016/01/02" exists
        Assert.assertTrue(this.fs.exists(notDeleted1.getParent()));
    }

    @AllArgsConstructor
    private static class MockFileSystemDatasetVersion implements FileSystemDatasetVersion {

        @Getter
        private final Path path;

        @Override
        public Object getVersion() {
            return null;
        }

        @Override
        public int compareTo(FileSystemDatasetVersion o) {
            return 0;
        }

        @Override
        public Set<Path> getPaths() {
            return Sets.newHashSet(this.path);
        }

    }
}