xref: /aosp_15_r20/external/angle/src/libANGLE/Program_unittest.cpp (revision 8975f5c5ed3d1c378011245431ada316dfb6f244)
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