blob: 72a3a046ccfbc1d0a89c9a842cca35fd86575935 [file] [log] [blame]
/*
* Copyright (C) 2010 The Android Open Source Project
*
* 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.android.tradefed.result;
import com.android.tradefed.build.IBuildInfo;
import com.android.tradefed.util.FileUtil;
import com.android.tradefed.util.StreamUtil;
import junit.framework.TestCase;
import org.easymock.EasyMock;
import java.io.BufferedReader;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStream;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.zip.ZipEntry;
import java.util.zip.ZipFile;
/**
* Unit tests for {@link FileSystemLogSaver}.
* <p>
* Depends on filesyste I/O.
* </p>
*/
public class FileSystemLogSaverTest extends TestCase {
private static final String BUILD_ID = "88888";
private static final String BRANCH = "somebranch";
private static final String TEST_TAG = "sometest";
private File mReportDir;
private IBuildInfo mMockBuild;
@Override
protected void setUp() throws Exception {
super.setUp();
mReportDir = FileUtil.createTempDir("tmpdir");
mMockBuild = EasyMock.createMock(IBuildInfo.class);
EasyMock.expect(mMockBuild.getBuildBranch()).andReturn(BRANCH).anyTimes();
EasyMock.expect(mMockBuild.getBuildId()).andReturn(BUILD_ID).anyTimes();
EasyMock.expect(mMockBuild.getTestTag()).andReturn(TEST_TAG).anyTimes();
EasyMock.replay(mMockBuild);
}
@Override
protected void tearDown() throws Exception {
FileUtil.recursiveDelete(mReportDir);
super.tearDown();
}
/**
* Test that a unique directory is created
*/
public void testGetFileDir() {
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.invocationStarted(mMockBuild);
File generatedDir = new File(saver.getLogReportDir().getPath());
File tagDir = generatedDir.getParentFile();
// ensure a directory with name == testtag is parent of generated directory
assertEquals(TEST_TAG, tagDir.getName());
File buildDir = tagDir.getParentFile();
// ensure a directory with name == build number is parent of generated directory
assertEquals(BUILD_ID, buildDir.getName());
// ensure a directory with name == branch is parent of generated directory
File branchDir = buildDir.getParentFile();
assertEquals(BRANCH, branchDir.getName());
// ensure parent directory is rootDir
assertEquals(0, mReportDir.compareTo(branchDir.getParentFile()));
// now create a new log saver,
FileSystemLogSaver newSaver = new FileSystemLogSaver();
newSaver.setReportDir(mReportDir);
newSaver.invocationStarted(mMockBuild);
File newGeneratedDir = new File(newSaver.getLogReportDir().getPath());
// ensure a new dir is created
assertTrue(generatedDir.compareTo(newGeneratedDir) != 0);
// verify tagDir is reused
File newTagDir = newGeneratedDir.getParentFile();
assertEquals(0, tagDir.compareTo(newTagDir));
}
/**
* Test that a unique directory is created when no branch is specified
*/
public void testGetFileDir_nobranch() {
IBuildInfo mockBuild = EasyMock.createMock(IBuildInfo.class);
EasyMock.expect(mockBuild.getBuildBranch()).andReturn(null).anyTimes();
EasyMock.expect(mockBuild.getBuildId()).andReturn(BUILD_ID).anyTimes();
EasyMock.expect(mockBuild.getTestTag()).andReturn(TEST_TAG).anyTimes();
EasyMock.replay(mockBuild);
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.invocationStarted(mockBuild);
File generatedDir = new File(saver.getLogReportDir().getPath());
File tagDir = generatedDir.getParentFile();
// ensure a directory with name == testtag is parent of generated directory
assertEquals(TEST_TAG, tagDir.getName());
File buildDir = tagDir.getParentFile();
// ensure a directory with name == build number is parent of generated directory
assertEquals(BUILD_ID, buildDir.getName());
// ensure parent directory is rootDir
assertEquals(0, mReportDir.compareTo(buildDir.getParentFile()));
}
/**
* Test that retention file creation
*/
@SuppressWarnings("deprecation")
public void testGetFileDir_retention() throws IOException, ParseException {
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.setLogRetentionDays(1);
saver.invocationStarted(mMockBuild);
File retentionFile = new File(new File(saver.getLogReportDir().getPath()),
RetentionFileSaver.RETENTION_FILE_NAME);
assertTrue(retentionFile.isFile());
String timestamp = StreamUtil.getStringFromStream(new FileInputStream(retentionFile));
SimpleDateFormat formatter = new SimpleDateFormat(RetentionFileSaver.RETENTION_DATE_FORMAT);
Date retentionDate = formatter.parse(timestamp);
Date currentDate = new Date();
int expectedDay = (currentDate.getDay() + 1) % 7;
assertEquals(expectedDay, retentionDate.getDay());
}
/**
* Test saving uncompressed data for
* {@link FileSystemLogSaver#saveLogData(String, LogDataType, InputStream)}.
*/
public void testSaveLogData_uncompressed() throws IOException {
LogFile logFile = null;
ZipFile zipFile = null;
BufferedReader logFileReader = null;
try {
// TODO: would be nice to create a mock file output to make this test not use disk I/O
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.invocationStarted(mMockBuild);
final String testData = "Here's some test data, blah";
ByteArrayInputStream mockInput = new ByteArrayInputStream(testData.getBytes());
logFile = saver.saveLogData("testSaveLogData", LogDataType.TEXT, mockInput);
assertTrue(logFile.getPath().endsWith(LogDataType.ZIP.getFileExt()));
// Verify test data was written to file
zipFile = new ZipFile(new File(logFile.getPath()));
String actualLogString = StreamUtil.getStringFromStream(zipFile.getInputStream(
new ZipEntry("testSaveLogData.txt")));
assertTrue(actualLogString.equals(testData));
} finally {
StreamUtil.close(logFileReader);
if (zipFile != null) {
zipFile.close();
}
FileUtil.deleteFile(new File(logFile.getPath()));
}
}
/**
* Test saving compressed data for
* {@link FileSystemLogSaver#saveLogDataRaw(String, String, InputStream)}.
*/
public void testSaveLogData_compressed() throws IOException {
LogFile logFile = null;
BufferedReader logFileReader = null;
try {
// TODO: would be nice to create a mock file output to make this test not use disk I/O
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.invocationStarted(mMockBuild);
final String testData = "Here's some test data, blah";
ByteArrayInputStream mockInput = new ByteArrayInputStream(testData.getBytes());
logFile = saver.saveLogData("testSaveLogData", LogDataType.ZIP, mockInput);
// Verify test data was written to file
logFileReader = new BufferedReader(new FileReader(new File(logFile.getPath())));
String actualLogString = logFileReader.readLine().trim();
assertTrue(actualLogString.equals(testData));
} finally {
StreamUtil.close(logFileReader);
FileUtil.deleteFile(new File(logFile.getPath()));
}
}
/**
* Simple normal case test for
* {@link FileSystemLogSaver#saveLogDataRaw(String, String, InputStream)}.
*/
public void testSaveLogDataRaw() throws IOException {
LogFile logFile = null;
BufferedReader logFileReader = null;
try {
// TODO: would be nice to create a mock file output to make this test not use disk I/O
FileSystemLogSaver saver = new FileSystemLogSaver();
saver.setReportDir(mReportDir);
saver.invocationStarted(mMockBuild);
final String testData = "Here's some test data, blah";
ByteArrayInputStream mockInput = new ByteArrayInputStream(testData.getBytes());
logFile = saver.saveLogDataRaw("testSaveLogData", LogDataType.TEXT.getFileExt(),
mockInput);
// Verify test data was written to file
logFileReader = new BufferedReader(new FileReader(new File(logFile.getPath())));
String actualLogString = logFileReader.readLine().trim();
assertTrue(actualLogString.equals(testData));
} finally {
StreamUtil.close(logFileReader);
FileUtil.deleteFile(new File(logFile.getPath()));
}
}
}