# This file is part of the Trezor project. # # Copyright (C) 2012-2023 SatoshiLabs and contributors # # This library is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License version 3 # as published by the Free Software Foundation. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the License along with this library. # If not, see . import pytest from trezorlib.debuglink import TrezorClientDebugLink as Client from trezorlib.solana import sign_tx from trezorlib.tools import parse_path from ...common import parametrize_using_common_fixtures pytestmark = [ pytest.mark.altcoin, pytest.mark.solana, pytest.mark.skip_t1, ] @parametrize_using_common_fixtures( "solana/sign_tx.json", ) def test_solana_sign_tx(client: Client, parameters, result): client.init_device(new_session=True) # make sure the annotated transaction matches the original one assert parameters["serialized_tx"] == "".join( [i for i in parameters["annotated_serialized_tx"] if "#" not in i] ) actual_result = sign_tx( client, address_n=parse_path(parameters["address"]), serialized_tx=bytes.fromhex(parameters["serialized_tx"]), ) assert actual_result.signature == bytes.fromhex(result["expected_signature"])