ture(escpos) Add buzzer function
- Add `buzzer(time, duration)` function to control the buzzer on supported printers. - Add unit tests for buzzer function.
This commit is contained in:
parent
f62fad2b7b
commit
c10242c09d
1
AUTHORS
1
AUTHORS
@ -3,6 +3,7 @@ akeonly
|
||||
Alejandro Hernández
|
||||
Alex Debiasio
|
||||
Alexander Bougakov
|
||||
Alfredo Orozco
|
||||
Asuki Kono
|
||||
B. Howell
|
||||
belono
|
||||
|
@ -63,6 +63,9 @@ PAPER_PART_CUT = _CUT_PAPER(b"\x01") #: Partial cut paper
|
||||
# Beep (please note that the actual beep sequence may differ between devices)
|
||||
BEEP = b"\x07"
|
||||
|
||||
# Internal buzzer (only supported printers)
|
||||
BUZZER = ESC + b"\x42"
|
||||
|
||||
# Panel buttons (e.g. the FEED button)
|
||||
_PANEL_BUTTON = lambda n: ESC + b"c5" + six.int2byte(n)
|
||||
PANEL_BUTTON_ON = _PANEL_BUTTON(0) # enable all panel buttons
|
||||
|
@ -58,6 +58,7 @@ from .constants import (
|
||||
CD_KICK_2,
|
||||
PAPER_FULL_CUT,
|
||||
PAPER_PART_CUT,
|
||||
BUZZER,
|
||||
)
|
||||
from .constants import HW_RESET, HW_SELECT, HW_INIT
|
||||
from .constants import (
|
||||
@ -1243,6 +1244,24 @@ class Escpos(object):
|
||||
"""
|
||||
self._raw(SLIP_SELECT)
|
||||
|
||||
def buzzer(self, times=2, duration=4):
|
||||
"""Activate the internal printer buzzer (only supported printers).
|
||||
|
||||
The 'times' paramreffers to the 'n' escpos command parameter, means how many
|
||||
times the buzzer will be 'beeped'.
|
||||
|
||||
:param times: Integer between 1 and 9, indicates the buzzer beeps.
|
||||
:param duration: Integer between 1 and 9, indicates the beep duration.
|
||||
:returns: None
|
||||
"""
|
||||
|
||||
if not 1 <= times <= 9:
|
||||
raise ValueError("times must be between 1 and 9")
|
||||
if not 1 <= duration <= 9:
|
||||
raise ValueError("duration must be between 1 and 9")
|
||||
|
||||
self._raw(BUZZER + six.int2byte(times) + six.int2byte(duration))
|
||||
|
||||
|
||||
class EscposIO(object):
|
||||
"""ESC/POS Printer IO object
|
||||
|
46
test/test_function_buzzer.py
Normal file
46
test/test_function_buzzer.py
Normal file
@ -0,0 +1,46 @@
|
||||
import six
|
||||
import pytest
|
||||
|
||||
from escpos import printer
|
||||
from escpos.constants import BUZZER
|
||||
|
||||
|
||||
def test_buzzer_function_with_default_params():
|
||||
instance = printer.Dummy()
|
||||
instance.buzzer()
|
||||
expected = BUZZER + six.int2byte(2) + six.int2byte(4)
|
||||
assert instance.output == expected
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"times, duration",
|
||||
[
|
||||
[1, 1], [2, 2], [3, 3], [4, 4], [5, 5], [6, 6], [7, 7], [8, 8], [9, 9],
|
||||
]
|
||||
)
|
||||
def test_buzzer_function(times, duration):
|
||||
instance = printer.Dummy()
|
||||
instance.buzzer(times, duration)
|
||||
expected = BUZZER + six.int2byte(times) + six.int2byte(duration)
|
||||
assert instance.output == expected
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"times, duration, expected_message",
|
||||
[
|
||||
[0, 0, "times must be between 1 and 9"],
|
||||
[-1, 0, "times must be between 1 and 9"],
|
||||
[10, 0, "times must be between 1 and 9"],
|
||||
[11, 0, "times must be between 1 and 9"],
|
||||
[3, 0, "duration must be between 1 and 9"],
|
||||
[3, -1, "duration must be between 1 and 9"],
|
||||
[3, 10, "duration must be between 1 and 9"],
|
||||
[3, 11, "duration must be between 1 and 9"],
|
||||
]
|
||||
)
|
||||
def test_buzzer_fuction_with_outrange_values(times, duration, expected_message):
|
||||
instance = printer.Dummy()
|
||||
with pytest.raises(ValueError) as e:
|
||||
instance.buzzer(times, duration)
|
||||
|
||||
assert str(e.value) == expected_message
|
Loading…
x
Reference in New Issue
Block a user