@baozi.bet/mcp-server 4.0.0
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/README.md +294 -0
- package/dist/__tests__/full-test.d.ts +1 -0
- package/dist/__tests__/full-test.js +291 -0
- package/dist/builders/affiliate-transaction.d.ts +41 -0
- package/dist/builders/affiliate-transaction.js +123 -0
- package/dist/builders/bet-transaction.d.ts +70 -0
- package/dist/builders/bet-transaction.js +323 -0
- package/dist/builders/claim-transaction.d.ts +57 -0
- package/dist/builders/claim-transaction.js +196 -0
- package/dist/builders/creator-transaction.d.ts +49 -0
- package/dist/builders/creator-transaction.js +177 -0
- package/dist/builders/dispute-transaction.d.ts +81 -0
- package/dist/builders/dispute-transaction.js +215 -0
- package/dist/builders/index.d.ts +14 -0
- package/dist/builders/index.js +15 -0
- package/dist/builders/market-creation-tx.d.ts +65 -0
- package/dist/builders/market-creation-tx.js +362 -0
- package/dist/builders/market-management-transaction.d.ts +85 -0
- package/dist/builders/market-management-transaction.js +239 -0
- package/dist/builders/race-transaction.d.ts +67 -0
- package/dist/builders/race-transaction.js +242 -0
- package/dist/builders/resolution-transaction.d.ts +108 -0
- package/dist/builders/resolution-transaction.js +250 -0
- package/dist/builders/whitelist-transaction.d.ts +72 -0
- package/dist/builders/whitelist-transaction.js +179 -0
- package/dist/config.d.ts +138 -0
- package/dist/config.js +307 -0
- package/dist/handlers/agent-network.d.ts +81 -0
- package/dist/handlers/agent-network.js +332 -0
- package/dist/handlers/claims.d.ts +47 -0
- package/dist/handlers/claims.js +218 -0
- package/dist/handlers/market-creation.d.ts +154 -0
- package/dist/handlers/market-creation.js +290 -0
- package/dist/handlers/markets.d.ts +41 -0
- package/dist/handlers/markets.js +319 -0
- package/dist/handlers/positions.d.ts +40 -0
- package/dist/handlers/positions.js +244 -0
- package/dist/handlers/quote.d.ts +33 -0
- package/dist/handlers/quote.js +144 -0
- package/dist/handlers/race-markets.d.ts +54 -0
- package/dist/handlers/race-markets.js +308 -0
- package/dist/handlers/resolution.d.ts +43 -0
- package/dist/handlers/resolution.js +194 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +109 -0
- package/dist/resources.d.ts +13 -0
- package/dist/resources.js +336 -0
- package/dist/tools.d.ts +3109 -0
- package/dist/tools.js +1956 -0
- package/dist/validation/bet-rules.d.ts +82 -0
- package/dist/validation/bet-rules.js +276 -0
- package/dist/validation/creation-rules.d.ts +69 -0
- package/dist/validation/creation-rules.js +302 -0
- package/dist/validation/index.d.ts +6 -0
- package/dist/validation/index.js +7 -0
- package/dist/validation/market-rules.d.ts +60 -0
- package/dist/validation/market-rules.js +237 -0
- package/dist/validation/parimutuel-rules.d.ts +117 -0
- package/dist/validation/parimutuel-rules.js +270 -0
- package/package.json +52 -0
package/README.md
ADDED
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
# @baozi/mcp-server
|
|
2
|
+
|
|
3
|
+
**MCP (Model Context Protocol) server for Baozi prediction markets on Solana**
|
|
4
|
+
|
|
5
|
+
[](https://www.npmjs.com/package/@baozi/mcp-server)
|
|
6
|
+
[](https://opensource.org/licenses/MIT)
|
|
7
|
+
|
|
8
|
+
## Overview
|
|
9
|
+
|
|
10
|
+
This MCP server enables AI agents to interact with [Baozi](https://baozi.bet) prediction markets on Solana. It provides **66 tools** for:
|
|
11
|
+
|
|
12
|
+
- **Market Discovery** - List and filter boolean/race markets
|
|
13
|
+
- **Quote Calculation** - Expected payouts with odds analysis
|
|
14
|
+
- **Transaction Building** - Unsigned transactions for betting, claims, resolution
|
|
15
|
+
- **Position Management** - View wallet positions and claimable winnings
|
|
16
|
+
- **Validation** - Enforce v6.2 timing rules before market creation
|
|
17
|
+
|
|
18
|
+
**Key Principle**: Agent builds, User signs. No private keys in agent.
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
AI Agent ──► MCP Tool ──► Unsigned Transaction (base64)
|
|
22
|
+
│
|
|
23
|
+
▼
|
|
24
|
+
User Wallet ──► Signs ──► Solana Network
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Installation
|
|
28
|
+
|
|
29
|
+
### Claude Desktop
|
|
30
|
+
|
|
31
|
+
Add to your Claude Desktop config:
|
|
32
|
+
|
|
33
|
+
**macOS**: `~/Library/Application Support/Claude/claude_desktop_config.json`
|
|
34
|
+
**Windows**: `%APPDATA%\Claude\claude_desktop_config.json`
|
|
35
|
+
|
|
36
|
+
```json
|
|
37
|
+
{
|
|
38
|
+
"mcpServers": {
|
|
39
|
+
"baozi": {
|
|
40
|
+
"command": "npx",
|
|
41
|
+
"args": ["@baozi/mcp-server"]
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
### Claude Code
|
|
48
|
+
|
|
49
|
+
Add to your project's MCP configuration or run directly:
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
npx @baozi/mcp-server
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## Tool Categories (66 Tools)
|
|
56
|
+
|
|
57
|
+
### Market Reading (6 tools)
|
|
58
|
+
| Tool | Description |
|
|
59
|
+
|------|-------------|
|
|
60
|
+
| `list_markets` | List boolean markets with filtering by layer/status |
|
|
61
|
+
| `get_market` | Get detailed market info by public key |
|
|
62
|
+
| `get_quote` | Calculate expected payout for a bet |
|
|
63
|
+
| `list_race_markets` | List multi-outcome race markets |
|
|
64
|
+
| `get_race_market` | Get race market details |
|
|
65
|
+
| `get_race_quote` | Calculate race bet payout |
|
|
66
|
+
|
|
67
|
+
### Betting (2 tools)
|
|
68
|
+
| Tool | Description |
|
|
69
|
+
|------|-------------|
|
|
70
|
+
| `build_bet_transaction` | Build unsigned bet tx (supports affiliate) |
|
|
71
|
+
| `build_race_bet_transaction` | Build unsigned race bet tx |
|
|
72
|
+
|
|
73
|
+
### Claims (6 tools)
|
|
74
|
+
| Tool | Description |
|
|
75
|
+
|------|-------------|
|
|
76
|
+
| `build_claim_winnings_transaction` | Claim winnings from resolved market |
|
|
77
|
+
| `build_claim_refund_transaction` | Claim refund from cancelled market |
|
|
78
|
+
| `build_claim_race_winnings_transaction` | Claim race market winnings |
|
|
79
|
+
| `build_claim_race_refund_transaction` | Claim race market refund |
|
|
80
|
+
| `build_claim_affiliate_transaction` | Claim affiliate earnings |
|
|
81
|
+
| `build_batch_claim_transaction` | Claim multiple positions at once |
|
|
82
|
+
|
|
83
|
+
### Market Creation (8 tools)
|
|
84
|
+
| Tool | Description |
|
|
85
|
+
|------|-------------|
|
|
86
|
+
| `preview_create_market` | Validate params and show costs |
|
|
87
|
+
| `build_create_lab_market_transaction` | Create Lab (community) market |
|
|
88
|
+
| `build_create_private_market_transaction` | Create Private (invite-only) market |
|
|
89
|
+
| `build_create_race_market_transaction` | Create Race (multi-outcome) market |
|
|
90
|
+
| `get_creation_fees` | Get fee structure by layer |
|
|
91
|
+
| `get_platform_fees` | Get platform fee rates |
|
|
92
|
+
| `get_timing_rules` | Get v6.2 timing constraints |
|
|
93
|
+
| `generate_invite_hash` | Generate hash for private markets |
|
|
94
|
+
|
|
95
|
+
### Resolution (6 tools)
|
|
96
|
+
| Tool | Description |
|
|
97
|
+
|------|-------------|
|
|
98
|
+
| `build_propose_resolution_transaction` | Propose market outcome |
|
|
99
|
+
| `build_resolve_market_transaction` | Direct resolve (creator) |
|
|
100
|
+
| `build_finalize_resolution_transaction` | Finalize after challenge period |
|
|
101
|
+
| `build_propose_race_resolution_transaction` | Propose race outcome |
|
|
102
|
+
| `build_resolve_race_transaction` | Resolve race market |
|
|
103
|
+
| `build_finalize_race_resolution_transaction` | Finalize race resolution |
|
|
104
|
+
|
|
105
|
+
### Disputes (4 tools)
|
|
106
|
+
| Tool | Description |
|
|
107
|
+
|------|-------------|
|
|
108
|
+
| `build_flag_dispute_transaction` | Flag disputed resolution |
|
|
109
|
+
| `build_flag_race_dispute_transaction` | Flag race dispute |
|
|
110
|
+
| `build_vote_council_transaction` | Council vote on dispute |
|
|
111
|
+
| `build_vote_council_race_transaction` | Council vote on race dispute |
|
|
112
|
+
|
|
113
|
+
### Whitelist Management (5 tools)
|
|
114
|
+
| Tool | Description |
|
|
115
|
+
|------|-------------|
|
|
116
|
+
| `build_add_to_whitelist_transaction` | Add user to private market |
|
|
117
|
+
| `build_remove_from_whitelist_transaction` | Remove from whitelist |
|
|
118
|
+
| `build_create_race_whitelist_transaction` | Create race whitelist |
|
|
119
|
+
| `build_add_to_race_whitelist_transaction` | Add to race whitelist |
|
|
120
|
+
| `build_remove_from_race_whitelist_transaction` | Remove from race whitelist |
|
|
121
|
+
|
|
122
|
+
### Creator Profiles (3 tools)
|
|
123
|
+
| Tool | Description |
|
|
124
|
+
|------|-------------|
|
|
125
|
+
| `build_create_creator_profile_transaction` | Create on-chain profile |
|
|
126
|
+
| `build_update_creator_profile_transaction` | Update profile settings |
|
|
127
|
+
| `build_claim_creator_transaction` | Claim creator fees |
|
|
128
|
+
|
|
129
|
+
### Market Management (6 tools)
|
|
130
|
+
| Tool | Description |
|
|
131
|
+
|------|-------------|
|
|
132
|
+
| `build_close_market_transaction` | Stop betting on market |
|
|
133
|
+
| `build_extend_market_transaction` | Extend market deadline |
|
|
134
|
+
| `build_close_race_market_transaction` | Close race market |
|
|
135
|
+
| `build_extend_race_market_transaction` | Extend race deadline |
|
|
136
|
+
| `build_cancel_market_transaction` | Cancel market (refunds enabled) |
|
|
137
|
+
| `build_cancel_race_transaction` | Cancel race market |
|
|
138
|
+
|
|
139
|
+
### Affiliates (10 tools)
|
|
140
|
+
| Tool | Description |
|
|
141
|
+
|------|-------------|
|
|
142
|
+
| `check_affiliate_code` | Check if code is available |
|
|
143
|
+
| `suggest_affiliate_codes` | Generate code suggestions |
|
|
144
|
+
| `get_affiliate_info` | Get affiliate account info |
|
|
145
|
+
| `get_my_affiliates` | List wallet's affiliates |
|
|
146
|
+
| `get_referrals` | List referred users |
|
|
147
|
+
| `get_agent_network_stats` | AI agent network stats |
|
|
148
|
+
| `format_affiliate_link` | Generate referral link |
|
|
149
|
+
| `get_commission_info` | Commission structure |
|
|
150
|
+
| `build_register_affiliate_transaction` | Register new affiliate |
|
|
151
|
+
| `build_toggle_affiliate_transaction` | Activate/deactivate |
|
|
152
|
+
|
|
153
|
+
### Positions & Validation (4 tools)
|
|
154
|
+
| Tool | Description |
|
|
155
|
+
|------|-------------|
|
|
156
|
+
| `get_positions` | Get wallet positions |
|
|
157
|
+
| `get_claimable` | Get claimable winnings/refunds |
|
|
158
|
+
| `validate_market_params` | Validate against v6.2 rules |
|
|
159
|
+
| `validate_bet` | Validate bet parameters |
|
|
160
|
+
|
|
161
|
+
### Simulation (1 tool)
|
|
162
|
+
| Tool | Description |
|
|
163
|
+
|------|-------------|
|
|
164
|
+
| `simulate_transaction` | Pre-sign simulation check |
|
|
165
|
+
|
|
166
|
+
### Resolution Status (3 tools)
|
|
167
|
+
| Tool | Description |
|
|
168
|
+
|------|-------------|
|
|
169
|
+
| `get_resolution_status` | Market resolution state |
|
|
170
|
+
| `get_disputed_markets` | List disputed markets |
|
|
171
|
+
| `get_markets_awaiting_resolution` | Pending resolution markets |
|
|
172
|
+
|
|
173
|
+
## Example Usage
|
|
174
|
+
|
|
175
|
+
### List Active Lab Markets
|
|
176
|
+
```json
|
|
177
|
+
{
|
|
178
|
+
"name": "list_markets",
|
|
179
|
+
"arguments": {
|
|
180
|
+
"layer": "Lab",
|
|
181
|
+
"status": "Active"
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
### Get Bet Quote
|
|
187
|
+
```json
|
|
188
|
+
{
|
|
189
|
+
"name": "get_quote",
|
|
190
|
+
"arguments": {
|
|
191
|
+
"market": "E71aYMXbzoC7nBeQFjMpZCiLKKNb7bqjYrXR3TnFjmQ",
|
|
192
|
+
"side": "Yes",
|
|
193
|
+
"amount": 1.0
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
### Build Bet Transaction
|
|
199
|
+
```json
|
|
200
|
+
{
|
|
201
|
+
"name": "build_bet_transaction",
|
|
202
|
+
"arguments": {
|
|
203
|
+
"market": "E71aYMXbzoC7nBeQFjMpZCiLKKNb7bqjYrXR3TnFjmQ",
|
|
204
|
+
"outcome": "yes",
|
|
205
|
+
"amount_sol": 1.0,
|
|
206
|
+
"user_wallet": "9rbVMeTHKpdWwTnjXZRp62RKuTKCsKBKNMtoLZ67PPVr",
|
|
207
|
+
"affiliate_code": "CLAUDE"
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
```
|
|
211
|
+
|
|
212
|
+
### Validate Market Before Creation
|
|
213
|
+
```json
|
|
214
|
+
{
|
|
215
|
+
"name": "validate_market_params",
|
|
216
|
+
"arguments": {
|
|
217
|
+
"question": "Will BTC reach $100k in 2026?",
|
|
218
|
+
"closing_time": "2026-06-01T00:00:00Z",
|
|
219
|
+
"market_type": "event",
|
|
220
|
+
"event_time": "2026-07-01T00:00:00Z"
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
## Transaction Signing
|
|
226
|
+
|
|
227
|
+
The MCP server returns unsigned transactions. Integration options:
|
|
228
|
+
|
|
229
|
+
### 1. Phantom Deep Link
|
|
230
|
+
```
|
|
231
|
+
phantom://sign?transaction={base64_tx}
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
### 2. Wallet Adapter (Web)
|
|
235
|
+
```typescript
|
|
236
|
+
const tx = Transaction.from(Buffer.from(base64Tx, 'base64'));
|
|
237
|
+
await wallet.signAndSendTransaction(tx);
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
### 3. Automated Wallets (Agents)
|
|
241
|
+
- [Turnkey](https://turnkey.com) - Policy-controlled signing
|
|
242
|
+
- [Crossmint](https://crossmint.com) - AI agent wallets
|
|
243
|
+
- [Privy](https://privy.io) - Embedded wallets
|
|
244
|
+
|
|
245
|
+
## Technical Details
|
|
246
|
+
|
|
247
|
+
| Parameter | Value |
|
|
248
|
+
|-----------|-------|
|
|
249
|
+
| **Network** | Solana Mainnet |
|
|
250
|
+
| **Program ID** | `DW4o8AoSXnSudjZhwo4ixkmVUw2Bnv5FDPYF9LgsS5YY` |
|
|
251
|
+
| **IDL Version** | baozi_markets_v4_7_6 |
|
|
252
|
+
| **Betting Model** | Pari-mutuel |
|
|
253
|
+
| **Min Bet** | 0.01 SOL |
|
|
254
|
+
| **Max Bet** | 100 SOL |
|
|
255
|
+
|
|
256
|
+
### Fee Structure
|
|
257
|
+
| Layer | Platform Fee | Creation Fee |
|
|
258
|
+
|-------|-------------|--------------|
|
|
259
|
+
| Official | 2.5% | 0.1 SOL |
|
|
260
|
+
| Lab | 3% | 0.04 SOL |
|
|
261
|
+
| Private | 2% | 0.04 SOL |
|
|
262
|
+
|
|
263
|
+
## Development
|
|
264
|
+
|
|
265
|
+
```bash
|
|
266
|
+
# Install dependencies
|
|
267
|
+
npm install
|
|
268
|
+
|
|
269
|
+
# Build
|
|
270
|
+
npm run build
|
|
271
|
+
|
|
272
|
+
# Run locally
|
|
273
|
+
npm start
|
|
274
|
+
|
|
275
|
+
# Type check
|
|
276
|
+
npm run typecheck
|
|
277
|
+
```
|
|
278
|
+
|
|
279
|
+
## Environment Variables
|
|
280
|
+
|
|
281
|
+
| Variable | Description | Default |
|
|
282
|
+
|----------|-------------|---------|
|
|
283
|
+
| `HELIUS_RPC` | Custom RPC endpoint | Helius mainnet |
|
|
284
|
+
| `DEBUG` | Enable debug logging | false |
|
|
285
|
+
|
|
286
|
+
## Resources
|
|
287
|
+
|
|
288
|
+
- **Website**: https://baozi.bet
|
|
289
|
+
- **API Docs**: https://baozi.bet/docs/api
|
|
290
|
+
- **GitHub**: https://github.com/baozi-markets/baozi-mcp
|
|
291
|
+
|
|
292
|
+
## License
|
|
293
|
+
|
|
294
|
+
MIT
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Full MCP Server Test Suite
|
|
3
|
+
*
|
|
4
|
+
* Tests all 40 tools for correct responses
|
|
5
|
+
*/
|
|
6
|
+
import { Connection } from '@solana/web3.js';
|
|
7
|
+
import { handleTool, TOOLS } from '../tools.js';
|
|
8
|
+
import { RPC_ENDPOINT } from '../config.js';
|
|
9
|
+
const connection = new Connection(RPC_ENDPOINT, 'confirmed');
|
|
10
|
+
// Test utilities
|
|
11
|
+
function parseResponse(response) {
|
|
12
|
+
return JSON.parse(response.content[0].text);
|
|
13
|
+
}
|
|
14
|
+
async function testTool(name, args = {}) {
|
|
15
|
+
try {
|
|
16
|
+
const response = await handleTool(name, args);
|
|
17
|
+
const data = parseResponse(response);
|
|
18
|
+
return { success: data.success, data, error: data.error };
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
return { success: false, error: err instanceof Error ? err.message : 'Unknown error' };
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
// =============================================================================
|
|
25
|
+
// TEST SUITES
|
|
26
|
+
// =============================================================================
|
|
27
|
+
async function testMarketReads() {
|
|
28
|
+
console.log('\n📊 MARKET READ OPERATIONS');
|
|
29
|
+
console.log('─'.repeat(50));
|
|
30
|
+
// list_markets
|
|
31
|
+
const markets = await testTool('list_markets');
|
|
32
|
+
console.log(`✓ list_markets: ${markets.success ? `${markets.data.count} markets` : markets.error}`);
|
|
33
|
+
// get_market (use first market if available)
|
|
34
|
+
if (markets.success && markets.data.count > 0) {
|
|
35
|
+
const marketPk = markets.data.markets[0].publicKey;
|
|
36
|
+
const market = await testTool('get_market', { publicKey: marketPk });
|
|
37
|
+
console.log(`✓ get_market: ${market.success ? market.data.market.question.substring(0, 40) + '...' : market.error}`);
|
|
38
|
+
// get_quote
|
|
39
|
+
const quote = await testTool('get_quote', { market: marketPk, side: 'Yes', amount: 0.1 });
|
|
40
|
+
console.log(`✓ get_quote: ${quote.success ? `${quote.data.quote.expectedPayoutSol?.toFixed(4)} SOL expected` : quote.error}`);
|
|
41
|
+
}
|
|
42
|
+
// list_race_markets
|
|
43
|
+
const raceMarkets = await testTool('list_race_markets');
|
|
44
|
+
console.log(`✓ list_race_markets: ${raceMarkets.success ? `${raceMarkets.data.count} race markets` : raceMarkets.error}`);
|
|
45
|
+
return { markets: markets.data?.count || 0, raceMarkets: raceMarkets.data?.count || 0 };
|
|
46
|
+
}
|
|
47
|
+
async function testMarketCreation() {
|
|
48
|
+
console.log('\n🏗️ MARKET CREATION');
|
|
49
|
+
console.log('─'.repeat(50));
|
|
50
|
+
// get_creation_fees
|
|
51
|
+
const fees = await testTool('get_creation_fees');
|
|
52
|
+
console.log(`✓ get_creation_fees: ${fees.success ? `Lab: ${fees.data.fees.lab.sol} SOL` : fees.error}`);
|
|
53
|
+
// get_platform_fees
|
|
54
|
+
const platformFees = await testTool('get_platform_fees');
|
|
55
|
+
console.log(`✓ get_platform_fees: ${platformFees.success ? `Lab: ${platformFees.data.fees.lab.percent}` : platformFees.error}`);
|
|
56
|
+
// get_timing_rules
|
|
57
|
+
const timing = await testTool('get_timing_rules');
|
|
58
|
+
console.log(`✓ get_timing_rules: ${timing.success ? `Min buffer: ${timing.data.rules.minEventBufferHours}h` : timing.error}`);
|
|
59
|
+
// generate_invite_hash
|
|
60
|
+
const invite = await testTool('generate_invite_hash');
|
|
61
|
+
console.log(`✓ generate_invite_hash: ${invite.success ? invite.data.inviteHash.substring(0, 16) + '...' : invite.error}`);
|
|
62
|
+
// preview_create_market
|
|
63
|
+
const closing = new Date(Date.now() + 7 * 24 * 60 * 60 * 1000).toISOString();
|
|
64
|
+
const event = new Date(Date.now() + 8 * 24 * 60 * 60 * 1000).toISOString();
|
|
65
|
+
const preview = await testTool('preview_create_market', {
|
|
66
|
+
question: 'Will BTC exceed 100K by end of Q1 2026?',
|
|
67
|
+
layer: 'lab',
|
|
68
|
+
closing_time: closing,
|
|
69
|
+
market_type: 'event',
|
|
70
|
+
event_time: event,
|
|
71
|
+
creator_wallet: '11111111111111111111111111111111',
|
|
72
|
+
});
|
|
73
|
+
console.log(`✓ preview_create_market: ${preview.success ? `Valid: ${preview.data.preview.validation.valid}` : preview.error}`);
|
|
74
|
+
return { valid: preview.data?.preview?.validation?.valid };
|
|
75
|
+
}
|
|
76
|
+
async function testPositions() {
|
|
77
|
+
console.log('\n💰 POSITIONS & CLAIMS');
|
|
78
|
+
console.log('─'.repeat(50));
|
|
79
|
+
// Use a known test wallet (system program as placeholder)
|
|
80
|
+
const testWallet = '11111111111111111111111111111111';
|
|
81
|
+
// get_positions
|
|
82
|
+
const positions = await testTool('get_positions', { wallet: testWallet });
|
|
83
|
+
console.log(`✓ get_positions: ${positions.success ? `${positions.data.totalPositions || 0} positions` : positions.error}`);
|
|
84
|
+
// get_claimable
|
|
85
|
+
const claimable = await testTool('get_claimable', { wallet: testWallet });
|
|
86
|
+
console.log(`✓ get_claimable: ${claimable.success ? `${claimable.data.totalClaimable || 0} claimable` : claimable.error}`);
|
|
87
|
+
return { positions: positions.data?.totalPositions || 0 };
|
|
88
|
+
}
|
|
89
|
+
async function testResolution() {
|
|
90
|
+
console.log('\n⚖️ RESOLUTION');
|
|
91
|
+
console.log('─'.repeat(50));
|
|
92
|
+
// get_disputed_markets
|
|
93
|
+
const disputed = await testTool('get_disputed_markets');
|
|
94
|
+
console.log(`✓ get_disputed_markets: ${disputed.success ? `${disputed.data.count} disputed` : disputed.error}`);
|
|
95
|
+
// get_markets_awaiting_resolution
|
|
96
|
+
const awaiting = await testTool('get_markets_awaiting_resolution');
|
|
97
|
+
console.log(`✓ get_markets_awaiting_resolution: ${awaiting.success ? `${awaiting.data.count} awaiting` : awaiting.error}`);
|
|
98
|
+
return { disputed: disputed.data?.count || 0, awaiting: awaiting.data?.count || 0 };
|
|
99
|
+
}
|
|
100
|
+
async function testAffiliates() {
|
|
101
|
+
console.log('\n🤝 AFFILIATES');
|
|
102
|
+
console.log('─'.repeat(50));
|
|
103
|
+
// check_affiliate_code
|
|
104
|
+
const codeCheck = await testTool('check_affiliate_code', { code: 'TESTCODE123' });
|
|
105
|
+
console.log(`✓ check_affiliate_code: ${codeCheck.success ? `Available: ${codeCheck.data.available}` : codeCheck.error}`);
|
|
106
|
+
// suggest_affiliate_codes
|
|
107
|
+
const suggestions = await testTool('suggest_affiliate_codes', { agentName: 'TestAgent', count: 3 });
|
|
108
|
+
console.log(`✓ suggest_affiliate_codes: ${suggestions.success ? suggestions.data.suggestions.slice(0, 2).join(', ') : suggestions.error}`);
|
|
109
|
+
// get_agent_network_stats
|
|
110
|
+
const stats = await testTool('get_agent_network_stats');
|
|
111
|
+
console.log(`✓ get_agent_network_stats: ${stats.success ? `${stats.data.totalAffiliates} affiliates` : stats.error}`);
|
|
112
|
+
// format_affiliate_link
|
|
113
|
+
const link = await testTool('format_affiliate_link', { code: 'TESTCODE' });
|
|
114
|
+
console.log(`✓ format_affiliate_link: ${link.success ? link.data.link : link.error}`);
|
|
115
|
+
// get_commission_info
|
|
116
|
+
const commission = await testTool('get_commission_info');
|
|
117
|
+
console.log(`✓ get_commission_info: ${commission.success ? `${commission.data.commissionBps} bps` : commission.error}`);
|
|
118
|
+
return { totalAffiliates: stats.data?.totalAffiliates || 0 };
|
|
119
|
+
}
|
|
120
|
+
async function testValidation() {
|
|
121
|
+
console.log('\n✅ VALIDATION');
|
|
122
|
+
console.log('─'.repeat(50));
|
|
123
|
+
// validate_market_params
|
|
124
|
+
const closing = new Date(Date.now() + 7 * 24 * 60 * 60 * 1000).toISOString();
|
|
125
|
+
const event = new Date(Date.now() + 8 * 24 * 60 * 60 * 1000).toISOString();
|
|
126
|
+
const marketValidation = await testTool('validate_market_params', {
|
|
127
|
+
question: 'Test market question?',
|
|
128
|
+
closing_time: closing,
|
|
129
|
+
market_type: 'event',
|
|
130
|
+
event_time: event,
|
|
131
|
+
});
|
|
132
|
+
console.log(`✓ validate_market_params: ${marketValidation.success ? `Valid: ${marketValidation.data.validation.valid}` : marketValidation.error}`);
|
|
133
|
+
// validate_bet (need a real market)
|
|
134
|
+
const markets = await testTool('list_markets', { status: 'Active' });
|
|
135
|
+
if (markets.success && markets.data.count > 0) {
|
|
136
|
+
const marketPk = markets.data.markets[0].publicKey;
|
|
137
|
+
const betValidation = await testTool('validate_bet', {
|
|
138
|
+
market: marketPk,
|
|
139
|
+
amount: 0.1,
|
|
140
|
+
side: 'Yes',
|
|
141
|
+
});
|
|
142
|
+
console.log(`✓ validate_bet: ${betValidation.success ? `Valid: ${betValidation.data.validation.valid}` : betValidation.error}`);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
console.log(`○ validate_bet: Skipped (no active markets)`);
|
|
146
|
+
}
|
|
147
|
+
return { marketValidation: marketValidation.data?.validation?.valid };
|
|
148
|
+
}
|
|
149
|
+
async function testTransactionBuilding() {
|
|
150
|
+
console.log('\n🔨 TRANSACTION BUILDING');
|
|
151
|
+
console.log('─'.repeat(50));
|
|
152
|
+
const testWallet = '11111111111111111111111111111111';
|
|
153
|
+
// Get an active market for testing
|
|
154
|
+
const markets = await testTool('list_markets', { status: 'Active' });
|
|
155
|
+
if (markets.success && markets.data.count > 0) {
|
|
156
|
+
const marketPk = markets.data.markets[0].publicKey;
|
|
157
|
+
// build_bet_transaction
|
|
158
|
+
const betTx = await testTool('build_bet_transaction', {
|
|
159
|
+
market: marketPk,
|
|
160
|
+
outcome: 'yes',
|
|
161
|
+
amount_sol: 0.01,
|
|
162
|
+
user_wallet: testWallet,
|
|
163
|
+
});
|
|
164
|
+
console.log(`✓ build_bet_transaction: ${betTx.success ? `TX: ${betTx.data.transaction?.serialized?.substring(0, 20)}...` : betTx.error}`);
|
|
165
|
+
// simulate_transaction (if we got a tx)
|
|
166
|
+
if (betTx.success && betTx.data.transaction?.serialized) {
|
|
167
|
+
const simulation = await testTool('simulate_transaction', {
|
|
168
|
+
transaction: betTx.data.transaction.serialized,
|
|
169
|
+
user_wallet: testWallet,
|
|
170
|
+
});
|
|
171
|
+
console.log(`✓ simulate_transaction: ${simulation.success ? `Success: ${simulation.data.simulation.success}` : simulation.error}`);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
console.log(`○ build_bet_transaction: Skipped (no active markets)`);
|
|
176
|
+
console.log(`○ simulate_transaction: Skipped`);
|
|
177
|
+
}
|
|
178
|
+
// Get race markets for testing
|
|
179
|
+
const raceMarkets = await testTool('list_race_markets', { status: 'Active' });
|
|
180
|
+
if (raceMarkets.success && raceMarkets.data.count > 0) {
|
|
181
|
+
const racePk = raceMarkets.data.markets[0].publicKey;
|
|
182
|
+
// build_race_bet_transaction
|
|
183
|
+
const raceBetTx = await testTool('build_race_bet_transaction', {
|
|
184
|
+
market: racePk,
|
|
185
|
+
outcome_index: 0,
|
|
186
|
+
amount_sol: 0.01,
|
|
187
|
+
user_wallet: testWallet,
|
|
188
|
+
});
|
|
189
|
+
console.log(`✓ build_race_bet_transaction: ${raceBetTx.success ? `TX built` : raceBetTx.error}`);
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
console.log(`○ build_race_bet_transaction: Skipped (no active race markets)`);
|
|
193
|
+
}
|
|
194
|
+
return { tested: true };
|
|
195
|
+
}
|
|
196
|
+
async function testClaimBuilding() {
|
|
197
|
+
console.log('\n💵 CLAIM BUILDING (Schema Only)');
|
|
198
|
+
console.log('─'.repeat(50));
|
|
199
|
+
// These require real positions, so just test error handling
|
|
200
|
+
const testWallet = '11111111111111111111111111111111';
|
|
201
|
+
const fakePda = '11111111111111111111111111111111';
|
|
202
|
+
// build_claim_winnings_transaction
|
|
203
|
+
const claimWin = await testTool('build_claim_winnings_transaction', {
|
|
204
|
+
market: fakePda,
|
|
205
|
+
position: fakePda,
|
|
206
|
+
user_wallet: testWallet,
|
|
207
|
+
});
|
|
208
|
+
console.log(`✓ build_claim_winnings_transaction: ${claimWin.success ? 'TX built' : 'Error as expected'}`);
|
|
209
|
+
// build_claim_refund_transaction
|
|
210
|
+
const claimRefund = await testTool('build_claim_refund_transaction', {
|
|
211
|
+
market: fakePda,
|
|
212
|
+
position: fakePda,
|
|
213
|
+
user_wallet: testWallet,
|
|
214
|
+
});
|
|
215
|
+
console.log(`✓ build_claim_refund_transaction: ${claimRefund.success ? 'TX built' : 'Error as expected'}`);
|
|
216
|
+
// build_claim_race_winnings_transaction
|
|
217
|
+
const claimRaceWin = await testTool('build_claim_race_winnings_transaction', {
|
|
218
|
+
race_market: fakePda,
|
|
219
|
+
position: fakePda,
|
|
220
|
+
user_wallet: testWallet,
|
|
221
|
+
});
|
|
222
|
+
console.log(`✓ build_claim_race_winnings_transaction: ${claimRaceWin.success ? 'TX built' : 'Handles error'}`);
|
|
223
|
+
// build_claim_race_refund_transaction
|
|
224
|
+
const claimRaceRefund = await testTool('build_claim_race_refund_transaction', {
|
|
225
|
+
race_market: fakePda,
|
|
226
|
+
position: fakePda,
|
|
227
|
+
user_wallet: testWallet,
|
|
228
|
+
});
|
|
229
|
+
console.log(`✓ build_claim_race_refund_transaction: ${claimRaceRefund.success ? 'TX built' : 'Handles error'}`);
|
|
230
|
+
return { tested: true };
|
|
231
|
+
}
|
|
232
|
+
async function testAffiliateBuilding() {
|
|
233
|
+
console.log('\n🔗 AFFILIATE BUILDING');
|
|
234
|
+
console.log('─'.repeat(50));
|
|
235
|
+
const testWallet = '11111111111111111111111111111111';
|
|
236
|
+
// build_register_affiliate_transaction (unique code)
|
|
237
|
+
const uniqueCode = `TEST${Date.now().toString(36).toUpperCase()}`;
|
|
238
|
+
const registerTx = await testTool('build_register_affiliate_transaction', {
|
|
239
|
+
code: uniqueCode,
|
|
240
|
+
user_wallet: testWallet,
|
|
241
|
+
});
|
|
242
|
+
console.log(`✓ build_register_affiliate_transaction: ${registerTx.success ? `Code: ${registerTx.data.code}` : registerTx.error}`);
|
|
243
|
+
// build_toggle_affiliate_transaction
|
|
244
|
+
const toggleTx = await testTool('build_toggle_affiliate_transaction', {
|
|
245
|
+
code: uniqueCode,
|
|
246
|
+
active: false,
|
|
247
|
+
user_wallet: testWallet,
|
|
248
|
+
});
|
|
249
|
+
console.log(`✓ build_toggle_affiliate_transaction: ${toggleTx.success ? 'TX built' : 'Handles error'}`);
|
|
250
|
+
return { tested: true };
|
|
251
|
+
}
|
|
252
|
+
// =============================================================================
|
|
253
|
+
// MAIN
|
|
254
|
+
// =============================================================================
|
|
255
|
+
async function runAllTests() {
|
|
256
|
+
console.log('═'.repeat(60));
|
|
257
|
+
console.log(' BAOZI MCP SERVER - FULL TEST SUITE');
|
|
258
|
+
console.log(` Version: 4.0.0 | Tools: ${TOOLS.length}`);
|
|
259
|
+
console.log('═'.repeat(60));
|
|
260
|
+
const results = {};
|
|
261
|
+
try {
|
|
262
|
+
results.marketReads = await testMarketReads();
|
|
263
|
+
results.marketCreation = await testMarketCreation();
|
|
264
|
+
results.positions = await testPositions();
|
|
265
|
+
results.resolution = await testResolution();
|
|
266
|
+
results.affiliates = await testAffiliates();
|
|
267
|
+
results.validation = await testValidation();
|
|
268
|
+
results.transactionBuilding = await testTransactionBuilding();
|
|
269
|
+
results.claimBuilding = await testClaimBuilding();
|
|
270
|
+
results.affiliateBuilding = await testAffiliateBuilding();
|
|
271
|
+
console.log('\n' + '═'.repeat(60));
|
|
272
|
+
console.log(' TEST SUMMARY');
|
|
273
|
+
console.log('═'.repeat(60));
|
|
274
|
+
console.log(` Total tools: ${TOOLS.length}`);
|
|
275
|
+
console.log(` Markets found: ${results.marketReads.markets}`);
|
|
276
|
+
console.log(` Race markets: ${results.marketReads.raceMarkets}`);
|
|
277
|
+
console.log(` Active affiliates: ${results.affiliates.totalAffiliates}`);
|
|
278
|
+
console.log(` Disputed: ${results.resolution.disputed}`);
|
|
279
|
+
console.log(` Awaiting resolution: ${results.resolution.awaiting}`);
|
|
280
|
+
console.log('═'.repeat(60));
|
|
281
|
+
console.log(' ✅ ALL TESTS COMPLETED');
|
|
282
|
+
console.log('═'.repeat(60));
|
|
283
|
+
}
|
|
284
|
+
catch (err) {
|
|
285
|
+
console.error('\n❌ TEST FAILED:', err);
|
|
286
|
+
process.exit(1);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
// Run tests
|
|
290
|
+
runAllTests();
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"full-test.js","sourceRoot":"","sources":["../../src/__tests__/full-test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Full MCP Server Test Suite\n *\n * Tests all 40 tools for correct responses\n */\nimport { Connection, PublicKey } from '@solana/web3.js';\nimport { handleTool, TOOLS } from '../tools.js';\nimport { RPC_ENDPOINT } from '../config.js';\n\nconst connection = new Connection(RPC_ENDPOINT, 'confirmed');\n\n// Test utilities\nfunction parseResponse(response: { content: Array<{ type: string; text: string }> }): any {\n  return JSON.parse(response.content[0].text);\n}\n\nasync function testTool(name: string, args: Record<string, unknown> = {}): Promise<{ success: boolean; data?: any; error?: string }> {\n  try {\n    const response = await handleTool(name, args);\n    const data = parseResponse(response);\n    return { success: data.success, data, error: data.error };\n  } catch (err) {\n    return { success: false, error: err instanceof Error ? err.message : 'Unknown error' };\n  }\n}\n\n// =============================================================================\n// TEST SUITES\n// =============================================================================\n\nasync function testMarketReads() {\n  console.log('\\n📊 MARKET READ OPERATIONS');\n  console.log('─'.repeat(50));\n\n  // list_markets\n  const markets = await testTool('list_markets');\n  console.log(`✓ list_markets: ${markets.success ? `${markets.data.count} markets` : markets.error}`);\n\n  // get_market (use first market if available)\n  if (markets.success && markets.data.count > 0) {\n    const marketPk = markets.data.markets[0].publicKey;\n    const market = await testTool('get_market', { publicKey: marketPk });\n    console.log(`✓ get_market: ${market.success ? market.data.market.question.substring(0, 40) + '...' : market.error}`);\n\n    // get_quote\n    const quote = await testTool('get_quote', { market: marketPk, side: 'Yes', amount: 0.1 });\n    console.log(`✓ get_quote: ${quote.success ? `${quote.data.quote.expectedPayoutSol?.toFixed(4)} SOL expected` : quote.error}`);\n  }\n\n  // list_race_markets\n  const raceMarkets = await testTool('list_race_markets');\n  console.log(`✓ list_race_markets: ${raceMarkets.success ? `${raceMarkets.data.count} race markets` : raceMarkets.error}`);\n\n  return { markets: markets.data?.count || 0, raceMarkets: raceMarkets.data?.count || 0 };\n}\n\nasync function testMarketCreation() {\n  console.log('\\n🏗️  MARKET CREATION');\n  console.log('─'.repeat(50));\n\n  // get_creation_fees\n  const fees = await testTool('get_creation_fees');\n  console.log(`✓ get_creation_fees: ${fees.success ? `Lab: ${fees.data.fees.lab.sol} SOL` : fees.error}`);\n\n  // get_platform_fees\n  const platformFees = await testTool('get_platform_fees');\n  console.log(`✓ get_platform_fees: ${platformFees.success ? `Lab: ${platformFees.data.fees.lab.percent}` : platformFees.error}`);\n\n  // get_timing_rules\n  const timing = await testTool('get_timing_rules');\n  console.log(`✓ get_timing_rules: ${timing.success ? `Min buffer: ${timing.data.rules.minEventBufferHours}h` : timing.error}`);\n\n  // generate_invite_hash\n  const invite = await testTool('generate_invite_hash');\n  console.log(`✓ generate_invite_hash: ${invite.success ? invite.data.inviteHash.substring(0, 16) + '...' : invite.error}`);\n\n  // preview_create_market\n  const closing = new Date(Date.now() + 7 * 24 * 60 * 60 * 1000).toISOString();\n  const event = new Date(Date.now() + 8 * 24 * 60 * 60 * 1000).toISOString();\n  const preview = await testTool('preview_create_market', {\n    question: 'Will BTC exceed 100K by end of Q1 2026?',\n    layer: 'lab',\n    closing_time: closing,\n    market_type: 'event',\n    event_time: event,\n    creator_wallet: '11111111111111111111111111111111',\n  });\n  console.log(`✓ preview_create_market: ${preview.success ? `Valid: ${preview.data.preview.validation.valid}` : preview.error}`);\n\n  return { valid: preview.data?.preview?.validation?.valid };\n}\n\nasync function testPositions() {\n  console.log('\\n💰 POSITIONS & CLAIMS');\n  console.log('─'.repeat(50));\n\n  // Use a known test wallet (system program as placeholder)\n  const testWallet = '11111111111111111111111111111111';\n\n  // get_positions\n  const positions = await testTool('get_positions', { wallet: testWallet });\n  console.log(`✓ get_positions: ${positions.success ? `${positions.data.totalPositions || 0} positions` : positions.error}`);\n\n  // get_claimable\n  const claimable = await testTool('get_claimable', { wallet: testWallet });\n  console.log(`✓ get_claimable: ${claimable.success ? `${claimable.data.totalClaimable || 0} claimable` : claimable.error}`);\n\n  return { positions: positions.data?.totalPositions || 0 };\n}\n\nasync function testResolution() {\n  console.log('\\n⚖️  RESOLUTION');\n  console.log('─'.repeat(50));\n\n  // get_disputed_markets\n  const disputed = await testTool('get_disputed_markets');\n  console.log(`✓ get_disputed_markets: ${disputed.success ? `${disputed.data.count} disputed` : disputed.error}`);\n\n  // get_markets_awaiting_resolution\n  const awaiting = await testTool('get_markets_awaiting_resolution');\n  console.log(`✓ get_markets_awaiting_resolution: ${awaiting.success ? `${awaiting.data.count} awaiting` : awaiting.error}`);\n\n  return { disputed: disputed.data?.count || 0, awaiting: awaiting.data?.count || 0 };\n}\n\nasync function testAffiliates() {\n  console.log('\\n🤝 AFFILIATES');\n  console.log('─'.repeat(50));\n\n  // check_affiliate_code\n  const codeCheck = await testTool('check_affiliate_code', { code: 'TESTCODE123' });\n  console.log(`✓ check_affiliate_code: ${codeCheck.success ? `Available: ${codeCheck.data.available}` : codeCheck.error}`);\n\n  // suggest_affiliate_codes\n  const suggestions = await testTool('suggest_affiliate_codes', { agentName: 'TestAgent', count: 3 });\n  console.log(`✓ suggest_affiliate_codes: ${suggestions.success ? suggestions.data.suggestions.slice(0, 2).join(', ') : suggestions.error}`);\n\n  // get_agent_network_stats\n  const stats = await testTool('get_agent_network_stats');\n  console.log(`✓ get_agent_network_stats: ${stats.success ? `${stats.data.totalAffiliates} affiliates` : stats.error}`);\n\n  // format_affiliate_link\n  const link = await testTool('format_affiliate_link', { code: 'TESTCODE' });\n  console.log(`✓ format_affiliate_link: ${link.success ? link.data.link : link.error}`);\n\n  // get_commission_info\n  const commission = await testTool('get_commission_info');\n  console.log(`✓ get_commission_info: ${commission.success ? `${commission.data.commissionBps} bps` : commission.error}`);\n\n  return { totalAffiliates: stats.data?.totalAffiliates || 0 };\n}\n\nasync function testValidation() {\n  console.log('\\n✅ VALIDATION');\n  console.log('─'.repeat(50));\n\n  // validate_market_params\n  const closing = new Date(Date.now() + 7 * 24 * 60 * 60 * 1000).toISOString();\n  const event = new Date(Date.now() + 8 * 24 * 60 * 60 * 1000).toISOString();\n  const marketValidation = await testTool('validate_market_params', {\n    question: 'Test market question?',\n    closing_time: closing,\n    market_type: 'event',\n    event_time: event,\n  });\n  console.log(`✓ validate_market_params: ${marketValidation.success ? `Valid: ${marketValidation.data.validation.valid}` : marketValidation.error}`);\n\n  // validate_bet (need a real market)\n  const markets = await testTool('list_markets', { status: 'Active' });\n  if (markets.success && markets.data.count > 0) {\n    const marketPk = markets.data.markets[0].publicKey;\n    const betValidation = await testTool('validate_bet', {\n      market: marketPk,\n      amount: 0.1,\n      side: 'Yes',\n    });\n    console.log(`✓ validate_bet: ${betValidation.success ? `Valid: ${betValidation.data.validation.valid}` : betValidation.error}`);\n  } else {\n    console.log(`○ validate_bet: Skipped (no active markets)`);\n  }\n\n  return { marketValidation: marketValidation.data?.validation?.valid };\n}\n\nasync function testTransactionBuilding() {\n  console.log('\\n🔨 TRANSACTION BUILDING');\n  console.log('─'.repeat(50));\n\n  const testWallet = '11111111111111111111111111111111';\n\n  // Get an active market for testing\n  const markets = await testTool('list_markets', { status: 'Active' });\n  if (markets.success && markets.data.count > 0) {\n    const marketPk = markets.data.markets[0].publicKey;\n\n    // build_bet_transaction\n    const betTx = await testTool('build_bet_transaction', {\n      market: marketPk,\n      outcome: 'yes',\n      amount_sol: 0.01,\n      user_wallet: testWallet,\n    });\n    console.log(`✓ build_bet_transaction: ${betTx.success ? `TX: ${betTx.data.transaction?.serialized?.substring(0, 20)}...` : betTx.error}`);\n\n    // simulate_transaction (if we got a tx)\n    if (betTx.success && betTx.data.transaction?.serialized) {\n      const simulation = await testTool('simulate_transaction', {\n        transaction: betTx.data.transaction.serialized,\n        user_wallet: testWallet,\n      });\n      console.log(`✓ simulate_transaction: ${simulation.success ? `Success: ${simulation.data.simulation.success}` : simulation.error}`);\n    }\n  } else {\n    console.log(`○ build_bet_transaction: Skipped (no active markets)`);\n    console.log(`○ simulate_transaction: Skipped`);\n  }\n\n  // Get race markets for testing\n  const raceMarkets = await testTool('list_race_markets', { status: 'Active' });\n  if (raceMarkets.success && raceMarkets.data.count > 0) {\n    const racePk = raceMarkets.data.markets[0].publicKey;\n\n    // build_race_bet_transaction\n    const raceBetTx = await testTool('build_race_bet_transaction', {\n      market: racePk,\n      outcome_index: 0,\n      amount_sol: 0.01,\n      user_wallet: testWallet,\n    });\n    console.log(`✓ build_race_bet_transaction: ${raceBetTx.success ? `TX built` : raceBetTx.error}`);\n  } else {\n    console.log(`○ build_race_bet_transaction: Skipped (no active race markets)`);\n  }\n\n  return { tested: true };\n}\n\nasync function testClaimBuilding() {\n  console.log('\\n💵 CLAIM BUILDING (Schema Only)');\n  console.log('─'.repeat(50));\n\n  // These require real positions, so just test error handling\n  const testWallet = '11111111111111111111111111111111';\n  const fakePda = '11111111111111111111111111111111';\n\n  // build_claim_winnings_transaction\n  const claimWin = await testTool('build_claim_winnings_transaction', {\n    market: fakePda,\n    position: fakePda,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_claim_winnings_transaction: ${claimWin.success ? 'TX built' : 'Error as expected'}`);\n\n  // build_claim_refund_transaction\n  const claimRefund = await testTool('build_claim_refund_transaction', {\n    market: fakePda,\n    position: fakePda,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_claim_refund_transaction: ${claimRefund.success ? 'TX built' : 'Error as expected'}`);\n\n  // build_claim_race_winnings_transaction\n  const claimRaceWin = await testTool('build_claim_race_winnings_transaction', {\n    race_market: fakePda,\n    position: fakePda,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_claim_race_winnings_transaction: ${claimRaceWin.success ? 'TX built' : 'Handles error'}`);\n\n  // build_claim_race_refund_transaction\n  const claimRaceRefund = await testTool('build_claim_race_refund_transaction', {\n    race_market: fakePda,\n    position: fakePda,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_claim_race_refund_transaction: ${claimRaceRefund.success ? 'TX built' : 'Handles error'}`);\n\n  return { tested: true };\n}\n\nasync function testAffiliateBuilding() {\n  console.log('\\n🔗 AFFILIATE BUILDING');\n  console.log('─'.repeat(50));\n\n  const testWallet = '11111111111111111111111111111111';\n\n  // build_register_affiliate_transaction (unique code)\n  const uniqueCode = `TEST${Date.now().toString(36).toUpperCase()}`;\n  const registerTx = await testTool('build_register_affiliate_transaction', {\n    code: uniqueCode,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_register_affiliate_transaction: ${registerTx.success ? `Code: ${registerTx.data.code}` : registerTx.error}`);\n\n  // build_toggle_affiliate_transaction\n  const toggleTx = await testTool('build_toggle_affiliate_transaction', {\n    code: uniqueCode,\n    active: false,\n    user_wallet: testWallet,\n  });\n  console.log(`✓ build_toggle_affiliate_transaction: ${toggleTx.success ? 'TX built' : 'Handles error'}`);\n\n  return { tested: true };\n}\n\n// =============================================================================\n// MAIN\n// =============================================================================\n\nasync function runAllTests() {\n  console.log('═'.repeat(60));\n  console.log('  BAOZI MCP SERVER - FULL TEST SUITE');\n  console.log(`  Version: 4.0.0 | Tools: ${TOOLS.length}`);\n  console.log('═'.repeat(60));\n\n  const results: Record<string, any> = {};\n\n  try {\n    results.marketReads = await testMarketReads();\n    results.marketCreation = await testMarketCreation();\n    results.positions = await testPositions();\n    results.resolution = await testResolution();\n    results.affiliates = await testAffiliates();\n    results.validation = await testValidation();\n    results.transactionBuilding = await testTransactionBuilding();\n    results.claimBuilding = await testClaimBuilding();\n    results.affiliateBuilding = await testAffiliateBuilding();\n\n    console.log('\\n' + '═'.repeat(60));\n    console.log('  TEST SUMMARY');\n    console.log('═'.repeat(60));\n    console.log(`  Total tools: ${TOOLS.length}`);\n    console.log(`  Markets found: ${results.marketReads.markets}`);\n    console.log(`  Race markets: ${results.marketReads.raceMarkets}`);\n    console.log(`  Active affiliates: ${results.affiliates.totalAffiliates}`);\n    console.log(`  Disputed: ${results.resolution.disputed}`);\n    console.log(`  Awaiting resolution: ${results.resolution.awaiting}`);\n    console.log('═'.repeat(60));\n    console.log('  ✅ ALL TESTS COMPLETED');\n    console.log('═'.repeat(60));\n\n  } catch (err) {\n    console.error('\\n❌ TEST FAILED:', err);\n    process.exit(1);\n  }\n}\n\n// Run tests\nrunAllTests();\n"]}
|