diff options
| author | Yifan Hong <elsk@google.com> | 2017-01-17 21:12:01 +0000 |
|---|---|---|
| committer | android-build-merger <android-build-merger@google.com> | 2017-01-17 21:12:01 +0000 |
| commit | cad2f77b0e980dd5c435bb8523971f2001569a39 (patch) | |
| tree | 9af918dfd2bf29d31956d1a38ee28a181d4828d8 | |
| parent | 902de51533645294a29008e858841da7fb372868 (diff) | |
| parent | 63a36d7b628101cbcc367b86c9d5c318ad92ceba (diff) | |
| download | android_hardware_interfaces-cad2f77b0e980dd5c435bb8523971f2001569a39.tar.gz android_hardware_interfaces-cad2f77b0e980dd5c435bb8523971f2001569a39.tar.bz2 android_hardware_interfaces-cad2f77b0e980dd5c435bb8523971f2001569a39.zip | |
Merge "Add test for type resolution." am: 5835d9ea59 am: 168bb896b7 am: 6cc9f50bd3
am: 63a36d7b62
Change-Id: I0477b4dc3e782752a556003ddaced227d2271b06
| -rw-r--r-- | tests/bar/1.0/Android.bp | 20 | ||||
| -rw-r--r-- | tests/bar/1.0/IFooCallback.hal | 20 | ||||
| -rw-r--r-- | tests/bar/1.0/IImportRules.hal | 47 | ||||
| -rw-r--r-- | tests/bar/1.0/types.hal | 21 | ||||
| -rw-r--r-- | tests/foo/1.0/types.hal | 4 |
5 files changed, 112 insertions, 0 deletions
diff --git a/tests/bar/1.0/Android.bp b/tests/bar/1.0/Android.bp index cad655c51..fbec8d1ff 100644 --- a/tests/bar/1.0/Android.bp +++ b/tests/bar/1.0/Android.bp @@ -5,13 +5,19 @@ genrule { tools: ["hidl-gen"], cmd: "$(location hidl-gen) -o $(genDir) -Lc++ -randroid.hardware:hardware/interfaces -randroid.hidl:system/libhidl/transport android.hardware.tests.bar@1.0", srcs: [ + "types.hal", "IBar.hal", "IComplicated.hal", + "IFooCallback.hal", + "IImportRules.hal", "IImportTypes.hal", ], out: [ + "android/hardware/tests/bar/1.0/types.cpp", "android/hardware/tests/bar/1.0/BarAll.cpp", "android/hardware/tests/bar/1.0/ComplicatedAll.cpp", + "android/hardware/tests/bar/1.0/FooCallbackAll.cpp", + "android/hardware/tests/bar/1.0/ImportRulesAll.cpp", "android/hardware/tests/bar/1.0/ImportTypesAll.cpp", ], } @@ -21,11 +27,15 @@ genrule { tools: ["hidl-gen"], cmd: "$(location hidl-gen) -o $(genDir) -Lc++ -randroid.hardware:hardware/interfaces -randroid.hidl:system/libhidl/transport android.hardware.tests.bar@1.0", srcs: [ + "types.hal", "IBar.hal", "IComplicated.hal", + "IFooCallback.hal", + "IImportRules.hal", "IImportTypes.hal", ], out: [ + "android/hardware/tests/bar/1.0/types.h", "android/hardware/tests/bar/1.0/IBar.h", "android/hardware/tests/bar/1.0/IHwBar.h", "android/hardware/tests/bar/1.0/BnHwBar.h", @@ -36,6 +46,16 @@ genrule { "android/hardware/tests/bar/1.0/BnHwComplicated.h", "android/hardware/tests/bar/1.0/BpHwComplicated.h", "android/hardware/tests/bar/1.0/BsComplicated.h", + "android/hardware/tests/bar/1.0/IFooCallback.h", + "android/hardware/tests/bar/1.0/IHwFooCallback.h", + "android/hardware/tests/bar/1.0/BnHwFooCallback.h", + "android/hardware/tests/bar/1.0/BpHwFooCallback.h", + "android/hardware/tests/bar/1.0/BsFooCallback.h", + "android/hardware/tests/bar/1.0/IImportRules.h", + "android/hardware/tests/bar/1.0/IHwImportRules.h", + "android/hardware/tests/bar/1.0/BnHwImportRules.h", + "android/hardware/tests/bar/1.0/BpHwImportRules.h", + "android/hardware/tests/bar/1.0/BsImportRules.h", "android/hardware/tests/bar/1.0/IImportTypes.h", "android/hardware/tests/bar/1.0/IHwImportTypes.h", "android/hardware/tests/bar/1.0/BnHwImportTypes.h", diff --git a/tests/bar/1.0/IFooCallback.hal b/tests/bar/1.0/IFooCallback.hal new file mode 100644 index 000000000..f42ce85f9 --- /dev/null +++ b/tests/bar/1.0/IFooCallback.hal @@ -0,0 +1,20 @@ +/* + * Copyright (C) 2016 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 android.hardware.tests.bar@1.0; + +interface IFooCallback { +}; diff --git a/tests/bar/1.0/IImportRules.hal b/tests/bar/1.0/IImportRules.hal new file mode 100644 index 000000000..db454b08d --- /dev/null +++ b/tests/bar/1.0/IImportRules.hal @@ -0,0 +1,47 @@ +/* + * Copyright (C) 2016 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 android.hardware.tests.bar@1.0; + +import android.hardware.tests.foo@1.0; + +interface IImportRules { + // Note that there is a android.hardware.tests.foo@1.0::Outer in types.hal + struct Outer { + struct Inner { + int32_t data; + }; + string data; + }; + + rule0a(Outer o); // should be resolved to Outer above + rule0a1(IImportRules.Outer o); // should be resolved to Outer above + rule0b(@1.0::IImportRules.Outer o); + rule0c(android.hardware.tests.foo@1.0::Outer o); + rule0d(@1.0::Outer o); // android.hardware.tests.foo@1.0::Outer + rule0e(Outer.Inner o); // should be resolved to Outer above + rule0f(@1.0::IImportRules.Outer.Inner o); + rule0g(android.hardware.tests.foo@1.0::Outer.Inner o); + rule0h(@1.0::Outer.Inner o); // android.hardware.tests.foo@1.0::Outer.Inner + + rule1a(Def abc); // should be resolved to Def in types.hal in this package + rule1b(android.hardware.tests.foo@1.0::Def abc); + + rule2a(Unrelated related); + + // android.hardware.tests.foo@1.0::IFooCallback, since bar@1.0::IFooCallback is not imported. + rule2b(IFooCallback fooCallback); +}; diff --git a/tests/bar/1.0/types.hal b/tests/bar/1.0/types.hal new file mode 100644 index 000000000..30022ad4e --- /dev/null +++ b/tests/bar/1.0/types.hal @@ -0,0 +1,21 @@ +/* + * Copyright (C) 2016 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 android.hardware.tests.bar@1.0; + +struct Def { + vec<string> vs; +}; diff --git a/tests/foo/1.0/types.hal b/tests/foo/1.0/types.hal index a01fc2d10..6b4b69748 100644 --- a/tests/foo/1.0/types.hal +++ b/tests/foo/1.0/types.hal @@ -22,6 +22,10 @@ struct Abc { handle z; }; +struct Def { + string g; +}; + struct Outer { struct Inner { struct Deep { |
