blob: 5f6dc460c9a9d9a05204a2ecd77139879838d523 [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(SbBlitterCreateSurfaceFromPixelDataTest, SunnyDay) {
SbBlitterDevice device = SbBlitterCreateDefaultDevice();
ASSERT_TRUE(SbBlitterIsDeviceValid(device));
const int kWidth = 128;
const int kHeight = 128;
// Test that we can get pitch on all supported image formats.
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);
EXPECT_TRUE(SbBlitterIsSurfaceValid(surface));
EXPECT_TRUE(SbBlitterDestroySurface(surface));
}
EXPECT_TRUE(SbBlitterDestroyDevice(device));
}
TEST(SbBlitterCreateSurfaceFromPixelDataTest, RainyDayInvalidPixelData) {
SbBlitterDevice device = SbBlitterCreateDefaultDevice();
ASSERT_TRUE(SbBlitterIsDeviceValid(device));
SbBlitterSurface surface =
SbBlitterCreateSurfaceFromPixelData(device, kSbBlitterInvalidPixelData);
EXPECT_FALSE(SbBlitterIsSurfaceValid(surface));
EXPECT_TRUE(SbBlitterDestroyDevice(device));
}
TEST(SbBlitterCreateSurfaceFromPixelDataTest, RainyDayInvalidDevice) {
// We still need a valid device to create the pixel data, we just won't pass
// it into SbBlitterCreateSurfaceFromPixelData().
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(
kSbBlitterInvalidDevice, pixel_data);
EXPECT_FALSE(SbBlitterIsSurfaceValid(surface));
EXPECT_TRUE(SbBlitterDestroyPixelData(pixel_data));
}
EXPECT_TRUE(SbBlitterDestroyDevice(device));
}
} // namespace
} // namespace nplb
} // namespace starboard
#endif // SB_HAS(BLITTER)