Edit

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

Branch :

  • Show log

    Commit

  • Author : Olli Etuaho
    Date : 2015-08-12 16:30:38
    Hash : 391befef
    Message : Revert "Add pragma errors for malformed pragmas." Since this commit was made, dEQP tests were fixed to check that unrecognized pragma tokens only generate warnings, not errors. This applies to both ESSL1.00 and ESSL3.00, which specify this behavior in section 3.4 Preprocessor. BUG=angleproject:989 TEST=dEQP-GLES2.functional.shaders.preprocessor.pragmas.* This reverts commit d3c29f57aaeb451b149bbb9fd17b3f1f99101c52. Change-Id: Ie4e0ec061fa3164d6f3872ac0016a063056ed110 Reviewed-on: https://chromium-review.googlesource.com/293181 Tested-by: Olli Etuaho <oetuaho@nvidia.com> Reviewed-by: Jamie Madill <jmadill@chromium.org> Reviewed-by: Geoff Lang <geofflang@chromium.org>

  • src/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
    {
    };
    
    TEST_F(PragmaTest, EmptyName)
    {
        const char* str = "#pragma\n";
        const char* expected = "\n";
    
        using testing::_;
        // No handlePragma calls.
        EXPECT_CALL(mDirectiveHandler, handlePragma(_, _, _, false)).Times(0);
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, EmptyValue)
    {
        const char* str = "#pragma foo\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "", false));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, NameValue)
    {
        const char* str = "#pragma foo(bar)\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar", false));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, STDGL)
    {
        const char* str = "#pragma STDGL\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(_, _, _, _)).Times(0);
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, STDGLInvariantAll)
    {
        const char* str = "#pragma STDGL invariant(all)\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "invariant", "all", true));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, Comments)
    {
        const char* str = "/*foo*/"
                          "#"
                          "/*foo*/"
                          "pragma"
                          "/*foo*/"
                          "foo"
                          "/*foo*/"
                          "("
                          "/*foo*/"
                          "bar"
                          "/*foo*/"
                          ")"
                          "/*foo*/"
                          "//foo"
                          "\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar", false));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(PragmaTest, MissingNewline)
    {
        const char* str = "#pragma foo(bar)";
        const char* expected = "";
    
        using testing::_;
        // Pragma successfully parsed.
        EXPECT_CALL(mDirectiveHandler,
                    handlePragma(pp::SourceLocation(0, 1), "foo", "bar", false));
        // Error reported about EOF.
        EXPECT_CALL(mDiagnostics, print(pp::Diagnostics::PP_EOF_IN_DIRECTIVE, _, _));
    
        preprocess(str, expected);
    }
    
    class InvalidPragmaTest : public PragmaTest,
                              public testing::WithParamInterface<const char*>
    {
    };
    
    TEST_P(InvalidPragmaTest, Identified)
    {
        const char* str = GetParam();
        const char* expected = "\n";
    
        using testing::_;
        // No handlePragma calls.
        EXPECT_CALL(mDirectiveHandler, handlePragma(_, _, _, false)).Times(0);
        // Unrecognized pragma warning.
        EXPECT_CALL(mDiagnostics,
                    print(pp::Diagnostics::PP_UNRECOGNIZED_PRAGMA,
                          pp::SourceLocation(0, 1), _));
    
        preprocess(str, expected);
    }
    
    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.