Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 1 | // Copyright 2021 The Tint Authors. |
| 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 | #include "src/tint/resolver/resolver.h" |
| 16 | |
| 17 | #include "gmock/gmock.h" |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 18 | #include "src/tint/resolver/resolver_test_helper.h" |
| 19 | #include "src/tint/sem/struct.h" |
| 20 | |
dan sinclair | d209379 | 2022-04-07 17:45:45 +0000 | [diff] [blame] | 21 | namespace tint::resolver { |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 22 | namespace { |
| 23 | |
| 24 | using ResolverHostShareableValidationTest = ResolverTest; |
| 25 | |
| 26 | TEST_F(ResolverHostShareableValidationTest, BoolMember) { |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 27 | auto* s = Structure("S", {Member(Source{{12, 34}}, "x", ty.bool_())}); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 28 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 29 | Global(Source{{56, 78}}, "g", ty.Of(s), ast::StorageClass::kStorage, ast::Access::kRead, |
| 30 | ast::AttributeList{ |
| 31 | create<ast::BindingAttribute>(0), |
| 32 | create<ast::GroupAttribute>(0), |
| 33 | }); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 34 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 35 | ASSERT_FALSE(r()->Resolve()); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 36 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 37 | EXPECT_EQ( |
| 38 | r()->error(), |
| 39 | R"(56:78 error: Type 'bool' cannot be used in storage class 'storage' as it is non-host-shareable |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 40 | 12:34 note: while analysing structure member S.x |
Ben Clayton | ee49b1e | 2022-06-20 15:30:41 +0000 | [diff] [blame] | 41 | 56:78 note: while instantiating 'var' g)"); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 42 | } |
| 43 | |
| 44 | TEST_F(ResolverHostShareableValidationTest, BoolVectorMember) { |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 45 | auto* s = Structure("S", {Member(Source{{12, 34}}, "x", ty.vec3<bool>())}); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 46 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 47 | Global(Source{{56, 78}}, "g", ty.Of(s), ast::StorageClass::kStorage, ast::Access::kRead, |
| 48 | ast::AttributeList{ |
| 49 | create<ast::BindingAttribute>(0), |
| 50 | create<ast::GroupAttribute>(0), |
| 51 | }); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 52 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 53 | ASSERT_FALSE(r()->Resolve()); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 54 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 55 | EXPECT_EQ( |
| 56 | r()->error(), |
| 57 | R"(56:78 error: Type 'vec3<bool>' cannot be used in storage class 'storage' as it is non-host-shareable |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 58 | 12:34 note: while analysing structure member S.x |
Ben Clayton | ee49b1e | 2022-06-20 15:30:41 +0000 | [diff] [blame] | 59 | 56:78 note: while instantiating 'var' g)"); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 60 | } |
| 61 | |
| 62 | TEST_F(ResolverHostShareableValidationTest, Aliases) { |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 63 | auto* a1 = Alias("a1", ty.bool_()); |
| 64 | auto* s = Structure("S", {Member(Source{{12, 34}}, "x", ty.Of(a1))}); |
| 65 | auto* a2 = Alias("a2", ty.Of(s)); |
| 66 | Global(Source{{56, 78}}, "g", ty.Of(a2), ast::StorageClass::kStorage, ast::Access::kRead, |
| 67 | ast::AttributeList{ |
| 68 | create<ast::BindingAttribute>(0), |
| 69 | create<ast::GroupAttribute>(0), |
| 70 | }); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 71 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 72 | ASSERT_FALSE(r()->Resolve()); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 73 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 74 | EXPECT_EQ( |
| 75 | r()->error(), |
| 76 | R"(56:78 error: Type 'bool' cannot be used in storage class 'storage' as it is non-host-shareable |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 77 | 12:34 note: while analysing structure member S.x |
Ben Clayton | ee49b1e | 2022-06-20 15:30:41 +0000 | [diff] [blame] | 78 | 56:78 note: while instantiating 'var' g)"); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 79 | } |
| 80 | |
| 81 | TEST_F(ResolverHostShareableValidationTest, NestedStructures) { |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 82 | auto* i1 = Structure("I1", {Member(Source{{1, 2}}, "x", ty.bool_())}); |
| 83 | auto* i2 = Structure("I2", {Member(Source{{3, 4}}, "y", ty.Of(i1))}); |
| 84 | auto* i3 = Structure("I3", {Member(Source{{5, 6}}, "z", ty.Of(i2))}); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 85 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 86 | auto* s = Structure("S", {Member(Source{{7, 8}}, "m", ty.Of(i3))}); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 87 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 88 | Global(Source{{9, 10}}, "g", ty.Of(s), ast::StorageClass::kStorage, ast::Access::kRead, |
| 89 | ast::AttributeList{ |
| 90 | create<ast::BindingAttribute>(0), |
| 91 | create<ast::GroupAttribute>(0), |
| 92 | }); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 93 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 94 | ASSERT_FALSE(r()->Resolve()); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 95 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 96 | EXPECT_EQ( |
| 97 | r()->error(), |
| 98 | R"(9:10 error: Type 'bool' cannot be used in storage class 'storage' as it is non-host-shareable |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 99 | 1:2 note: while analysing structure member I1.x |
| 100 | 3:4 note: while analysing structure member I2.y |
| 101 | 5:6 note: while analysing structure member I3.z |
| 102 | 7:8 note: while analysing structure member S.m |
Ben Clayton | ee49b1e | 2022-06-20 15:30:41 +0000 | [diff] [blame] | 103 | 9:10 note: while instantiating 'var' g)"); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 104 | } |
| 105 | |
| 106 | TEST_F(ResolverHostShareableValidationTest, NoError) { |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 107 | auto* i1 = Structure("I1", { |
| 108 | Member(Source{{1, 1}}, "x1", ty.f32()), |
| 109 | Member(Source{{2, 1}}, "y1", ty.vec3<f32>()), |
| 110 | Member(Source{{3, 1}}, "z1", ty.array<i32, 4>()), |
| 111 | }); |
| 112 | auto* a1 = Alias("a1", ty.Of(i1)); |
| 113 | auto* i2 = Structure("I2", { |
| 114 | Member(Source{{4, 1}}, "x2", ty.mat2x2<f32>()), |
| 115 | Member(Source{{5, 1}}, "y2", ty.Of(i1)), |
| 116 | }); |
| 117 | auto* a2 = Alias("a2", ty.Of(i2)); |
| 118 | auto* i3 = Structure("I3", { |
| 119 | Member(Source{{4, 1}}, "x3", ty.Of(a1)), |
| 120 | Member(Source{{5, 1}}, "y3", ty.Of(i2)), |
| 121 | Member(Source{{6, 1}}, "z3", ty.Of(a2)), |
| 122 | }); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 123 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 124 | auto* s = Structure("S", {Member(Source{{7, 8}}, "m", ty.Of(i3))}); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 125 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 126 | Global(Source{{9, 10}}, "g", ty.Of(s), ast::StorageClass::kStorage, ast::Access::kRead, |
| 127 | ast::AttributeList{ |
| 128 | create<ast::BindingAttribute>(0), |
| 129 | create<ast::GroupAttribute>(0), |
| 130 | }); |
| 131 | WrapInFunction(); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 132 | |
dan sinclair | 41e4d9a | 2022-05-01 14:40:55 +0000 | [diff] [blame] | 133 | ASSERT_TRUE(r()->Resolve()) << r()->error(); |
Ryan Harrison | dbc13af | 2022-02-21 15:19:07 +0000 | [diff] [blame] | 134 | } |
| 135 | |
| 136 | } // namespace |
dan sinclair | d209379 | 2022-04-07 17:45:45 +0000 | [diff] [blame] | 137 | } // namespace tint::resolver |