Home | History | Annotate | Download | only in security
      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_JAVA_RESOURCE_DIRS := res
     22 
     23 LOCAL_MODULE_TAGS := optional
     24 
     25 # tag this module as a cts test artifact
     26 LOCAL_COMPATIBILITY_SUITE := cts vts general-tests sts
     27 
     28 # Must match the package name in CtsTestCaseList.mk
     29 LOCAL_MODULE := CtsSecurityHostTestCases
     30 
     31 LOCAL_MODULE_CLASS := JAVA_LIBRARIES
     32 
     33 LOCAL_JAVA_LIBRARIES := cts-tradefed tradefed compatibility-host-util
     34 
     35 LOCAL_CTS_TEST_PACKAGE := android.host.security
     36 
     37 ifeq ($(HOST_OS),darwin)
     38 SHAREDLIB_EXT=dylib
     39 else
     40 SHAREDLIB_EXT=so
     41 endif
     42 
     43 selinux_plat_seapp_contexts := $(call intermediates-dir-for,ETC,plat_seapp_contexts)/plat_seapp_contexts
     44 
     45 selinux_plat_seapp_neverallows := $(call intermediates-dir-for,ETC,plat_seapp_neverallows)/plat_seapp_neverallows
     46 
     47 selinux_plat_file_contexts := $(call intermediates-dir-for,ETC,plat_file_contexts)/plat_file_contexts
     48 
     49 selinux_plat_property_contexts := $(call intermediates-dir-for,ETC,plat_property_contexts)/plat_property_contexts
     50 
     51 selinux_plat_service_contexts := $(call intermediates-dir-for,ETC,plat_service_contexts)/plat_service_contexts
     52 
     53 LOCAL_JAVA_RESOURCE_FILES := \
     54     $(HOST_OUT_EXECUTABLES)/checkseapp \
     55     $(HOST_OUT_EXECUTABLES)/checkfc \
     56     $(HOST_OUT_EXECUTABLES)/property_info_checker \
     57     $(HOST_OUT_EXECUTABLES)/searchpolicy \
     58     $(HOST_OUT_EXECUTABLES)/secilc \
     59     $(HOST_OUT_EXECUTABLES)/sepolicy_tests \
     60     $(HOST_OUT_EXECUTABLES)/treble_sepolicy_tests \
     61     $(HOST_OUT)/lib64/libsepolwrap.$(SHAREDLIB_EXT) \
     62     $(HOST_OUT)/lib64/libc++.$(SHAREDLIB_EXT) \
     63     $(selinux_plat_seapp_contexts) \
     64     $(selinux_plat_seapp_neverallows) \
     65     $(selinux_plat_file_contexts) \
     66     $(selinux_plat_property_contexts) \
     67     $(selinux_plat_service_contexts)
     68 
     69 selinux_general_policy := $(call intermediates-dir-for,ETC,general_sepolicy.conf)/general_sepolicy.conf
     70 
     71 selinux_neverallow_gen := cts/tools/selinux/SELinuxNeverallowTestGen.py
     72 
     73 selinux_neverallow_gen_data := cts/tools/selinux/SELinuxNeverallowTestFrame.py
     74 
     75 LOCAL_ADDITIONAL_DEPENDENCIES := $(COMPATIBILITY_TESTCASES_OUT_cts)/sepolicy-analyze
     76 
     77 LOCAL_GENERATED_SOURCES := $(call local-generated-sources-dir)/android/cts/security/SELinuxNeverallowRulesTest.java
     78 
     79 $(LOCAL_GENERATED_SOURCES) : PRIVATE_SELINUX_GENERAL_POLICY := $(selinux_general_policy)
     80 $(LOCAL_GENERATED_SOURCES) : $(selinux_neverallow_gen) $(selinux_general_policy) $(selinux_neverallow_gen_data)
     81 	mkdir -p $(dir $@)
     82 	$< $(PRIVATE_SELINUX_GENERAL_POLICY) $@
     83 
     84 include $(BUILD_CTS_HOST_JAVA_LIBRARY)
     85 
     86 include $(call all-makefiles-under,$(LOCAL_PATH))
     87