OSDN Git Service

original
[gb-231r1-is01/GB_2.3_IS01.git] / cts / tools / host / test / com / android / cts / CtsTestBase.java
diff --git a/cts/tools/host/test/com/android/cts/CtsTestBase.java b/cts/tools/host/test/com/android/cts/CtsTestBase.java
new file mode 100644 (file)
index 0000000..1df40a7
--- /dev/null
@@ -0,0 +1,182 @@
+/*
+ * Copyright (C) 2008 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.cts;
+
+import java.io.BufferedWriter;
+import java.io.File;
+import java.io.FileWriter;
+import java.io.IOException;
+
+import junit.framework.TestCase;
+
+/**
+ * Set up the test environment and offer the utility APIs.
+ */
+public abstract class CtsTestBase extends TestCase {
+    public static final String APK_SUFFIX = ".apk";
+    public static final String DESCRITION_SUFFIX = ".xml";
+
+    protected static final String ROOT = "tmp";
+    protected static final String CONFIG_PATH = ROOT + File.separator + "host_config.xml";
+
+    private static final String CASE_REPOSITORY = "case_rep_demo";
+    private static final String RESULT_REPOSITORY = "result_rep_demo";
+    private static final String PLAN_REPOSITORY = "plan_rep_demo";
+
+    /** {@inheritDoc} */
+    @Override
+    public void setUp() {
+        // create root direcoty for the test
+        new File(ROOT).mkdirs();
+
+        initConfig();
+        Log.initLog(ROOT);
+    }
+
+    /** {@inheritDoc} */
+    @Override
+    public void tearDown() {
+        Log.closeLog();
+        clearDirectory(ROOT);
+    }
+
+    /**
+     * Initialize the configuration for tests.
+     */
+    private void initConfig() {
+        StringBuilder buf = new StringBuilder();
+
+        buf.append("<HostConfiguration>");
+        buf.append("\t<Repository root=\"" + ROOT + "\" >");
+        buf.append("\t\t<TestPlan path=\"" + PLAN_REPOSITORY + "\" />");
+        buf.append("\t\t<TestCase path=\"" + CASE_REPOSITORY + "\" />");
+        buf.append("\t\t<TestResult path=\"" + RESULT_REPOSITORY + "\" />");
+        buf.append("\t</Repository>");
+        buf.append("</HostConfiguration>");
+        try {
+            new File(ROOT + File.separator + PLAN_REPOSITORY).mkdirs();
+            new File(ROOT + File.separator + CASE_REPOSITORY).mkdirs();
+            new File(ROOT + File.separator + RESULT_REPOSITORY).mkdirs();
+            createFile(buf.toString(), CONFIG_PATH);
+
+        } catch (IOException e1) {
+            fail("Can't create config file");
+        }
+
+        try {
+            TestHost.loadConfig(CONFIG_PATH);
+        } catch (Exception e) {
+            e.printStackTrace();
+            fail("Can't initiate config");
+        }
+    }
+
+    /**
+     * Create test package with the package name and the xml message as the content.
+     * 
+     * @param xmlMsg The message as the content of the package.
+     * @param packageName The package name.
+     */
+    protected void createTestPackage(String xmlMsg, String packageName) throws IOException {
+        String caseRoot = HostConfig.getInstance().getCaseRepository()
+                .getRoot();
+
+        String apkPath = caseRoot + File.separator + packageName + APK_SUFFIX;
+        String xmlPath = caseRoot + File.separator + packageName
+                + DESCRITION_SUFFIX;
+
+        createFile(null, apkPath);
+        createFile(xmlMsg, xmlPath);
+    }
+
+    /**
+     * Delete the test package.
+     */
+    protected void deleteTestPackage(String path) {
+        String apkPath = path + File.separator + APK_SUFFIX;
+        String desPath = path + File.separator + DESCRITION_SUFFIX;
+
+        deleteFile(apkPath);
+        deleteFile(desPath);
+    }
+
+    /**
+     * Create the specified file with the specified content.
+     * 
+     * @param content The content written into the file.
+     * @param filePath The file to be created.
+     */
+    protected void createFile(String content, String filePath)
+            throws IOException {
+        BufferedWriter out = new BufferedWriter(new FileWriter(filePath));
+        if (content != null) {
+            out.write(content);
+        }
+
+        out.close();
+    }
+
+    /**
+     * Delete the specified file.
+     * 
+     * @param path The file to be deleted.
+     */
+    protected void deleteFile(String path) {
+        File f = new File(path);
+
+        if (f.exists() && f.canWrite()) {
+            f.delete();
+        }
+    }
+
+    /**
+     * Clear the directory by deleting the files and directories under it.
+     * 
+     * @param path The directory to be cleared.
+     */
+    private void clearDirectory(String path) {
+        File root = new File(path);
+        for (File f : root.listFiles()) {
+            if (f.isFile()) {
+                f.delete();
+            } else {
+                deleteDirectory(f);
+            }
+        }
+
+        root.delete();
+    }
+
+    /**
+     * Deleted the directory, including the files and sub-directories under it.
+     * 
+     * @param path The directory to be deleted.
+     */
+    private void deleteDirectory(File path) {
+        if (path.exists()) {
+            File[] files = path.listFiles();
+            for (int i = 0; i < files.length; i++) {
+                if (files[i].isDirectory()) {
+                    deleteDirectory(files[i]);
+                } else {
+                    files[i].delete();
+                }
+            }
+
+            path.delete();
+        }
+    }
+}