Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(300)

Side by Side Diff: third_party/WebKit/Source/platform/image-decoders/gif/GIFImageDecoderTest.cpp

Issue 1769343002: GIF decoding: Add a unit test for repetition count (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@test_file
Patch Set: Add a test in BitmapImage to make sure we loop one extra time Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 482 matching lines...) Expand 10 before | Expand all | Expand 10 after
493 if (decoder->isSizeAvailable() && !frameSize.width() && !frameSize.heigh t()) { 493 if (decoder->isSizeAvailable() && !frameSize.width() && !frameSize.heigh t()) {
494 frameSize = decoder->decodedSize(); 494 frameSize = decoder->decodedSize();
495 continue; 495 continue;
496 } 496 }
497 497
498 ASSERT_EQ(frameSize.width(), decoder->decodedSize().width()); 498 ASSERT_EQ(frameSize.width(), decoder->decodedSize().width());
499 ASSERT_EQ(frameSize.height(), decoder->decodedSize().height()); 499 ASSERT_EQ(frameSize.height(), decoder->decodedSize().height());
500 } 500 }
501 } 501 }
502 502
503 TEST(GIFImageDecoderTest, verifyRepetitionCount)
504 {
505 const int expectedRepetitionCount = 2;
506 OwnPtr<ImageDecoder> decoder = createDecoder();
507 RefPtr<SharedBuffer> data = readFile(layoutTestResourcesDir, "full2loop.gif" );
508 ASSERT_TRUE(data.get());
509 decoder->setData(data.get(), true);
510 EXPECT_EQ(cAnimationLoopOnce, decoder->repetitionCount()); // Default value before decode.
511
512 ImageFrame* frame = decoder->frameBufferAtIndex(0);
513 EXPECT_EQ(ImageFrame::FrameComplete, frame->getStatus());
514 frame = decoder->frameBufferAtIndex(1);
515 EXPECT_EQ(ImageFrame::FrameComplete, frame->getStatus());
516
517 EXPECT_EQ(expectedRepetitionCount, decoder->repetitionCount()); // Expected value after decode.
518 }
519
503 } // namespace blink 520 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698