Skip to content

Commit

Permalink
feat(ci): adjusts mining-tests
Browse files Browse the repository at this point in the history
  • Loading branch information
jurajpiar committed May 7, 2024
1 parent acc1c99 commit 7967b6a
Show file tree
Hide file tree
Showing 2 changed files with 227 additions and 58 deletions.
87 changes: 87 additions & 0 deletions .github/mining-test/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
#!/bin/bash

#echo "create docker network for bitcoin nodes exposing it to host"
#sudo docker network create bitcoin-network
#docker network ls
#docker network inspect bitcoin-network
#docker network connect bitcoin-network bitcoind01
#docker network connect bitcoin-network bitcoind02

#sudo docker run -d --network bitcoin-network --name bitcoind01 -p 31591:31591 -p 32591:32591 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31591 -connect=localhost:31592 -rpcbind=0.0.0.0:32591 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
#sudo docker run -d --network bitcoin-network --name bitcoind02 -p 31592:31592 -p 32592:32592 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31592 -connect=localhost:31591 -rpcbind=0.0.0.0:32592 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin

sudo docker run -d --name bitcoind01 -p 31591:31591 -p 32591:32591 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31591 -connect=localhost:31592 -rpcbind=0.0.0.0:32591 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
sudo docker run -d --name bitcoind02 -p 31592:31592 -p 32592:32592 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31592 -connect=localhost:31591 -rpcbind=0.0.0.0:32592 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin

while ! docker ps --format "{{.Names}}" | grep -wq bitcoind01; do
echo "Waiting for container bitcoind01 to start..."
sleep 5 # Wait for 5 seconds before checking again
done
echo "bitcoind01 container is running."

while ! docker ps --format "{{.Names}}" | grep -wq bitcoind02; do
echo "Waiting for container bitcoind02 to start..."
sleep 5 # Wait for 5 seconds before checking again
done
echo "bitcoind02 container is running."

#echo "Verify nodes are attached to the network"
#docker network ls
#docker network inspect bitcoin-network
#if ! docker network inspect bitcoin-network | grep -q "\"Name\": \"bitcoind01\""; then
# echo "bitcoind01 is not on the network"
# exit 1
#fi
#if ! docker network inspect bitcoin-network | grep -q "\"Name\": \"bitcoind02\""; then
# echo "bitcoind02 is not on the network"
# exit 1
#fi

ports=(31591 32591 31592 32592)
for port in "${ports[@]}"; do
if ! sudo lsof -i:$port -sTCP:LISTEN > /dev/null; then
echo "Error: No process is listening on port $port"
exit 1
fi
done
echo "Success: All specified ports are being listened to."


echo Test bitcoin node 1
curl -s -u admin:admin --data-binary '{"jsonrpc":"1.0","id":"curltext","method":"getblockchaininfo","params":[]}' -H 'content-type:text/plain;' http://localhost:32591 --fail
if [ $? -ne 0 ]; then
echo "Error: Failed to connect to the Bitcoin bitcoind01 node"
exit 1
fi
echo Test bitcoin node 2
curl -s -u admin:admin --data-binary '{"jsonrpc":"1.0","id":"curltext","method":"getblockchaininfo","params":[]}' -H 'content-type:text/plain;' http://localhost:32592 --fail
if [ $? -ne 0 ]; then
echo "Error: Failed to connect to the Bitcoin bitcoind02 node"
exit 1
fi
#
#echo "Linking btc nodes to localhost"
#echo "127.0.0.1 bitcoind01" | sudo tee -a /etc/host
#echo "127.0.0.1 bitcoind02" | sudo tee -a /etc/host
#echo "/etc/hosts"
#cat /etc/hosts

echo "Modify test suite config"
# shellcheck disable=SC2046
echo "bitcoind url before"
jq -r 'bitcoind.url' "mining-integration-tests/config.json"
jq --arg new_url "localhost" '.bitcoind.url = $new_url' "mining-integration-tests/config.json" > temp.json && mv temp.json "mining-integration-tests/config.json"
echo "bitcoind url after"
jq -r 'bitcoind.url' "mining-integration-tests/config.json"

echo "Generate BTC blocks"

echo "Inside mining-integration-tests"
cd mining-integration-tests || echo "mining-integration-tests does not exist in $(pwd)}" && echo "content:" && ls -al && exit 1

echo "Generate bitcoin blocks"
node generateBtcBlocks.js

echo "And run tests"
npm test

198 changes: 140 additions & 58 deletions .github/workflows/build_and_test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ jobs:
with:
path: |
build
key: ${{ runner.os }}-build-${{ hashFiles('build') }}
key: ${{ runner.os }}-build-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-build-
Expand Down Expand Up @@ -92,12 +92,12 @@ jobs:
extra_flags="-Dsonar.branch.name=master"
echo "Branch analysis flags: $extra_flags"
fi
sonar_url=${{ secrets.SONAR_URL }}
sonar_token=${{ secrets.SONAR_TOKEN }}
echo "Event name: $event_name"
echo "Sonar URL: $sonar_url"
echo "Running SonarQube analysis"
./configure.sh
./gradlew sonarqube --no-daemon -x build -x test $extra_flags \
Expand Down Expand Up @@ -155,63 +155,145 @@ jobs:
if: always()

mining-tests:
needs: build
runs-on: ubuntu-latest
defaults:
run:
working-directory: .

steps:
- name: Checkout code
- uses: actions/checkout@v2
- name: Setup System Tools
run: |
sudo apt-get update -y
sudo apt-get install -y jq
- name: Setup Node.js
uses: actions/setup-node@v2
with:
node-version: '12'
- name: Check Node.js version
run: node --version

- name: Checkout Mining Integration Tests Repository
uses: actions/checkout@v2
with:
repository: rsksmart/mining-integration-tests
# ref: ${{ secrets.MINING_INTEGRATION_TESTS_REF }}
# token: ${{ secrets.GITHUB_TOKEN }}
path: mining-integration-tests

# - uses: actions/cache@v2
# with:
# path: |
# node_modules
# key: ${{ runner.os }}-node-${{ hashFiles('package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-node-

- name: Setup
run: |
sudo apt-get update
sudo apt-get install -y curl jq
- name: Mining integration tests
run: |
function wait_for_completion() {
build_number=$1
poll_interval=60
i=0
max_count=20
while [ $i -lt $max_count ]; do
res=$(curl -Ssfu "${{ secrets.GITHUB_TOKEN }}" \
"https://circleci.com/api/v1.1/project/github/$MIT_ORGANIZATION/$MIT_PROJECT/$build_numbe" \
| jq -r '[.status, .conclusion] | @tsv')
IFS=" " set -- $res
status=${1:-}
conclusion=${2:-}
if [ "$status" = "queued" ]; then
echo "Build is enqueued. Waiting..."
else
echo "[$i/$max_count] Waiting for build $build_url ..."
i=$((i + 1))
fi
if [ "$status" = "completed" ]; then
echo "Build $build_number finished. Outcome: \"$conclusion\"."
test "$conclusion" = "success"
return $?
fi
sleep $poll_interval
done
return 1
}
json_payload='{
"ref": "'${{ github.ref }}'",
"inputs": {
"RSKJ_CIRCLE_BRANCH": "${{ github.ref }}",
"RSKJ_CIRCLE_USERNAME": "${{ github.actor }}",
"RSKJ_CIRCLE_REPONAME": "${{ github.repository }}",
"RSKJ_PR_NUMBER": "${{ github.event.pull_request.number }}",
"RSKJ_CIRCLE_SHA1": "${{ github.sha }}"
}
}'
res=$(curl -Ssf -u "${{ secrets.GITHUB_TOKEN }}:" \
-H "Content-type: application/json" -d "$json_payload" \
"https://circleci.com/api/v1.1/project/github/$MIT_ORGANIZATION/$MIT_PROJECT/tree/$MIT_BRANCH" \
| jq -r '[.url, .id] | @tsv')
IFS=" " set -- $res
build_url=$1
build_num=$2
echo "Running mining integration tests. Follow it on:\n\n $build_url\n\n"
sleep 10
wait_for_completion "$build_num"
- name: Install Mining Integration Tests dependencies
working-directory: mining-integration-tests
run: |
npm install
#
# - name: Start Bitcoin nodes
# run: |
# docker run -itd bitcoind01 /usr/local/bin/bitcoind -printtoconsole -regtest -debug -server -listen -port=31591 -connect=localhost:31592 -rpcbind=0.0.0.0:32591 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
# docker run -itd bitcoind02 /usr/local/bin/bitcoind -printtoconsole -regtest -debug -server -listen -port=31592 -connect=localhost:31591 -rpcbind=0.0.0.0:32591 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
# - name: Start Bitcoin nodes
# run: |
# docker run -d --name bitcoind01 -p 31591:31591 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31591 -connect=localhost:31592 -rpcbind=0.0.0.0:32591 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
# docker run -d --name bitcoind02 -p 31592:31592 --entrypoint "/usr/local/bin/bitcoind" kylemanna/bitcoind:latest -printtoconsole -regtest -debug -server -listen -port=31592 -connect=localhost:31591 -rpcbind=0.0.0.0:32592 -rpcallowip=0.0.0.0/0 -rpcuser=admin -rpcpassword=admin
#
#
# - name: Test bitcoin nodes
# run: |
# echo Test bitcoin node 1
# curl -s -u admin:admin --data-binary '{"jsonrpc":"1.0","id":"curltext","method":"getblockchaininfo","params":[]}' -H 'content-type:text/plain;' http://localhost:32591
# echo Test bitcoin node 2
# curl -s -u admin:admin --data-binary '{"jsonrpc":"1.0","id":"curltext","method":"getblockchaininfo","params":[]}' -H 'content-type:text/plain;' http://localhost:32592
#
# - name: Generate BTC blocks
# working-directory: mining-integration-tests
# run: |
# node generateBtcBlocks.js

- name: Setup Java JDK
uses: actions/setup-java@v2
with:
java-version: '17'
distribution: 'temurin'

- name: Verify Java installation
run: java -version

- name: Get RSKj version
run: |
version=$(tr -d "'\"" < rskj-core/src/main/resources/version.properties \
| cut -d = -f 2- | paste -sd - -)
- uses: actions/cache@v4
name: Restore gradle cache
with:
path: |
.gradle/caches
gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Get Gradle jar
run: |
./configure.sh
- uses: actions/cache@v4
name: Restore build
with:
path: |
build
key: ${{ runner.os }}-build-${{ hashFiles('build') }}
restore-keys: |
${{ runner.os }}-build-
- name: Build
run: |
./configure.sh
./gradlew --no-daemon dependencies
./gradlew --no-daemon --stacktrace build -x test
ls -la ./gradle/wrapper/gradle-wrapper.jar
- name: Show build directory
run: |
ls -la
- name: Start RSKj
run: |
java -Drsk.conf.file=./rsk-integration-test.conf -cp rskj-core/build/libs/rskj-core-"$version"-all.jar co.rsk.Start --regtest
rskpid=$!
echo "RSKj PID: $rskpid"
until nc -z 127.0.0.1 4444
do
echo "Waiting for RskJ..."
sleep 1
done
- name: Run Mining Integration Tests
run: |
chmod +x .github/mining-test/run.sh
./.github/mining-test/run.sh
# - name: Run Mining Integration Tests
# working-directory: mining-integration-tests
# run: |
# npm test

- name: Stop RSKj
if: always()
run: |
kill $rskpid
- name: Stop and Remove Docker Containers
if: always()
run: |
/usr/bin/docker stop bitcoind01 bitcoind02
/usr/bin/docker rm bitcoind01 bitcoind02

0 comments on commit 7967b6a

Please sign in to comment.