mintd_payment_processor.sh 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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 &
  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 120 seconds
  81. for ((i=0; i<120; i++)); do
  82. if [ -f "$CDK_ITESTS_DIR/signal_received" ]; then
  83. echo "break signal received"
  84. break
  85. fi
  86. sleep 1
  87. done
  88. echo "Regtest set up continuing"
  89. export CDK_PAYMENT_PROCESSOR_CLN_BOLT12=true
  90. fi
  91. # Start payment processor
  92. export CDK_TEST_MINT_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0"
  93. export CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH="$CDK_ITESTS_DIR/cln/one/regtest/lightning-rpc";
  94. export CDK_PAYMENT_PROCESSOR_LND_ADDRESS="https://localhost:10010";
  95. export CDK_PAYMENT_PROCESSOR_LND_CERT_FILE="$CDK_ITESTS_DIR/lnd/two/tls.cert";
  96. export CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE="$CDK_ITESTS_DIR/lnd/two/data/chain/bitcoin/regtest/admin.macaroon";
  97. export CDK_PAYMENT_PROCESSOR_LN_BACKEND=$LN_BACKEND;
  98. export CDK_PAYMENT_PROCESSOR_LISTEN_HOST="127.0.0.1";
  99. export CDK_PAYMENT_PROCESSOR_LISTEN_PORT="8090";
  100. echo "$CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH"
  101. cargo run --bin cdk-payment-processor &
  102. CDK_PAYMENT_PROCESSOR_PID=$!
  103. sleep 10;
  104. export CDK_MINTD_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0";
  105. export CDK_MINTD_WORK_DIR="$CDK_ITESTS_DIR";
  106. export CDK_MINTD_LISTEN_HOST=$CDK_ITESTS_MINT_ADDR;
  107. export CDK_MINTD_LISTEN_PORT=$CDK_ITESTS_MINT_PORT_0;
  108. export CDK_MINTD_LN_BACKEND="grpcprocessor";
  109. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_ADDRESS="http://127.0.0.1";
  110. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_PORT="8090";
  111. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_SUPPORTED_UNITS="sat";
  112. export CDK_MINTD_MNEMONIC="eye survey guilt napkin crystal cup whisper salt luggage manage unveil loyal";
  113. cargo run --bin cdk-mintd --no-default-features --features grpc-processor &
  114. CDK_MINTD_PID=$!
  115. echo $CDK_ITESTS_DIR
  116. TIMEOUT=100
  117. START_TIME=$(date +%s)
  118. # Loop until the endpoint returns a 200 OK status or timeout is reached
  119. while true; do
  120. # Get the current time
  121. CURRENT_TIME=$(date +%s)
  122. # Calculate the elapsed time
  123. ELAPSED_TIME=$((CURRENT_TIME - START_TIME))
  124. # Check if the elapsed time exceeds the timeout
  125. if [ $ELAPSED_TIME -ge $TIMEOUT ]; then
  126. echo "Timeout of $TIMEOUT seconds reached. Exiting..."
  127. exit 1
  128. fi
  129. # Make a request to the endpoint and capture the HTTP status code
  130. HTTP_STATUS=$(curl -o /dev/null -s -w "%{http_code}" $URL)
  131. # Check if the HTTP status is 200 OK
  132. if [ "$HTTP_STATUS" -eq 200 ]; then
  133. echo "Received 200 OK from $URL"
  134. break
  135. else
  136. echo "Waiting for 200 OK response, current status: $HTTP_STATUS"
  137. sleep 2 # Wait for 2 seconds before retrying
  138. fi
  139. done
  140. cargo test -p cdk-integration-tests --test happy_path_mint_wallet
  141. # Capture the exit status of cargo test
  142. test_status=$?
  143. if [ "$LN_BACKEND" = "CLN" ]; then
  144. echo "Running bolt12 tests for CLN backend"
  145. cargo test -p cdk-integration-tests --test bolt12
  146. bolt12_test_status=$?
  147. # Exit with non-zero status if either test failed
  148. if [ $test_status -ne 0 ] || [ $bolt12_test_status -ne 0 ]; then
  149. echo "Tests failed - happy_path_mint_wallet: $test_status, bolt12: $bolt12_test_status"
  150. exit 1
  151. fi
  152. fi
  153. # Exit with the status of the tests
  154. exit $test_status