Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1c3a97fd authored by Thiébaud Weksteen's avatar Thiébaud Weksteen
Browse files

AndroidGlobalLintCheckerIntegrationTest: Add missing annotation test

Bug: 302400088
Test: atest --host AndroidGlobalLintCheckerIntegrationTest
Change-Id: Ie71a8976a62b42ab490f43ead2764747686d181f
parent 4c785fe1
Loading
Loading
Loading
Loading
+39 −6
Original line number Original line Diff line number Diff line
@@ -12,25 +12,58 @@
// See the License for the specific language governing permissions and
// See the License for the specific language governing permissions and
// limitations under the License.
// limitations under the License.


java_library {
// Integration tests for @EnforcePermission linters.
    name: "AndroidGlobalLintTestNoAidl",
// Each test defines its own java_library. The XML lint report from this
    srcs: ["TestNoAidl/**/*.java"],
// java_library is wrapped under a Python library with a unique pkg_path (this
// is to avoid a name conflict for the report file). All the tests are
// referenced and executed by AndroidGlobalLintCheckerIntegrationTest.

java_defaults {
    name: "AndroidGlobalLintIntegrationTestDefault",
    libs: [
    libs: [
        "framework-annotations-lib",
        "framework-annotations-lib",
    ],
    ],
    lint: {
    lint: {
        // It is expected that lint returns an error when processing this
        // It is expected that lint returns an error when processing the
        // library. Silence it here, the lint output is verified in tests.py.
        // library. Silence it here, the lint output is verified in tests.py.
        suppress_exit_code: true,
        suppress_exit_code: true,
    },
    },
}
}


java_library {
    name: "AndroidGlobalLintTestNoAidl",
    srcs: ["TestNoAidl/**/*.java"],
    defaults: ["AndroidGlobalLintIntegrationTestDefault"],
}

python_library_host {
    name: "AndroidGlobalLintTestNoAidl_py",
    data: [":AndroidGlobalLintTestNoAidl{.lint}"],
    pkg_path: "no_aidl",
}

java_library {
    name: "AndroidGlobalLintTestMissingAnnotation",
    srcs: [
        "TestMissingAnnotation/**/*.java",
        "TestMissingAnnotation/**/*.aidl",
    ],
    defaults: ["AndroidGlobalLintIntegrationTestDefault"],
}

python_library_host {
    name: "AndroidGlobalLintTestMissingAnnotation_py",
    data: [":AndroidGlobalLintTestMissingAnnotation{.lint}"],
    pkg_path: "missing_annotation",
}

python_test_host {
python_test_host {
    name: "AndroidGlobalLintCheckerIntegrationTest",
    name: "AndroidGlobalLintCheckerIntegrationTest",
    srcs: ["tests.py"],
    srcs: ["tests.py"],
    main: "tests.py",
    main: "tests.py",
    data: [
    libs: [
        ":AndroidGlobalLintTestNoAidl{.lint}",
        "AndroidGlobalLintTestNoAidl_py",
        "AndroidGlobalLintTestMissingAnnotation_py",
    ],
    ],
    version: {
    version: {
        py3: {
        py3: {
+28 −0
Original line number Original line Diff line number Diff line
/*
 * Copyright (C) 2023 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.
 */

package com.google.android.lint.integration_tests;

/**
 * A class that implements an AIDL interface, but is missing the @EnforcePermission annotation.
 */
class TestMissingAnnotation extends IFoo.Stub {

    @Override
    public void Method() {
    }

}
+7 −0
Original line number Original line Diff line number Diff line
package com.google.android.lint.integration_tests;

interface IFoo {

    @EnforcePermission("INTERNET")
    void Method();
}
+14 −2
Original line number Original line Diff line number Diff line
@@ -19,16 +19,28 @@ import xml.etree.ElementTree
class TestLinterReports(unittest.TestCase):
class TestLinterReports(unittest.TestCase):
    """Integration tests for the linters used by @EnforcePermission."""
    """Integration tests for the linters used by @EnforcePermission."""


    def test_no_aidl(self):
    def _read_report(self, pkg_path):
        report = pkgutil.get_data("lint", "lint-report.xml").decode()
        report = pkgutil.get_data(pkg_path, "lint/lint-report.xml").decode()
        issues = xml.etree.ElementTree.fromstring(report)
        issues = xml.etree.ElementTree.fromstring(report)
        self.assertEqual(issues.tag, "issues")
        self.assertEqual(issues.tag, "issues")
        return issues

    def test_no_aidl(self):
        issues = self._read_report("no_aidl")
        self.assertEqual(len(issues), 1)
        self.assertEqual(len(issues), 1)


        issue = issues[0]
        issue = issues[0]
        self.assertEqual(issue.attrib["id"], "MisusingEnforcePermissionAnnotation")
        self.assertEqual(issue.attrib["id"], "MisusingEnforcePermissionAnnotation")
        self.assertEqual(issue.attrib["severity"], "Error")
        self.assertEqual(issue.attrib["severity"], "Error")


    def test_missing_annotation(self):
        issues = self._read_report("missing_annotation")
        self.assertEqual(len(issues), 1)

        issue = issues[0]
        self.assertEqual(issue.attrib["id"], "MissingEnforcePermissionAnnotation")
        self.assertEqual(issue.attrib["severity"], "Error")



if __name__ == '__main__':
if __name__ == '__main__':
    unittest.main(verbosity=2)
    unittest.main(verbosity=2)