blob: 9b0f3db6efc68208ed204fdadb143d4a57207a1a [file] [log] [blame]
// Copyright 2015 The Cobalt Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "starboard/common/log.h"
#include "starboard/system.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace starboard {
namespace nplb {
namespace {
SB_C_NOINLINE int GetStackWithAnExtraFrame(void** out_stack, int stack_size) {
// These EXPECT_NE and EXPECT_LT should be enough to make function complicated
// and avoid inlining with optimizations on some platforms. But we'll have to
// keep an eye on it as this may not be enough on some other platforms.
void** const kNullVpp = NULL;
EXPECT_NE(kNullVpp, out_stack);
int ret = SbSystemGetStack(out_stack, stack_size);
EXPECT_LT(1, ret);
return ret;
}
SB_C_NOINLINE void WowThatsADeepStack() {
void* stack1[10] = {0};
void* stack2[10] = {0};
EXPECT_LT(0, SbSystemGetStack(stack1, SB_ARRAY_SIZE_INT(stack1)));
EXPECT_LT(1, GetStackWithAnExtraFrame(stack2, SB_ARRAY_SIZE_INT(stack2)));
EXPECT_EQ(stack1[3], stack2[4]);
}
TEST(SbSystemGetStackTest, SunnyDayStackDirection) {
// Make sure there are enough frames for us to look down the stack a ways,
// without assuming anything about how the test runner calls or compiles these
// tests.
WowThatsADeepStack();
}
TEST(SbSystemGetStackTest, SunnyDay) {
// Ensure we have more entries than actual stack frames, to check that we have
// the correct target positioning within the destination array.
void* stack[1024] = {0};
int count = SbSystemGetStack(&stack[2], SB_ARRAY_SIZE_INT(stack) - 2);
EXPECT_LT(0, count);
EXPECT_GE(SB_ARRAY_SIZE_INT(stack) - 2, count);
// The target should be filled in from the front of the destination array
// towards the back.
EXPECT_NE(static_cast<void*>(NULL), stack[2]);
// Ensure no data before the given entry is modified.
EXPECT_EQ(static_cast<void*>(NULL), stack[0]);
EXPECT_EQ(static_cast<void*>(NULL), stack[1]);
}
TEST(SbSystemGetStackTest, SunnyDayShortStack) {
// Ensure we have fewer entries than actual stack frames.
void* stack[2] = {0};
int count = SbSystemGetStack(stack, SB_ARRAY_SIZE_INT(stack));
EXPECT_LT(0, count);
EXPECT_GE(SB_ARRAY_SIZE_INT(stack), count);
EXPECT_NE(static_cast<void*>(NULL), stack[0]);
}
TEST(SbSystemGetStackTest, SunnyDayNoStack) {
void* stack[1] = {0};
int count = SbSystemGetStack(stack, 0);
EXPECT_EQ(0, count);
EXPECT_EQ(static_cast<void*>(NULL), stack[0]);
}
} // namespace
} // namespace nplb
} // namespace starboard