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