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 15 LOCAL_PATH := $(call my-dir) 16 17 include $(CLEAR_VARS) 18 19 LOCAL_SRC_FILES := $(call all-java-files-under, src) 20 21 LOCAL_MODULE_TAGS := optional 22 23 # tag this module as a cts test artifact 24 LOCAL_COMPATIBILITY_SUITE := cts 25 26 # Must match the package name in CtsTestCaseList.mk 27 LOCAL_MODULE := CtsSecurityHostTestCases 28 29 LOCAL_MODULE_CLASS := JAVA_LIBRARIES 30 31 LOCAL_JAVA_LIBRARIES := cts-tradefed tradefed-prebuilt compatibility-host-util 32 33 LOCAL_STATIC_JAVA_LIBRARIES := cts-migration-lib 34 35 LOCAL_CTS_TEST_PACKAGE := android.host.security 36 37 selinux_general_seapp_contexts := $(call intermediates-dir-for,ETC,general_seapp_contexts)/general_seapp_contexts 38 39 selinux_general_seapp_neverallows := $(call intermediates-dir-for,ETC,general_seapp_neverallows)/general_seapp_neverallows 40 41 selinux_general_file_contexts := $(call intermediates-dir-for,ETC,general_file_contexts.bin)/general_file_contexts.bin 42 43 selinux_general_property_contexts := $(call intermediates-dir-for,ETC,general_property_contexts)/general_property_contexts 44 45 selinux_general_service_contexts := $(call intermediates-dir-for,ETC,general_service_contexts)/general_service_contexts 46 47 LOCAL_JAVA_RESOURCE_FILES := \ 48 $(HOST_OUT_EXECUTABLES)/checkseapp \ 49 $(HOST_OUT_EXECUTABLES)/checkfc \ 50 $(selinux_general_seapp_contexts) \ 51 $(selinux_general_seapp_neverallows) \ 52 $(selinux_general_file_contexts) \ 53 $(selinux_general_property_contexts) \ 54 $(selinux_general_service_contexts) 55 56 selinux_general_policy := $(call intermediates-dir-for,ETC,general_sepolicy.conf)/general_sepolicy.conf 57 58 selinux_neverallow_gen := cts/tools/selinux/SELinuxNeverallowTestGen.py 59 60 selinux_neverallow_gen_data := cts/tools/selinux/SELinuxNeverallowTestFrame.py 61 62 old_cts_sepolicy-analyze := $(CTS_TESTCASES_OUT)/sepolicy-analyze 63 64 LOCAL_ADDITIONAL_DEPENDENCIES := $(COMPATIBILITY_TESTCASES_OUT_cts)/sepolicy-analyze \ 65 $(old_cts_sepolicy-analyze) 66 67 $(old_cts_sepolicy-analyze) : $(HOST_OUT_EXECUTABLES)/sepolicy-analyze 68 mkdir -p $(dir $@) 69 $(copy-file-to-target) 70 71 LOCAL_GENERATED_SOURCES := $(call local-generated-sources-dir)/android/cts/security/SELinuxNeverallowRulesTest.java 72 73 $(LOCAL_GENERATED_SOURCES) : PRIVATE_SELINUX_GENERAL_POLICY := $(selinux_general_policy) 74 $(LOCAL_GENERATED_SOURCES) : $(selinux_neverallow_gen) $(selinux_general_policy) $(selinux_neverallow_gen_data) 75 mkdir -p $(dir $@) 76 $< $(PRIVATE_SELINUX_GENERAL_POLICY) $@ 77 78 include $(BUILD_CTS_HOST_JAVA_LIBRARY) 79 80 include $(call all-makefiles-under,$(LOCAL_PATH)) 81