Package com.splunk.shuttl.archiver.filesystem.glacier

Source Code of com.splunk.shuttl.archiver.filesystem.glacier.GlacierArchiveFileSystemTest

// Copyright (C) 2011 Splunk Inc.
//
// Splunk Inc. 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.splunk.shuttl.archiver.filesystem.glacier;

import static com.splunk.shuttl.testutil.TUtilsFile.*;
import static org.mockito.Matchers.*;
import static org.mockito.Mockito.*;

import java.io.File;
import java.io.IOException;

import org.apache.log4j.Logger;
import org.mockito.InOrder;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;

import com.amazonaws.AmazonClientException;
import com.amazonaws.AmazonServiceException;
import com.splunk.shuttl.archiver.archive.BucketDeleter;
import com.splunk.shuttl.archiver.archive.BucketFormat;
import com.splunk.shuttl.archiver.filesystem.transaction.bucket.TransfersBuckets;
import com.splunk.shuttl.archiver.importexport.tgz.TgzFormatExporter;
import com.splunk.shuttl.archiver.model.Bucket;
import com.splunk.shuttl.archiver.model.LocalBucket;
import com.splunk.shuttl.testutil.TUtilsBucket;

@Test(groups = { "fast-unit" })
public class GlacierArchiveFileSystemTest {

  private GlacierClient glacierClient;
  private TransfersBuckets glacierBucketTransferer;

  private String temp;
  private String dst;
  private TgzFormatExporter tgzFormatExporter;
  private Logger logger;
  private BucketDeleter bucketDeleter;
  private GlacierArchiveIdStore glacierArchiveIdStore;

  @BeforeMethod
  public void setUp() {
    glacierClient = mock(GlacierClient.class);
    tgzFormatExporter = mock(TgzFormatExporter.class);
    logger = mock(Logger.class);
    bucketDeleter = mock(BucketDeleter.class);
    glacierArchiveIdStore = mock(GlacierArchiveIdStore.class);
    glacierBucketTransferer = new GlacierArchiveFileSystem(null, glacierClient,
        tgzFormatExporter, logger, bucketDeleter, glacierArchiveIdStore)
        .getBucketTransferer();

    temp = "/path/temp";
    dst = "/path/dst";
  }

  public void putBucket_givenTgzBucket_uploadBucketToTheRealDestination()
      throws IOException {
    LocalBucket tgzBucket = TUtilsBucket.createTgzBucket();
    glacierBucketTransferer.put(tgzBucket, temp, dst);
    verify(glacierClient).upload(eq(getBucketFile(tgzBucket)), eq(dst));
  }

  public void putBucket_tgzBucket_afterUpLoadingBucketPersistArchiveId()
      throws AmazonServiceException, AmazonClientException, IOException {
    LocalBucket tgzBucket = TUtilsBucket.createTgzBucket();
    String archiveId = "archiveId";
    when(glacierClient.getArchiveId(dst)).thenReturn(archiveId);
    glacierBucketTransferer.put(tgzBucket, temp, dst);

    InOrder inOrder = inOrder(glacierClient, glacierArchiveIdStore);
    inOrder.verify(glacierClient).upload(any(File.class), anyString());
    inOrder.verify(glacierClient).getArchiveId(dst);
    inOrder.verify(glacierArchiveIdStore).putArchiveId(tgzBucket, archiveId);
  }

  private File getBucketFile(LocalBucket tgzBucket) {
    return tgzBucket.getDirectory().listFiles()[0];
  }

  public void putBucket_givenSplunkBucket_exportBucketToTgzAndLogThisEventThenUploadTgz()
      throws IOException {
    LocalBucket bucket = TUtilsBucket.createBucket();
    LocalBucket tgzBucket = TUtilsBucket.createTgzBucket();
    when(tgzFormatExporter.exportBucket(bucket)).thenReturn(tgzBucket);
    glacierBucketTransferer.put(bucket, temp, dst);
    verify(glacierClient).upload(eq(getBucketFile(tgzBucket)), eq(dst));
    verify(logger).warn(anyString());
  }

  public void putBucket_givenSplunkBucket_exportedBucketGetsUploadedThenDeleted()
      throws IOException {
    LocalBucket bucket = TUtilsBucket.createBucket();
    LocalBucket tgzBucket = TUtilsBucket.createTgzBucket();
    when(tgzFormatExporter.exportBucket(bucket)).thenReturn(tgzBucket);
    glacierBucketTransferer.put(bucket, temp, dst);
    InOrder inOrder = inOrder(glacierClient, bucketDeleter);
    inOrder.verify(glacierClient).upload(eq(getBucketFile(tgzBucket)), eq(dst));
    inOrder.verify(bucketDeleter).deleteBucket(tgzBucket);
    inOrder.verifyNoMoreInteractions();
  }

  public void getBucket_bucket_getTheFileInTheBucketWhichIsTheGlacierArchiveByUsingTheExtensionToTheBucketFormat()
      throws IOException {
    Bucket tgzBucket = TUtilsBucket.createTgzBucket();

    String bucketFileName = tgzBucket.getName()
        + BucketFormat.extensionOfFormat(tgzBucket.getFormat());

    File temp = createDirectory();
    File fileInBucketWhichIsTheGlacierArchive = new File(temp, bucketFileName);
    File dst = mock(File.class);
    glacierBucketTransferer.get(tgzBucket, temp, dst);

    verify(glacierClient).downloadArchiveToFile(eq(tgzBucket.getPath()),
        eq(fileInBucketWhichIsTheGlacierArchive));
    verifyZeroInteractions(glacierArchiveIdStore);
  }

  public void getBucket_archiveIdDoesNotExist_putsArchiveIdWithGlacierArchiveIdStore()
      throws IOException {
    Bucket remoteBucket = TUtilsBucket.createRemoteBucket();
    String key = remoteBucket.getPath();
    File localTemp = createDirectory();
    File localDst = mock(File.class);
    when(glacierClient.getArchiveId(key)).thenThrow(
        new GlacierArchiveIdDoesNotExist("msg"));
    String archiveId = "archiveId";
    when(glacierArchiveIdStore.getArchiveId(remoteBucket))
        .thenReturn(archiveId);

    glacierBucketTransferer.get(remoteBucket, localTemp, localDst);
    InOrder inOrder = inOrder(glacierClient, glacierArchiveIdStore);
    inOrder.verify(glacierClient).getArchiveId(key);
    inOrder.verify(glacierArchiveIdStore).getArchiveId(remoteBucket);
    inOrder.verify(glacierClient).putArchiveId(key, archiveId);
  }

  @Test(expectedExceptions = { GlacierArchivingException.class })
  public void putBucket_glacierClientThrows_wrapsExceptionInGlacierArchivingException()
      throws IOException {
    doThrow(RuntimeException.class).when(glacierClient).upload(any(File.class),
        anyString());
    glacierBucketTransferer.put(TUtilsBucket.createTgzBucket(), temp, dst);
  }

  @Test(expectedExceptions = { GlacierThawingException.class })
  public void getBucket_glacierClientThrows_wrapsExceptionInGlacierThawingException()
      throws IOException {
    doThrow(RuntimeException.class).when(glacierClient).downloadArchiveToFile(
        anyString(), any(File.class));
    glacierBucketTransferer.get(TUtilsBucket.createRemoteBucket(),
        createDirectory(), mock(File.class));
  }
}
TOP

Related Classes of com.splunk.shuttl.archiver.filesystem.glacier.GlacierArchiveFileSystemTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.