Edit

kc3-lang/angle/tests/preprocessor_tests/pragma_test.cpp

Branch :

  • Show log

    Commit

  • Author : alokp@chromium.org
    Date : 2012-05-30 20:13:14
    Hash : 484730bc
    Message : Removed the unnecessary usage of GTEST_HAS_PARAM_TEST and GTEST_HAS_COMBINE. I would rather have tests fail to compile than be silently ignored. git-svn-id: https://angleproject.googlecode.com/svn/trunk@1098 736b8ea6-26fd-11df-bfd4-992fa37f6226

  • tests/preprocessor_tests/pragma_test.cpp
  • //
    // Copyright (c) 2012 The ANGLE Project 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 "PreprocessorTest.h"
    #include "Token.h"
    
    class PragmaTest : public PreprocessorTest
    {
    protected:
        void preprocess(const char* str)
        {
            ASSERT_TRUE(mPreprocessor.init(1, &str, NULL));
    
            pp::Token token;
            mPreprocessor.lex(&token);
            EXPECT_EQ(pp::Token::LAST, token.type);
            EXPECT_EQ("", token.value);
        }
    };
    
    TEST_F(PragmaTest, EmptyName)
    {
        const char* str = "#pragma\n";
    
        using testing::_;
        // No handlePragma calls.
        EXPECT_CALL(mDirectiveHandler, handlePragma(_, _, _)).Times(0);
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str);
    }
    
    TEST_F(PragmaTest, EmptyValue)
    {
        const char* str = "#pragma foo\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", ""));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str);
    }
    
    TEST_F(PragmaTest, NameValue)
    {
        const char* str = "#pragma foo(bar)\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar"));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str);
    }
    
    TEST_F(PragmaTest, Comments)
    {
        const char* str = "/*foo*/"
                          "#"
                          "/*foo*/"
                          "pragma"
                          "/*foo*/"
                          "foo"
                          "/*foo*/"
                          "("
                          "/*foo*/"
                          "bar"
                          "/*foo*/"
                          ")"
                          "/*foo*/"
                          "//foo"
                          "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar"));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str);
    }
    
    TEST_F(PragmaTest, MissingNewline)
    {
        const char* str = "#pragma foo(bar)";
    
        using testing::_;
        // Pragma successfully parsed.
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar"));
        // Error reported about EOF.
        EXPECT_CALL(mDiagnostics, print(pp::Diagnostics::EOF_IN_DIRECTIVE, _, _));
    
        preprocess(str);
    }
    
    class InvalidPragmaTest : public PragmaTest,
                              public testing::WithParamInterface<const char*>
    {
    };
    
    TEST_P(InvalidPragmaTest, Identified)
    {
        const char* str = GetParam();
    
        using testing::_;
        // No handlePragma calls.
        EXPECT_CALL(mDirectiveHandler, handlePragma(_, _, _)).Times(0);
        // Unrecognized pragma warning.
        EXPECT_CALL(mDiagnostics,
                    print(pp::Diagnostics::UNRECOGNIZED_PRAGMA,
                          pp::SourceLocation(0, 1), _));
    
        preprocess(str);
    }
    
    INSTANTIATE_TEST_CASE_P(All, InvalidPragmaTest, testing::Values(
        "#pragma 1\n",               // Invalid name.
        "#pragma foo()\n",           // Missing value.
        "#pragma foo bar)\n",        // Missing left paren,
        "#pragma foo(bar\n",         // Missing right paren.
        "#pragma foo bar\n",         // Missing parens.
        "#pragma foo(bar) baz\n"));  // Extra tokens.