PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-xtz/dist/test/unit

Просмотр файла: util.js

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const assert_1 = __importDefault(require("assert"));
const should_1 = __importDefault(require("should"));
const resources_1 = require("../resources");
const src_1 = require("../../src");
describe('XTZ util library', function () {
    describe('address', function () {
        it('should validate addresses', function () {
            const validAddresses = [
                'tz1aWXP237BLwNHJcCD4b3DutCevhqq2T1Z9',
                'tz2SHdGxFGhs68wYNC4hEqxbWARxp2J4mVxv',
                'tz3gN8NTLNLJg5KRsUU47NHNVHbdhcFXjjaB',
                'KT1EGbAxguaWQFkV3Egb2Z1r933MWuEYyrJS',
            ];
            for (const address of validAddresses) {
                src_1.XtzLib.Utils.isValidAddress(address).should.be.true();
            }
        });
        it('should fail to validate invalid addresses', function () {
            const invalidAddresses = [
                'tz4aWXP237BLwNHJcCD4b3DutCevhqq2T1Z9',
                'xtz2SHdGxFGhs68wYNC4hEqxbWARxp2J4mVxv',
                'KT2EGbAxguaWQFkV3Egb2Z1r933MWuEYyrJS',
                'abc',
            ];
            for (const address of invalidAddresses) {
                should_1.default.doesNotThrow(() => src_1.XtzLib.Utils.isValidAddress(address));
                src_1.XtzLib.Utils.isValidAddress(address).should.be.false();
            }
        });
    });
    describe('block hash', function () {
        it('should validate block hashes', function () {
            const validHashes = [
                'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku',
                'BL4oxWAkozJ3mJHwVFQqga5dQMBi8kBCPAQyBKgF78z7SQT1AvN',
                'BL29n92KHaarq1r7XjwTFotzCpxq7LtXMc9bF2qD9Qt26ZTYQia',
            ];
            for (const hash of validHashes) {
                src_1.XtzLib.Utils.isValidBlockHash(hash).should.be.true();
            }
        });
        it('should fail to validate invalid block hashes', function () {
            const invalidHashes = [
                'AKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku',
                'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku1111111111',
                'invalid',
            ];
            for (const hash of invalidHashes) {
                src_1.XtzLib.Utils.isValidBlockHash(hash).should.be.false();
            }
        });
    });
    describe('transaction hash', function () {
        it('should validate tx hashes', function () {
            const validHashes = [
                'opUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu',
                'ookyzxsYF7vyTeDzsgs58XJ4PXuvBkK8wWqZJ4EoRS6RWQb4Y9P',
                'ooXQoUX32szALRvgzD2TDzeRPXtPfmfqwoehPaK5khbrBiMAtSw',
            ];
            for (const hash of validHashes) {
                src_1.XtzLib.Utils.isValidTransactionHash(hash).should.be.true();
            }
        });
        it('should fail to validate invalid tx hashes', function () {
            const invalidHashes = [
                'lpUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu',
                'opUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu1111111111',
                'invalid',
            ];
            for (const hash of invalidHashes) {
                src_1.XtzLib.Utils.isValidTransactionHash(hash).should.be.false();
            }
        });
        it('should calculate the transaction hash', async function () {
            const operationId = await src_1.XtzLib.Utils.calculateTransactionId(resources_1.signedSerializedOriginationTransaction);
            operationId.should.equal('opPsNbm7EcqPyryBDDR28BjdthnriktK8TbMvpwc9r4NwmvToYP');
        });
        it('should calculate the originated account address', async function () {
            const accountAddress = await src_1.XtzLib.Utils.calculateOriginatedAddress('opPsNbm7EcqPyryBDDR28BjdthnriktK8TbMvpwc9r4NwmvToYP', 0);
            accountAddress.should.equal('KT1LJvp55fbdNwbisJFign9wA4cPgq9T9oc4');
        });
    });
    describe('sign', function () {
        it('should produce a valid signature', async function () {
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, resources_1.defaultDataToSign);
            signatures.bytes.should.equal('0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b');
            signatures.prefixSig.should.equal('spsig19yWAc5nBpGmNCWdvEWHnpJXEiTqZjhNgWwWa1Lz6kVgakb7qCPj9z6G6LLEFWmsmNcPCZYseERVDUXh99N7wqDppcDKQM');
            signatures.sbytes.should.equal('0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b1fd49502ba8dc7adb01716093abe715d1eef87f47a88d8ec104fcc1d6baca7ba06cc2ced6c5baa880d6045b44be926d63bc3aeb3b9124f3b32ac6d9c63584fe5');
            signatures.sig.should.equal('sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZy9gwJedKMCrcQPxm9C7i1gesETbhFD6Gm8BpadGgd2cgiGoQbiY');
        });
        it('should produce a valid signature with watermark', async function () {
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, resources_1.defaultDataToSign, new Uint8Array());
            signatures.bytes.should.equal('0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b');
            signatures.prefixSig.should.equal('spsig1DWTuXdgUg2t64PLRfaapsYejCoCVVkqy2Zjv41Zirt7MjoqSfBnP38qoAg3SWicfQNiG25yMqGYge4jrfrwv9H8hRKDyY');
            signatures.sbytes.should.equal('0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b3ad76776913e2c0cfe827b572c417b73a14debcf9e5db726ce9b10aa4bea6aa1173b313ff67eb9bdfdcf9a753178e6ac78ac5f53aef8bcca6d56706f5c3fb01f');
            signatures.sig.should.equal('sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk');
        });
        it('should validate a signature belongs to a public key for a string message', async function () {
            const message = 'helloworld';
            const messageHex = Buffer.from(message).toString('hex');
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, messageHex, new Uint8Array(0));
            const result = await src_1.XtzLib.Utils.verifySignature(messageHex, resources_1.defaultKeyPairFromPub.getKeys().pub, signatures.sig, new Uint8Array(0));
            result.should.be.true();
        });
        it('should validate a signature belongs to a public key for dataToSign', async function () {
            const messageHex = Buffer.from(resources_1.defaultDataToSign).toString('hex');
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, messageHex, new Uint8Array(0));
            const result = await src_1.XtzLib.Utils.verifySignature(messageHex, resources_1.defaultKeyPairFromPub.getKeys().pub, signatures.sig, new Uint8Array(0));
            result.should.be.true();
        });
        it('should fail to validate a signature with the wrong watermark', async function () {
            const messageHex = Buffer.from(resources_1.defaultDataToSign).toString('hex');
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, messageHex);
            const result = await src_1.XtzLib.Utils.verifySignature(messageHex, resources_1.defaultKeyPairFromPub.getKeys().pub, signatures.sig, new Uint8Array(3));
            result.should.be.false();
        });
        it('should fail to validate a signature with the wrong public key', async function () {
            const messageHex = Buffer.from(resources_1.defaultDataToSign).toString('hex');
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, messageHex);
            const result = await src_1.XtzLib.Utils.verifySignature(messageHex, 'sppk7d2ztzbrLdBaTB7yzaWRkPfcWGsrNQNJdkBE9bCTSSzekLNzpvf', signatures.sig);
            result.should.be.false();
        });
        it('should fail to validate a signature with the wrong message', async function () {
            const messageHex = Buffer.from(resources_1.defaultDataToSign).toString('hex');
            const signatures = await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPrv, messageHex);
            const secondMessageHex = Buffer.from('helloWorld').toString('hex');
            const result = await src_1.XtzLib.Utils.verifySignature(secondMessageHex, resources_1.defaultKeyPairFromPub.getKeys().pub, signatures.sig);
            result.should.be.false();
        });
        it('should fail if the key pair does not have the private key', async function () {
            await src_1.XtzLib.Utils.sign(resources_1.defaultKeyPairFromPub, resources_1.defaultDataToSign).should.be.rejectedWith(new RegExp('Missing private key'));
        });
    });
    describe('generateDataToSign', function () {
        it('should build transfer data to sign', function () {
            const dataToSign = src_1.XtzLib.Utils.generateDataToSign('KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL', 'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS', '100', '0');
            JSON.stringify(dataToSign).should.equal(JSON.stringify(resources_1.validDataToSign));
        });
        it('should fail if the contract address has the wrong format', function () {
            assert_1.default.throws(() => src_1.XtzLib.Utils.generateDataToSign('tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS', 'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS', '0', '0'), new RegExp('Invalid contract address'));
        });
        it('should fail if the destination address has the wrong format', function () {
            assert_1.default.throws(() => src_1.XtzLib.Utils.generateDataToSign('KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL', 'abc', '0', '0'), new RegExp('Invalid destination address'));
        });
    });
    describe('signature', function () {
        it('should validate signature', function () {
            const validSignatures = [
                'sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk',
                'spsig1DWTuXdgUg2t64PLRfaapsYejCoCVVkqy2Zjv41Zirt7MjoqSfBnP38qoAg3SWicfQNiG25yMqGYge4jrfrwv9H8hRKDyY',
                'sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZy9gwJedKMCrcQPxm9C7i1gesETbhFD6Gm8BpadGgd2cgiGoQbiY',
                'spsig19yWAc5nBpGmNCWdvEWHnpJXEiTqZjhNgWwWa1Lz6kVgakb7qCPj9z6G6LLEFWmsmNcPCZYseERVDUXh99N7wqDppcDKQM',
            ];
            for (const hash of validSignatures) {
                src_1.XtzLib.Utils.isValidSignature(hash).should.be.true();
            }
        });
        it('should fail to validate invalid signature', function () {
            const invalidHashes = [
                'sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZ',
                'sig',
                'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku1111111111',
                'invalid',
            ];
            for (const hash of invalidHashes) {
                src_1.XtzLib.Utils.isValidSignature(hash).should.be.false();
            }
        });
    });
    describe('decodeKey', function () {
        it('should decode the key', function () {
            const validKeys = [['spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL', src_1.XtzLib.Utils.hashTypes.spsk]];
            for (const data of validKeys) {
                src_1.XtzLib.Utils.decodeKey(data[0], data[1])
                    .toString('hex')
                    .should.equal('9cc0aaa9ef687e70f7780e60de08d7a443488a9cf8e1ebe9689118763376c07c');
            }
        });
        it('should fail to decode an invalid key', function () {
            const invalidKeys = [
                [
                    'sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk',
                    src_1.XtzLib.Utils.hashTypes.tz1,
                ],
                ['sppk', src_1.XtzLib.Utils.hashTypes.sppk],
            ];
            for (const data of invalidKeys) {
                assert_1.default.throws(() => src_1.XtzLib.Utils.decodeKey(data[0], data[1]), new RegExp('Unsupported private key'));
            }
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../test/unit/util.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\n\nimport {\n  defaultDataToSign,\n  defaultKeyPairFromPrv,\n  defaultKeyPairFromPub,\n  signedSerializedOriginationTransaction,\n  validDataToSign,\n} from '../resources';\nimport { XtzLib } from '../../src';\nimport { HashType } from '../../src/lib/iface';\n\ndescribe('XTZ util library', function () {\n  describe('address', function () {\n    it('should validate addresses', function () {\n      const validAddresses = [\n        'tz1aWXP237BLwNHJcCD4b3DutCevhqq2T1Z9',\n        'tz2SHdGxFGhs68wYNC4hEqxbWARxp2J4mVxv',\n        'tz3gN8NTLNLJg5KRsUU47NHNVHbdhcFXjjaB',\n        'KT1EGbAxguaWQFkV3Egb2Z1r933MWuEYyrJS',\n      ];\n\n      for (const address of validAddresses) {\n        XtzLib.Utils.isValidAddress(address).should.be.true();\n      }\n    });\n\n    it('should fail to validate invalid addresses', function () {\n      const invalidAddresses = [\n        'tz4aWXP237BLwNHJcCD4b3DutCevhqq2T1Z9',\n        'xtz2SHdGxFGhs68wYNC4hEqxbWARxp2J4mVxv',\n        'KT2EGbAxguaWQFkV3Egb2Z1r933MWuEYyrJS',\n        'abc',\n      ];\n\n      for (const address of invalidAddresses) {\n        should.doesNotThrow(() => XtzLib.Utils.isValidAddress(address));\n        XtzLib.Utils.isValidAddress(address).should.be.false();\n      }\n    });\n  });\n\n  describe('block hash', function () {\n    it('should validate block hashes', function () {\n      const validHashes = [\n        'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku',\n        'BL4oxWAkozJ3mJHwVFQqga5dQMBi8kBCPAQyBKgF78z7SQT1AvN',\n        'BL29n92KHaarq1r7XjwTFotzCpxq7LtXMc9bF2qD9Qt26ZTYQia',\n      ];\n\n      for (const hash of validHashes) {\n        XtzLib.Utils.isValidBlockHash(hash).should.be.true();\n      }\n    });\n\n    it('should fail to validate invalid block hashes', function () {\n      const invalidHashes = [\n        'AKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku',\n        'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku1111111111',\n        'invalid',\n      ];\n\n      for (const hash of invalidHashes) {\n        XtzLib.Utils.isValidBlockHash(hash).should.be.false();\n      }\n    });\n  });\n\n  describe('transaction hash', function () {\n    it('should validate tx hashes', function () {\n      const validHashes = [\n        'opUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu',\n        'ookyzxsYF7vyTeDzsgs58XJ4PXuvBkK8wWqZJ4EoRS6RWQb4Y9P',\n        'ooXQoUX32szALRvgzD2TDzeRPXtPfmfqwoehPaK5khbrBiMAtSw',\n      ];\n\n      for (const hash of validHashes) {\n        XtzLib.Utils.isValidTransactionHash(hash).should.be.true();\n      }\n    });\n\n    it('should fail to validate invalid tx hashes', function () {\n      const invalidHashes = [\n        'lpUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu',\n        'opUmZNMueryYFxTbzzocS7K4dzs3NmgKqhhr9TkcftszDDnoRVu1111111111',\n        'invalid',\n      ];\n\n      for (const hash of invalidHashes) {\n        XtzLib.Utils.isValidTransactionHash(hash).should.be.false();\n      }\n    });\n\n    it('should calculate the transaction hash', async function () {\n      const operationId = await XtzLib.Utils.calculateTransactionId(signedSerializedOriginationTransaction);\n      operationId.should.equal('opPsNbm7EcqPyryBDDR28BjdthnriktK8TbMvpwc9r4NwmvToYP');\n    });\n\n    it('should calculate the originated account address', async function () {\n      const accountAddress = await XtzLib.Utils.calculateOriginatedAddress(\n        'opPsNbm7EcqPyryBDDR28BjdthnriktK8TbMvpwc9r4NwmvToYP',\n        0\n      );\n      accountAddress.should.equal('KT1LJvp55fbdNwbisJFign9wA4cPgq9T9oc4');\n    });\n  });\n\n  describe('sign', function () {\n    it('should produce a valid signature', async function () {\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, defaultDataToSign);\n      signatures.bytes.should.equal(\n        '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b'\n      );\n      signatures.prefixSig.should.equal(\n        'spsig19yWAc5nBpGmNCWdvEWHnpJXEiTqZjhNgWwWa1Lz6kVgakb7qCPj9z6G6LLEFWmsmNcPCZYseERVDUXh99N7wqDppcDKQM'\n      );\n      signatures.sbytes.should.equal(\n        '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b1fd49502ba8dc7adb01716093abe715d1eef87f47a88d8ec104fcc1d6baca7ba06cc2ced6c5baa880d6045b44be926d63bc3aeb3b9124f3b32ac6d9c63584fe5'\n      );\n      signatures.sig.should.equal(\n        'sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZy9gwJedKMCrcQPxm9C7i1gesETbhFD6Gm8BpadGgd2cgiGoQbiY'\n      );\n    });\n\n    it('should produce a valid signature with watermark', async function () {\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, defaultDataToSign, new Uint8Array());\n      signatures.bytes.should.equal(\n        '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b'\n      );\n      signatures.prefixSig.should.equal(\n        'spsig1DWTuXdgUg2t64PLRfaapsYejCoCVVkqy2Zjv41Zirt7MjoqSfBnP38qoAg3SWicfQNiG25yMqGYge4jrfrwv9H8hRKDyY'\n      );\n      signatures.sbytes.should.equal(\n        '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b3ad76776913e2c0cfe827b572c417b73a14debcf9e5db726ce9b10aa4bea6aa1173b313ff67eb9bdfdcf9a753178e6ac78ac5f53aef8bcca6d56706f5c3fb01f'\n      );\n      signatures.sig.should.equal(\n        'sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk'\n      );\n    });\n\n    it('should validate a signature belongs to a public key for a string message', async function () {\n      const message = 'helloworld';\n      const messageHex = Buffer.from(message).toString('hex');\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, messageHex, new Uint8Array(0));\n      const result = await XtzLib.Utils.verifySignature(\n        messageHex,\n        defaultKeyPairFromPub.getKeys().pub,\n        signatures.sig,\n        new Uint8Array(0)\n      );\n      result.should.be.true();\n    });\n\n    it('should validate a signature belongs to a public key for dataToSign', async function () {\n      const messageHex = Buffer.from(defaultDataToSign).toString('hex');\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, messageHex, new Uint8Array(0));\n      const result = await XtzLib.Utils.verifySignature(\n        messageHex,\n        defaultKeyPairFromPub.getKeys().pub,\n        signatures.sig,\n        new Uint8Array(0)\n      );\n      result.should.be.true();\n    });\n\n    it('should fail to validate a signature with the wrong watermark', async function () {\n      const messageHex = Buffer.from(defaultDataToSign).toString('hex');\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, messageHex);\n      const result = await XtzLib.Utils.verifySignature(\n        messageHex,\n        defaultKeyPairFromPub.getKeys().pub,\n        signatures.sig,\n        new Uint8Array(3)\n      );\n      result.should.be.false();\n    });\n\n    it('should fail to validate a signature with the wrong public key', async function () {\n      const messageHex = Buffer.from(defaultDataToSign).toString('hex');\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, messageHex);\n      const result = await XtzLib.Utils.verifySignature(\n        messageHex,\n        'sppk7d2ztzbrLdBaTB7yzaWRkPfcWGsrNQNJdkBE9bCTSSzekLNzpvf',\n        signatures.sig\n      );\n      result.should.be.false();\n    });\n\n    it('should fail to validate a signature with the wrong message', async function () {\n      const messageHex = Buffer.from(defaultDataToSign).toString('hex');\n      const signatures = await XtzLib.Utils.sign(defaultKeyPairFromPrv, messageHex);\n      const secondMessageHex = Buffer.from('helloWorld').toString('hex');\n      const result = await XtzLib.Utils.verifySignature(\n        secondMessageHex,\n        defaultKeyPairFromPub.getKeys().pub,\n        signatures.sig\n      );\n      result.should.be.false();\n    });\n\n    it('should fail if the key pair does not have the private key', async function () {\n      await XtzLib.Utils.sign(defaultKeyPairFromPub, defaultDataToSign).should.be.rejectedWith(\n        new RegExp('Missing private key')\n      );\n    });\n  });\n\n  describe('generateDataToSign', function () {\n    it('should build transfer data to sign', function () {\n      const dataToSign = XtzLib.Utils.generateDataToSign(\n        'KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL',\n        'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS',\n        '100',\n        '0'\n      );\n      JSON.stringify(dataToSign).should.equal(JSON.stringify(validDataToSign));\n    });\n\n    it('should fail if the contract address has the wrong format', function () {\n      assert.throws(\n        () =>\n          XtzLib.Utils.generateDataToSign(\n            'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS',\n            'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS',\n            '0',\n            '0'\n          ),\n        new RegExp('Invalid contract address')\n      );\n    });\n\n    it('should fail if the destination address has the wrong format', function () {\n      assert.throws(\n        () => XtzLib.Utils.generateDataToSign('KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL', 'abc', '0', '0'),\n        new RegExp('Invalid destination address')\n      );\n    });\n  });\n\n  describe('signature', function () {\n    it('should validate signature', function () {\n      const validSignatures = [\n        'sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk',\n        'spsig1DWTuXdgUg2t64PLRfaapsYejCoCVVkqy2Zjv41Zirt7MjoqSfBnP38qoAg3SWicfQNiG25yMqGYge4jrfrwv9H8hRKDyY',\n        'sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZy9gwJedKMCrcQPxm9C7i1gesETbhFD6Gm8BpadGgd2cgiGoQbiY',\n        'spsig19yWAc5nBpGmNCWdvEWHnpJXEiTqZjhNgWwWa1Lz6kVgakb7qCPj9z6G6LLEFWmsmNcPCZYseERVDUXh99N7wqDppcDKQM',\n      ];\n\n      for (const hash of validSignatures) {\n        XtzLib.Utils.isValidSignature(hash).should.be.true();\n      }\n    });\n\n    it('should fail to validate invalid signature', function () {\n      const invalidHashes = [\n        'sigS9pqYUXiUJcz2Wsx5x98ud9KtgGVg4gCwpBoDBgHrZ',\n        'sig',\n        'BKoifs5gGffAzuRBcg3ygxbLdrCXyDDS1ALvMG8SFYWahzoYMku1111111111',\n        'invalid',\n      ];\n\n      for (const hash of invalidHashes) {\n        XtzLib.Utils.isValidSignature(hash).should.be.false();\n      }\n    });\n  });\n\n  describe('decodeKey', function () {\n    it('should decode the key', function () {\n      const validKeys = [['spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL', XtzLib.Utils.hashTypes.spsk]];\n\n      for (const data of validKeys) {\n        XtzLib.Utils.decodeKey(data[0] as string, data[1] as HashType)\n          .toString('hex')\n          .should.equal('9cc0aaa9ef687e70f7780e60de08d7a443488a9cf8e1ebe9689118763376c07c');\n      }\n    });\n\n    it('should fail to decode an invalid key', function () {\n      const invalidKeys = [\n        [\n          'sigVgnaU2S1L4jhtPaTX2SAxsGpP1dRS89VTSR9FrFuxxPvgA2G67QRuez6o6xP7ekagdZX4ELvh7pbMMdLoBSzvk2AVyQpk',\n          XtzLib.Utils.hashTypes.tz1,\n        ],\n        ['sppk', XtzLib.Utils.hashTypes.sppk],\n      ];\n\n      for (const data of invalidKeys) {\n        assert.throws(\n          () => XtzLib.Utils.decodeKey(data[0] as string, data[1] as HashType),\n          new RegExp('Unsupported private key')\n        );\n      }\n    });\n  });\n});\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!