QRImageTest.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. /**
  3. * Class QRImageTest
  4. *
  5. * @filesource QRImageTest.php
  6. * @created 24.12.2017
  7. * @package chillerlan\QRCodeTest\Output
  8. * @author Smiley <smiley@chillerlan.net>
  9. * @copyright 2017 Smiley
  10. * @license MIT
  11. */
  12. namespace chillerlan\QRCodeTest\Output;
  13. use chillerlan\QRCode\{QRCode, Output\QRImage};
  14. class QRImageTest extends QROutputTestAbstract{
  15. protected $FQCN = QRImage::class;
  16. public function types(){
  17. return [
  18. 'png' => [QRCode::OUTPUT_IMAGE_PNG],
  19. 'gif' => [QRCode::OUTPUT_IMAGE_GIF],
  20. 'jpg' => [QRCode::OUTPUT_IMAGE_JPG],
  21. ];
  22. }
  23. /**
  24. * @dataProvider types
  25. * @param $type
  26. */
  27. public function testImageOutput($type){
  28. $this->options->outputType = $type;
  29. $this->options->imageBase64 = false;
  30. $this->setOutputInterface();
  31. $this->outputInterface->dump($this::cachefile.$type);
  32. $img = $this->outputInterface->dump();
  33. if($type === QRCode::OUTPUT_IMAGE_JPG){ // jpeg encoding may cause different results
  34. $this->markAsRisky();
  35. }
  36. $this->assertSame($img, file_get_contents($this::cachefile.$type));
  37. }
  38. public function testSetModuleValues(){
  39. $this->options->moduleValues = [
  40. // data
  41. 1024 => [0, 0, 0],
  42. 4 => [255, 255, 255],
  43. ];
  44. $this->setOutputInterface()->dump();
  45. $this->assertTrue(true); // tricking the code coverage
  46. }
  47. public function testOutputGetResource():void{
  48. $this->options->returnResource = true;
  49. $this->setOutputInterface();
  50. $this::assertIsResource($this->outputInterface->dump());
  51. }
  52. }