| OLD | NEW |
| 1 // Copyright 2014 PDFium Authors. All rights reserved. | 1 // Copyright 2014 PDFium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <stdint.h> | 5 #include <stdint.h> |
| 6 | 6 |
| 7 #include <limits> | 7 #include <limits> |
| 8 | 8 |
| 9 #include "core/fxcodec/codec/codec_int.h" | 9 #include "core/fxcodec/codec/codec_int.h" |
| 10 #include "testing/fx_string_testhelpers.h" | 10 #include "testing/fx_string_testhelpers.h" |
| (...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 289 | 289 |
| 290 // Note: Some care needs to be taken here because the skip/seek functions | 290 // Note: Some care needs to be taken here because the skip/seek functions |
| 291 // take OPJ_OFF_T's as arguments, which are typically a signed type. | 291 // take OPJ_OFF_T's as arguments, which are typically a signed type. |
| 292 TEST(fxcodec, DecodeDataSkip) { | 292 TEST(fxcodec, DecodeDataSkip) { |
| 293 unsigned char buffer[16]; | 293 unsigned char buffer[16]; |
| 294 { | 294 { |
| 295 DecodeData dd(stream_data, sizeof(stream_data)); | 295 DecodeData dd(stream_data, sizeof(stream_data)); |
| 296 | 296 |
| 297 // Skiping within buffer is allowed. | 297 // Skiping within buffer is allowed. |
| 298 memset(buffer, 0xbd, sizeof(buffer)); | 298 memset(buffer, 0xbd, sizeof(buffer)); |
| 299 EXPECT_EQ(1, opj_skip_from_memory(1, &dd)); | 299 EXPECT_EQ(1u, opj_skip_from_memory(1, &dd)); |
| 300 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 300 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 301 EXPECT_EQ(0x01, buffer[0]); | 301 EXPECT_EQ(0x01, buffer[0]); |
| 302 EXPECT_EQ(0xbd, buffer[1]); | 302 EXPECT_EQ(0xbd, buffer[1]); |
| 303 | 303 |
| 304 // Skiping 0 bytes changes nothing. | 304 // Skiping 0 bytes changes nothing. |
| 305 memset(buffer, 0xbd, sizeof(buffer)); | 305 memset(buffer, 0xbd, sizeof(buffer)); |
| 306 EXPECT_EQ(0, opj_skip_from_memory(0, &dd)); | 306 EXPECT_EQ(0, opj_skip_from_memory(0, &dd)); |
| 307 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 307 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 308 EXPECT_EQ(0x02, buffer[0]); | 308 EXPECT_EQ(0x02, buffer[0]); |
| 309 EXPECT_EQ(0xbd, buffer[1]); | 309 EXPECT_EQ(0xbd, buffer[1]); |
| 310 | 310 |
| 311 // Skiping to EOS-1 is possible. | 311 // Skiping to EOS-1 is possible. |
| 312 memset(buffer, 0xbd, sizeof(buffer)); | 312 memset(buffer, 0xbd, sizeof(buffer)); |
| 313 EXPECT_EQ(4, opj_skip_from_memory(4, &dd)); | 313 EXPECT_EQ(4u, opj_skip_from_memory(4, &dd)); |
| 314 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 314 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 315 EXPECT_EQ(0x87, buffer[0]); | 315 EXPECT_EQ(0x87, buffer[0]); |
| 316 EXPECT_EQ(0xbd, buffer[1]); | 316 EXPECT_EQ(0xbd, buffer[1]); |
| 317 | 317 |
| 318 // Next read fails. | 318 // Next read fails. |
| 319 memset(buffer, 0xbd, sizeof(buffer)); | 319 memset(buffer, 0xbd, sizeof(buffer)); |
| 320 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 320 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 321 EXPECT_EQ(0xbd, buffer[0]); | 321 EXPECT_EQ(0xbd, buffer[0]); |
| 322 } | 322 } |
| 323 { | 323 { |
| 324 DecodeData dd(stream_data, sizeof(stream_data)); | 324 DecodeData dd(stream_data, sizeof(stream_data)); |
| 325 | 325 |
| 326 // Skiping directly to EOS is allowed. | 326 // Skiping directly to EOS is allowed. |
| 327 memset(buffer, 0xbd, sizeof(buffer)); | 327 memset(buffer, 0xbd, sizeof(buffer)); |
| 328 EXPECT_EQ(8, opj_skip_from_memory(8, &dd)); | 328 EXPECT_EQ(8u, opj_skip_from_memory(8, &dd)); |
| 329 | 329 |
| 330 // Next read fails. | 330 // Next read fails. |
| 331 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 331 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 332 EXPECT_EQ(0xbd, buffer[0]); | 332 EXPECT_EQ(0xbd, buffer[0]); |
| 333 } | 333 } |
| 334 { | 334 { |
| 335 DecodeData dd(stream_data, sizeof(stream_data)); | 335 DecodeData dd(stream_data, sizeof(stream_data)); |
| 336 | 336 |
| 337 // Skipping beyond end of stream is allowed and returns full distance. | 337 // Skipping beyond end of stream is allowed and returns full distance. |
| 338 memset(buffer, 0xbd, sizeof(buffer)); | 338 memset(buffer, 0xbd, sizeof(buffer)); |
| 339 EXPECT_EQ(9, opj_skip_from_memory(9, &dd)); | 339 EXPECT_EQ(9u, opj_skip_from_memory(9, &dd)); |
| 340 | 340 |
| 341 // Next read fails. | 341 // Next read fails. |
| 342 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 342 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 343 EXPECT_EQ(0xbd, buffer[0]); | 343 EXPECT_EQ(0xbd, buffer[0]); |
| 344 } | 344 } |
| 345 { | 345 { |
| 346 DecodeData dd(stream_data, sizeof(stream_data)); | 346 DecodeData dd(stream_data, sizeof(stream_data)); |
| 347 | 347 |
| 348 // Skipping way beyond EOS is allowd, doesn't wrap, and returns | 348 // Skipping way beyond EOS is allowd, doesn't wrap, and returns |
| 349 // full distance. | 349 // full distance. |
| 350 memset(buffer, 0xbd, sizeof(buffer)); | 350 memset(buffer, 0xbd, sizeof(buffer)); |
| 351 EXPECT_EQ(4, opj_skip_from_memory(4, &dd)); | 351 EXPECT_EQ(4u, opj_skip_from_memory(4, &dd)); |
| 352 EXPECT_EQ(std::numeric_limits<OPJ_OFF_T>::max(), | 352 EXPECT_EQ(std::numeric_limits<OPJ_OFF_T>::max(), |
| 353 opj_skip_from_memory(std::numeric_limits<OPJ_OFF_T>::max(), &dd)); | 353 opj_skip_from_memory(std::numeric_limits<OPJ_OFF_T>::max(), &dd)); |
| 354 | 354 |
| 355 // Next read fails. If it succeeds, it may mean we wrapped. | 355 // Next read fails. If it succeeds, it may mean we wrapped. |
| 356 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 356 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 357 EXPECT_EQ(0xbd, buffer[0]); | 357 EXPECT_EQ(0xbd, buffer[0]); |
| 358 } | 358 } |
| 359 { | 359 { |
| 360 DecodeData dd(stream_data, sizeof(stream_data)); | 360 DecodeData dd(stream_data, sizeof(stream_data)); |
| 361 | 361 |
| 362 // Negative skip within buffer not is allowed, position unchanged. | 362 // Negative skip within buffer not is allowed, position unchanged. |
| 363 memset(buffer, 0xbd, sizeof(buffer)); | 363 memset(buffer, 0xbd, sizeof(buffer)); |
| 364 EXPECT_EQ(4, opj_skip_from_memory(4, &dd)); | 364 EXPECT_EQ(4u, opj_skip_from_memory(4, &dd)); |
| 365 EXPECT_EQ(kSkipError, opj_skip_from_memory(-2, &dd)); | 365 EXPECT_EQ(kSkipError, opj_skip_from_memory(-2, &dd)); |
| 366 | 366 |
| 367 // Next read succeeds as if nothing has happenned. | 367 // Next read succeeds as if nothing has happenned. |
| 368 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 368 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 369 EXPECT_EQ(0x84, buffer[0]); | 369 EXPECT_EQ(0x84, buffer[0]); |
| 370 EXPECT_EQ(0xbd, buffer[1]); | 370 EXPECT_EQ(0xbd, buffer[1]); |
| 371 | 371 |
| 372 // Negative skip before buffer is not allowed, position unchanged. | 372 // Negative skip before buffer is not allowed, position unchanged. |
| 373 memset(buffer, 0xbd, sizeof(buffer)); | 373 memset(buffer, 0xbd, sizeof(buffer)); |
| 374 EXPECT_EQ(kSkipError, opj_skip_from_memory(-4, &dd)); | 374 EXPECT_EQ(kSkipError, opj_skip_from_memory(-4, &dd)); |
| 375 | 375 |
| 376 // Next read succeeds as if nothing has happenned. | 376 // Next read succeeds as if nothing has happenned. |
| 377 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 377 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 378 EXPECT_EQ(0x85, buffer[0]); | 378 EXPECT_EQ(0x85, buffer[0]); |
| 379 EXPECT_EQ(0xbd, buffer[1]); | 379 EXPECT_EQ(0xbd, buffer[1]); |
| 380 } | 380 } |
| 381 { | 381 { |
| 382 DecodeData dd(stream_data, sizeof(stream_data)); | 382 DecodeData dd(stream_data, sizeof(stream_data)); |
| 383 | 383 |
| 384 // Negative skip way before buffer is not allowed, doesn't wrap | 384 // Negative skip way before buffer is not allowed, doesn't wrap |
| 385 memset(buffer, 0xbd, sizeof(buffer)); | 385 memset(buffer, 0xbd, sizeof(buffer)); |
| 386 EXPECT_EQ(4, opj_skip_from_memory(4, &dd)); | 386 EXPECT_EQ(4u, opj_skip_from_memory(4, &dd)); |
| 387 EXPECT_EQ(kSkipError, | 387 EXPECT_EQ(kSkipError, |
| 388 opj_skip_from_memory(std::numeric_limits<OPJ_OFF_T>::min(), &dd)); | 388 opj_skip_from_memory(std::numeric_limits<OPJ_OFF_T>::min(), &dd)); |
| 389 | 389 |
| 390 // Next read succeeds. If it fails, it may mean we wrapped. | 390 // Next read succeeds. If it fails, it may mean we wrapped. |
| 391 EXPECT_EQ(1, opj_read_from_memory(buffer, 1, &dd)); | 391 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 392 EXPECT_EQ(0x84, buffer[0]); | 392 EXPECT_EQ(0x84, buffer[0]); |
| 393 EXPECT_EQ(0xbd, buffer[1]); | 393 EXPECT_EQ(0xbd, buffer[1]); |
| 394 } | 394 } |
| 395 { | 395 { |
| 396 DecodeData dd(stream_data, sizeof(stream_data)); | 396 DecodeData dd(stream_data, sizeof(stream_data)); |
| 397 | 397 |
| 398 // Negative skip after EOS isn't alowed, still EOS. | 398 // Negative skip after EOS isn't alowed, still EOS. |
| 399 memset(buffer, 0xbd, sizeof(buffer)); | 399 memset(buffer, 0xbd, sizeof(buffer)); |
| 400 EXPECT_EQ(8, opj_skip_from_memory(8, &dd)); | 400 EXPECT_EQ(8u, opj_skip_from_memory(8, &dd)); |
| 401 EXPECT_EQ(kSkipError, opj_skip_from_memory(-4, &dd)); | 401 EXPECT_EQ(kSkipError, opj_skip_from_memory(-4, &dd)); |
| 402 | 402 |
| 403 // Next read fails. | 403 // Next read fails. |
| 404 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 404 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 405 EXPECT_EQ(0xbd, buffer[0]); | 405 EXPECT_EQ(0xbd, buffer[0]); |
| 406 } | 406 } |
| 407 } | 407 } |
| 408 | 408 |
| 409 TEST(fxcodec, DecodeDataSeek) { | 409 TEST(fxcodec, DecodeDataSeek) { |
| 410 unsigned char buffer[16]; | 410 unsigned char buffer[16]; |
| 411 DecodeData dd(stream_data, sizeof(stream_data)); | 411 DecodeData dd(stream_data, sizeof(stream_data)); |
| 412 | 412 |
| 413 // Seeking within buffer is allowed and read succeeds | 413 // Seeking within buffer is allowed and read succeeds |
| 414 memset(buffer, 0xbd, sizeof(buffer)); | 414 memset(buffer, 0xbd, sizeof(buffer)); |
| 415 EXPECT_TRUE(opj_seek_from_memory(1, &dd)); | 415 EXPECT_TRUE(opj_seek_from_memory(1, &dd)); |
| 416 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); | 416 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 417 EXPECT_EQ(0x01, buffer[0]); | 417 EXPECT_EQ(0x01, buffer[0]); |
| 418 EXPECT_EQ(0xbd, buffer[1]); | 418 EXPECT_EQ(0xbd, buffer[1]); |
| 419 | 419 |
| 420 // Seeking before start returns error leaving position unchanged. | 420 // Seeking before start returns error leaving position unchanged. |
| 421 memset(buffer, 0xbd, sizeof(buffer)); | 421 memset(buffer, 0xbd, sizeof(buffer)); |
| 422 EXPECT_FALSE(opj_seek_from_memory(-1, &dd)); | 422 EXPECT_FALSE(opj_seek_from_memory(-1, &dd)); |
| 423 EXPECT_EQ(1, opj_read_from_memory(buffer, 1, &dd)); | 423 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 424 EXPECT_EQ(0x02, buffer[0]); | 424 EXPECT_EQ(0x02, buffer[0]); |
| 425 EXPECT_EQ(0xbd, buffer[1]); | 425 EXPECT_EQ(0xbd, buffer[1]); |
| 426 | 426 |
| 427 // Seeking way before start returns error leaving position unchanged. | 427 // Seeking way before start returns error leaving position unchanged. |
| 428 memset(buffer, 0xbd, sizeof(buffer)); | 428 memset(buffer, 0xbd, sizeof(buffer)); |
| 429 EXPECT_FALSE( | 429 EXPECT_FALSE( |
| 430 opj_seek_from_memory(std::numeric_limits<OPJ_OFF_T>::min(), &dd)); | 430 opj_seek_from_memory(std::numeric_limits<OPJ_OFF_T>::min(), &dd)); |
| 431 EXPECT_EQ(1, opj_read_from_memory(buffer, 1, &dd)); | 431 EXPECT_EQ(1u, opj_read_from_memory(buffer, 1, &dd)); |
| 432 EXPECT_EQ(0x03, buffer[0]); | 432 EXPECT_EQ(0x03, buffer[0]); |
| 433 EXPECT_EQ(0xbd, buffer[1]); | 433 EXPECT_EQ(0xbd, buffer[1]); |
| 434 | 434 |
| 435 // Seeking exactly to EOS is allowed but read fails. | 435 // Seeking exactly to EOS is allowed but read fails. |
| 436 memset(buffer, 0xbd, sizeof(buffer)); | 436 memset(buffer, 0xbd, sizeof(buffer)); |
| 437 EXPECT_TRUE(opj_seek_from_memory(8, &dd)); | 437 EXPECT_TRUE(opj_seek_from_memory(8, &dd)); |
| 438 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); | 438 EXPECT_EQ(kReadError, opj_read_from_memory(buffer, 1, &dd)); |
| 439 EXPECT_EQ(0xbd, buffer[0]); | 439 EXPECT_EQ(0xbd, buffer[0]); |
| 440 | 440 |
| 441 // Seeking back to zero offset is allowed and read succeeds. | 441 // Seeking back to zero offset is allowed and read succeeds. |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 491 opj_image_t img; | 491 opj_image_t img; |
| 492 memset(&img, 0, sizeof(img)); | 492 memset(&img, 0, sizeof(img)); |
| 493 img.numcomps = 3; | 493 img.numcomps = 3; |
| 494 img.color_space = OPJ_CLRSPC_SYCC; | 494 img.color_space = OPJ_CLRSPC_SYCC; |
| 495 img.comps = FX_Alloc(opj_image_comp_t, 3); | 495 img.comps = FX_Alloc(opj_image_comp_t, 3); |
| 496 const struct { | 496 const struct { |
| 497 OPJ_UINT32 w; | 497 OPJ_UINT32 w; |
| 498 bool expected; | 498 bool expected; |
| 499 } cases[] = {{0, false}, {1, false}, {30, false}, {31, true}, | 499 } cases[] = {{0, false}, {1, false}, {30, false}, {31, true}, |
| 500 {32, true}, {33, false}, {34, false}, {UINT_MAX, false}}; | 500 {32, true}, {33, false}, {34, false}, {UINT_MAX, false}}; |
| 501 for (int i = 0; i < sizeof(cases) / sizeof(cases[0]); ++i) { | 501 for (size_t i = 0; i < sizeof(cases) / sizeof(cases[0]); ++i) { |
| 502 y.w = cases[i].w; | 502 y.w = cases[i].w; |
| 503 y.h = y.w; | 503 y.h = y.w; |
| 504 img.x1 = y.w; | 504 img.x1 = y.w; |
| 505 img.y1 = y.h; | 505 img.y1 = y.h; |
| 506 y.data = FX_Alloc(OPJ_INT32, y.w * y.h); | 506 y.data = FX_Alloc(OPJ_INT32, y.w * y.h); |
| 507 memset(y.data, 1, y.w * y.h * sizeof(OPJ_INT32)); | 507 memset(y.data, 1, y.w * y.h * sizeof(OPJ_INT32)); |
| 508 u.data = FX_Alloc(OPJ_INT32, u.w * u.h); | 508 u.data = FX_Alloc(OPJ_INT32, u.w * u.h); |
| 509 memset(u.data, 0, u.w * u.h * sizeof(OPJ_INT32)); | 509 memset(u.data, 0, u.w * u.h * sizeof(OPJ_INT32)); |
| 510 v.data = FX_Alloc(OPJ_INT32, v.w * v.h); | 510 v.data = FX_Alloc(OPJ_INT32, v.w * v.h); |
| 511 memset(v.data, 0, v.w * v.h * sizeof(OPJ_INT32)); | 511 memset(v.data, 0, v.w * v.h * sizeof(OPJ_INT32)); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 523 EXPECT_NE(img.comps[0].h, img.comps[1].h); | 523 EXPECT_NE(img.comps[0].h, img.comps[1].h); |
| 524 EXPECT_NE(img.comps[0].w, img.comps[2].w); | 524 EXPECT_NE(img.comps[0].w, img.comps[2].w); |
| 525 EXPECT_NE(img.comps[0].h, img.comps[2].h); | 525 EXPECT_NE(img.comps[0].h, img.comps[2].h); |
| 526 } | 526 } |
| 527 FX_Free(img.comps[0].data); | 527 FX_Free(img.comps[0].data); |
| 528 FX_Free(img.comps[1].data); | 528 FX_Free(img.comps[1].data); |
| 529 FX_Free(img.comps[2].data); | 529 FX_Free(img.comps[2].data); |
| 530 } | 530 } |
| 531 FX_Free(img.comps); | 531 FX_Free(img.comps); |
| 532 } | 532 } |
| OLD | NEW |