| Index: chrome/browser/image_decoder_browsertest.cc
|
| diff --git a/chrome/browser/image_decoder_browsertest.cc b/chrome/browser/image_decoder_browsertest.cc
|
| index f2fdf537da8e9ec4ca5b5070632a994b822b34d9..602e3a4f6f06650a667a7f3ca21597b4113a78f0 100644
|
| --- a/chrome/browser/image_decoder_browsertest.cc
|
| +++ b/chrome/browser/image_decoder_browsertest.cc
|
| @@ -18,7 +18,7 @@ using content::BrowserThread;
|
|
|
| namespace {
|
|
|
| -std::string GetValidPngString() {
|
| +std::vector<uint8_t> GetValidPngData() {
|
| // 1x1 PNG. Does not get much smaller than this.
|
| static const char kPngData[] =
|
| "\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52"
|
| @@ -27,12 +27,12 @@ std::string GetValidPngString() {
|
| "\x00\x05\xfe\x02\xfe\xdc\xcc\x59\xe7\x00\x00\x00\x00\x49\x45\x4e"
|
| "\x44\xae\x42\x60\x82";
|
| // Need to specify the buffer size because it contains NULs.
|
| - return std::string(kPngData, sizeof(kPngData) - 1);
|
| + return std::vector<uint8_t>(kPngData, kPngData + sizeof(kPngData) - 1);
|
| }
|
|
|
| #if defined(OS_CHROMEOS)
|
|
|
| -std::string GetValidJpgString() {
|
| +std::vector<uint8_t> GetValidJpgData() {
|
| // 1x1 JPG created from the 1x1 PNG above.
|
| static const char kJpgData[] =
|
| "\xFF\xD8\xFF\xE0\x00\x10\x4A\x46\x49\x46\x00\x01\x01\x01\x00\x48"
|
| @@ -54,7 +54,7 @@ std::string GetValidJpgString() {
|
| "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xFF\xDA\x00\x0C\x03\x01"
|
| "\x00\x02\x11\x03\x11\x00\x3F\x00\xA0\x00\xFF\xD9";
|
| // Need to specify the buffer size because it contains NULs.
|
| - return std::string(kJpgData, sizeof(kJpgData) - 1);
|
| + return std::vector<uint8_t>(kJpgData, kJpgData + sizeof(kJpgData) - 1);
|
| }
|
|
|
| #endif // defined(OS_CHROMEOS)
|
| @@ -163,18 +163,31 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, Basic) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::Start(&test_request, std::string());
|
| + ImageDecoder::Start(&test_request, std::vector<uint8_t>());
|
| runner->Run();
|
| EXPECT_FALSE(test_request.decode_succeeded());
|
| }
|
|
|
| #if defined(OS_CHROMEOS)
|
|
|
| +IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, BasicDecodeWithOptionsString) {
|
| + scoped_refptr<content::MessageLoopRunner> runner =
|
| + new content::MessageLoopRunner;
|
| + TestImageRequest test_request(runner->QuitClosure());
|
| + const std::vector<uint8_t> data = GetValidPngData();
|
| + ImageDecoder::StartWithOptions(&test_request,
|
| + std::string(data.begin(), data.end()),
|
| + ImageDecoder::ROBUST_PNG_CODEC,
|
| + false /* shrink_to_fit */);
|
| + runner->Run();
|
| + EXPECT_TRUE(test_request.decode_succeeded());
|
| +}
|
| +
|
| IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, RobustJpegCodecWithJpegData) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::StartWithOptions(&test_request, GetValidJpgString(),
|
| + ImageDecoder::StartWithOptions(&test_request, GetValidJpgData(),
|
| ImageDecoder::ROBUST_JPEG_CODEC,
|
| false /* shrink_to_fit */);
|
| runner->Run();
|
| @@ -185,7 +198,7 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, RobustJpegCodecWithPngData) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::StartWithOptions(&test_request, GetValidPngString(),
|
| + ImageDecoder::StartWithOptions(&test_request, GetValidPngData(),
|
| ImageDecoder::ROBUST_JPEG_CODEC,
|
| false /* shrink_to_fit */);
|
| runner->Run();
|
| @@ -197,7 +210,7 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, RobustPngCodecWithPngData) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::StartWithOptions(&test_request, GetValidPngString(),
|
| + ImageDecoder::StartWithOptions(&test_request, GetValidPngData(),
|
| ImageDecoder::ROBUST_PNG_CODEC,
|
| false /* shrink_to_fit */);
|
| runner->Run();
|
| @@ -208,7 +221,7 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, RobustPngCodecWithJpegData) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::StartWithOptions(&test_request, GetValidJpgString(),
|
| + ImageDecoder::StartWithOptions(&test_request, GetValidJpgData(),
|
| ImageDecoder::ROBUST_PNG_CODEC,
|
| false /* shrink_to_fit */);
|
| runner->Run();
|
| @@ -222,7 +235,17 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, BasicDecode) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::Start(&test_request, GetValidPngString());
|
| + ImageDecoder::Start(&test_request, GetValidPngData());
|
| + runner->Run();
|
| + EXPECT_TRUE(test_request.decode_succeeded());
|
| +}
|
| +
|
| +IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, BasicDecodeString) {
|
| + scoped_refptr<content::MessageLoopRunner> runner =
|
| + new content::MessageLoopRunner;
|
| + TestImageRequest test_request(runner->QuitClosure());
|
| + const std::vector<uint8_t> data = GetValidPngData();
|
| + ImageDecoder::Start(&test_request, std::string(data.begin(), data.end()));
|
| runner->Run();
|
| EXPECT_TRUE(test_request.decode_succeeded());
|
| }
|
| @@ -232,7 +255,7 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, StartAndDestroy) {
|
| new content::MessageLoopRunner;
|
| std::unique_ptr<TestImageRequest> test_request(
|
| new TestImageRequest(runner->QuitClosure()));
|
| - ImageDecoder::Start(test_request.get(), std::string());
|
| + ImageDecoder::Start(test_request.get(), std::vector<uint8_t>());
|
| test_request.reset();
|
| runner->Run();
|
| }
|
| @@ -248,7 +271,7 @@ IN_PROC_BROWSER_TEST_F(ImageDecoderBrowserTest, StartAndKillProcess) {
|
| scoped_refptr<content::MessageLoopRunner> runner =
|
| new content::MessageLoopRunner;
|
| TestImageRequest test_request(runner->QuitClosure());
|
| - ImageDecoder::Start(&test_request, GetValidPngString());
|
| + ImageDecoder::Start(&test_request, GetValidPngData());
|
| runner->Run();
|
| if (!test_request.decode_succeeded()) {
|
| // The UI thread won the race. Make sure the utility process did get killed.
|
|
|