OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "Resources.h" | 8 #include "Resources.h" |
9 #include "SkData.h" | 9 #include "SkData.h" |
10 #include "SkFrontBufferedStream.h" | 10 #include "SkFrontBufferedStream.h" |
(...skipping 255 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
266 for (size_t i = 1; i < fileStream.getLength(); i++) { | 266 for (size_t i = 1; i < fileStream.getLength(); i++) { |
267 REPORTER_ASSERT(reporter, !fileStream.peek(storage.get(), i)); | 267 REPORTER_ASSERT(reporter, !fileStream.peek(storage.get(), i)); |
268 } | 268 } |
269 | 269 |
270 // Now test some FrontBufferedStreams | 270 // Now test some FrontBufferedStreams |
271 for (size_t i = 1; i < memStream.getLength(); i++) { | 271 for (size_t i = 1; i < memStream.getLength(); i++) { |
272 test_peeking_front_buffered_stream(reporter, memStream, i); | 272 test_peeking_front_buffered_stream(reporter, memStream, i); |
273 } | 273 } |
274 } | 274 } |
275 #endif | 275 #endif |
| 276 |
| 277 // Asserts that asset == expected and is peekable. |
| 278 static void stream_peek_test(skiatest::Reporter*rep, |
| 279 SkStreamAsset* asset, |
| 280 const SkData* expected) { |
| 281 if (asset->getLength() != expected->size()) { |
| 282 ERRORF(rep, "Unexpected length."); |
| 283 return; |
| 284 } |
| 285 SkRandom rand; |
| 286 uint8_t buffer[4096]; |
| 287 const uint8_t* expect = expected->bytes(); |
| 288 for (unsigned i = 0; i < asset->getLength(); ++i) { |
| 289 size_t maxSize = SkTMin(sizeof(buffer), asset->getLength() - i); |
| 290 size_t size = rand.nextRangeU(1, maxSize); |
| 291 SkASSERT(size >= 1); |
| 292 SkASSERT(size <= sizeof(buffer)); |
| 293 SkASSERT(size + i <= asset->getLength()); |
| 294 if (!asset->peek(buffer, size)) { |
| 295 ERRORF(rep, "Peek Failed!"); |
| 296 return; |
| 297 } |
| 298 if (0 != memcmp(buffer, &expect[i], size)) { |
| 299 ERRORF(rep, "Peek returned wrong bytes!"); |
| 300 return; |
| 301 } |
| 302 uint8_t value; |
| 303 REPORTER_ASSERT(rep, 1 == asset->read(&value, 1)); |
| 304 if (value != expect[i]) { |
| 305 ERRORF(rep, "Read Failed!"); |
| 306 return; |
| 307 } |
| 308 } |
| 309 } |
| 310 |
| 311 DEF_TEST(StreamPeek_BlockMemoryStream, rep) { |
| 312 const static int kSeed = 1234; |
| 313 SkRandom valueSource(kSeed); |
| 314 SkRandom rand(kSeed << 1); |
| 315 uint8_t buffer[4096]; |
| 316 SkDynamicMemoryWStream dynamicMemoryWStream; |
| 317 for (int i = 0; i < 32; ++i) { |
| 318 // Randomize the length of the blocks. |
| 319 size_t size = rand.nextRangeU(1, sizeof(buffer)); |
| 320 for (unsigned j = 0; j < size; ++j) { |
| 321 buffer[j] = valueSource.nextU() & 0xFF; |
| 322 } |
| 323 dynamicMemoryWStream.write(buffer, size); |
| 324 } |
| 325 SkAutoTDelete<SkStreamAsset> asset(dynamicMemoryWStream.detachAsStream()); |
| 326 SkAutoTUnref<SkData> expected(SkData::NewUninitialized(asset->getLength())); |
| 327 uint8_t* expectedPtr = static_cast<uint8_t*>(expected->writable_data()); |
| 328 valueSource.setSeed(kSeed); // reseed. |
| 329 // We want the exact same same "random" string of numbers to put |
| 330 // in expected. i.e.: don't rely on SkDynamicMemoryStream to work |
| 331 // correctly while we are testing SkDynamicMemoryStream. |
| 332 for (unsigned i = 0; i < asset->getLength(); ++i) { |
| 333 expectedPtr[i] = valueSource.nextU() & 0xFF; |
| 334 } |
| 335 stream_peek_test(rep, asset, expected); |
| 336 } |
OLD | NEW |