1*8975f5c5SAndroid Build Coastguard Worker //
2*8975f5c5SAndroid Build Coastguard Worker // Copyright 2015 The ANGLE Project Authors. All rights reserved.
3*8975f5c5SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
4*8975f5c5SAndroid Build Coastguard Worker // found in the LICENSE file.
5*8975f5c5SAndroid Build Coastguard Worker //
6*8975f5c5SAndroid Build Coastguard Worker // Unit tests for Program and related classes.
7*8975f5c5SAndroid Build Coastguard Worker //
8*8975f5c5SAndroid Build Coastguard Worker
9*8975f5c5SAndroid Build Coastguard Worker #include <gtest/gtest.h>
10*8975f5c5SAndroid Build Coastguard Worker
11*8975f5c5SAndroid Build Coastguard Worker #include "libANGLE/Program.h"
12*8975f5c5SAndroid Build Coastguard Worker
13*8975f5c5SAndroid Build Coastguard Worker using namespace gl;
14*8975f5c5SAndroid Build Coastguard Worker
15*8975f5c5SAndroid Build Coastguard Worker namespace
16*8975f5c5SAndroid Build Coastguard Worker {
17*8975f5c5SAndroid Build Coastguard Worker
18*8975f5c5SAndroid Build Coastguard Worker // Tests that the log length properly counts the terminating \0.
TEST(InfoLogTest,LogLengthCountsTerminator)19*8975f5c5SAndroid Build Coastguard Worker TEST(InfoLogTest, LogLengthCountsTerminator)
20*8975f5c5SAndroid Build Coastguard Worker {
21*8975f5c5SAndroid Build Coastguard Worker InfoLog infoLog;
22*8975f5c5SAndroid Build Coastguard Worker EXPECT_EQ(0u, infoLog.getLength());
23*8975f5c5SAndroid Build Coastguard Worker infoLog << " ";
24*8975f5c5SAndroid Build Coastguard Worker
25*8975f5c5SAndroid Build Coastguard Worker // " \n\0" = 3 characters
26*8975f5c5SAndroid Build Coastguard Worker EXPECT_EQ(3u, infoLog.getLength());
27*8975f5c5SAndroid Build Coastguard Worker }
28*8975f5c5SAndroid Build Coastguard Worker
29*8975f5c5SAndroid Build Coastguard Worker // Tests that the log doesn't append newlines to an empty string
TEST(InfoLogTest,InfoLogEmptyString)30*8975f5c5SAndroid Build Coastguard Worker TEST(InfoLogTest, InfoLogEmptyString)
31*8975f5c5SAndroid Build Coastguard Worker {
32*8975f5c5SAndroid Build Coastguard Worker InfoLog infoLog;
33*8975f5c5SAndroid Build Coastguard Worker EXPECT_EQ(0u, infoLog.getLength());
34*8975f5c5SAndroid Build Coastguard Worker infoLog << "";
35*8975f5c5SAndroid Build Coastguard Worker
36*8975f5c5SAndroid Build Coastguard Worker // "" = 3 characters
37*8975f5c5SAndroid Build Coastguard Worker EXPECT_EQ(0u, infoLog.getLength());
38*8975f5c5SAndroid Build Coastguard Worker }
39*8975f5c5SAndroid Build Coastguard Worker
40*8975f5c5SAndroid Build Coastguard Worker // Tests that newlines get appended to the info log properly.
TEST(InfoLogTest,AppendingNewline)41*8975f5c5SAndroid Build Coastguard Worker TEST(InfoLogTest, AppendingNewline)
42*8975f5c5SAndroid Build Coastguard Worker {
43*8975f5c5SAndroid Build Coastguard Worker InfoLog infoLog;
44*8975f5c5SAndroid Build Coastguard Worker
45*8975f5c5SAndroid Build Coastguard Worker infoLog << "First" << 1 << 'x';
46*8975f5c5SAndroid Build Coastguard Worker infoLog << "Second" << 2 << 'y';
47*8975f5c5SAndroid Build Coastguard Worker
48*8975f5c5SAndroid Build Coastguard Worker std::string expected = "First1x\nSecond2y\n";
49*8975f5c5SAndroid Build Coastguard Worker
50*8975f5c5SAndroid Build Coastguard Worker EXPECT_EQ(expected, infoLog.str());
51*8975f5c5SAndroid Build Coastguard Worker }
52*8975f5c5SAndroid Build Coastguard Worker
53*8975f5c5SAndroid Build Coastguard Worker } // namespace
54