mintd_payment_processor.sh 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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. }
  46. # Set up trap to call cleanup on script exit
  47. trap cleanup EXIT
  48. # Create a temporary directory
  49. export CDK_ITESTS_DIR=$(mktemp -d)
  50. export CDK_ITESTS_MINT_ADDR="127.0.0.1";
  51. export CDK_ITESTS_MINT_PORT_0=8086;
  52. export LN_BACKEND="$1";
  53. URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0/v1/info"
  54. # Check if the temporary directory was created successfully
  55. if [[ ! -d "$CDK_ITESTS_DIR" ]]; then
  56. echo "Failed to create temp directory"
  57. exit 1
  58. fi
  59. echo "Temp directory created: $CDK_ITESTS_DIR"
  60. export MINT_DATABASE="$1";
  61. cargo build -p cdk-integration-tests
  62. export CDK_TEST_REGTEST=0
  63. if [ "$LN_BACKEND" != "FAKEWALLET" ]; then
  64. export CDK_TEST_REGTEST=1
  65. cargo run --bin start_regtest &
  66. CDK_REGTEST_PID=$!
  67. mkfifo "$CDK_ITESTS_DIR/progress_pipe"
  68. rm -f "$CDK_ITESTS_DIR/signal_received" # Ensure clean state
  69. # Start reading from pipe in background
  70. (while read line; do
  71. case "$line" in
  72. "checkpoint1")
  73. echo "Reached first checkpoint"
  74. touch "$CDK_ITESTS_DIR/signal_received"
  75. exit 0
  76. ;;
  77. esac
  78. done < "$CDK_ITESTS_DIR/progress_pipe") &
  79. # Wait for up to 120 seconds
  80. for ((i=0; i<120; i++)); do
  81. if [ -f "$CDK_ITESTS_DIR/signal_received" ]; then
  82. echo "break signal received"
  83. break
  84. fi
  85. sleep 1
  86. done
  87. echo "Regtest set up continuing"
  88. fi
  89. # Start payment processor
  90. export CDK_TEST_MINT_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0"
  91. export CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH="$CDK_ITESTS_DIR/cln/one/regtest/lightning-rpc";
  92. export CDK_PAYMENT_PROCESSOR_LND_ADDRESS="https://localhost:10010";
  93. export CDK_PAYMENT_PROCESSOR_LND_CERT_FILE="$CDK_ITESTS_DIR/lnd/two/tls.cert";
  94. export CDK_PAYMENT_PROCESSOR_LND_MACAROON_FILE="$CDK_ITESTS_DIR/lnd/two/data/chain/bitcoin/regtest/admin.macaroon";
  95. export CDK_PAYMENT_PROCESSOR_LN_BACKEND=$LN_BACKEND;
  96. export CDK_PAYMENT_PROCESSOR_LISTEN_HOST="127.0.0.1";
  97. export CDK_PAYMENT_PROCESSOR_LISTEN_PORT="8090";
  98. echo "$CDK_PAYMENT_PROCESSOR_CLN_RPC_PATH"
  99. cargo run --bin cdk-payment-processor &
  100. CDK_PAYMENT_PROCESSOR_PID=$!
  101. sleep 10;
  102. export CDK_MINTD_URL="http://$CDK_ITESTS_MINT_ADDR:$CDK_ITESTS_MINT_PORT_0";
  103. export CDK_MINTD_WORK_DIR="$CDK_ITESTS_DIR";
  104. export CDK_MINTD_LISTEN_HOST=$CDK_ITESTS_MINT_ADDR;
  105. export CDK_MINTD_LISTEN_PORT=$CDK_ITESTS_MINT_PORT_0;
  106. export CDK_MINTD_LN_BACKEND="grpcprocessor";
  107. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_ADDRESS="http://127.0.0.1";
  108. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_PORT="8090";
  109. export CDK_MINTD_GRPC_PAYMENT_PROCESSOR_SUPPORTED_UNITS="sat";
  110. export CDK_MINTD_MNEMONIC="eye survey guilt napkin crystal cup whisper salt luggage manage unveil loyal";
  111. cargo run --bin cdk-mintd --no-default-features --features grpc-processor &
  112. CDK_MINTD_PID=$!
  113. echo $CDK_ITESTS_DIR
  114. TIMEOUT=100
  115. START_TIME=$(date +%s)
  116. # Loop until the endpoint returns a 200 OK status or timeout is reached
  117. while true; do
  118. # Get the current time
  119. CURRENT_TIME=$(date +%s)
  120. # Calculate the elapsed time
  121. ELAPSED_TIME=$((CURRENT_TIME - START_TIME))
  122. # Check if the elapsed time exceeds the timeout
  123. if [ $ELAPSED_TIME -ge $TIMEOUT ]; then
  124. echo "Timeout of $TIMEOUT seconds reached. Exiting..."
  125. exit 1
  126. fi
  127. # Make a request to the endpoint and capture the HTTP status code
  128. HTTP_STATUS=$(curl -o /dev/null -s -w "%{http_code}" $URL)
  129. # Check if the HTTP status is 200 OK
  130. if [ "$HTTP_STATUS" -eq 200 ]; then
  131. echo "Received 200 OK from $URL"
  132. break
  133. else
  134. echo "Waiting for 200 OK response, current status: $HTTP_STATUS"
  135. sleep 2 # Wait for 2 seconds before retrying
  136. fi
  137. done
  138. cargo test -p cdk-integration-tests --test happy_path_mint_wallet
  139. # Capture the exit status of cargo test
  140. test_status=$?
  141. # Exit with the status of the tests
  142. exit $test_status