@sentio/sdk 1.27.3 → 1.27.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/processor-runner.js +2 -2
- package/lib/processor-runner.js.map +1 -1
- package/package.json +4 -4
- package/src/processor-runner.ts +2 -2
- package/lib/aptos/types.test.js +0 -19
- package/lib/core/generic-processor.test.js +0 -58
- package/lib/core/meter.test.js +0 -21
- package/lib/core/numberish.test.js +0 -70
- package/lib/tests/aptos.test.d.ts +0 -1
- package/lib/tests/aptos.test.js +0 -379
- package/lib/tests/aptos.test.js.map +0 -1
- package/lib/tests/codegen.test.d.ts +0 -1
- package/lib/tests/codegen.test.js +0 -49
- package/lib/tests/codegen.test.js.map +0 -1
- package/lib/tests/erc20-template.test.d.ts +0 -1
- package/lib/tests/erc20-template.test.js +0 -56
- package/lib/tests/erc20-template.test.js.map +0 -1
- package/lib/tests/erc20.d.ts +0 -1
- package/lib/tests/erc20.js +0 -54
- package/lib/tests/erc20.js.map +0 -1
- package/lib/tests/erc20.test.d.ts +0 -1
- package/lib/tests/erc20.test.js +0 -94
- package/lib/tests/erc20.test.js.map +0 -1
- package/lib/tests/error-capture.test.d.ts +0 -1
- package/lib/tests/error-capture.test.js +0 -76
- package/lib/tests/error-capture.test.js.map +0 -1
- package/lib/tests/logger.test.d.ts +0 -1
- package/lib/tests/logger.test.js +0 -40
- package/lib/tests/logger.test.js.map +0 -1
- package/lib/tests/solana.test.d.ts +0 -1
- package/lib/tests/solana.test.js +0 -77
- package/lib/tests/solana.test.js.map +0 -1
- package/lib/tests/souffl3.d.ts +0 -1
- package/lib/tests/souffl3.js +0 -49
- package/lib/tests/souffl3.js.map +0 -1
- package/lib/tests/sui.test.d.ts +0 -1
- package/lib/tests/sui.test.js +0 -193
- package/lib/tests/sui.test.js.map +0 -1
- package/lib/tests/types/aptos/soffl3.d.ts +0 -786
- package/lib/tests/types/aptos/soffl3.js +0 -559
- package/lib/tests/types/aptos/soffl3.js.map +0 -1
- package/lib/tests/types/aptos/souffle.d.ts +0 -348
- package/lib/tests/types/aptos/souffle.js +0 -303
- package/lib/tests/types/aptos/souffle.js.map +0 -1
- package/lib/tests/types/solana/basic_1.d.ts +0 -26
- package/lib/tests/types/solana/basic_1.js +0 -66
- package/lib/tests/types/solana/basic_1.js.map +0 -1
- package/lib/tests/types/solana/basic_1_processor.d.ts +0 -13
- package/lib/tests/types/solana/basic_1_processor.js +0 -41
- package/lib/tests/types/solana/basic_1_processor.js.map +0 -1
- package/lib/tests/wormhole-token-bridge.d.ts +0 -1
- package/lib/tests/wormhole-token-bridge.js +0 -22
- package/lib/tests/wormhole-token-bridge.js.map +0 -1
- package/lib/utils/dex-price.test.js +0 -22
- package/lib/utils/erc20.test.js +0 -23
- package/src/aptos/types.test.ts +0 -18
- package/src/aptos-codegen/typegen.test.ts +0 -44
- package/src/core/generic-processor.test.ts +0 -69
- package/src/core/meter.test.ts +0 -23
- package/src/core/numberish.test.ts +0 -82
- package/src/tests/abis/aptos/soffl3.json +0 -1411
- package/src/tests/abis/aptos/souffle.json +0 -389
- package/src/tests/abis/evm/CommitmentPool.json +0 -1034
- package/src/tests/abis/evm/Seaport.json +0 -2595
- package/src/tests/abis/evm/anyswapRouter.json +0 -490
- package/src/tests/abis/solana/basic_1.json +0 -62
- package/src/tests/aptos.test.ts +0 -402
- package/src/tests/codegen.test.ts +0 -29
- package/src/tests/erc20-template.test.ts +0 -60
- package/src/tests/erc20.test.ts +0 -115
- package/src/tests/erc20.ts +0 -60
- package/src/tests/error-capture.test.ts +0 -82
- package/src/tests/logger.test.ts +0 -46
- package/src/tests/solana.test.ts +0 -79
- package/src/tests/souffl3.ts +0 -56
- package/src/tests/sui.test.ts +0 -197
- package/src/tests/types/aptos/soffl3.ts +0 -1377
- package/src/tests/types/aptos/souffle.ts +0 -698
- package/src/tests/types/solana/basic_1.ts +0 -62
- package/src/tests/types/solana/basic_1_processor.ts +0 -41
- package/src/tests/wormhole-token-bridge.ts +0 -21
- package/src/types/global.d.ts +0 -5
- package/src/utils/dex-price.test.ts +0 -25
- package/src/utils/erc20.test.ts +0 -26
- package/templates/aptos/.gitignore +0 -107
- package/templates/aptos/src/processor.test.ts +0 -14
- package/templates/evm/.gitignore +0 -107
- package/templates/evm/src/processor.test.ts +0 -29
- package/templates/raw/.gitignore +0 -107
- package/templates/raw/src/processor.test.ts +0 -14
package/lib/tests/souffl3.js
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const souffle_1 = require("./types/aptos/souffle");
|
|
4
|
-
const _0x3_1 = require("../builtin/aptos/0x3");
|
|
5
|
-
const _0x1_1 = require("../builtin/aptos/0x1");
|
|
6
|
-
const types_1 = require("../aptos/types");
|
|
7
|
-
const sdk_1 = require("@sentio/sdk");
|
|
8
|
-
const aptos_processor_1 = require("../aptos/aptos-processor");
|
|
9
|
-
const accountTracker = sdk_1.AccountEventTracker.register('pull');
|
|
10
|
-
souffle_1.SouffleChefCampaign.bind({ startVersion: 3212312n })
|
|
11
|
-
.onEntryPullTokenV2((call, ctx) => {
|
|
12
|
-
ctx.meter.Counter('call_num').add(1);
|
|
13
|
-
ctx.meter.Counter('pulled').add(call.arguments_typed[3]);
|
|
14
|
-
})
|
|
15
|
-
.onEventPullTokenEvent((evt, ctx) => {
|
|
16
|
-
ctx.meter.Counter('burned').add(1);
|
|
17
|
-
accountTracker.trackEvent(ctx, { distinctId: ctx.transaction.sender });
|
|
18
|
-
})
|
|
19
|
-
.onEvent((event, ctx) => {
|
|
20
|
-
ctx.meter.Counter('evt_num').add(1);
|
|
21
|
-
}, {
|
|
22
|
-
type: '0x1::coin::DepositEvent',
|
|
23
|
-
})
|
|
24
|
-
.onTransaction((txn, ctx) => {
|
|
25
|
-
const events = types_1.TYPE_REGISTRY.filterAndDecodeEvents('0x3::token::DepositEvent', txn.events);
|
|
26
|
-
for (const event of events) {
|
|
27
|
-
// const depositEventInstance = DEFAULT_TYPE_REGISTRY.decodeEvent(event) as DepositEventInstance
|
|
28
|
-
ctx.meter.Counter('deposit_token_count').add(event.data_typed.amount);
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
souffle_1.CandyMachine.bind().onEntryPullToken((call, ctx) => {
|
|
32
|
-
ctx.meter.Counter('pulled').add(call.arguments[2]);
|
|
33
|
-
});
|
|
34
|
-
_0x3_1.token.bind().onEventDepositEvent((evt, ctx) => {
|
|
35
|
-
ctx.meter.Gauge('version').record(evt.data_typed.id.property_version);
|
|
36
|
-
ctx.meter.Counter('deposit').add(evt.data_typed.amount, { token: evt.data_typed.id.token_data_id.name });
|
|
37
|
-
});
|
|
38
|
-
_0x1_1.voting.bind().onEventCreateProposalEvent((evt, ctx) => {
|
|
39
|
-
// console.log(evt)
|
|
40
|
-
evt.data_typed.expiration_secs + evt.data_typed.expiration_secs;
|
|
41
|
-
ctx.meter.Gauge('size').record(evt.data_typed.metadata.data.length);
|
|
42
|
-
});
|
|
43
|
-
aptos_processor_1.AptosAccountProcessor.bind({ address: '0x1' }).onTimeInterval((resources, ctx) => {
|
|
44
|
-
ctx.meter.Counter('onTimer').add(1);
|
|
45
|
-
}, 10000);
|
|
46
|
-
_0x1_1.aptos_account.bind().onEntryCreateAccount((call, ctx) => {
|
|
47
|
-
ctx.meter.Counter('xx').add(1);
|
|
48
|
-
});
|
|
49
|
-
//# sourceMappingURL=souffl3.js.map
|
package/lib/tests/souffl3.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"souffl3.js","sourceRoot":"","sources":["../../src/tests/souffl3.ts"],"names":[],"mappings":"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","sourcesContent":["import { SouffleChefCampaign, CandyMachine } from './types/aptos/souffle'\nimport { token } from '../builtin/aptos/0x3'\nimport { aptos_account, voting } from '../builtin/aptos/0x1'\nimport { TYPE_REGISTRY } from '../aptos/types'\nimport { AccountEventTracker } from '@sentio/sdk'\nimport { AptosAccountProcessor } from '../aptos/aptos-processor'\n\nconst accountTracker = AccountEventTracker.register('pull')\n\nSouffleChefCampaign.bind({ startVersion: 3212312n })\n .onEntryPullTokenV2((call: SouffleChefCampaign.PullTokenV2Payload, ctx) => {\n ctx.meter.Counter('call_num').add(1)\n ctx.meter.Counter('pulled').add(call.arguments_typed[3])\n })\n .onEventPullTokenEvent((evt, ctx) => {\n ctx.meter.Counter('burned').add(1)\n accountTracker.trackEvent(ctx, { distinctId: ctx.transaction.sender })\n })\n .onEvent(\n (event, ctx) => {\n ctx.meter.Counter('evt_num').add(1)\n },\n {\n type: '0x1::coin::DepositEvent',\n }\n )\n .onTransaction((txn, ctx) => {\n const events = TYPE_REGISTRY.filterAndDecodeEvents<token.DepositEvent>('0x3::token::DepositEvent', txn.events)\n for (const event of events) {\n // const depositEventInstance = DEFAULT_TYPE_REGISTRY.decodeEvent(event) as DepositEventInstance\n ctx.meter.Counter('deposit_token_count').add(event.data_typed.amount)\n }\n })\n\nCandyMachine.bind().onEntryPullToken((call: CandyMachine.PullTokenPayload, ctx) => {\n ctx.meter.Counter('pulled').add(call.arguments[2])\n})\n\ntoken.bind().onEventDepositEvent((evt: token.DepositEventInstance, ctx) => {\n ctx.meter.Gauge('version').record(evt.data_typed.id.property_version)\n ctx.meter.Counter('deposit').add(evt.data_typed.amount, { token: evt.data_typed.id.token_data_id.name })\n})\n\nvoting.bind().onEventCreateProposalEvent((evt, ctx) => {\n // console.log(evt)\n evt.data_typed.expiration_secs + evt.data_typed.expiration_secs\n ctx.meter.Gauge('size').record(evt.data_typed.metadata.data.length)\n})\n\nAptosAccountProcessor.bind({ address: '0x1' }).onTimeInterval((resources, ctx) => {\n ctx.meter.Counter('onTimer').add(1)\n}, 10000)\n\naptos_account.bind().onEntryCreateAccount((call, ctx) => {\n ctx.meter.Counter('xx').add(1)\n})\n"]}
|
package/lib/tests/sui.test.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/lib/tests/sui.test.js
DELETED
|
@@ -1,193 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const chai_1 = require("chai");
|
|
7
|
-
const long_1 = __importDefault(require("long"));
|
|
8
|
-
const util_1 = require("util");
|
|
9
|
-
const __1 = require("..");
|
|
10
|
-
const utils_1 = require("../utils");
|
|
11
|
-
const testing_1 = require("../testing");
|
|
12
|
-
describe('Test Sui Example', () => {
|
|
13
|
-
const service = new testing_1.TestProcessorServer(() => {
|
|
14
|
-
class TicTacToeProcessor extends __1.SuiBaseProcessor {
|
|
15
|
-
static bind(options) {
|
|
16
|
-
return new TicTacToeProcessor('TicTacToe', options);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
TicTacToeProcessor.bind({
|
|
20
|
-
startBlock: 0,
|
|
21
|
-
address: '',
|
|
22
|
-
}).onTransaction((txn, ctx) => {
|
|
23
|
-
if (txn.certificate.data.transactions && txn.certificate.data.transactions.length > 0) {
|
|
24
|
-
if (txn.certificate.data.transactions[0].Call.package.objectId === '0xb8252513f0b9efaa3e260842c4b84d8ff933522d') {
|
|
25
|
-
if (txn.effects.events) {
|
|
26
|
-
txn.effects.events.forEach((event) => {
|
|
27
|
-
if (event.newObject) {
|
|
28
|
-
const owner = event.newObject.recipient.AddressOwner;
|
|
29
|
-
if (owner.toString().includes('0x1c27')) {
|
|
30
|
-
ctx.meter.Counter('win_count').add(1);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
beforeAll(async () => {
|
|
40
|
-
await service.start({ templateInstances: [] });
|
|
41
|
-
});
|
|
42
|
-
test('check configuration ', async () => {
|
|
43
|
-
const config = await service.getConfig({});
|
|
44
|
-
(0, chai_1.expect)(config.contractConfigs).length(1);
|
|
45
|
-
});
|
|
46
|
-
test('Check tictactoe transaction dispatch', async () => {
|
|
47
|
-
const request = {
|
|
48
|
-
chainId: utils_1.chain.SUI_DEVNET_ID,
|
|
49
|
-
transactions: [
|
|
50
|
-
{
|
|
51
|
-
slot: long_1.default.fromNumber(12345),
|
|
52
|
-
raw: new util_1.TextEncoder().encode(JSON.stringify(testData)),
|
|
53
|
-
programAccountId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',
|
|
54
|
-
},
|
|
55
|
-
],
|
|
56
|
-
};
|
|
57
|
-
const res = await service.processTransactions(request);
|
|
58
|
-
(0, chai_1.expect)(res.result?.counters).length(1);
|
|
59
|
-
(0, chai_1.expect)(res.result?.gauges).length(0);
|
|
60
|
-
(0, chai_1.expect)(res.result?.counters[0].metadata?.blockNumber.toInt()).equal(12345);
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
const testData = {
|
|
64
|
-
certificate: {
|
|
65
|
-
transactionDigest: 'z3HjnnFFKAaszOi0pMSImtGMpRd2r7ljLjAjUoqs3Kw=',
|
|
66
|
-
data: {
|
|
67
|
-
transactions: [
|
|
68
|
-
{
|
|
69
|
-
Call: {
|
|
70
|
-
package: {
|
|
71
|
-
objectId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',
|
|
72
|
-
version: 1,
|
|
73
|
-
digest: 'UyeEXDb5jCLGuk/PVcqdLtbKSI3mSANB2/DxiyzXRC8=',
|
|
74
|
-
},
|
|
75
|
-
module: 'shared_tic_tac_toe',
|
|
76
|
-
function: 'place_mark',
|
|
77
|
-
arguments: ['0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4', 2, ''],
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
],
|
|
81
|
-
sender: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
82
|
-
gasPayment: {
|
|
83
|
-
objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',
|
|
84
|
-
version: 8,
|
|
85
|
-
digest: 'suj5fniFCh3oqu+3BQWASz5zyUl4jUWVmJFf76AwVoE=',
|
|
86
|
-
},
|
|
87
|
-
gasBudget: 1000,
|
|
88
|
-
},
|
|
89
|
-
txSignature: 'ACIBv8kDff83DOjZsrUe4RqC1BLBGZtLAwFf/3tHUWJe1F+fxtg16Kqdm85TY9IWeYhVTtQkmchROxX8g0pi/Ak48WB/fgCTwX6K9CIMWgmr+j4k7x4dPYBNizpjHvBgCQ==',
|
|
90
|
-
authSignInfo: {
|
|
91
|
-
epoch: 0,
|
|
92
|
-
signature: [
|
|
93
|
-
'o4tOmjc4jJ27NoKGEHlNDZav0rBJLDqzzsL1kGJOviPKgpLlxyFCeBHrgjAwoc4Y5M75wYgccCuiv67l1w05DQ==',
|
|
94
|
-
'B2tClnK9GYCDFg6HbO/IW7hlJkhfIXi6NoDn7s4Pyw94BjMB/v0S0ZufbLwDO/WhBwU83q+wRTanG4HRhvUuBw==',
|
|
95
|
-
'5s49bESgHvDH7/oqjuxjy9YW4xWCG4e8g6hGlZC0bTXskPdf+q6bSGglkkMpOr1B3uIlMeif1NAlRQCKsfNcCg==',
|
|
96
|
-
],
|
|
97
|
-
signers_map: [58, 48, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 16, 0, 0, 0, 1, 0, 2, 0, 3, 0],
|
|
98
|
-
},
|
|
99
|
-
},
|
|
100
|
-
effects: {
|
|
101
|
-
status: {
|
|
102
|
-
status: 'success',
|
|
103
|
-
},
|
|
104
|
-
gasUsed: {
|
|
105
|
-
computationCost: 716,
|
|
106
|
-
storageCost: 48,
|
|
107
|
-
storageRebate: 35,
|
|
108
|
-
},
|
|
109
|
-
sharedObjects: [
|
|
110
|
-
{
|
|
111
|
-
objectId: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',
|
|
112
|
-
version: 6,
|
|
113
|
-
digest: 'kY/I9fcr6rL2EbDO88MxrEmEaxAEtRxgd+lcfQnE4ww=',
|
|
114
|
-
},
|
|
115
|
-
],
|
|
116
|
-
transactionDigest: 'z3HjnnFFKAaszOi0pMSImtGMpRd2r7ljLjAjUoqs3Kw=',
|
|
117
|
-
created: [
|
|
118
|
-
{
|
|
119
|
-
owner: {
|
|
120
|
-
AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
121
|
-
},
|
|
122
|
-
reference: {
|
|
123
|
-
objectId: '0x2e37e03297a9d138687ffd921f8a830a6f498ec6',
|
|
124
|
-
version: 1,
|
|
125
|
-
digest: '1zZhoVoTLPRM1YpGX9EcrwPJulKcXyLrF+40rTIQ06g=',
|
|
126
|
-
},
|
|
127
|
-
},
|
|
128
|
-
],
|
|
129
|
-
mutated: [
|
|
130
|
-
{
|
|
131
|
-
owner: {
|
|
132
|
-
AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
133
|
-
},
|
|
134
|
-
reference: {
|
|
135
|
-
objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',
|
|
136
|
-
version: 9,
|
|
137
|
-
digest: 'naHwWYK8vl7UBnhp40o7h7JI+cxvFF8rTIOQ4RJ4vus=',
|
|
138
|
-
},
|
|
139
|
-
},
|
|
140
|
-
{
|
|
141
|
-
owner: 'Shared',
|
|
142
|
-
reference: {
|
|
143
|
-
objectId: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',
|
|
144
|
-
version: 7,
|
|
145
|
-
digest: 's3R+lWAMGde7eqZzllafAJkoR7Em55An8gHgz7oCImw=',
|
|
146
|
-
},
|
|
147
|
-
},
|
|
148
|
-
],
|
|
149
|
-
gasObject: {
|
|
150
|
-
owner: {
|
|
151
|
-
AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
152
|
-
},
|
|
153
|
-
reference: {
|
|
154
|
-
objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',
|
|
155
|
-
version: 9,
|
|
156
|
-
digest: 'naHwWYK8vl7UBnhp40o7h7JI+cxvFF8rTIOQ4RJ4vus=',
|
|
157
|
-
},
|
|
158
|
-
},
|
|
159
|
-
events: [
|
|
160
|
-
{
|
|
161
|
-
moveEvent: {
|
|
162
|
-
packageId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',
|
|
163
|
-
transactionModule: 'shared_tic_tac_toe',
|
|
164
|
-
sender: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
165
|
-
type: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d::shared_tic_tac_toe::GameEndEvent',
|
|
166
|
-
fields: {
|
|
167
|
-
game_id: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',
|
|
168
|
-
},
|
|
169
|
-
bcs: 'jtJAeNZKoaKnWTy6erZOsgFvo9Q=',
|
|
170
|
-
},
|
|
171
|
-
},
|
|
172
|
-
{
|
|
173
|
-
newObject: {
|
|
174
|
-
packageId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',
|
|
175
|
-
transactionModule: 'shared_tic_tac_toe',
|
|
176
|
-
sender: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
177
|
-
recipient: {
|
|
178
|
-
AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',
|
|
179
|
-
},
|
|
180
|
-
objectId: '0x2e37e03297a9d138687ffd921f8a830a6f498ec6',
|
|
181
|
-
},
|
|
182
|
-
},
|
|
183
|
-
],
|
|
184
|
-
dependencies: [
|
|
185
|
-
'UgLnWz4u9GTgAJYwR+rz+YO5TDJiZHuFjzyh9blJO2o=',
|
|
186
|
-
'lw2dyQ9J3fPeH5Lx5aiHfjxDHJENTH4910r2/Y/PQX4=',
|
|
187
|
-
'phojYeMd7C6mRxGXQFDPF10NFYMEUfBND+f8wJGKkbg=',
|
|
188
|
-
],
|
|
189
|
-
},
|
|
190
|
-
timestamp_ms: 1662996912461,
|
|
191
|
-
parsed_data: null,
|
|
192
|
-
};
|
|
193
|
-
//# sourceMappingURL=sui.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sui.test.js","sourceRoot":"","sources":["../../src/tests/sui.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect } from 'chai'\nimport Long from 'long'\nimport { TextEncoder } from 'util'\nimport { ProcessTransactionsRequest, SuiBaseProcessor, SuiBindOptions } from '..'\nimport { chain } from '../utils'\n\nimport { TestProcessorServer } from '../testing'\n\ndescribe('Test Sui Example', () => {\n const service = new TestProcessorServer(() => {\n class TicTacToeProcessor extends SuiBaseProcessor {\n static bind(options: SuiBindOptions): TicTacToeProcessor {\n return new TicTacToeProcessor('TicTacToe', options)\n }\n }\n\n TicTacToeProcessor.bind({\n startBlock: 0,\n address: '',\n }).onTransaction((txn, ctx) => {\n if (txn.certificate.data.transactions && txn.certificate.data.transactions.length > 0) {\n if (\n txn.certificate.data.transactions[0].Call.package.objectId === '0xb8252513f0b9efaa3e260842c4b84d8ff933522d'\n ) {\n if (txn.effects.events) {\n txn.effects.events.forEach((event: { newObject: { recipient: { AddressOwner: any } } }) => {\n if (event.newObject) {\n const owner = event.newObject.recipient.AddressOwner\n if ((owner.toString() as string).includes('0x1c27')) {\n ctx.meter.Counter('win_count').add(1)\n }\n }\n })\n }\n }\n }\n })\n })\n\n beforeAll(async () => {\n await service.start({ templateInstances: [] })\n })\n\n test('check configuration ', async () => {\n const config = await service.getConfig({})\n expect(config.contractConfigs).length(1)\n })\n\n test('Check tictactoe transaction dispatch', async () => {\n const request: ProcessTransactionsRequest = {\n chainId: chain.SUI_DEVNET_ID,\n transactions: [\n {\n slot: Long.fromNumber(12345),\n raw: new TextEncoder().encode(JSON.stringify(testData)),\n programAccountId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',\n },\n ],\n }\n const res = await service.processTransactions(request)\n expect(res.result?.counters).length(1)\n expect(res.result?.gauges).length(0)\n expect(res.result?.counters[0].metadata?.blockNumber.toInt()).equal(12345)\n })\n})\n\nconst testData = {\n certificate: {\n transactionDigest: 'z3HjnnFFKAaszOi0pMSImtGMpRd2r7ljLjAjUoqs3Kw=',\n data: {\n transactions: [\n {\n Call: {\n package: {\n objectId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',\n version: 1,\n digest: 'UyeEXDb5jCLGuk/PVcqdLtbKSI3mSANB2/DxiyzXRC8=',\n },\n module: 'shared_tic_tac_toe',\n function: 'place_mark',\n arguments: ['0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4', 2, ''],\n },\n },\n ],\n sender: '0x1c270459011d19dc342751aff75b4188334438fa',\n gasPayment: {\n objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',\n version: 8,\n digest: 'suj5fniFCh3oqu+3BQWASz5zyUl4jUWVmJFf76AwVoE=',\n },\n gasBudget: 1000,\n },\n txSignature:\n 'ACIBv8kDff83DOjZsrUe4RqC1BLBGZtLAwFf/3tHUWJe1F+fxtg16Kqdm85TY9IWeYhVTtQkmchROxX8g0pi/Ak48WB/fgCTwX6K9CIMWgmr+j4k7x4dPYBNizpjHvBgCQ==',\n authSignInfo: {\n epoch: 0,\n signature: [\n 'o4tOmjc4jJ27NoKGEHlNDZav0rBJLDqzzsL1kGJOviPKgpLlxyFCeBHrgjAwoc4Y5M75wYgccCuiv67l1w05DQ==',\n 'B2tClnK9GYCDFg6HbO/IW7hlJkhfIXi6NoDn7s4Pyw94BjMB/v0S0ZufbLwDO/WhBwU83q+wRTanG4HRhvUuBw==',\n '5s49bESgHvDH7/oqjuxjy9YW4xWCG4e8g6hGlZC0bTXskPdf+q6bSGglkkMpOr1B3uIlMeif1NAlRQCKsfNcCg==',\n ],\n signers_map: [58, 48, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 16, 0, 0, 0, 1, 0, 2, 0, 3, 0],\n },\n },\n effects: {\n status: {\n status: 'success',\n },\n gasUsed: {\n computationCost: 716,\n storageCost: 48,\n storageRebate: 35,\n },\n sharedObjects: [\n {\n objectId: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',\n version: 6,\n digest: 'kY/I9fcr6rL2EbDO88MxrEmEaxAEtRxgd+lcfQnE4ww=',\n },\n ],\n transactionDigest: 'z3HjnnFFKAaszOi0pMSImtGMpRd2r7ljLjAjUoqs3Kw=',\n created: [\n {\n owner: {\n AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',\n },\n reference: {\n objectId: '0x2e37e03297a9d138687ffd921f8a830a6f498ec6',\n version: 1,\n digest: '1zZhoVoTLPRM1YpGX9EcrwPJulKcXyLrF+40rTIQ06g=',\n },\n },\n ],\n mutated: [\n {\n owner: {\n AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',\n },\n reference: {\n objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',\n version: 9,\n digest: 'naHwWYK8vl7UBnhp40o7h7JI+cxvFF8rTIOQ4RJ4vus=',\n },\n },\n {\n owner: 'Shared',\n reference: {\n objectId: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',\n version: 7,\n digest: 's3R+lWAMGde7eqZzllafAJkoR7Em55An8gHgz7oCImw=',\n },\n },\n ],\n gasObject: {\n owner: {\n AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',\n },\n reference: {\n objectId: '0x018b73e6652bab0f6419fa998263b568fa0688bb',\n version: 9,\n digest: 'naHwWYK8vl7UBnhp40o7h7JI+cxvFF8rTIOQ4RJ4vus=',\n },\n },\n events: [\n {\n moveEvent: {\n packageId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',\n transactionModule: 'shared_tic_tac_toe',\n sender: '0x1c270459011d19dc342751aff75b4188334438fa',\n type: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d::shared_tic_tac_toe::GameEndEvent',\n fields: {\n game_id: '0x8ed24078d64aa1a2a7593cba7ab64eb2016fa3d4',\n },\n bcs: 'jtJAeNZKoaKnWTy6erZOsgFvo9Q=',\n },\n },\n {\n newObject: {\n packageId: '0xb8252513f0b9efaa3e260842c4b84d8ff933522d',\n transactionModule: 'shared_tic_tac_toe',\n sender: '0x1c270459011d19dc342751aff75b4188334438fa',\n recipient: {\n AddressOwner: '0x1c270459011d19dc342751aff75b4188334438fa',\n },\n objectId: '0x2e37e03297a9d138687ffd921f8a830a6f498ec6',\n },\n },\n ],\n dependencies: [\n 'UgLnWz4u9GTgAJYwR+rz+YO5TDJiZHuFjzyh9blJO2o=',\n 'lw2dyQ9J3fPeH5Lx5aiHfjxDHJENTH4910r2/Y/PQX4=',\n 'phojYeMd7C6mRxGXQFDPF10NFYMEUfBND+f8wJGKkbg=',\n ],\n },\n timestamp_ms: 1662996912461,\n parsed_data: null,\n}\n"]}
|