From ce973e355c27e2e3b4f8ab504006578acff9c33f Mon Sep 17 00:00:00 2001 From: Sarah Mashayekhi Date: Fri, 24 Jul 2020 14:50:51 +0000 Subject: [PATCH] [validation] Add a disabled test for re-assigning a constant. Bug:6 Change-Id: Ic2cd1d0eed82354e605e15aec2ba350c15773e51 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/25522 Reviewed-by: dan sinclair --- src/validator_test.cc | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/src/validator_test.cc b/src/validator_test.cc index 4b62dca1bf..9966ab072e 100644 --- a/src/validator_test.cc +++ b/src/validator_test.cc @@ -162,5 +162,28 @@ TEST_F(ValidatorTest, AssignCompatibleTypes_Pass) { EXPECT_TRUE(v.ValidateAssign(assign)); } +TEST_F(ValidatorTest, DISABLED_AssignToConstant_Fail) { + // v-0021: Cannot re-assign a constant. + // const a :i32 = 1; + // a = 2; + ast::type::I32Type i32; + + ast::Variable var("a", ast::StorageClass::kPrivate, &i32); + var.set_constructor(std::make_unique( + std::make_unique(&i32, 1))); + var.set_is_const(true); + auto lhs = std::make_unique("a"); + + auto rhs = std::make_unique( + std::make_unique(&i32, 2)); + + ast::AssignmentStatement assign(std::move(lhs), std::move(rhs)); + + tint::ValidatorImpl v; + // TODO(SarahM0): Invalidate assignments to a constant. + ASSERT_TRUE(v.has_error()); + EXPECT_EQ(v.error(), "2:1: v-0021: cannot re-assign a constant"); +} + } // namespace } // namespace tint