1# Copyright (C) 2014 The Android Open Source Project 2# 3# Licensed under the Apache License, Version 2.0 (the "License"); 4# you may not use this file except in compliance with the License. 5# You may obtain a copy of the License at 6# 7# http://www.apache.org/licenses/LICENSE-2.0 8# 9# Unless required by applicable law or agreed to in writing, software 10# distributed under the License is distributed on an "AS IS" BASIS, 11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12# See the License for the specific language governing permissions and 13# limitations under the License. 14 15LOCAL_PATH := $(call my-dir) 16 17include $(CLEAR_VARS) 18 19LOCAL_SRC_FILES := $(call all-java-files-under, src) 20 21LOCAL_MODULE_TAGS := optional 22 23# tag this module as a cts test artifact 24LOCAL_COMPATIBILITY_SUITE := cts general-tests 25 26# Must match the package name in CtsTestCaseList.mk 27LOCAL_MODULE := CtsSecurityHostTestCases 28LOCAL_LICENSE_KINDS := SPDX-license-identifier-Apache-2.0 29LOCAL_LICENSE_CONDITIONS := notice 30 31LOCAL_MODULE_CLASS := JAVA_LIBRARIES 32 33LOCAL_JAVA_LIBRARIES := cts-tradefed tradefed compatibility-host-util 34 35LOCAL_CTS_TEST_PACKAGE := android.host.security 36 37selinux_plat_seapp_contexts := $(call intermediates-dir-for,ETC,plat_seapp_contexts)/plat_seapp_contexts 38 39selinux_plat_seapp_neverallows := $(call intermediates-dir-for,ETC,plat_seapp_neverallows)/plat_seapp_neverallows 40 41selinux_plat_file_contexts := $(call intermediates-dir-for,ETC,plat_file_contexts)/plat_file_contexts 42 43selinux_plat_property_contexts := $(call intermediates-dir-for,ETC,plat_property_contexts)/plat_property_contexts 44 45selinux_plat_service_contexts := $(call intermediates-dir-for,ETC,plat_service_contexts)/plat_service_contexts 46 47LOCAL_JAVA_RESOURCE_FILES := \ 48 $(HOST_OUT_EXECUTABLES)/checkseapp \ 49 $(HOST_OUT_EXECUTABLES)/checkfc \ 50 $(HOST_OUT_EXECUTABLES)/property_info_checker \ 51 $(HOST_OUT_EXECUTABLES)/searchpolicy \ 52 $(HOST_OUT_EXECUTABLES)/secilc \ 53 $(HOST_OUT_EXECUTABLES)/sepolicy-analyze \ 54 $(HOST_OUT_EXECUTABLES)/sepolicy_tests \ 55 $(HOST_OUT_EXECUTABLES)/treble_sepolicy_tests \ 56 $(HOST_OUT_SHARED_LIBRARIES)/libsepolwrap$(HOST_SHLIB_SUFFIX) \ 57 $(HOST_OUT_SHARED_LIBRARIES)/libc++$(HOST_SHLIB_SUFFIX) \ 58 $(selinux_plat_seapp_contexts) \ 59 $(selinux_plat_seapp_neverallows) \ 60 $(selinux_plat_file_contexts) \ 61 $(selinux_plat_property_contexts) \ 62 $(selinux_plat_service_contexts) 63 64selinux_general_policy := $(call intermediates-dir-for,ETC,general_sepolicy.conf)/general_sepolicy.conf 65 66selinux_neverallow_gen := cts/tools/selinux/SELinuxNeverallowTestGen.py 67 68selinux_neverallow_gen_data := cts/tools/selinux/SELinuxNeverallowTestFrame.py 69 70LOCAL_GENERATED_SOURCES := $(call local-generated-sources-dir)/android/cts/security/SELinuxNeverallowRulesTest.java 71 72$(LOCAL_GENERATED_SOURCES) : PRIVATE_SELINUX_GENERAL_POLICY := $(selinux_general_policy) 73$(LOCAL_GENERATED_SOURCES) : $(selinux_neverallow_gen) $(selinux_general_policy) $(selinux_neverallow_gen_data) 74 mkdir -p $(dir $@) 75 $< $(PRIVATE_SELINUX_GENERAL_POLICY) $@ 76 77LOCAL_TARGET_REQUIRED_MODULES := CtsDeviceInfo 78 79include $(BUILD_CTS_HOST_JAVA_LIBRARY) 80 81include $(call all-makefiles-under,$(LOCAL_PATH)) 82