tint/resolver: Rename var_let_*test.cc -> variable_*test.cc
Gives us a place to put `const` and `override` tests. Bug: tint:1580 Change-Id: I0340c37e96f796d2f879d4045623b35927e45c78 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/94601 Reviewed-by: David Neto <dneto@google.com> Commit-Queue: Ben Clayton <bclayton@google.com>
This commit is contained in:
parent
dfeaf29055
commit
68ae36e43d
|
@ -1118,8 +1118,8 @@ if (tint_build_unittests) {
|
||||||
"resolver/uniformity_test.cc",
|
"resolver/uniformity_test.cc",
|
||||||
"resolver/validation_test.cc",
|
"resolver/validation_test.cc",
|
||||||
"resolver/validator_is_storeable_test.cc",
|
"resolver/validator_is_storeable_test.cc",
|
||||||
"resolver/var_let_test.cc",
|
"resolver/variable_test.cc",
|
||||||
"resolver/var_let_validation_test.cc",
|
"resolver/variable_validation_test.cc",
|
||||||
]
|
]
|
||||||
deps = [ ":tint_unittests_ast_src" ]
|
deps = [ ":tint_unittests_ast_src" ]
|
||||||
}
|
}
|
||||||
|
|
|
@ -814,8 +814,8 @@ if(TINT_BUILD_TESTS)
|
||||||
resolver/type_validation_test.cc
|
resolver/type_validation_test.cc
|
||||||
resolver/validation_test.cc
|
resolver/validation_test.cc
|
||||||
resolver/validator_is_storeable_test.cc
|
resolver/validator_is_storeable_test.cc
|
||||||
resolver/var_let_test.cc
|
resolver/variable_test.cc
|
||||||
resolver/var_let_validation_test.cc
|
resolver/variable_validation_test.cc
|
||||||
scope_stack_test.cc
|
scope_stack_test.cc
|
||||||
sem/atomic.cc
|
sem/atomic.cc
|
||||||
sem/bool_test.cc
|
sem/bool_test.cc
|
||||||
|
|
|
@ -23,9 +23,9 @@ using namespace tint::number_suffixes; // NOLINT
|
||||||
namespace tint::resolver {
|
namespace tint::resolver {
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
struct ResolverVarLetTest : public resolver::TestHelper, public testing::Test {};
|
struct ResolverVariableTest : public resolver::TestHelper, public testing::Test {};
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, VarDeclWithoutConstructor) {
|
TEST_F(ResolverVariableTest, VarDeclWithoutConstructor) {
|
||||||
// struct S { i : i32; }
|
// struct S { i : i32; }
|
||||||
// alias A = S;
|
// alias A = S;
|
||||||
// fn F(){
|
// fn F(){
|
||||||
|
@ -82,7 +82,7 @@ TEST_F(ResolverVarLetTest, VarDeclWithoutConstructor) {
|
||||||
EXPECT_EQ(Sem().Get(a)->Constructor(), nullptr);
|
EXPECT_EQ(Sem().Get(a)->Constructor(), nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, VarDeclWithConstructor) {
|
TEST_F(ResolverVariableTest, VarDeclWithConstructor) {
|
||||||
// struct S { i : i32; }
|
// struct S { i : i32; }
|
||||||
// alias A = S;
|
// alias A = S;
|
||||||
// fn F(){
|
// fn F(){
|
||||||
|
@ -146,7 +146,7 @@ TEST_F(ResolverVarLetTest, VarDeclWithConstructor) {
|
||||||
EXPECT_EQ(Sem().Get(a)->Constructor()->Declaration(), a_c);
|
EXPECT_EQ(Sem().Get(a)->Constructor()->Declaration(), a_c);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LetDecl) {
|
TEST_F(ResolverVariableTest, LetDecl) {
|
||||||
// struct S { i : i32; }
|
// struct S { i : i32; }
|
||||||
// fn F(){
|
// fn F(){
|
||||||
// var v : i32;
|
// var v : i32;
|
||||||
|
@ -212,7 +212,7 @@ TEST_F(ResolverVarLetTest, LetDecl) {
|
||||||
EXPECT_EQ(Sem().Get(p)->Constructor()->Declaration(), p_c);
|
EXPECT_EQ(Sem().Get(p)->Constructor()->Declaration(), p_c);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, DefaultVarStorageClass) {
|
TEST_F(ResolverVariableTest, DefaultVarStorageClass) {
|
||||||
// https://gpuweb.github.io/gpuweb/wgsl/#storage-class
|
// https://gpuweb.github.io/gpuweb/wgsl/#storage-class
|
||||||
|
|
||||||
auto* buf = Structure("S", {Member("m", ty.i32())});
|
auto* buf = Structure("S", {Member("m", ty.i32())});
|
||||||
|
@ -254,7 +254,7 @@ TEST_F(ResolverVarLetTest, DefaultVarStorageClass) {
|
||||||
EXPECT_EQ(TypeOf(handle)->As<sem::Reference>()->Access(), ast::Access::kRead);
|
EXPECT_EQ(TypeOf(handle)->As<sem::Reference>()->Access(), ast::Access::kRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, ExplicitVarStorageClass) {
|
TEST_F(ResolverVariableTest, ExplicitVarStorageClass) {
|
||||||
// https://gpuweb.github.io/gpuweb/wgsl/#storage-class
|
// https://gpuweb.github.io/gpuweb/wgsl/#storage-class
|
||||||
|
|
||||||
auto* buf = Structure("S", {Member("m", ty.i32())});
|
auto* buf = Structure("S", {Member("m", ty.i32())});
|
||||||
|
@ -271,7 +271,7 @@ TEST_F(ResolverVarLetTest, ExplicitVarStorageClass) {
|
||||||
EXPECT_EQ(TypeOf(storage)->As<sem::Reference>()->Access(), ast::Access::kReadWrite);
|
EXPECT_EQ(TypeOf(storage)->As<sem::Reference>()->Access(), ast::Access::kReadWrite);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LetInheritsAccessFromOriginatingVariable) {
|
TEST_F(ResolverVariableTest, LetInheritsAccessFromOriginatingVariable) {
|
||||||
// struct Inner {
|
// struct Inner {
|
||||||
// arr: array<i32, 4>;
|
// arr: array<i32, 4>;
|
||||||
// }
|
// }
|
||||||
|
@ -304,7 +304,7 @@ TEST_F(ResolverVarLetTest, LetInheritsAccessFromOriginatingVariable) {
|
||||||
EXPECT_EQ(TypeOf(ptr)->As<sem::Pointer>()->Access(), ast::Access::kReadWrite);
|
EXPECT_EQ(TypeOf(ptr)->As<sem::Pointer>()->Access(), ast::Access::kReadWrite);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsAlias) {
|
TEST_F(ResolverVariableTest, LocalShadowsAlias) {
|
||||||
// type a = i32;
|
// type a = i32;
|
||||||
//
|
//
|
||||||
// fn X() {
|
// fn X() {
|
||||||
|
@ -334,7 +334,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsAlias) {
|
||||||
EXPECT_EQ(local_l->Shadows(), type_t);
|
EXPECT_EQ(local_l->Shadows(), type_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsStruct) {
|
TEST_F(ResolverVariableTest, LocalShadowsStruct) {
|
||||||
// struct a {
|
// struct a {
|
||||||
// m : i32;
|
// m : i32;
|
||||||
// };
|
// };
|
||||||
|
@ -366,7 +366,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsStruct) {
|
||||||
EXPECT_EQ(local_l->Shadows(), type_t);
|
EXPECT_EQ(local_l->Shadows(), type_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsFunction) {
|
TEST_F(ResolverVariableTest, LocalShadowsFunction) {
|
||||||
// fn a() {
|
// fn a() {
|
||||||
// var a = true;
|
// var a = true;
|
||||||
// }
|
// }
|
||||||
|
@ -396,7 +396,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsFunction) {
|
||||||
EXPECT_EQ(local_l->Shadows(), func_b);
|
EXPECT_EQ(local_l->Shadows(), func_b);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsGlobalVar) {
|
TEST_F(ResolverVariableTest, LocalShadowsGlobalVar) {
|
||||||
// var<private> a : i32;
|
// var<private> a : i32;
|
||||||
//
|
//
|
||||||
// fn X() {
|
// fn X() {
|
||||||
|
@ -435,7 +435,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsGlobalVar) {
|
||||||
EXPECT_EQ(user_l->Variable(), global);
|
EXPECT_EQ(user_l->Variable(), global);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsGlobalLet) {
|
TEST_F(ResolverVariableTest, LocalShadowsGlobalLet) {
|
||||||
// let a : i32 = 1;
|
// let a : i32 = 1;
|
||||||
//
|
//
|
||||||
// fn X() {
|
// fn X() {
|
||||||
|
@ -474,7 +474,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsGlobalLet) {
|
||||||
EXPECT_EQ(user_l->Variable(), global);
|
EXPECT_EQ(user_l->Variable(), global);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsLocalVar) {
|
TEST_F(ResolverVariableTest, LocalShadowsLocalVar) {
|
||||||
// fn X() {
|
// fn X() {
|
||||||
// var a : i32;
|
// var a : i32;
|
||||||
// {
|
// {
|
||||||
|
@ -513,7 +513,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsLocalVar) {
|
||||||
EXPECT_EQ(user_l->Variable(), local_s);
|
EXPECT_EQ(user_l->Variable(), local_s);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsLocalLet) {
|
TEST_F(ResolverVariableTest, LocalShadowsLocalLet) {
|
||||||
// fn X() {
|
// fn X() {
|
||||||
// let a = 1;
|
// let a = 1;
|
||||||
// {
|
// {
|
||||||
|
@ -552,7 +552,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsLocalLet) {
|
||||||
EXPECT_EQ(user_l->Variable(), local_s);
|
EXPECT_EQ(user_l->Variable(), local_s);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, LocalShadowsParam) {
|
TEST_F(ResolverVariableTest, LocalShadowsParam) {
|
||||||
// fn F(a : i32) {
|
// fn F(a : i32) {
|
||||||
// {
|
// {
|
||||||
// var a = a;
|
// var a = a;
|
||||||
|
@ -590,7 +590,7 @@ TEST_F(ResolverVarLetTest, LocalShadowsParam) {
|
||||||
EXPECT_EQ(user_l->Variable(), param);
|
EXPECT_EQ(user_l->Variable(), param);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, ParamShadowsFunction) {
|
TEST_F(ResolverVariableTest, ParamShadowsFunction) {
|
||||||
// fn a(a : bool) {
|
// fn a(a : bool) {
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
@ -608,7 +608,7 @@ TEST_F(ResolverVarLetTest, ParamShadowsFunction) {
|
||||||
EXPECT_EQ(param->Shadows(), func);
|
EXPECT_EQ(param->Shadows(), func);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, ParamShadowsGlobalVar) {
|
TEST_F(ResolverVariableTest, ParamShadowsGlobalVar) {
|
||||||
// var<private> a : i32;
|
// var<private> a : i32;
|
||||||
//
|
//
|
||||||
// fn F(a : bool) {
|
// fn F(a : bool) {
|
||||||
|
@ -629,7 +629,7 @@ TEST_F(ResolverVarLetTest, ParamShadowsGlobalVar) {
|
||||||
EXPECT_EQ(param->Shadows(), global);
|
EXPECT_EQ(param->Shadows(), global);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, ParamShadowsGlobalLet) {
|
TEST_F(ResolverVariableTest, ParamShadowsGlobalLet) {
|
||||||
// let a : i32 = 1;
|
// let a : i32 = 1;
|
||||||
//
|
//
|
||||||
// fn F(a : bool) {
|
// fn F(a : bool) {
|
||||||
|
@ -650,7 +650,7 @@ TEST_F(ResolverVarLetTest, ParamShadowsGlobalLet) {
|
||||||
EXPECT_EQ(param->Shadows(), global);
|
EXPECT_EQ(param->Shadows(), global);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetTest, ParamShadowsAlias) {
|
TEST_F(ResolverVariableTest, ParamShadowsAlias) {
|
||||||
// type a = i32;
|
// type a = i32;
|
||||||
//
|
//
|
||||||
// fn F(a : a) {
|
// fn F(a : a) {
|
|
@ -22,9 +22,9 @@ using namespace tint::number_suffixes; // NOLINT
|
||||||
namespace tint::resolver {
|
namespace tint::resolver {
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
struct ResolverVarLetValidationTest : public resolver::TestHelper, public testing::Test {};
|
struct ResolverVariableValidationTest : public resolver::TestHelper, public testing::Test {};
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarNoInitializerNoType) {
|
TEST_F(ResolverVariableValidationTest, VarNoInitializerNoType) {
|
||||||
// var a;
|
// var a;
|
||||||
WrapInFunction(Var(Source{{12, 34}}, "a", nullptr));
|
WrapInFunction(Var(Source{{12, 34}}, "a", nullptr));
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ TEST_F(ResolverVarLetValidationTest, VarNoInitializerNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: 'var' declaration requires a type or initializer");
|
EXPECT_EQ(r()->error(), "12:34 error: 'var' declaration requires a type or initializer");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, GlobalVarNoInitializerNoType) {
|
TEST_F(ResolverVariableValidationTest, GlobalVarNoInitializerNoType) {
|
||||||
// var a;
|
// var a;
|
||||||
Global(Source{{12, 34}}, "a", nullptr);
|
Global(Source{{12, 34}}, "a", nullptr);
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ TEST_F(ResolverVarLetValidationTest, GlobalVarNoInitializerNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: 'var' declaration requires a type or initializer");
|
EXPECT_EQ(r()->error(), "12:34 error: 'var' declaration requires a type or initializer");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, OverrideNoInitializerNoType) {
|
TEST_F(ResolverVariableValidationTest, OverrideNoInitializerNoType) {
|
||||||
// override a;
|
// override a;
|
||||||
Override(Source{{12, 34}}, "a", nullptr, nullptr);
|
Override(Source{{12, 34}}, "a", nullptr, nullptr);
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ TEST_F(ResolverVarLetValidationTest, OverrideNoInitializerNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: 'override' declaration requires a type or initializer");
|
EXPECT_EQ(r()->error(), "12:34 error: 'override' declaration requires a type or initializer");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarTypeNotStorable) {
|
TEST_F(ResolverVariableValidationTest, VarTypeNotStorable) {
|
||||||
// var i : i32;
|
// var i : i32;
|
||||||
// var p : pointer<function, i32> = &v;
|
// var p : pointer<function, i32> = &v;
|
||||||
auto* i = Var("i", ty.i32(), ast::StorageClass::kNone);
|
auto* i = Var("i", ty.i32(), ast::StorageClass::kNone);
|
||||||
|
@ -62,7 +62,7 @@ TEST_F(ResolverVarLetValidationTest, VarTypeNotStorable) {
|
||||||
"type of a var");
|
"type of a var");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, LetTypeNotConstructible) {
|
TEST_F(ResolverVariableValidationTest, LetTypeNotConstructible) {
|
||||||
// @group(0) @binding(0) var t1 : texture_2d<f32>;
|
// @group(0) @binding(0) var t1 : texture_2d<f32>;
|
||||||
// let t2 : t1;
|
// let t2 : t1;
|
||||||
auto* t1 = Global("t1", ty.sampled_texture(ast::TextureDimension::k2d, ty.f32()),
|
auto* t1 = Global("t1", ty.sampled_texture(ast::TextureDimension::k2d, ty.f32()),
|
||||||
|
@ -74,7 +74,7 @@ TEST_F(ResolverVarLetValidationTest, LetTypeNotConstructible) {
|
||||||
EXPECT_EQ(r()->error(), "56:78 error: texture_2d<f32> cannot be used as the type of a 'let'");
|
EXPECT_EQ(r()->error(), "56:78 error: texture_2d<f32> cannot be used as the type of a 'let'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, OverrideExplicitTypeNotScalar) {
|
TEST_F(ResolverVariableValidationTest, OverrideExplicitTypeNotScalar) {
|
||||||
// override o : vec3<f32>;
|
// override o : vec3<f32>;
|
||||||
Override(Source{{56, 78}}, "o", ty.vec3<f32>(), nullptr);
|
Override(Source{{56, 78}}, "o", ty.vec3<f32>(), nullptr);
|
||||||
|
|
||||||
|
@ -82,7 +82,7 @@ TEST_F(ResolverVarLetValidationTest, OverrideExplicitTypeNotScalar) {
|
||||||
EXPECT_EQ(r()->error(), "56:78 error: vec3<f32> cannot be used as the type of a 'override'");
|
EXPECT_EQ(r()->error(), "56:78 error: vec3<f32> cannot be used as the type of a 'override'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, OverrideInferedTypeNotScalar) {
|
TEST_F(ResolverVariableValidationTest, OverrideInferedTypeNotScalar) {
|
||||||
// override o = vec3(1.0f);
|
// override o = vec3(1.0f);
|
||||||
Override(Source{{56, 78}}, "o", nullptr, vec3<f32>(1.0_f));
|
Override(Source{{56, 78}}, "o", nullptr, vec3<f32>(1.0_f));
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ TEST_F(ResolverVarLetValidationTest, OverrideInferedTypeNotScalar) {
|
||||||
EXPECT_EQ(r()->error(), "56:78 error: vec3<f32> cannot be used as the type of a 'override'");
|
EXPECT_EQ(r()->error(), "56:78 error: vec3<f32> cannot be used as the type of a 'override'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, LetConstructorWrongType) {
|
TEST_F(ResolverVariableValidationTest, LetConstructorWrongType) {
|
||||||
// var v : i32 = 2u
|
// var v : i32 = 2u
|
||||||
WrapInFunction(Let(Source{{3, 3}}, "v", ty.i32(), Expr(2_u)));
|
WrapInFunction(Let(Source{{3, 3}}, "v", ty.i32(), Expr(2_u)));
|
||||||
|
|
||||||
|
@ -99,7 +99,7 @@ TEST_F(ResolverVarLetValidationTest, LetConstructorWrongType) {
|
||||||
R"(3:3 error: cannot initialize let of type 'i32' with value of type 'u32')");
|
R"(3:3 error: cannot initialize let of type 'i32' with value of type 'u32')");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarConstructorWrongType) {
|
TEST_F(ResolverVariableValidationTest, VarConstructorWrongType) {
|
||||||
// var v : i32 = 2u
|
// var v : i32 = 2u
|
||||||
WrapInFunction(Var(Source{{3, 3}}, "v", ty.i32(), ast::StorageClass::kNone, Expr(2_u)));
|
WrapInFunction(Var(Source{{3, 3}}, "v", ty.i32(), ast::StorageClass::kNone, Expr(2_u)));
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ TEST_F(ResolverVarLetValidationTest, VarConstructorWrongType) {
|
||||||
R"(3:3 error: cannot initialize var of type 'i32' with value of type 'u32')");
|
R"(3:3 error: cannot initialize var of type 'i32' with value of type 'u32')");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, LetConstructorWrongTypeViaAlias) {
|
TEST_F(ResolverVariableValidationTest, LetConstructorWrongTypeViaAlias) {
|
||||||
auto* a = Alias("I32", ty.i32());
|
auto* a = Alias("I32", ty.i32());
|
||||||
WrapInFunction(Let(Source{{3, 3}}, "v", ty.Of(a), Expr(2_u)));
|
WrapInFunction(Let(Source{{3, 3}}, "v", ty.Of(a), Expr(2_u)));
|
||||||
|
|
||||||
|
@ -117,7 +117,7 @@ TEST_F(ResolverVarLetValidationTest, LetConstructorWrongTypeViaAlias) {
|
||||||
R"(3:3 error: cannot initialize let of type 'i32' with value of type 'u32')");
|
R"(3:3 error: cannot initialize let of type 'i32' with value of type 'u32')");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarConstructorWrongTypeViaAlias) {
|
TEST_F(ResolverVariableValidationTest, VarConstructorWrongTypeViaAlias) {
|
||||||
auto* a = Alias("I32", ty.i32());
|
auto* a = Alias("I32", ty.i32());
|
||||||
WrapInFunction(Var(Source{{3, 3}}, "v", ty.Of(a), ast::StorageClass::kNone, Expr(2_u)));
|
WrapInFunction(Var(Source{{3, 3}}, "v", ty.Of(a), ast::StorageClass::kNone, Expr(2_u)));
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ TEST_F(ResolverVarLetValidationTest, VarConstructorWrongTypeViaAlias) {
|
||||||
R"(3:3 error: cannot initialize var of type 'i32' with value of type 'u32')");
|
R"(3:3 error: cannot initialize var of type 'i32' with value of type 'u32')");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, LetOfPtrConstructedWithRef) {
|
TEST_F(ResolverVariableValidationTest, LetOfPtrConstructedWithRef) {
|
||||||
// var a : f32;
|
// var a : f32;
|
||||||
// let b : ptr<function,f32> = a;
|
// let b : ptr<function,f32> = a;
|
||||||
const auto priv = ast::StorageClass::kFunction;
|
const auto priv = ast::StorageClass::kFunction;
|
||||||
|
@ -141,7 +141,7 @@ TEST_F(ResolverVarLetValidationTest, LetOfPtrConstructedWithRef) {
|
||||||
R"(12:34 error: cannot initialize let of type 'ptr<function, f32, read_write>' with value of type 'f32')");
|
R"(12:34 error: cannot initialize let of type 'ptr<function, f32, read_write>' with value of type 'f32')");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, LocalLetRedeclared) {
|
TEST_F(ResolverVariableValidationTest, LocalLetRedeclared) {
|
||||||
// let l : f32 = 1.;
|
// let l : f32 = 1.;
|
||||||
// let l : i32 = 0;
|
// let l : i32 = 0;
|
||||||
auto* l1 = Let("l", ty.f32(), Expr(1_f));
|
auto* l1 = Let("l", ty.f32(), Expr(1_f));
|
||||||
|
@ -153,7 +153,7 @@ TEST_F(ResolverVarLetValidationTest, LocalLetRedeclared) {
|
||||||
"12:34 error: redeclaration of 'l'\nnote: 'l' previously declared here");
|
"12:34 error: redeclaration of 'l'\nnote: 'l' previously declared here");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, GlobalVarRedeclaredAsLocal) {
|
TEST_F(ResolverVariableValidationTest, GlobalVarRedeclaredAsLocal) {
|
||||||
// var v : f32 = 2.1;
|
// var v : f32 = 2.1;
|
||||||
// fn my_func() {
|
// fn my_func() {
|
||||||
// var v : f32 = 2.0;
|
// var v : f32 = 2.0;
|
||||||
|
@ -167,7 +167,7 @@ TEST_F(ResolverVarLetValidationTest, GlobalVarRedeclaredAsLocal) {
|
||||||
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarRedeclaredInInnerBlock) {
|
TEST_F(ResolverVariableValidationTest, VarRedeclaredInInnerBlock) {
|
||||||
// {
|
// {
|
||||||
// var v : f32;
|
// var v : f32;
|
||||||
// { var v : f32; }
|
// { var v : f32; }
|
||||||
|
@ -182,7 +182,7 @@ TEST_F(ResolverVarLetValidationTest, VarRedeclaredInInnerBlock) {
|
||||||
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VarRedeclaredInIfBlock) {
|
TEST_F(ResolverVariableValidationTest, VarRedeclaredInIfBlock) {
|
||||||
// {
|
// {
|
||||||
// var v : f32 = 3.14;
|
// var v : f32 = 3.14;
|
||||||
// if (true) { var v : f32 = 2.0; }
|
// if (true) { var v : f32 = 2.0; }
|
||||||
|
@ -201,7 +201,7 @@ TEST_F(ResolverVarLetValidationTest, VarRedeclaredInIfBlock) {
|
||||||
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
EXPECT_TRUE(r()->Resolve()) << r()->error();
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, InferredPtrStorageAccessMismatch) {
|
TEST_F(ResolverVariableValidationTest, InferredPtrStorageAccessMismatch) {
|
||||||
// struct Inner {
|
// struct Inner {
|
||||||
// arr: array<i32, 4>;
|
// arr: array<i32, 4>;
|
||||||
// }
|
// }
|
||||||
|
@ -234,7 +234,7 @@ TEST_F(ResolverVarLetValidationTest, InferredPtrStorageAccessMismatch) {
|
||||||
"'ptr<storage, i32, read>'");
|
"'ptr<storage, i32, read>'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, NonConstructibleType_Atomic) {
|
TEST_F(ResolverVariableValidationTest, NonConstructibleType_Atomic) {
|
||||||
auto* v = Var("v", ty.atomic(Source{{12, 34}}, ty.i32()));
|
auto* v = Var("v", ty.atomic(Source{{12, 34}}, ty.i32()));
|
||||||
WrapInFunction(v);
|
WrapInFunction(v);
|
||||||
|
|
||||||
|
@ -242,7 +242,7 @@ TEST_F(ResolverVarLetValidationTest, NonConstructibleType_Atomic) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: function-scope 'var' must have a constructible type");
|
EXPECT_EQ(r()->error(), "12:34 error: function-scope 'var' must have a constructible type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, NonConstructibleType_RuntimeArray) {
|
TEST_F(ResolverVariableValidationTest, NonConstructibleType_RuntimeArray) {
|
||||||
auto* s = Structure("S", {Member(Source{{56, 78}}, "m", ty.array(ty.i32()))});
|
auto* s = Structure("S", {Member(Source{{56, 78}}, "m", ty.array(ty.i32()))});
|
||||||
auto* v = Var(Source{{12, 34}}, "v", ty.Of(s));
|
auto* v = Var(Source{{12, 34}}, "v", ty.Of(s));
|
||||||
WrapInFunction(v);
|
WrapInFunction(v);
|
||||||
|
@ -254,7 +254,7 @@ TEST_F(ResolverVarLetValidationTest, NonConstructibleType_RuntimeArray) {
|
||||||
12:34 note: while instantiating 'var' v)");
|
12:34 note: while instantiating 'var' v)");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, NonConstructibleType_Struct_WithAtomic) {
|
TEST_F(ResolverVariableValidationTest, NonConstructibleType_Struct_WithAtomic) {
|
||||||
auto* s = Structure("S", {Member("m", ty.atomic(ty.i32()))});
|
auto* s = Structure("S", {Member("m", ty.atomic(ty.i32()))});
|
||||||
auto* v = Var("v", ty.Of(s));
|
auto* v = Var("v", ty.Of(s));
|
||||||
WrapInFunction(v);
|
WrapInFunction(v);
|
||||||
|
@ -263,7 +263,7 @@ TEST_F(ResolverVarLetValidationTest, NonConstructibleType_Struct_WithAtomic) {
|
||||||
EXPECT_EQ(r()->error(), "error: function-scope 'var' must have a constructible type");
|
EXPECT_EQ(r()->error(), "error: function-scope 'var' must have a constructible type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, NonConstructibleType_InferredType) {
|
TEST_F(ResolverVariableValidationTest, NonConstructibleType_InferredType) {
|
||||||
// @group(0) @binding(0) var s : sampler;
|
// @group(0) @binding(0) var s : sampler;
|
||||||
// fn foo() {
|
// fn foo() {
|
||||||
// var v = s;
|
// var v = s;
|
||||||
|
@ -276,7 +276,7 @@ TEST_F(ResolverVarLetValidationTest, NonConstructibleType_InferredType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: function-scope 'var' must have a constructible type");
|
EXPECT_EQ(r()->error(), "12:34 error: function-scope 'var' must have a constructible type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, InvalidStorageClassForInitializer) {
|
TEST_F(ResolverVariableValidationTest, InvalidStorageClassForInitializer) {
|
||||||
// var<workgroup> v : f32 = 1.23;
|
// var<workgroup> v : f32 = 1.23;
|
||||||
Global(Source{{12, 34}}, "v", ty.f32(), ast::StorageClass::kWorkgroup, Expr(1.23_f));
|
Global(Source{{12, 34}}, "v", ty.f32(), ast::StorageClass::kWorkgroup, Expr(1.23_f));
|
||||||
|
|
||||||
|
@ -287,7 +287,7 @@ TEST_F(ResolverVarLetValidationTest, InvalidStorageClassForInitializer) {
|
||||||
"storage classes 'private' and 'function'");
|
"storage classes 'private' and 'function'");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VectorLetNoType) {
|
TEST_F(ResolverVariableValidationTest, VectorLetNoType) {
|
||||||
// let a : mat3x3 = mat3x3<f32>();
|
// let a : mat3x3 = mat3x3<f32>();
|
||||||
WrapInFunction(Let("a", create<ast::Vector>(Source{{12, 34}}, nullptr, 3), vec3<f32>()));
|
WrapInFunction(Let("a", create<ast::Vector>(Source{{12, 34}}, nullptr, 3), vec3<f32>()));
|
||||||
|
|
||||||
|
@ -295,7 +295,7 @@ TEST_F(ResolverVarLetValidationTest, VectorLetNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: missing vector element type");
|
EXPECT_EQ(r()->error(), "12:34 error: missing vector element type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, VectorVarNoType) {
|
TEST_F(ResolverVariableValidationTest, VectorVarNoType) {
|
||||||
// var a : mat3x3;
|
// var a : mat3x3;
|
||||||
WrapInFunction(Var("a", create<ast::Vector>(Source{{12, 34}}, nullptr, 3)));
|
WrapInFunction(Var("a", create<ast::Vector>(Source{{12, 34}}, nullptr, 3)));
|
||||||
|
|
||||||
|
@ -303,7 +303,7 @@ TEST_F(ResolverVarLetValidationTest, VectorVarNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: missing vector element type");
|
EXPECT_EQ(r()->error(), "12:34 error: missing vector element type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, MatrixLetNoType) {
|
TEST_F(ResolverVariableValidationTest, MatrixLetNoType) {
|
||||||
// let a : mat3x3 = mat3x3<f32>();
|
// let a : mat3x3 = mat3x3<f32>();
|
||||||
WrapInFunction(Let("a", create<ast::Matrix>(Source{{12, 34}}, nullptr, 3, 3), mat3x3<f32>()));
|
WrapInFunction(Let("a", create<ast::Matrix>(Source{{12, 34}}, nullptr, 3, 3), mat3x3<f32>()));
|
||||||
|
|
||||||
|
@ -311,7 +311,7 @@ TEST_F(ResolverVarLetValidationTest, MatrixLetNoType) {
|
||||||
EXPECT_EQ(r()->error(), "12:34 error: missing matrix element type");
|
EXPECT_EQ(r()->error(), "12:34 error: missing matrix element type");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(ResolverVarLetValidationTest, MatrixVarNoType) {
|
TEST_F(ResolverVariableValidationTest, MatrixVarNoType) {
|
||||||
// var a : mat3x3;
|
// var a : mat3x3;
|
||||||
WrapInFunction(Var("a", create<ast::Matrix>(Source{{12, 34}}, nullptr, 3, 3)));
|
WrapInFunction(Var("a", create<ast::Matrix>(Source{{12, 34}}, nullptr, 3, 3)));
|
||||||
|
|
Loading…
Reference in New Issue