blob: 94f233353347bd25412c3863a2671b96259c7897 [file] [log] [blame]
// Copyright 2016 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/blitter.h"
#include "starboard/nplb/blitter_helpers.h"
#include "starboard/window.h"
#include "testing/gtest/include/gtest/gtest.h"
#if SB_HAS(BLITTER)
namespace starboard {
namespace nplb {
namespace {
TEST(SbBlitterGetSurfaceInfoTest, SunnyDayWithRenderTargetSurfaces) {
SbBlitterDevice device = SbBlitterCreateDefaultDevice();
ASSERT_TRUE(SbBlitterIsDeviceValid(device));
const int kWidth = 128;
const int kHeight = 128;
// Test that we can get a render target from all supported pixel formats.
SurfaceFormats supported_formats =
GetAllSupportedSurfaceFormatsForRenderTargetSurfaces(device);
for (SurfaceFormats::const_iterator iter = supported_formats.begin();
iter != supported_formats.end(); ++iter) {
SbBlitterSurface surface =
SbBlitterCreateRenderTargetSurface(device, kWidth, kHeight, *iter);
ASSERT_TRUE(SbBlitterIsSurfaceValid(surface));
SbBlitterSurfaceInfo surface_info;
ASSERT_TRUE(SbBlitterGetSurfaceInfo(surface, &surface_info));
EXPECT_EQ(kWidth, surface_info.width);
EXPECT_EQ(kHeight, surface_info.height);
EXPECT_EQ(*iter, surface_info.format);
EXPECT_TRUE(SbBlitterDestroySurface(surface));
}
EXPECT_TRUE(SbBlitterDestroyDevice(device));
}
// Surfaces created from SbBlitterPixelData objects are not able to provide
// SbBlitterRenderTargets, and this test verifies that.
TEST(SbBlitterGetSurfaceInfoTest, SunnyDayWithPixelDataSurfaces) {
SbBlitterDevice device = SbBlitterCreateDefaultDevice();
ASSERT_TRUE(SbBlitterIsDeviceValid(device));
const int kWidth = 128;
const int kHeight = 128;
std::vector<SbBlitterPixelDataFormat> supported_formats =
GetAllSupportedPixelFormatsForPixelData(device);
for (std::vector<SbBlitterPixelDataFormat>::const_iterator iter =
supported_formats.begin();
iter != supported_formats.end(); ++iter) {
SbBlitterPixelData pixel_data =
SbBlitterCreatePixelData(device, kWidth, kHeight, *iter);
ASSERT_TRUE(SbBlitterIsPixelDataValid(pixel_data));
SbBlitterSurface surface =
SbBlitterCreateSurfaceFromPixelData(device, pixel_data);
ASSERT_TRUE(SbBlitterIsSurfaceValid(surface));
SbBlitterSurfaceInfo surface_info;
ASSERT_TRUE(SbBlitterGetSurfaceInfo(surface, &surface_info));
EXPECT_EQ(kWidth, surface_info.width);
EXPECT_EQ(kHeight, surface_info.height);
EXPECT_EQ(SbBlitterPixelDataFormatToSurfaceFormat(*iter),
surface_info.format);
EXPECT_TRUE(SbBlitterDestroySurface(surface));
}
EXPECT_TRUE(SbBlitterDestroyDevice(device));
}
TEST(SbBlitterGetSurfaceInfoTest, RainyDayInvalidSurface) {
SbBlitterSurfaceInfo surface_info;
EXPECT_FALSE(
SbBlitterGetSurfaceInfo(kSbBlitterInvalidSurface, &surface_info));
}
} // namespace
} // namespace nplb
} // namespace starboard
#endif // SB_HAS(BLITTER)