DataTest.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. /**
  3. *
  4. * @filesource DataTest.php
  5. * @created 08.02.2016
  6. * @author Smiley <smiley@chillerlan.net>
  7. * @copyright 2015 Smiley
  8. * @license MIT
  9. */
  10. namespace chillerlan\QRCodeTest\Data;
  11. use chillerlan\QRCode\BitBuffer;
  12. use chillerlan\QRCode\QRConst;
  13. use chillerlan\QRCode\Data\AlphaNum;
  14. use chillerlan\QRCode\Data\Byte;
  15. use chillerlan\QRCode\Data\Kanji;
  16. use chillerlan\QRCode\Data\Number;
  17. class DataTest extends \PHPUnit_Framework_TestCase{
  18. /**
  19. * @var \chillerlan\QRCode\BitBuffer
  20. */
  21. protected $bitBuffer;
  22. /**
  23. * @var \chillerlan\QRCode\Data\QRDataInterface
  24. */
  25. protected $module;
  26. public function bitProvider(){
  27. return [
  28. [QRConst::MODE_NUMBER, Number::class, '1234567890'],
  29. [QRConst::MODE_ALPHANUM, AlphaNum::class, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890 $%*+-./:'],
  30. [QRConst::MODE_BYTE, Byte::class, '#'],
  31. [QRConst::MODE_KANJI, Kanji::class, '茗荷'],
  32. ];
  33. }
  34. protected function setUp(){
  35. $this->bitBuffer = new BitBuffer;
  36. }
  37. /**
  38. * @dataProvider bitProvider
  39. */
  40. public function testMode($mode, $class, $data){
  41. $module = new $class($data);
  42. $this->assertEquals($mode, $module->mode);
  43. }
  44. /**
  45. * @dataProvider bitProvider
  46. */
  47. public function testWrite($mode, $class, $data){
  48. $module = new $class($data);
  49. $module->write($this->bitBuffer);
  50. // todo...
  51. }
  52. }