/*
* Copyright (C) 2012 The CyanogenMod 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.cyanogenmod.filemanager.commands.shell;
import android.os.Environment;
import android.test.suitebuilder.annotation.LargeTest;
import android.util.Log;
import com.cyanogenmod.filemanager.commands.AsyncResultExecutable;
import com.cyanogenmod.filemanager.commands.AsyncResultListener;
import com.cyanogenmod.filemanager.model.FolderUsage;
import com.cyanogenmod.filemanager.util.CommandHelper;
import com.cyanogenmod.filemanager.util.MimeTypeHelper.MimeTypeCategory;
/**
* A class for testing folder usage command.
*
* @see FolderUsageCommand
*/
public class FolderUsageCommandTest extends AbstractConsoleTest {
private static final String TAG = "FolderUsageCommandTest"; //$NON-NLS-1$
private static final String PATH =
Environment.getDataDirectory().getAbsolutePath() + "/app"; //$NON-NLS-1$
/**
* @hide
*/
final Object mSync = new Object();
/**
* @hide
*/
boolean mNewPartialData;
/**
* @hide
*/
boolean mNormalEnd;
/**
* @hide
*/
FolderUsage mUsage;
/**
* {@inheritDoc}
*/
@Override
public boolean isRootConsoleNeeded() {
return true;
}
/**
* Method that performs a test over known search results.
*
* @throws Exception If test failed
*/
@LargeTest
public void testFolderUsageWithPartialResult() throws Exception {
this.mNewPartialData = false;
this.mNormalEnd = false;
this.mUsage = null;
AsyncResultExecutable cmd =
CommandHelper.getFolderUsage(getContext(), PATH, new AsyncResultListener() {
@Override
public void onAsyncStart() {
/**NON BLOCK**/
}
@Override
public void onAsyncEnd(boolean cancelled) {
synchronized (FolderUsageCommandTest.this.mSync) {
FolderUsageCommandTest.this.mNormalEnd = true;
FolderUsageCommandTest.this.mSync.notify();
}
}
@Override
public void onAsyncExitCode(int exitCode) {
/**NON BLOCK**/
}
@Override
public void onException(Exception cause) {
fail(String.valueOf(cause));
}
@Override
public void onPartialResult(Object result) {
FolderUsageCommandTest.this.mNewPartialData = true;
try {
FolderUsageCommandTest.this.mUsage =
(FolderUsage)(((FolderUsage)result).clone());
} catch (Exception e) {/**NON BLOCK**/}
Log.d(TAG, FolderUsageCommandTest.this.mUsage.toString());
}
}, getConsole());
synchronized (FolderUsageCommandTest.this.mSync) {
FolderUsageCommandTest.this.mSync.wait(15000L);
}
try {
if (!this.mNormalEnd && cmd != null && cmd.isCancellable() && !cmd.isCancelled()) {
cmd.cancel();
}
} catch (Exception e) {/**NON BLOCK**/}
assertTrue("no new partial data", this.mNewPartialData); //$NON-NLS-1$
assertNotNull("usage==null", this.mUsage); //$NON-NLS-1$
assertTrue("no files returned", this.mUsage.getNumberOfFiles() > 0); //$NON-NLS-1$
assertTrue("no size returned", this.mUsage.getTotalSize() > 0); //$NON-NLS-1$
assertTrue("no text category returned", //$NON-NLS-1$
this.mUsage.getStatisticsForCategory(MimeTypeCategory.APP) > 0);
}
}