| Index: tools/gn/parse_tree_unittest.cc
|
| diff --git a/tools/gn/parse_tree_unittest.cc b/tools/gn/parse_tree_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8120e22435d8d26de23230ac035a13f3a1b91a23
|
| --- /dev/null
|
| +++ b/tools/gn/parse_tree_unittest.cc
|
| @@ -0,0 +1,49 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +#include "tools/gn/input_file.h"
|
| +#include "tools/gn/parse_tree.h"
|
| +#include "tools/gn/scope.h"
|
| +#include "tools/gn/test_with_scope.h"
|
| +
|
| +TEST(ParseTree, Accessor) {
|
| + TestWithScope setup;
|
| +
|
| + // Make a pretend parse node with proper tracking that we can blame for the
|
| + // given value.
|
| + InputFile input_file(SourceFile("//foo"));
|
| + Token base_token(Location(&input_file, 1, 1), Token::IDENTIFIER, "a");
|
| + Token member_token(Location(&input_file, 1, 1), Token::IDENTIFIER, "b");
|
| +
|
| + AccessorNode accessor;
|
| + accessor.set_base(base_token);
|
| +
|
| + scoped_ptr<IdentifierNode> member_identifier(
|
| + new IdentifierNode(member_token));
|
| + accessor.set_member(member_identifier.Pass());
|
| +
|
| + // The access should fail because a is not defined.
|
| + Err err;
|
| + Value result = accessor.Execute(setup.scope(), &err);
|
| + EXPECT_TRUE(err.has_error());
|
| + EXPECT_EQ(Value::NONE, result.type());
|
| +
|
| + // Define a as a Scope. It should still fail because b isn't defined.
|
| + Scope a_scope(setup.scope());
|
| + err = Err();
|
| + setup.scope()->SetValue("a", Value(NULL, &a_scope), NULL);
|
| + result = accessor.Execute(setup.scope(), &err);
|
| + EXPECT_TRUE(err.has_error());
|
| + EXPECT_EQ(Value::NONE, result.type());
|
| +
|
| + // Define b, accessor should succeed now.
|
| + const int64 kBValue = 42;
|
| + err = Err();
|
| + a_scope.SetValue("b", Value(NULL, kBValue), NULL);
|
| + result = accessor.Execute(setup.scope(), &err);
|
| + EXPECT_FALSE(err.has_error());
|
| + ASSERT_EQ(Value::INTEGER, result.type());
|
| + EXPECT_EQ(kBValue, result.int_value());
|
| +}
|
|
|