mintd_payment_processor.sh 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. #!/usr/bin/env bash
  2. # Function to perform cleanup
  3. cleanup() {
  4. echo "Cleaning up..."
  5. echo "Killing the cdk payment processor"
  6. kill -2 $CDK_PAYMENT_PROCESSOR_PID
  7. wait $CDK_PAYMENT_PROCESSOR_PID
  8. echo "Killing the cdk mintd"
  9. kill -2 $CDK_MINTD_PID
  10. wait $CDK_MINTD_PID
  11. echo "Killing the cdk regtest"
  12. kill -2 $CDK_REGTEST_PID
  13. wait $CDK_REGTEST_PID
  14. echo "Mint binary terminated"
  15. # Remove the temporary directory
  16. rm -rf "$CDK_ITESTS_DIR"
  17. echo "Temp directory removed: $CDK_ITESTS_DIR"
  18. # Unset all environment variables that were set
  19. unset CDK_ITESTS_DIR
  20. unset CDK_ITESTS_MINT_ADDR
  21. unset CDK_ITESTS_MINT_PORT_0
  22. unset CDK_REGTEST_PID
  23. unset LN_BACKEND
  24. unset MINT_DATABASE
  25. unset CDK_TEST_REGTEST
  26. unset CDK_TEST_MINT_URL
  27. unset CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH
  28. unset CDK_PAYMENT_PROCESSOR_LND_ADDRESS
  29. unset CDK_PAYMENT_PROCESSOR_LND_CERT_FILE
  30. unset CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE
  31. unset CDK_PAYMENT_PROCESSOR_LN_BACKEND
  32. unset CDK_PAYMENT_PROCESSOR_LISTEN_HOST
  33. unset CDK_PAYMENT_PROCESSOR_LISTEN_PORT
  34. unset CDK_PAYMENT_PROCESSOR_PID
  35. unset CDK_MINTD_URL
  36. unset CDK_MINTD_WORK_DIR
  37. unset CDK_MINTD_LISTEN_HOST
  38. unset CDK_MINTD_LISTEN_PORT
  39. unset CDK_MINTD_LN_BACKEND
  40. unset CDK_MINTD_GRPC_PAYMENT_PROCESSOR_ADDRESS
  41. unset CDK_MINTD_GRPC_PAYMENT_PROCESSOR_PORT
  42. unset CDK_MINTD_GRPC_PAYMENT_PROCESSOR_SUPPORTED_UNITS
  43. unset CDK_MINTD_MNEMONIC
  44. unset CDK_MINTD_PID
  45. unset CDK_PAYMENT_PROCESSOR_CLN_BOLT12
  46. }
  47. # Set up trap to call cleanup on script exit
  48. trap cleanup EXIT
  49. # Create a temporary directory
  50. export CDK_ITESTS_DIR=$(mktemp -d)
  51. export CDK_ITESTS_MINT_ADDR="127.0.0.1";
  52. export CDK_ITESTS_MINT_PORT_0=8086;
  53. export LN_BACKEND="$1";
  54. URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0/v1/info"
  55. # Check if the temporary directory was created successfully
  56. if [[ ! -d "$CDK_ITESTS_DIR" ]]; then
  57. echo "Failed to create temp directory"
  58. exit 1
  59. fi
  60. echo "Temp directory created: $CDK_ITESTS_DIR"
  61. export MINT_DATABASE="$1";
  62. cargo build -p cdk-integration-tests
  63. export CDK_TEST_REGTEST=0
  64. if [ "$LN_BACKEND" != "FAKEWALLET" ]; then
  65. export CDK_TEST_REGTEST=1
  66. cargo run --bin start_regtest "$CDK_ITESTS_DIR" &
  67. CDK_REGTEST_PID=$!
  68. mkfifo "$CDK_ITESTS_DIR/progress_pipe"
  69. rm -f "$CDK_ITESTS_DIR/signal_received" # Ensure clean state
  70. # Start reading from pipe in background
  71. (while read line; do
  72. case "$line" in
  73. "checkpoint1")
  74. echo "Reached first checkpoint"
  75. touch "$CDK_ITESTS_DIR/signal_received"
  76. exit 0
  77. ;;
  78. esac
  79. done < "$CDK_ITESTS_DIR/progress_pipe") &
  80. # Wait for up to 300 seconds (5 minutes) for regtest setup
  81. # This needs to be long enough for cargo to compile start_regtest binary
  82. for ((i=0; i<300; i++)); do
  83. if [ -f "$CDK_ITESTS_DIR/signal_received" ]; then
  84. echo "Checkpoint signal received"
  85. break
  86. fi
  87. sleep 1
  88. done
  89. # Check if we actually received the signal or timed out
  90. if [ ! -f "$CDK_ITESTS_DIR/signal_received" ]; then
  91. echo "Timeout waiting for regtest setup after 300 seconds"
  92. exit 1
  93. fi
  94. echo "Regtest set up continuing"
  95. export CDK_PAYMENT_PROCESSOR_CLN_BOLT12=true
  96. fi
  97. # Start payment processor
  98. export CDK_TEST_MINT_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0"
  99. export CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH="$CDK_ITESTS_DIR/cln/one/regtest/lightning-rpc";
  100. export CDK_PAYMENT_PROCESSOR_LND_ADDRESS="https://localhost:10010";
  101. export CDK_PAYMENT_PROCESSOR_LND_CERT_FILE="$CDK_ITESTS_DIR/lnd/two/tls.cert";
  102. export CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE="$CDK_ITESTS_DIR/lnd/two/data/chain/bitcoin/regtest/admin.macaroon";
  103. export CDK_PAYMENT_PROCESSOR_LN_BACKEND=$LN_BACKEND;
  104. export CDK_PAYMENT_PROCESSOR_LISTEN_HOST="127.0.0.1";
  105. export CDK_PAYMENT_PROCESSOR_LISTEN_PORT="8090";
  106. echo "$CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH"
  107. # Wait for LND certificate and macaroon files to exist (only if using LND backend)
  108. if [ "$LN_BACKEND" = "LND" ]; then
  109. echo "Waiting for LND certificate and macaroon files..."
  110. CERT_TIMEOUT=120
  111. CERT_START_TIME=$(date +%s)
  112. while [ ! -f "$CDK_PAYMENT_PROCESSOR_LND_CERT_FILE" ] || [ ! -f "$CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE" ]; do
  113. CURRENT_TIME=$(date +%s)
  114. ELAPSED_TIME=$((CURRENT_TIME - CERT_START_TIME))
  115. if [ $ELAPSED_TIME -ge $CERT_TIMEOUT ]; then
  116. echo "Timeout waiting for LND files after $CERT_TIMEOUT seconds"
  117. echo "Expected cert file: $CDK_PAYMENT_PROCESSOR_LND_CERT_FILE"
  118. echo "Expected macaroon file: $CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE"
  119. exit 1
  120. fi
  121. sleep 0.5
  122. done
  123. echo "LND certificate and macaroon files found"
  124. fi
  125. cargo b --bin cdk-payment-processor
  126. cargo run --bin cdk-payment-processor &
  127. CDK_PAYMENT_PROCESSOR_PID=$!
  128. export CDK_MINTD_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0";
  129. export CDK_MINTD_WORK_DIR="$CDK_ITESTS_DIR";
  130. export CDK_MINTD_LISTEN_HOST=$CDK_ITESTS_MINT_ADDR;
  131. export CDK_MINTD_LISTEN_PORT=$CDK_ITESTS_MINT_PORT_0;
  132. export CDK_MINTD_LN_BACKEND="grpcprocessor";
  133. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_ADDRESS="http://127.0.0.1";
  134. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_PORT="8090";
  135. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_SUPPORTED_UNITS="sat";
  136. export CDK_MINTD_MNEMONIC="eye survey guilt napkin crystal cup whisper salt luggage manage unveil loyal";
  137. cargo build --bin cdk-mintd --no-default-features --features grpc-processor
  138. cargo run --bin cdk-mintd --no-default-features --features grpc-processor &
  139. CDK_MINTD_PID=$!
  140. echo $CDK_ITESTS_DIR
  141. TIMEOUT=300
  142. START_TIME=$(date +%s)
  143. # Loop until the endpoint returns a 200 OK status or timeout is reached
  144. while true; do
  145. # Get the current time
  146. CURRENT_TIME=$(date +%s)
  147. # Calculate the elapsed time
  148. ELAPSED_TIME=$((CURRENT_TIME - START_TIME))
  149. # Check if the elapsed time exceeds the timeout
  150. if [ $ELAPSED_TIME -ge $TIMEOUT ]; then
  151. echo "Timeout of $TIMEOUT seconds reached. Exiting..."
  152. exit 1
  153. fi
  154. # Make a request to the endpoint and capture the HTTP status code
  155. HTTP_STATUS=$(curl -o /dev/null -s -w "%{http_code}" $URL)
  156. # Check if the HTTP status is 200 OK
  157. if [ "$HTTP_STATUS" -eq 200 ]; then
  158. echo "Received 200 OK from $URL"
  159. break
  160. else
  161. echo "Waiting for 200 OK response, current status: $HTTP_STATUS"
  162. sleep 2 # Wait for 2 seconds before retrying
  163. fi
  164. done
  165. cargo test -p cdk-integration-tests --test happy_path_mint_wallet
  166. # Capture the exit status of cargo test
  167. test_status=$?
  168. if [ "$LN_BACKEND" = "CLN" ]; then
  169. echo "Running bolt12 tests for CLN backend"
  170. cargo test -p cdk-integration-tests --test bolt12
  171. bolt12_test_status=$?
  172. # Exit with non-zero status if either test failed
  173. if [ $test_status -ne 0 ] || [ $bolt12_test_status -ne 0 ]; then
  174. echo "Tests failed - happy_path_mint_wallet: $test_status, bolt12: $bolt12_test_status"
  175. exit 1
  176. fi
  177. fi
  178. # Exit with the status of the tests
  179. exit $test_status