| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
- // Exceptions. See /LICENSE for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- #include "executable_semantics/syntax/paren_contents.h"
- #include "gtest/gtest.h"
- namespace Carbon {
- namespace {
- TEST(ParenContentsTest, EmptyAsExpression) {
- ParenContents contents;
- const Expression* expression = contents.AsExpression(/*line_num=*/1);
- EXPECT_EQ(expression->line_num, 1);
- ASSERT_EQ(expression->tag, ExpressionKind::Tuple);
- EXPECT_EQ(expression->u.tuple.fields->size(), 0);
- }
- TEST(ParenContentsTest, EmptyAsTuple) {
- ParenContents contents;
- const Expression* tuple = contents.AsTuple(/*line_num=*/1);
- EXPECT_EQ(tuple->line_num, 1);
- ASSERT_EQ(tuple->tag, ExpressionKind::Tuple);
- EXPECT_EQ(tuple->u.tuple.fields->size(), 0);
- }
- TEST(ParenContentsTest, UnaryNoCommaAsExpression) {
- // Equivalent to a code fragment like
- // ```
- // (
- // 42
- // )
- // ```
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)}},
- ParenContents::HasTrailingComma::No);
- const Expression* expression = contents.AsExpression(/*line_num=*/1);
- EXPECT_EQ(expression->line_num, 2);
- ASSERT_EQ(expression->tag, ExpressionKind::Integer);
- }
- TEST(ParenContentsTest, UnaryNoCommaAsTuple) {
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)}},
- ParenContents::HasTrailingComma::No);
- const Expression* tuple = contents.AsTuple(/*line_num=*/1);
- EXPECT_EQ(tuple->line_num, 1);
- ASSERT_EQ(tuple->tag, ExpressionKind::Tuple);
- std::vector<std::pair<std::string, const Expression*>> fields =
- *tuple->u.tuple.fields;
- ASSERT_EQ(fields.size(), 1);
- EXPECT_EQ(fields[0].second->tag, ExpressionKind::Integer);
- }
- TEST(ParenContentsTest, UnaryWithCommaAsExpression) {
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)}},
- ParenContents::HasTrailingComma::Yes);
- const Expression* expression = contents.AsExpression(/*line_num=*/1);
- EXPECT_EQ(expression->line_num, 1);
- ASSERT_EQ(expression->tag, ExpressionKind::Tuple);
- std::vector<std::pair<std::string, const Expression*>> fields =
- *expression->u.tuple.fields;
- ASSERT_EQ(fields.size(), 1);
- EXPECT_EQ(fields[0].second->tag, ExpressionKind::Integer);
- }
- TEST(ParenContentsTest, UnaryWithCommaAsTuple) {
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)}},
- ParenContents::HasTrailingComma::Yes);
- const Expression* tuple = contents.AsTuple(/*line_num=*/1);
- EXPECT_EQ(tuple->line_num, 1);
- ASSERT_EQ(tuple->tag, ExpressionKind::Tuple);
- std::vector<std::pair<std::string, const Expression*>> fields =
- *tuple->u.tuple.fields;
- ASSERT_EQ(fields.size(), 1);
- EXPECT_EQ(fields[0].second->tag, ExpressionKind::Integer);
- }
- TEST(ParenContentsTest, BinaryAsExpression) {
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)},
- {.expression = MakeInt(/*line_num=*/3, 42)}},
- ParenContents::HasTrailingComma::Yes);
- const Expression* expression = contents.AsExpression(/*line_num=*/1);
- EXPECT_EQ(expression->line_num, 1);
- ASSERT_EQ(expression->tag, ExpressionKind::Tuple);
- std::vector<std::pair<std::string, const Expression*>> fields =
- *expression->u.tuple.fields;
- ASSERT_EQ(fields.size(), 2);
- EXPECT_EQ(fields[0].second->tag, ExpressionKind::Integer);
- EXPECT_EQ(fields[1].second->tag, ExpressionKind::Integer);
- }
- TEST(ParenContentsTest, BinaryAsTuple) {
- ParenContents contents({{.expression = MakeInt(/*line_num=*/2, 42)},
- {.expression = MakeInt(/*line_num=*/3, 42)}},
- ParenContents::HasTrailingComma::Yes);
- const Expression* tuple = contents.AsTuple(/*line_num=*/1);
- EXPECT_EQ(tuple->line_num, 1);
- ASSERT_EQ(tuple->tag, ExpressionKind::Tuple);
- std::vector<std::pair<std::string, const Expression*>> fields =
- *tuple->u.tuple.fields;
- ASSERT_EQ(fields.size(), 2);
- EXPECT_EQ(fields[0].second->tag, ExpressionKind::Integer);
- EXPECT_EQ(fields[1].second->tag, ExpressionKind::Integer);
- }
- } // namespace
- } // namespace Carbon
|