/* * Copyright (C) 2011 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. */ #ifndef ART_RUNTIME_COMMON_RUNTIME_TEST_H_ #define ART_RUNTIME_COMMON_RUNTIME_TEST_H_ #include #include #include #include "base/mutex.h" #include "globals.h" #include "os.h" namespace art { class ClassLinker; class CompilerCallbacks; class DexFile; class JavaVMExt; class Runtime; typedef std::vector> RuntimeOptions; class ScratchFile { public: ScratchFile(); ScratchFile(const ScratchFile& other, const char* suffix); explicit ScratchFile(File* file); ~ScratchFile(); const std::string& GetFilename() const { return filename_; } File* GetFile() const { return file_.get(); } int GetFd() const; void Close(); void Unlink(); private: std::string filename_; std::unique_ptr file_; }; class CommonRuntimeTest : public testing::Test { public: static void SetUpAndroidRoot(); // Note: setting up ANDROID_DATA may create a temporary directory. If this is used in a // non-derived class, be sure to also call the corresponding tear-down below. static void SetUpAndroidData(std::string& android_data); static void TearDownAndroidData(const std::string& android_data, bool fail_on_error); CommonRuntimeTest(); ~CommonRuntimeTest(); // Gets the path of the libcore dex file. static std::string GetLibCoreDexFileName(); protected: static bool IsHost() { return !kIsTargetBuild; } // File location to core.art, e.g. $ANDROID_HOST_OUT/system/framework/core.art static std::string GetCoreArtLocation(); // File location to core.oat, e.g. $ANDROID_HOST_OUT/system/framework/core.oat static std::string GetCoreOatLocation(); std::unique_ptr LoadExpectSingleDexFile(const char* location); virtual void SetUp(); // Allow subclases such as CommonCompilerTest to add extra options. virtual void SetUpRuntimeOptions(RuntimeOptions* options ATTRIBUTE_UNUSED) {} void ClearDirectory(const char* dirpath); virtual void TearDown(); // Called before the runtime is created. virtual void PreRuntimeCreate() {} // Called after the runtime is created. virtual void PostRuntimeCreate() {} // Gets the path of the specified dex file for host or target. static std::string GetDexFileName(const std::string& jar_prefix); std::string GetTestAndroidRoot(); std::string GetTestDexFileName(const char* name); std::vector> OpenTestDexFiles(const char* name) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); std::unique_ptr OpenTestDexFile(const char* name) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); jobject LoadDex(const char* dex_name) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); std::string android_data_; std::string dalvik_cache_; std::unique_ptr runtime_; // The class_linker_, java_lang_dex_file_, and boot_class_path_ are all // owned by the runtime. ClassLinker* class_linker_; const DexFile* java_lang_dex_file_; std::vector boot_class_path_; // Get the dex files from a PathClassLoader. This in order of the dex elements and their dex // arrays. std::vector GetDexFiles(jobject jclass_loader); // Get the first dex file from a PathClassLoader. Will abort if it is null. const DexFile* GetFirstDexFile(jobject jclass_loader); std::unique_ptr callbacks_; private: static std::string GetCoreFileLocation(const char* suffix); std::vector> loaded_dex_files_; }; // Sets a CheckJni abort hook to catch failures. Note that this will cause CheckJNI to carry on // rather than aborting, so be careful! class CheckJniAbortCatcher { public: CheckJniAbortCatcher(); ~CheckJniAbortCatcher(); void Check(const char* expected_text); private: static void Hook(void* data, const std::string& reason); JavaVMExt* const vm_; std::string actual_; DISALLOW_COPY_AND_ASSIGN(CheckJniAbortCatcher); }; // TODO: When heap reference poisoning works with the compiler, get rid of this. #define TEST_DISABLED_FOR_HEAP_REFERENCE_POISONING() \ if (kPoisonHeapReferences) { \ printf("WARNING: TEST DISABLED FOR HEAP REFERENCE POISONING\n"); \ return; \ } #define TEST_DISABLED_FOR_MIPS() \ if (kRuntimeISA == kMips || kRuntimeISA == kMips64) { \ printf("WARNING: TEST DISABLED FOR MIPS\n"); \ return; \ } } // namespace art namespace std { // TODO: isn't gtest supposed to be able to print STL types for itself? template std::ostream& operator<<(std::ostream& os, const std::vector& rhs); } // namespace std #endif // ART_RUNTIME_COMMON_RUNTIME_TEST_H_