From e5184712b65c1f736d51a616939d9efb3dc6b33a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Palmer?= Date: Tue, 5 Nov 2024 11:18:53 +0100 Subject: [PATCH] [test] gathering batched operations tests --- Makefile | 4 +- tests/integration/nano/nanos/__init__.py | 0 .../test_nanos_regression_batched_ops.py | 66 -------- tests/integration/nano/nanox/__init__.py | 0 .../test_nanox_regression_batched_ops.py | 66 -------- .../test_sign_batched_operations.py | 158 ++++++++++++++++++ .../nano/test_sign_complex_operation.py | 70 -------- 7 files changed, 159 insertions(+), 205 deletions(-) delete mode 100644 tests/integration/nano/nanos/__init__.py delete mode 100755 tests/integration/nano/nanos/test_nanos_regression_batched_ops.py delete mode 100644 tests/integration/nano/nanox/__init__.py delete mode 100755 tests/integration/nano/nanox/test_nanox_regression_batched_ops.py create mode 100644 tests/integration/nano/test_sign/operations/test_sign_batched_operations.py delete mode 100644 tests/integration/nano/test_sign_complex_operation.py diff --git a/Makefile b/Makefile index 1e776f0b1..6b5a810e2 100644 --- a/Makefile +++ b/Makefile @@ -111,9 +111,7 @@ integration_tests_basic_flex: app_flex.tgz \ integration_tests_basic_%: app_%.tgz \ app_%_dbg.tgz \ - tests/integration/* \ - tests/integration/nano/* \ - tests/integration/nano/%/* + $(shell find tests/integration/nano -type f) docker run --rm -i -v "$(realpath .):/app" \ --entrypoint=/bin/sh ledger-app-tezos-integration-tests -c " \ TMP_DIR=\$$(mktemp -d /tmp/foo-XXXXXX); \ diff --git a/tests/integration/nano/nanos/__init__.py b/tests/integration/nano/nanos/__init__.py deleted file mode 100644 index e69de29bb..000000000 diff --git a/tests/integration/nano/nanos/test_nanos_regression_batched_ops.py b/tests/integration/nano/nanos/test_nanos_regression_batched_ops.py deleted file mode 100755 index 3143e874a..000000000 --- a/tests/integration/nano/nanos/test_nanos_regression_batched_ops.py +++ /dev/null @@ -1,66 +0,0 @@ -#!/usr/bin/env python3 -# Copyright 2023 Functori - -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at - -# http://www.apache.org/licenses/LICENSE-2.0 - -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -"""Check signing batch operation""" - -from pathlib import Path - -from conftest import requires_device - -from utils.app import TezosAppScreen, DEFAULT_ACCOUNT -from utils.message import OperationGroup, Transaction - -@requires_device("nanos") -def test_nanos_regression_batched_ops(app: TezosAppScreen): - """Check signing batch operation""" - test_name = Path(__file__).stem - - app.setup_expert_mode() - - message = OperationGroup([ - Transaction( - source = 'tz1McCh72NRhYmJBcWr3zDrLJAxnfR9swcFh', - fee = 390000, - counter = 9, - gas_limit = 0, - storage_limit = 6, - destination = 'tz1cfdVKpBb9VRBdny8BQ5RSK82UudAp2miM', - amount = 20000, - entrypoint = 'jean_bob', - parameter = [{'prim':'Pair','args':[[],{'prim':'Right','args':[{'int':-76723569314251090535296646}]}]},{'prim':'Pair','args':[[{'prim':'Elt','args':[{'prim':'Unit','args':[]},{'prim':'Pair','args':[[{'prim':'Left','args':[{'prim':'Unit','args':[]}]}],{'prim':'Pair','args':[{'prim':'Left','args':[{'bytes':"03F01167865DC63DFEE0E31251329CEAB660D94606"}]},{'prim':'Pair','args':[{'bytes':"0107B21FCA96C5763F67B286752C7AAEFC5931D15A"},{'prim':'Unit','args':[]}]}]}]}]}],{'prim':'Right','args':[{'int':3120123370638446806591421154959427514880865200209654970345}]},]},{'prim':'Pair','args':[[],{'prim':'Left','args':[{'prim':'Some','args':[{'prim':'Unit','args':[]}]}]}]}] - ), - Transaction( - source = 'tz2W3Tvcm64GjcV2bipUynnEsctLFz5Z6yRa', - fee = 650000, - counter = 6, - gas_limit = 50, - storage_limit = 2, - destination = 'KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti', - amount = 60000 - ) - ]) - - data = app.sign(DEFAULT_ACCOUNT, - message, - with_hash=True, - path=test_name) - - app.checker.check_signature( - account=DEFAULT_ACCOUNT, - message=message, - with_hash=True, - data=data) - - app.quit() diff --git a/tests/integration/nano/nanox/__init__.py b/tests/integration/nano/nanox/__init__.py deleted file mode 100644 index e69de29bb..000000000 diff --git a/tests/integration/nano/nanox/test_nanox_regression_batched_ops.py b/tests/integration/nano/nanox/test_nanox_regression_batched_ops.py deleted file mode 100755 index 4c54f0684..000000000 --- a/tests/integration/nano/nanox/test_nanox_regression_batched_ops.py +++ /dev/null @@ -1,66 +0,0 @@ -#!/usr/bin/env python3 -# Copyright 2023 Functori - -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at - -# http://www.apache.org/licenses/LICENSE-2.0 - -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -"""Check signing batch operation""" - -from pathlib import Path - -from conftest import requires_device - -from utils.app import TezosAppScreen, DEFAULT_ACCOUNT -from utils.message import OperationGroup, Transaction - -@requires_device("nanox") -def test_nanox_regression_batched_ops(app: TezosAppScreen): - """Check signing batch operation""" - test_name = Path(__file__).stem - - app.setup_expert_mode() - - message = OperationGroup([ - Transaction( - source = 'tz1McCh72NRhYmJBcWr3zDrLJAxnfR9swcFh', - fee = 390000, - counter = 9, - gas_limit = 0, - storage_limit = 6, - destination = 'tz1cfdVKpBb9VRBdny8BQ5RSK82UudAp2miM', - amount = 20000, - entrypoint = 'jean_bob', - parameter = [{'prim':'Pair','args':[[],{'prim':'Right','args':[{'int':-76723569314251090535296646}]}]},{'prim':'Pair','args':[[{'prim':'Elt','args':[{'prim':'Unit','args':[]},{'prim':'Pair','args':[[{'prim':'Left','args':[{'prim':'Unit','args':[]}]}],{'prim':'Pair','args':[{'prim':'Left','args':[{'bytes':"03F01167865DC63DFEE0E31251329CEAB660D94606"}]},{'prim':'Pair','args':[{'bytes':"0107B21FCA96C5763F67B286752C7AAEFC5931D15A"},{'prim':'Unit','args':[]}]}]}]}]}],{'prim':'Right','args':[{'int':3120123370638446806591421154959427514880865200209654970345}]},]},{'prim':'Pair','args':[[],{'prim':'Left','args':[{'prim':'Some','args':[{'prim':'Unit','args':[]}]}]}]}] - ), - Transaction( - source = 'tz2W3Tvcm64GjcV2bipUynnEsctLFz5Z6yRa', - fee = 650000, - counter = 6, - gas_limit = 50, - storage_limit = 2, - destination = 'KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti', - amount = 60000 - ) - ]) - - data = app.sign(DEFAULT_ACCOUNT, - message, - with_hash=True, - path=test_name) - - app.checker.check_signature( - account=DEFAULT_ACCOUNT, - message=message, - with_hash=True, - data=data) - - app.quit() diff --git a/tests/integration/nano/test_sign/operations/test_sign_batched_operations.py b/tests/integration/nano/test_sign/operations/test_sign_batched_operations.py new file mode 100644 index 000000000..cc820da51 --- /dev/null +++ b/tests/integration/nano/test_sign/operations/test_sign_batched_operations.py @@ -0,0 +1,158 @@ +#!/usr/bin/env python3 +# Copyright 2024 Functori +# Copyright 2024 Trilitech + +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at + +# http://www.apache.org/licenses/LICENSE-2.0 + +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +"""Gathering of tests related to Batched operations.""" + +from conftest import requires_device + +from utils.app import Screen, TezosAppScreen, DEFAULT_ACCOUNT +from utils.message import ( + OperationGroup, + Origination, + Transaction, + TransferTicket +) + +@requires_device("nanos") +def test_nanos_regression_batched_ops(app: TezosAppScreen): + """Check signing batch operation""" + test_name = "test_nanos_regression_batched_ops" + + app.setup_expert_mode() + + message = OperationGroup([ + Transaction( + source = 'tz1McCh72NRhYmJBcWr3zDrLJAxnfR9swcFh', + fee = 390000, + counter = 9, + gas_limit = 0, + storage_limit = 6, + destination = 'tz1cfdVKpBb9VRBdny8BQ5RSK82UudAp2miM', + amount = 20000, + entrypoint = 'jean_bob', + parameter = [{'prim':'Pair','args':[[],{'prim':'Right','args':[{'int':-76723569314251090535296646}]}]},{'prim':'Pair','args':[[{'prim':'Elt','args':[{'prim':'Unit','args':[]},{'prim':'Pair','args':[[{'prim':'Left','args':[{'prim':'Unit','args':[]}]}],{'prim':'Pair','args':[{'prim':'Left','args':[{'bytes':"03F01167865DC63DFEE0E31251329CEAB660D94606"}]},{'prim':'Pair','args':[{'bytes':"0107B21FCA96C5763F67B286752C7AAEFC5931D15A"},{'prim':'Unit','args':[]}]}]}]}]}],{'prim':'Right','args':[{'int':3120123370638446806591421154959427514880865200209654970345}]},]},{'prim':'Pair','args':[[],{'prim':'Left','args':[{'prim':'Some','args':[{'prim':'Unit','args':[]}]}]}]}] + ), + Transaction( + source = 'tz2W3Tvcm64GjcV2bipUynnEsctLFz5Z6yRa', + fee = 650000, + counter = 6, + gas_limit = 50, + storage_limit = 2, + destination = 'KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti', + amount = 60000 + ) + ]) + + data = app.sign(DEFAULT_ACCOUNT, + message, + with_hash=True, + path=test_name) + + app.checker.check_signature( + account=DEFAULT_ACCOUNT, + message=message, + with_hash=True, + data=data) + + app.quit() + +@requires_device("nanox") +def test_nanox_regression_batched_ops(app: TezosAppScreen): + """Check signing batch operation""" + test_name = "test_nanox_regression_batched_ops" + + app.setup_expert_mode() + + message = OperationGroup([ + Transaction( + source = 'tz1McCh72NRhYmJBcWr3zDrLJAxnfR9swcFh', + fee = 390000, + counter = 9, + gas_limit = 0, + storage_limit = 6, + destination = 'tz1cfdVKpBb9VRBdny8BQ5RSK82UudAp2miM', + amount = 20000, + entrypoint = 'jean_bob', + parameter = [{'prim':'Pair','args':[[],{'prim':'Right','args':[{'int':-76723569314251090535296646}]}]},{'prim':'Pair','args':[[{'prim':'Elt','args':[{'prim':'Unit','args':[]},{'prim':'Pair','args':[[{'prim':'Left','args':[{'prim':'Unit','args':[]}]}],{'prim':'Pair','args':[{'prim':'Left','args':[{'bytes':"03F01167865DC63DFEE0E31251329CEAB660D94606"}]},{'prim':'Pair','args':[{'bytes':"0107B21FCA96C5763F67B286752C7AAEFC5931D15A"},{'prim':'Unit','args':[]}]}]}]}]}],{'prim':'Right','args':[{'int':3120123370638446806591421154959427514880865200209654970345}]},]},{'prim':'Pair','args':[[],{'prim':'Left','args':[{'prim':'Some','args':[{'prim':'Unit','args':[]}]}]}]}] + ), + Transaction( + source = 'tz2W3Tvcm64GjcV2bipUynnEsctLFz5Z6yRa', + fee = 650000, + counter = 6, + gas_limit = 50, + storage_limit = 2, + destination = 'KT1CYT8oACUcCSNTu2qfgB4fj5bD7szYrpti', + amount = 60000 + ) + ]) + + data = app.sign(DEFAULT_ACCOUNT, + message, + with_hash=True, + path=test_name) + + app.checker.check_signature( + account=DEFAULT_ACCOUNT, + message=message, + with_hash=True, + data=data) + + app.quit() + +def test_sign_complex_operation(app: TezosAppScreen): + """Check signing complex operation""" + test_name = "test_sign_complex_operation" + + app.assert_screen(Screen.HOME) + app.setup_expert_mode() + + message = OperationGroup([ + Origination( + source = 'tz1ixvCiPJYyMjsp2nKBVaq54f6AdbV8hCKa', + fee = 500000, + counter = 4, + gas_limit = 3, + storage_limit = 4, + code = {'prim': 'UNPACK', 'args': [{'prim': 'mutez'}]}, + storage = {'prim': 'or', 'args': [{'prim': 'key'}, {'prim': 'chest'}]}, + balance = 1000000 + ), + TransferTicket( + source = 'tz1ixvCiPJYyMjsp2nKBVaq54f6AdbV8hCKa', + fee = 10000, + counter = 5, + gas_limit = 4, + storage_limit = 5, + ticket_contents = {'prim': 'None'}, + ticket_ty = {'prim': 'option', 'args': [{'prim': 'nat'}]}, + ticket_ticketer = 'tz1TmFPVZsGQ8MnrBJtnECJgkFUwLa6EWYDm', + ticket_amount = 7, + destination = 'tz3eydffbLkjdVb8zx42BvxpGV87zaRnqL3r' + ) + ]) + + data = app.sign(DEFAULT_ACCOUNT, + message, + with_hash=True, + path=test_name) + + app.checker.check_signature( + account=DEFAULT_ACCOUNT, + message=message, + with_hash=True, + data=data) + + app.quit() diff --git a/tests/integration/nano/test_sign_complex_operation.py b/tests/integration/nano/test_sign_complex_operation.py deleted file mode 100644 index 0ccf3ddf5..000000000 --- a/tests/integration/nano/test_sign_complex_operation.py +++ /dev/null @@ -1,70 +0,0 @@ -#!/usr/bin/env python3 -# Copyright 2024 Functori - -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at - -# http://www.apache.org/licenses/LICENSE-2.0 - -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -"""Check signing complex operation""" - -from pathlib import Path - -from utils.app import Screen, TezosAppScreen, DEFAULT_ACCOUNT -from utils.message import ( - OperationGroup, - Origination, - TransferTicket -) - -def test_sign_complex_operation(app: TezosAppScreen): - """Check signing complex operation""" - test_name = Path(__file__).stem - - app.assert_screen(Screen.HOME) - app.setup_expert_mode() - - message = OperationGroup([ - Origination( - source = 'tz1ixvCiPJYyMjsp2nKBVaq54f6AdbV8hCKa', - fee = 500000, - counter = 4, - gas_limit = 3, - storage_limit = 4, - code = {'prim': 'UNPACK', 'args': [{'prim': 'mutez'}]}, - storage = {'prim': 'or', 'args': [{'prim': 'key'}, {'prim': 'chest'}]}, - balance = 1000000 - ), - TransferTicket( - source = 'tz1ixvCiPJYyMjsp2nKBVaq54f6AdbV8hCKa', - fee = 10000, - counter = 5, - gas_limit = 4, - storage_limit = 5, - ticket_contents = {'prim': 'None'}, - ticket_ty = {'prim': 'option', 'args': [{'prim': 'nat'}]}, - ticket_ticketer = 'tz1TmFPVZsGQ8MnrBJtnECJgkFUwLa6EWYDm', - ticket_amount = 7, - destination = 'tz3eydffbLkjdVb8zx42BvxpGV87zaRnqL3r' - ) - ]) - - data = app.sign(DEFAULT_ACCOUNT, - message, - with_hash=True, - path=test_name) - - app.checker.check_signature( - account=DEFAULT_ACCOUNT, - message=message, - with_hash=True, - data=data) - - app.quit()