Edit

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

Branch :

  • Show log

    Commit

  • Author : alokp@chromium.org
    Date : 2012-05-31 18:10:43
    Hash : c745adb0
    Message : Added PreprocessorTest::preprocess that preprocesses the input string and compares the output with that of the expected string. Renamed other *Test::preprocess methods to something different and clearer. git-svn-id: https://angleproject.googlecode.com/svn/trunk@1126 736b8ea6-26fd-11df-bfd4-992fa37f6226

  • tests/preprocessor_tests/error_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 ErrorTest : public PreprocessorTest
    {
    };
    
    TEST_F(ErrorTest, Empty)
    {
        const char* str = "#error\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler, handleError(pp::SourceLocation(0, 1), ""));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(ErrorTest, OneTokenMessage)
    {
        const char* str = "#error foo\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handleError(pp::SourceLocation(0, 1), " foo"));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(ErrorTest, TwoTokenMessage)
    {
        const char* str = "#error foo bar\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handleError(pp::SourceLocation(0, 1), " foo bar"));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(ErrorTest, Comments)
    {
        const char* str = "/*foo*/"
                          "#"
                          "/*foo*/"
                          "error"
                          "/*foo*/"
                          "foo"
                          "/*foo*/"
                          "bar"
                          "/*foo*/"
                          "//foo"
                          "\n";
        const char* expected = "\n";
    
        using testing::_;
        EXPECT_CALL(mDirectiveHandler,
                    handleError(pp::SourceLocation(0, 1), " foo bar"));
        // No error or warning.
        EXPECT_CALL(mDiagnostics, print(_, _, _)).Times(0);
    
        preprocess(str, expected);
    }
    
    TEST_F(ErrorTest, MissingNewline)
    {
        const char* str = "#error foo";
        const char* expected = "";
    
        using testing::_;
        // Directive successfully parsed.
        EXPECT_CALL(mDirectiveHandler,
                    handleError(pp::SourceLocation(0, 1), " foo"));
        // Error reported about EOF.
        EXPECT_CALL(mDiagnostics, print(pp::Diagnostics::EOF_IN_DIRECTIVE, _, _));
    
        preprocess(str, expected);
    }