Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: transaction template #808

Open
wants to merge 29 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
cbb5490
feat: POC implementation
r4mmer Nov 11, 2024
9755aa8
feat: initial implementation
r4mmer Nov 11, 2024
a342ab7
feat: add support for create token transaction
r4mmer Dec 16, 2024
edb3894
feat: add balance management for created token reference
r4mmer Dec 17, 2024
250105d
tests: instruction tests
r4mmer Dec 20, 2024
90dab94
feat: complete instruction
r4mmer Dec 23, 2024
13efa80
feat: complete instruction
r4mmer Dec 23, 2024
fec87f6
feat: executor tests
r4mmer Dec 26, 2024
fff192b
tests: executor and interpreter tests
r4mmer Dec 26, 2024
d46c571
tests(integration): custom token integration template tests
r4mmer Dec 26, 2024
6f91f9e
chore: linter changes
r4mmer Dec 27, 2024
3a3b9ea
chore: linter changes
r4mmer Dec 27, 2024
30f1764
tests(integration): change injectFunds options
r4mmer Dec 27, 2024
3b2ae37
tests(integration): create token tx have different serialization
r4mmer Dec 27, 2024
7099194
tests(integration): include change outputs in checks
r4mmer Dec 27, 2024
edd8234
tests(integration): change output orderr
r4mmer Dec 27, 2024
d120896
tests(integration): add change value to send operation
r4mmer Dec 27, 2024
a50620a
chore: remove helper types to use inferred types from zod
r4mmer Dec 27, 2024
ee5edf4
tests(integration): add change and complete tests
r4mmer Dec 27, 2024
ab0b78e
tests(integration): wrong complete instruction type
r4mmer Dec 30, 2024
49ad6d3
fix: change would add invalid tokens on transaction
r4mmer Dec 31, 2024
674aa2d
tests(unit): mock balance properly
r4mmer Dec 31, 2024
c7e968c
feat: expose transaction template and helper method on the wallet
r4mmer Jan 7, 2025
61b9502
chore: linter changes
r4mmer Jan 8, 2025
ba4110d
test(integration): increase coverage on integration tests
r4mmer Jan 8, 2025
1d8cb3f
tests(integration): change position of tests
r4mmer Jan 8, 2025
b2cd834
tests(integration): change tx version
r4mmer Jan 8, 2025
d82aa19
feat: make tx signing optional when building with the facade
r4mmer Jan 9, 2025
33591c3
feat: correctly pass the arguments to build template
r4mmer Jan 9, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: linter changes
  • Loading branch information
r4mmer committed Dec 27, 2024
commit 6f91f9e01d63a06a22e8b7d291a1fd3ba81df800
Original file line number Diff line number Diff line change
Expand Up @@ -10,22 +10,20 @@ import HathorWallet from '../../../../src/new/wallet';
import SendTransaction from '../../../../src/new/sendTransaction';
import transactionUtils from '../../../../src/utils/transaction';
import { TransactionTemplateBuilder } from '../../../../src/template/transaction/builder';
import { WalletTxTemplateInterpreter } from '../../../../lib/template/transaction/interpreter';
import { WalletTxTemplateInterpreter } from '../../../../src/template/transaction/interpreter';

const DEBUG = true;

describe('Template execution', async () => {
/** @type HathorWallet */
let hWallet;
/** @type WalletTxTemplateInterpreter */
let interpreter;
let tokenUid;
describe('Template execution', () => {
let hWallet: HathorWallet;
let interpreter: WalletTxTemplateInterpreter;
let tokenUid: string;

beforeAll(async () => {
hWallet = await generateWalletHelper();
interpreter = WalletTxTemplateInterpreter(hWallet);
hWallet = await generateWalletHelper(null);
interpreter = new WalletTxTemplateInterpreter(hWallet);
const address = await hWallet.getAddressAtIndex(0);
await GenesisWalletHelper.injectFunds(hWallet, address, 10n);
await GenesisWalletHelper.injectFunds(hWallet, address, 10n, null);
});

afterAll(async () => {
Expand All @@ -36,7 +34,7 @@ describe('Template execution', async () => {

it('should be able to create a custom token', async () => {
const template = new TransactionTemplateBuilder()
.addConfigAction({ tokenName: 'Tmpl Test Token 01', tokenSymbol: 'TTT01'})
.addConfigAction({ tokenName: 'Tmpl Test Token 01', tokenSymbol: 'TTT01' })
.addSetVarAction({ name: 'addr', action: 'get_wallet_address' })
.addUtxoSelect({ fill: 1 })
.addTokenOutput({ address: '{addr}', amount: 100, useCreatedToken: true })
Expand All @@ -47,10 +45,13 @@ describe('Template execution', async () => {
const tx = await interpreter.build(template, DEBUG);
await transactionUtils.signTransaction(tx, hWallet.storage, DEFAULT_PIN_CODE);
tx.prepareToSend();
const sendTx = SendTransaction({ storage: hWallet.storage, transaction: tx });
const sendTx = new SendTransaction({ storage: hWallet.storage, transaction: tx });
await sendTx.runFromMining();
if (tx.hash === null) {
throw new Error('Transaction does not have a hash');
}
tokenUid = tx.hash;
await waitForTxReceived(hWallet, tx.hash);
await waitForTxReceived(hWallet, tx.hash, null);

expect(tx.outputs).toHaveLength(12);

Expand Down Expand Up @@ -85,17 +86,17 @@ describe('Template execution', async () => {
.addUtxoSelect({ fill: 3, token: '{token}' })
.addTokenOutput({ address: '{addr}', amount: 3, token: '{token}' })
.addAuthoritySelect({ authority: 'mint', token: '{token}', count: 1 })
.addAuthorityOutput({ address: '{addr}', authority: 'mint', count: 1, token: '{token}'})
.addAuthorityOutput({ address: '{addr}', authority: 'mint', count: 1, token: '{token}' })
.addAuthoritySelect({ authority: 'melt', token: '{token}', count: 2 })
.addAuthorityOutput({ address: '{addr}', authority: 'melt', count: 2, token: '{token}'})
.addAuthorityOutput({ address: '{addr}', authority: 'melt', count: 2, token: '{token}' })
.build();

const tx = await interpreter.build(template, DEBUG);
await transactionUtils.signTransaction(tx, hWallet.storage, DEFAULT_PIN_CODE);
tx.prepareToSend();
const sendTx = SendTransaction({ storage: hWallet.storage, transaction: tx });
const sendTx = new SendTransaction({ storage: hWallet.storage, transaction: tx });
await sendTx.runFromMining();
await waitForTxReceived(hWallet, tx.hash);
await waitForTxReceived(hWallet, tx.hash, null);

expect(tx.outputs).toHaveLength(5);

Expand Down Expand Up @@ -128,9 +129,9 @@ describe('Template execution', async () => {
const tx = await interpreter.build(template, DEBUG);
await transactionUtils.signTransaction(tx, hWallet.storage, DEFAULT_PIN_CODE);
tx.prepareToSend();
const sendTx = SendTransaction({ storage: hWallet.storage, transaction: tx });
const sendTx = new SendTransaction({ storage: hWallet.storage, transaction: tx });
await sendTx.runFromMining();
await waitForTxReceived(hWallet, tx.hash);
await waitForTxReceived(hWallet, tx.hash, null);

expect(tx.outputs).toHaveLength(0);
});
Expand All @@ -143,15 +144,15 @@ describe('Template execution', async () => {
.addUtxoSelect({ fill: 1 })
.addAuthoritySelect({ authority: 'mint', token: '{token}' })
.addTokenOutput({ address: '{addr}', amount: 100, token: '{token}' })
.addAuthorityOutput({ address: '{addr}', authority: 'mint', token: '{token}'})
.addAuthorityOutput({ address: '{addr}', authority: 'mint', token: '{token}' })
.build();

const tx = await interpreter.build(template, DEBUG);
await transactionUtils.signTransaction(tx, hWallet.storage, DEFAULT_PIN_CODE);
tx.prepareToSend();
const sendTx = SendTransaction({ storage: hWallet.storage, transaction: tx });
const sendTx = new SendTransaction({ storage: hWallet.storage, transaction: tx });
await sendTx.runFromMining();
await waitForTxReceived(hWallet, tx.hash);
await waitForTxReceived(hWallet, tx.hash, null);

expect(tx.outputs[0].tokenData).toBe(1);
expect(tx.outputs[0].value).toBe(100n);
Expand All @@ -165,20 +166,19 @@ describe('Template execution', async () => {
.addUtxoSelect({ fill: 100, token: '{token}' })
.addAuthoritySelect({ authority: 'melt', token: '{token}' })
.addTokenOutput({ address: '{addr}', amount: 1 })
.addAuthorityOutput({ address: '{addr}', authority: 'melt', token: '{token}'})
.addAuthorityOutput({ address: '{addr}', authority: 'melt', token: '{token}' })
.build();

const tx = await interpreter.build(template, DEBUG);
await transactionUtils.signTransaction(tx, hWallet.storage, DEFAULT_PIN_CODE);
tx.prepareToSend();
const sendTx = SendTransaction({ storage: hWallet.storage, transaction: tx });
const sendTx = new SendTransaction({ storage: hWallet.storage, transaction: tx });
await sendTx.runFromMining();
await waitForTxReceived(hWallet, tx.hash);
await waitForTxReceived(hWallet, tx.hash, null);

expect(tx.outputs[0].tokenData).toBe(0);
expect(tx.outputs[0].value).toBe(1n);
expect(tx.outputs[1].tokenData).toBe(129);
expect(tx.outputs[1].value).toBe(2n);
});

});
Loading