- Organized 252 files across project - Root directory: 187 → 2 files (98.9% reduction) - Moved configuration guides to docs/04-configuration/ - Moved troubleshooting guides to docs/09-troubleshooting/ - Moved quick start guides to docs/01-getting-started/ - Moved reports to reports/ directory - Archived temporary files - Generated comprehensive reports and documentation - Created maintenance scripts and guides All files organized according to established standards.
217 lines
6.8 KiB
Bash
Executable File
217 lines
6.8 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Test bridge transfers to destination chains
|
|
# Usage: ./test-bridge-transfers.sh [chain] [amount] [token]
|
|
# Example: ./test-bridge-transfers.sh bsc 0.01 weth9
|
|
|
|
set -euo pipefail
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
|
|
SOURCE_PROJECT="/home/intlc/projects/smom-dbis-138"
|
|
|
|
# Colors
|
|
RED='\033[0;31m'
|
|
GREEN='\033[0;32m'
|
|
YELLOW='\033[1;33m'
|
|
BLUE='\033[0;34m'
|
|
NC='\033[0m'
|
|
|
|
log_info() { echo -e "${BLUE}[INFO]${NC} $1"; }
|
|
log_success() { echo -e "${GREEN}[✓]${NC} $1"; }
|
|
log_warn() { echo -e "${YELLOW}[WARN]${NC} $1"; }
|
|
log_error() { echo -e "${RED}[ERROR]${NC} $1"; }
|
|
|
|
# Load environment variables
|
|
if [ -f "$SOURCE_PROJECT/.env" ]; then
|
|
source "$SOURCE_PROJECT/.env"
|
|
else
|
|
log_error ".env file not found in $SOURCE_PROJECT"
|
|
exit 1
|
|
fi
|
|
|
|
# Configuration
|
|
RPC_URL="${RPC_URL_138:-http://192.168.11.250:8545}"
|
|
WETH9_ADDRESS="0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2"
|
|
WETH10_ADDRESS="0xf4BB2e28688e89fCcE3c0580D37d36A7672E8A9f"
|
|
WETH9_BRIDGE="${CCIPWETH9_BRIDGE_CHAIN138:-0x89dd12025bfCD38A168455A44B400e913ED33BE2}"
|
|
WETH10_BRIDGE="${CCIPWETH10_BRIDGE_CHAIN138:-0xe0E93247376aa097dB308B92e6Ba36bA015535D0}"
|
|
|
|
# Destination chain configurations
|
|
declare -A CHAIN_SELECTORS=(
|
|
["bsc"]="11344663589394136015"
|
|
["polygon"]="4051577828743386545"
|
|
["avalanche"]="6433500567565415381"
|
|
["base"]="15971525489660198786"
|
|
["arbitrum"]="4949039107694359620"
|
|
["optimism"]="3734403246176062136"
|
|
)
|
|
|
|
declare -A CHAIN_NAMES=(
|
|
["bsc"]="BSC"
|
|
["polygon"]="Polygon"
|
|
["avalanche"]="Avalanche"
|
|
["base"]="Base"
|
|
["arbitrum"]="Arbitrum"
|
|
["optimism"]="Optimism"
|
|
)
|
|
|
|
# Parse arguments
|
|
CHAIN="${1:-}"
|
|
AMOUNT="${2:-0.01}"
|
|
TOKEN="${3:-weth9}"
|
|
|
|
if [ -z "$CHAIN" ]; then
|
|
log_info "Usage: $0 [chain] [amount] [token]"
|
|
log_info "Chains: bsc, polygon, avalanche, base, arbitrum, optimism"
|
|
log_info "Example: $0 bsc 0.01 weth9"
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${CHAIN_SELECTORS[$CHAIN]:-}" ]; then
|
|
log_error "Invalid chain: $CHAIN"
|
|
log_info "Valid chains: bsc, polygon, avalanche, base, arbitrum, optimism"
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${PRIVATE_KEY:-}" ]; then
|
|
log_error "PRIVATE_KEY not set in .env file"
|
|
exit 1
|
|
fi
|
|
|
|
SELECTOR="${CHAIN_SELECTORS[$CHAIN]}"
|
|
CHAIN_NAME="${CHAIN_NAMES[$CHAIN]}"
|
|
|
|
# Determine token and bridge
|
|
if [ "$TOKEN" = "weth9" ]; then
|
|
TOKEN_ADDRESS="$WETH9_ADDRESS"
|
|
BRIDGE_ADDRESS="$WETH9_BRIDGE"
|
|
TOKEN_NAME="WETH9"
|
|
elif [ "$TOKEN" = "weth10" ]; then
|
|
TOKEN_ADDRESS="$WETH10_ADDRESS"
|
|
BRIDGE_ADDRESS="$WETH10_BRIDGE"
|
|
TOKEN_NAME="WETH10"
|
|
else
|
|
log_error "Invalid token: $TOKEN (use weth9 or weth10)"
|
|
exit 1
|
|
fi
|
|
|
|
log_info "========================================="
|
|
log_info "Test Bridge Transfer"
|
|
log_info "========================================="
|
|
log_info ""
|
|
log_info "Configuration:"
|
|
log_info " Destination: $CHAIN_NAME (Selector: $SELECTOR)"
|
|
log_info " Token: $TOKEN_NAME"
|
|
log_info " Amount: $AMOUNT ETH"
|
|
log_info " Bridge: $BRIDGE_ADDRESS"
|
|
log_info " RPC: $RPC_URL"
|
|
log_info ""
|
|
|
|
# Get deployer address
|
|
DEPLOYER=$(cast wallet address --private-key "$PRIVATE_KEY" 2>/dev/null || echo "")
|
|
if [ -z "$DEPLOYER" ]; then
|
|
log_error "Failed to get deployer address"
|
|
exit 1
|
|
fi
|
|
|
|
log_info "Deployer: $DEPLOYER"
|
|
log_info ""
|
|
|
|
# Step 1: Check ETH balance
|
|
log_info "Step 1: Checking ETH balance..."
|
|
ETH_BALANCE=$(cast balance "$DEPLOYER" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
ETH_BALANCE_ETH=$(echo "scale=6; $ETH_BALANCE / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
log_info "ETH Balance: $ETH_BALANCE_ETH ETH"
|
|
|
|
if (( $(echo "$ETH_BALANCE_ETH < $AMOUNT" | bc -l 2>/dev/null || echo 1) )); then
|
|
log_error "Insufficient ETH balance. Need at least $AMOUNT ETH"
|
|
exit 1
|
|
fi
|
|
|
|
# Step 2: Wrap ETH to WETH
|
|
log_info ""
|
|
log_info "Step 2: Wrapping $AMOUNT ETH to $TOKEN_NAME..."
|
|
AMOUNT_WEI=$(cast --to-wei "$AMOUNT" ether 2>/dev/null || echo "")
|
|
|
|
if [ -z "$AMOUNT_WEI" ]; then
|
|
log_error "Failed to convert amount to wei"
|
|
exit 1
|
|
fi
|
|
|
|
if [ "$TOKEN" = "weth9" ]; then
|
|
WRAP_TX=$(cast send "$TOKEN_ADDRESS" "deposit()" --value "$AMOUNT_WEI" --rpc-url "$RPC_URL" --private-key "$PRIVATE_KEY" 2>&1 || echo "")
|
|
else
|
|
WRAP_TX=$(cast send "$TOKEN_ADDRESS" "deposit()" --value "$AMOUNT_WEI" --rpc-url "$RPC_URL" --private-key "$PRIVATE_KEY" 2>&1 || echo "")
|
|
fi
|
|
|
|
if echo "$WRAP_TX" | grep -qE "(blockHash|transactionHash)"; then
|
|
log_success "✓ ETH wrapped to $TOKEN_NAME"
|
|
sleep 2 # Wait for transaction to be mined
|
|
else
|
|
log_error "Failed to wrap ETH"
|
|
log_info "Output: $WRAP_TX"
|
|
exit 1
|
|
fi
|
|
|
|
# Step 3: Approve bridge
|
|
log_info ""
|
|
log_info "Step 3: Approving bridge to spend $TOKEN_NAME..."
|
|
APPROVE_TX=$(cast send "$TOKEN_ADDRESS" "approve(address,uint256)" "$BRIDGE_ADDRESS" "$AMOUNT_WEI" --rpc-url "$RPC_URL" --private-key "$PRIVATE_KEY" 2>&1 || echo "")
|
|
|
|
if echo "$APPROVE_TX" | grep -qE "(blockHash|transactionHash)"; then
|
|
log_success "✓ Bridge approved"
|
|
sleep 2
|
|
else
|
|
log_error "Failed to approve bridge"
|
|
log_info "Output: $APPROVE_TX"
|
|
exit 1
|
|
fi
|
|
|
|
# Step 4: Calculate fee
|
|
log_info ""
|
|
log_info "Step 4: Calculating CCIP fee..."
|
|
FEE=$(cast call "$BRIDGE_ADDRESS" "calculateFee(uint64,uint256)" "$SELECTOR" "$AMOUNT_WEI" --rpc-url "$RPC_URL" 2>/dev/null || echo "0")
|
|
FEE_ETH=$(echo "scale=10; $FEE / 1000000000000000000" | bc 2>/dev/null || echo "0")
|
|
log_info "Fee: $FEE_ETH ETH ($FEE wei)"
|
|
|
|
# Step 5: Send cross-chain transfer
|
|
log_info ""
|
|
log_info "Step 5: Sending cross-chain transfer to $CHAIN_NAME..."
|
|
log_info " Recipient: $DEPLOYER (same address on destination)"
|
|
log_info " Amount: $AMOUNT $TOKEN_NAME"
|
|
|
|
SEND_TX=$(cast send "$BRIDGE_ADDRESS" "sendCrossChain(uint64,address,uint256)" "$SELECTOR" "$DEPLOYER" "$AMOUNT_WEI" --rpc-url "$RPC_URL" --private-key "$PRIVATE_KEY" 2>&1 || echo "")
|
|
|
|
if echo "$SEND_TX" | grep -qE "transactionHash"; then
|
|
TX_HASH=$(echo "$SEND_TX" | grep -oE "transactionHash[[:space:]]+0x[0-9a-fA-F]{64}" | awk '{print $2}' || echo "")
|
|
if [ -n "$TX_HASH" ]; then
|
|
log_success "✓ Transfer initiated"
|
|
log_info "Transaction Hash: $TX_HASH"
|
|
log_info ""
|
|
log_info "Monitor transfer:"
|
|
log_info " - Check events on source chain"
|
|
log_info " - Wait for CCIP processing (1-5 minutes)"
|
|
log_info " - Check destination chain for receipt"
|
|
else
|
|
log_warn "Transfer initiated but could not extract transaction hash"
|
|
log_info "Output: $SEND_TX"
|
|
fi
|
|
else
|
|
log_error "Failed to send cross-chain transfer"
|
|
log_info "Output: $SEND_TX"
|
|
exit 1
|
|
fi
|
|
|
|
log_info ""
|
|
log_success "========================================="
|
|
log_success "Test Transfer Complete!"
|
|
log_success "========================================="
|
|
log_info ""
|
|
log_info "Summary:"
|
|
log_info " Destination: $CHAIN_NAME"
|
|
log_info " Token: $TOKEN_NAME"
|
|
log_info " Amount: $AMOUNT ETH"
|
|
log_info " Transaction: $TX_HASH"
|
|
log_info ""
|
|
|