mintd_payment_processor.sh 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  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 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 b --bin cdk-payment-processor
  102. cargo run --bin cdk-payment-processor &
  103. CDK_PAYMENT_PROCESSOR_PID=$!
  104. sleep 10;
  105. export CDK_MINTD_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0";
  106. export CDK_MINTD_WORK_DIR="$CDK_ITESTS_DIR";
  107. export CDK_MINTD_LISTEN_HOST=$CDK_ITESTS_MINT_ADDR;
  108. export CDK_MINTD_LISTEN_PORT=$CDK_ITESTS_MINT_PORT_0;
  109. export CDK_MINTD_LN_BACKEND="grpcprocessor";
  110. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_ADDRESS="http://127.0.0.1";
  111. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_PORT="8090";
  112. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_SUPPORTED_UNITS="sat";
  113. export CDK_MINTD_MNEMONIC="eye survey guilt napkin crystal cup whisper salt luggage manage unveil loyal";
  114. cargo run --bin cdk-mintd --no-default-features --features grpc-processor &
  115. CDK_MINTD_PID=$!
  116. echo $CDK_ITESTS_DIR
  117. TIMEOUT=100
  118. START_TIME=$(date +%s)
  119. # Loop until the endpoint returns a 200 OK status or timeout is reached
  120. while true; do
  121. # Get the current time
  122. CURRENT_TIME=$(date +%s)
  123. # Calculate the elapsed time
  124. ELAPSED_TIME=$((CURRENT_TIME - START_TIME))
  125. # Check if the elapsed time exceeds the timeout
  126. if [ $ELAPSED_TIME -ge $TIMEOUT ]; then
  127. echo "Timeout of $TIMEOUT seconds reached. Exiting..."
  128. exit 1
  129. fi
  130. # Make a request to the endpoint and capture the HTTP status code
  131. HTTP_STATUS=$(curl -o /dev/null -s -w "%{http_code}" $URL)
  132. # Check if the HTTP status is 200 OK
  133. if [ "$HTTP_STATUS" -eq 200 ]; then
  134. echo "Received 200 OK from $URL"
  135. break
  136. else
  137. echo "Waiting for 200 OK response, current status: $HTTP_STATUS"
  138. sleep 2 # Wait for 2 seconds before retrying
  139. fi
  140. done
  141. cargo test -p cdk-integration-tests --test happy_path_mint_wallet
  142. # Capture the exit status of cargo test
  143. test_status=$?
  144. if [ "$LN_BACKEND" = "CLN" ]; then
  145. echo "Running bolt12 tests for CLN backend"
  146. cargo test -p cdk-integration-tests --test bolt12
  147. bolt12_test_status=$?
  148. # Exit with non-zero status if either test failed
  149. if [ $test_status -ne 0 ] || [ $bolt12_test_status -ne 0 ]; then
  150. echo "Tests failed - happy_path_mint_wallet: $test_status, bolt12: $bolt12_test_status"
  151. exit 1
  152. fi
  153. fi
  154. # Exit with the status of the tests
  155. exit $test_status